]>
git.ipfire.org Git - thirdparty/sarg.git/blob - repday.c
2 * SARG Squid Analysis Report Generator http://sarg.sourceforge.net
6 * please look at http://sarg.sourceforge.net/donations.php
8 * http://sourceforge.net/projects/sarg/forums/forum/363374
9 * ---------------------------------------------------------------------
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.
27 #include "include/conf.h"
28 #include "include/defs.h"
32 void report_day(const struct userinfostruct
*uinfo
)
45 int daylist
[MAX_DATETIME_DAYS
];
46 int daysort
[MAX_DATETIME_DAYS
];
52 long long int tbytes
[MAX_DATETIME_DAYS
*24];
53 long long int telap
[MAX_DATETIME_DAYS
*24];
55 long long int tttime
[24];
57 struct getwordstruct gwarea
;
60 if (datetimeby
==0) return;
61 snprintf(wdirname
,sizeof(wdirname
),"%s/%s.day",tmp
,uinfo
->filename
);
62 if(access(wdirname
, R_OK
) != 0) return;
64 if (snprintf(arqout
,sizeof(arqout
),"%s/%s/d%s.html",outdirname
,uinfo
->filename
,uinfo
->filename
)>=sizeof(arqout
)) {
65 debuga(_("Path too long: "));
66 debuga_more("%s/%s/d%s.html\n",outdirname
,uinfo
->filename
,uinfo
->filename
);
70 if((fp_in
=fopen(wdirname
,"r"))==NULL
) {
71 debuga(_("Cannot open file \"%s\": %s\n"),wdirname
,strerror(errno
));
75 memset(tbytes
,0,sizeof(tbytes
));
76 memset(telap
,0,sizeof(telap
));
79 while(fgets(buf
,sizeof(buf
),fp_in
)!=NULL
) {
81 getword_start(&gwarea
,buf
);
82 if (getword(data
,sizeof(data
),&gwarea
,'\t')<0) {
83 debuga(_("Invalid date in file \"%s\"\n"),wdirname
);
86 if (sscanf(data
,"%d/%d/%d",&day
,&month
,&year
)!=3) continue;
87 if (day
<1 || day
>31 || month
<1 || month
>12 || year
>9999) continue;
88 daynum
=(year
*10000)+(month
*100)+day
;
89 for (dayidx
=0 ; dayidx
<ndaylist
&& daynum
!=daylist
[dayidx
] ; dayidx
++);
90 if (dayidx
>=ndaylist
) {
91 if (dayidx
>=sizeof(daylist
)/sizeof(*daylist
)) {
92 debuga(_("Too many different dates in file \"%s\"\n"),wdirname
);
95 daylist
[ndaylist
++]=daynum
;
98 if (getword_atoll(&hour
,&gwarea
,'\t')<0) {
99 debuga(_("Invalid time in file \"%s\"\n"),wdirname
);
105 if ((datetimeby
& DATETIME_BYTE
)!=0) {
106 colsep
=((datetimeby
& DATETIME_ELAP
)!=0) ? '\t' : '\0';
107 if (getword_atoll(&bytes
,&gwarea
,colsep
)<0) {
108 debuga(_("Invalid number of bytes in file \"%s\"\n"),wdirname
);
113 if ((datetimeby
& DATETIME_ELAP
)!=0) {
114 if (getword_atoll(&elap
,&gwarea
,'\0')<0) {
115 debuga(_("Invalid elapsed time in file \"%s\"\n"),wdirname
);
121 if (fclose(fp_in
)==EOF
) {
122 debuga(_("Read error in \"%s\": %s\n"),wdirname
,strerror(errno
));
126 if((fp_ou
=fopen(arqout
,"w"))==NULL
) {
127 debuga(_("Cannot open file \"%s\": %s\n"),arqout
,strerror(errno
));
131 write_html_header(fp_ou
,(IndexTree
== INDEX_TREE_DATE
) ? 4 : 2,_("Day report"),HTML_JS_NONE
);
132 fprintf(fp_ou
,"<tr><td class=\"header_c\" colspan=\"2\">%s: %s</td></tr>\n",_("Period"),period
.html
);
133 fprintf(fp_ou
,"<tr><th class=\"header_c\" colspan=\"2\">%s: %s</th></tr>\n",_("User"),uinfo
->label
);
134 close_html_header(fp_ou
);
137 for (i
=0 ; i
<ndaylist
; i
++) {
139 for (j
=dayidx
; j
>0 && daynum
<daylist
[daysort
[j
-1]] ; j
--) daysort
[j
]=daysort
[j
-1];
144 if((datetimeby
& DATETIME_BYTE
)!=0) {
146 fputs("<table class=\"report\" cellpadding=\"0\" cellspacing=\"2\">\n", fp_ou
);
147 fputs("<tr><th class=\"header_c\"></th>",fp_ou
);
148 for( i
= 0; i
< hours
.len
; i
++ ) {
149 /* TRANSLATORS: It is an hour in the hourly report */
150 sprintf(data
,_("%02dH"),hours
.list
[ i
]);
151 fprintf(fp_ou
, "<td class=\"header_c\">%s<br>%s</td>\n", data
, label
);
153 fprintf(fp_ou
, "<td class=\"header_c\">%s<br>%s</td></tr>\n", _("TOTAL"), label
);
155 memset(tttime
,0,sizeof(tttime
));
156 for (dayidx
=0 ; dayidx
<ndaylist
; dayidx
++) {
157 daynum
=daysort
[dayidx
];
158 day
=daylist
[daynum
]%100;
159 month
=(daylist
[daynum
]/100)%100;
160 year
=daylist
[daynum
]/10000;
161 computedate(year
,month
,day
,&t
);
162 strftime(data
,sizeof(data
),"%x",&t
);
163 fprintf(fp_ou
, "<tr><td class=\"data\">%s</td>\n", data
);
165 for( i
= 0; i
< hours
.len
; i
++ ) {
167 if (tbytes
[daynum
*24+ihour
]>0) {
168 fprintf(fp_ou
, "<td class=\"data\">%s</td>\n",fixnum(tbytes
[daynum
*24+ihour
],1));
169 tt
+=tbytes
[daynum
*24+ihour
];
170 tttime
[ihour
]+=tbytes
[daynum
*24+ihour
];
172 fputs("<td class=\"data\"></td>\n",fp_ou
);
174 fprintf(fp_ou
, "<td class=\"data\">%s</td></tr>\n",fixnum(tt
,1));
177 fprintf(fp_ou
, "<tr><td class=\"header_l\">%s</td>\n", _("TOTAL") );
179 for( i
= 0; i
< hours
.len
; i
++ ) {
181 fprintf(fp_ou
, "<td class=\"header_r\">%s</td>\n",fixnum(tttime
[i
],1));
184 fputs("<td class=\"header_r\"></td>\n",fp_ou
);
186 fprintf(fp_ou
, "<td class=\"header_r\">%s</td></tr>\n",fixnum(tt
,1));
187 fputs("</table>\n",fp_ou
);
188 #ifdef ENABLE_DOUBLE_CHECK_DATA
189 if (tt
!=uinfo
->nbytes
) {
190 debuga(_("Total downloaded bytes is %"PRIi64
" instead of %"PRIi64
" in the hourly report of user %s\n"),
191 (int64_t)tt
,(int64_t)uinfo
->nbytes
,uinfo
->label
);
197 if((datetimeby
& DATETIME_ELAP
)!=0) {
199 fputs("<table class=\"report\" cellpadding=\"0\" cellspacing=\"2\">\n", fp_ou
);
200 fputs("<tr><th class=\"header_c\"></th>",fp_ou
);
201 for( i
= 0; i
< hours
.len
; i
++ ) {
202 sprintf(data
,_("%02dH"),hours
.list
[ i
]);
203 fprintf(fp_ou
, "<td class=\"header_c\">%s<br>%s</td>\n", data
, label
);
205 fprintf(fp_ou
, "<td class=\"header_c\">%s<br>%s</td></tr>\n", _("TOTAL"), label
);
207 memset(tttime
,0,sizeof(tttime
));
208 for (dayidx
=0 ; dayidx
<ndaylist
; dayidx
++) {
209 daynum
=daysort
[dayidx
];
210 day
=daylist
[daynum
]%100;
211 month
=(daylist
[daynum
]/100)%100;
212 year
=daylist
[daynum
]/10000;
213 computedate(year
,month
,day
,&t
);
214 strftime(data
,sizeof(data
),"%x",&t
);
215 fprintf(fp_ou
, "<tr><td class=\"data\">%s</td>\n", data
);
217 for( i
= 0; i
< hours
.len
; i
++ ) {
219 if (telap
[daynum
*24+ihour
]>0) {
220 fprintf(fp_ou
, "<td class=\"data\">%s</td>\n",fixtime(telap
[daynum
*24+ihour
]));
221 tt
+=telap
[daynum
*24+ihour
];
222 tttime
[ihour
]+=telap
[daynum
*24+ihour
];
224 fputs("<td class=\"data\"></td>\n",fp_ou
);
226 fprintf(fp_ou
, "<td class=\"data\">%s</td></tr>\n",fixtime(tt
));
229 fprintf(fp_ou
, "<tr><td class=\"header_l\">%s</td>\n", _("TOTAL") );
231 for( i
= 0; i
< hours
.len
; i
++ ) {
233 fprintf(fp_ou
, "<td class=\"header_r\">%s</td>\n",fixtime(tttime
[i
]));
236 fputs("<td class=\"header_r\"></td>\n",fp_ou
);
238 fprintf(fp_ou
, "<td class=\"header_r\">%s</td></tr>\n",fixtime(tt
));
239 fputs("</table>\n",fp_ou
);
240 #ifdef ENABLE_DOUBLE_CHECK_DATA
241 if (tt
!=uinfo
->elap
) {
242 debuga(_("Total elapsed time is %"PRIi64
" instead of %"PRIi64
" in the hourly report of user %s\n"),
243 (int64_t)tt
,(int64_t)uinfo
->elap
,uinfo
->label
);
249 write_html_trailer(fp_ou
);
250 if (fclose(fp_ou
)==EOF
) {
251 debuga(_("Write error in \"%s\": %s\n"),arqout
,strerror(errno
));