X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Frrd_cgi.c;h=53c104f08aaa2797bf9fa766b4d8cc4ec861def2;hb=298b318acaf1147474ab9e97cac37c3608660efd;hp=e79ecb7c1bee78fa1d6ad49a52cbe4b1167cac3e;hpb=5837606887a6d81e8b1f7588525cb1c8783fb62b;p=rrdtool.git diff --git a/src/rrd_cgi.c b/src/rrd_cgi.c index e79ecb7..53c104f 100644 --- a/src/rrd_cgi.c +++ b/src/rrd_cgi.c @@ -1,5 +1,5 @@ /***************************************************************************** - * RRDtool 1.0.33 Copyright Tobias Oetiker, 1997 - 2000 + * RRDtool 1.1.x Copyright Tobias Oetiker, 1997 - 2002 ***************************************************************************** * rrd_cgi.c RRD Web Page Generator *****************************************************************************/ @@ -128,9 +128,9 @@ int main(int argc, char *argv[]) { server_url = getenv("SERVER_URL"); } - if (optind != argc-1) { - fprintf(stderr, "ERROR: expected a filename\n"); - exit(1); + if ( (optind != argc-2 && strstr(getenv("SERVER_SOFTWARE"),"Apache/2") != NULL) && optind != argc-1) { + fprintf(stderr, "ERROR: expected a filename\n"); + exit(1); } else { length = readfile(argv[optind], &buffer, 1); } @@ -211,8 +211,13 @@ char* rrdsetenv(long argc, char **args){ char* rrdgetenv(long argc, char **args){ if (argc != 1) { return stralloc("[ERROR: getenv faild because it did not get 1 argument only]"); - }; - return stralloc(getenv(args[0])); + } + else if (getenv(args[0]) == NULL) { + return stralloc(""); + } + else { + return stralloc(getenv(args[0])); + } } char* rrdgoodfor(long argc, char **args){ @@ -248,6 +253,7 @@ char* includefile(long argc, char **args){ } } +static char* rrdstrip(char *buf){ char *start; if (buf == NULL) return NULL; @@ -407,7 +413,7 @@ char* printtimelast(long argc, char **args) { rrd_clear_error(); return err; } - tm_last = *localtime(&last); + localtime_r(&last, &tm_last); strftime(buf,254,args[1],&tm_last); return buf; } @@ -426,7 +432,7 @@ char* printtimenow(long argc, char **args) { if (buf == NULL){ return stralloc("[ERROR: allocating strftime buffer]"); }; - tm_now = *localtime(&now); + localtime_r(&now, &tm_now); strftime(buf,254,args[0],&tm_now); return buf; } @@ -437,6 +443,7 @@ char* printtimenow(long argc, char **args) { } /* scan aLine until an unescaped '>' arives */ +static char* scanargs(char *aLine, long *argc, char ***args) { char *getP, *putP; @@ -454,7 +461,7 @@ char* scanargs(char *aLine, long *argc, char ***args) getP = aLine; putP = aLine; while (*getP && !( !Quote && (braket == 0) && ((*getP) == '>'))){ - if (*getP < ' ') *getP = ' '; /*remove all special chars*/ + if ((unsigned)*getP < ' ') *getP = ' '; /*remove all special chars*/ switch (*getP) { case ' ': if (Quote){ @@ -571,10 +578,10 @@ int parse(char **buf, long i, char *tag, char * http_time(time_t *now) { - struct tm *tmptime; + struct tm tmptime; static char buf[60]; - tmptime=gmtime(now); - strftime(buf,sizeof(buf),"%a, %d %b %Y %H:%M:%S GMT",tmptime); + gmtime_r(now, &tmptime); + strftime(buf,sizeof(buf),"%a, %d %b %Y %H:%M:%S GMT", &tmptime); return(buf); }