- { \r
- time_t t = time(NULL) - 3600*24 ; /* yesterday's timestamp*/\r
- struct tm *timep = localtime(&t); \r
- \r
- if(argv[1][1]=='m') /* -m yestarday - month */\r
- {\r
- strftime(mstr, 4, "%b", timep);\r
- month=mstr;\r
- strftime(ystr, 5, "%Y", timep);\r
- year=ystr; \r
- }\r
- else /* -y yesterday - year */\r
- {\r
- month="Year";\r
- any_month=1;\r
- strftime(ystr, 5, "%Y", timep);\r
- year=ystr;\r
- }\r
- }\r
- printf("Analysing traffic for %s %s ...\n",month,year);\r
-\r
- sprintf(str,"%s %s/*.log",ls,log_dir);\r
- shell(str);\r
-\r
- input(str,STRLEN)\r
- {\r
- ptr=strrchr(str,'\n');\r
- if(ptr) *ptr='\0';\r
- printf("Parsing %s ...",str);\r
- accept_month=0;\r
- traffic_month=0;\r
- parse(str)\r
- {\r
- y_ok=m_ok=0; \r
- valid_columns(ptr,_,'\t',col) switch(col)\r
- {\r
- case 2: name=ptr;break;\r
- case 3: traffic=atol(ptr);break;\r
- /* column number - was 7, now 9...*/\r
- case 7:\r
- case 8:\r
- case 9: if (isalnum(*ptr)) /* alphanumeric string = date, just one*/\r
- {\r
- valid_columns(ptr2,ptr,' ',col2) switch(col2)\r
- {\r
- case 2: if(any_month || eq(ptr2,month)) m_ok=1; break;\r
- case 5: if(eq(ptr2,year)) y_ok=1; break;\r
- }\r
- }\r
- }\r
- \r
- if(y_ok && m_ok) \r
- {\r
- traffic_month+=traffic;\r
- accept_month=1;\r
- }\r
- }\r
- done;\r
-\r
- if(accept_month)\r
- {\r
- create(iplog,IpLog);\r
- iplog->name=name;\r
- iplog->traffic=traffic_month;\r
- insert(iplog,iplogs,desc_order_by,traffic);\r
- printf(" %ld MB\n",iplog->traffic);\r
- }\r
- else\r
- puts(" no records.");\r
- }\r
- sprintf(str,"%s/%s-%s.html",html_log_dir,year,month);\r
- printf("Writing %s ...",str);\r
- f=fopen(str,"w");\r
- if(f)\r