]>
git.ipfire.org Git - thirdparty/sarg.git/blob - siteuser.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"
39 char general2
[MAXLEN
];
49 struct generalitemstruct item
;
50 struct userinfostruct
*uinfo
;
53 if (debugz
>=LogLevel_Process
) debugaz(__FILE__
,__LINE__
,_("Sites & users report not generated because privacy option is on\n"));
57 if (debugz
>=LogLevel_Process
)
58 debuga(__FILE__
,__LINE__
,_("Creating report to list who visisted what site...\n"));
60 sprintf(general
,"%s/sarg-general",outdirname
);
61 sprintf(sites
,"%s/sarg-sites",outdirname
);
62 sprintf(general2
,"%s/sarg-general2",outdirname
);
63 sprintf(report
,"%s/siteuser.html",outdirname
);
65 if (snprintf(csort
,sizeof(csort
),"sort -t \"\t\" -k 4,4 -k 1,1 -o \"%s\" \"%s\"",general2
,general
)>=sizeof(csort
)) {
66 debuga(__FILE__
,__LINE__
,_("Sort command too long when sorting file \"%s\" to \"%s\"\n"),general
,general2
);
69 cstatus
=system(csort
);
70 if (!WIFEXITED(cstatus
) || WEXITSTATUS(cstatus
)) {
71 debuga(__FILE__
,__LINE__
,_("sort command return status %d\n"),WEXITSTATUS(cstatus
));
72 debuga(__FILE__
,__LINE__
,_("sort command: %s\n"),csort
);
76 if((fp_in
=FileObject_Open(general2
))==NULL
) {
77 debuga(__FILE__
,__LINE__
,_("Cannot open file \"%s\": %s\n"),general2
,FileObject_GetLastOpenError());
78 debuga(__FILE__
,__LINE__
,_("sort command: %s\n"),csort
);
82 if((fp_ou
=fopen(report
,"w"))==NULL
) {
83 debuga(__FILE__
,__LINE__
,_("Cannot open file \"%s\": %s\n"),report
,strerror(errno
));
87 write_html_header(fp_ou
,(IndexTree
== INDEX_TREE_DATE
) ? 3 : 1,_("Sites & Users"),HTML_JS_SORTTABLE
);
88 fputs("<tr><td class=\"header_c\">",fp_ou
);
89 fprintf(fp_ou
,_("Period: %s"),period
.html
);
90 fputs("</td></tr>\n",fp_ou
);
91 fprintf(fp_ou
,"<tr><th class=\"header_c\">%s</th></tr>\n",_("Sites & Users"));
92 close_html_header(fp_ou
);
94 fputs("<div class=\"report\"><table cellpadding=\"0\" cellspacing=\"2\"",fp_ou
);
95 if (SortTableJs
[0]) fputs(" class=\"sortable\"",fp_ou
);
96 fprintf(fp_ou
,">\n<thead><tr><th class=\"header_l\">%s</th><th class=\"header_l",_("NUM"));
97 if (SortTableJs
[0]) fputs(" sorttable_alpha",fp_ou
);
98 fprintf(fp_ou
,"\">%s</th>",_("ACCESSED SITE"));
99 if(BytesInSitesUsersReport
)
100 fprintf(fp_ou
,"<th class=\"header_l\">%s</th>",_("BYTES"));
101 fputs("<th class=\"header_l",fp_ou
);
102 if (SortTableJs
[0]) fputs(" sorttable_alpha",fp_ou
);
103 /* TRANSLATORS: This is a column header showing the users who visited each site. */
104 fprintf(fp_ou
,"\">%s</th></tr></thead>\n",_("USERS"));
109 userinfo_clearflag();
110 topuser_link
=((ReportType
& REPORT_TYPE_USERS_SITES
) != 0 && !indexonly
);
112 if ((line
=longline_create())==NULL
) {
113 debuga(__FILE__
,__LINE__
,_("Not enough memory to read file \"%s\"\n"),general2
);
117 while((buf
=longline_read(fp_in
,line
))!=NULL
) {
118 ger_read(buf
,&item
,general2
);
119 if(item
.total
) continue;
120 uinfo
=userinfo_find_from_id(item
.user
);
122 debuga(__FILE__
,__LINE__
,_("Unknown user ID %s in file \"%s\"\n"),item
.user
,general2
);
126 if (item
.nacc
> 0) nsitesusers
= 1;
127 if (!nsitesusers
) continue;
129 if (ourl
==NULL
|| strcmp(item
.url
,ourl
) != 0) {
130 if (regs
>0) fputs("</td></tr>\n",fp_ou
);
133 if (SiteUsersReportLimit
&& regs
>= SiteUsersReportLimit
)
135 fprintf(fp_ou
,"<tr><td class=\"data\">%d</td><td class=\"data2\">",regs
);
137 url_len
=strlen(item
.url
);
138 if (url_len
>=ourl_size
) {
140 ourl
=realloc(ourl
,ourl_size
);
142 debuga(__FILE__
,__LINE__
,_("Not enough memory to store the url\n"));
146 strcpy(ourl
,item
.url
);
148 if(BlockIt
[0]!='\0' && ourl
[0]!=ALIAS_PREFIX
) {
149 fprintf(fp_ou
,"<a href=\"%s%s?url=",wwwDocumentRoot
,BlockIt
);
150 output_html_url(fp_ou
,ourl
);
151 fputs("\"><img src=\"../images/sarg-squidguard-block.png\"></a> ",fp_ou
);
153 output_html_link(fp_ou
,ourl
,100);
154 fputs("</td>",fp_ou
);
156 if (BytesInSitesUsersReport
) {
157 fputs("<td class=\"data\"",fp_ou
);
158 if (SortTableJs
[0]) fprintf(fp_ou
," sorttable_customkey=\"%"PRId64
"\"",(int64_t)item
.nbytes
);
159 fprintf(fp_ou
,">%s</td>",fixnum(item
.nbytes
,1));
161 fputs("<td class=\"data2\">",fp_ou
);
163 userinfo_clearflag();
164 if (topuser_link
&& uinfo
->topuser
)
165 fprintf(fp_ou
,"<a href=\"%s/%s.html\">%s</a>",uinfo
->filename
,uinfo
->filename
,uinfo
->label
);
167 fprintf(fp_ou
,"%s",uinfo
->label
);
170 else if (uinfo
->flag
==0) {
171 if (topuser_link
&& uinfo
->topuser
)
172 fprintf(fp_ou
," <a href=\"%s/%s.html\">%s</a>",uinfo
->filename
,uinfo
->filename
,uinfo
->label
);
174 fprintf(fp_ou
," %s",uinfo
->label
);
179 if (FileObject_Close(fp_in
)) {
180 debuga(__FILE__
,__LINE__
,_("Read error in \"%s\": %s\n"),general2
,FileObject_GetLastCloseError());
183 longline_destroy(&line
);
186 fputs("</td></tr>\n",fp_ou
);
188 if (ourl
) free(ourl
);
190 if (!KeepTempLog
&& unlink(general2
)) {
191 debuga(__FILE__
,__LINE__
,_("Cannot delete \"%s\": %s\n"),general2
,strerror(errno
));
195 fputs("</table></div>\n",fp_ou
);
196 write_html_trailer(fp_ou
);
197 if (fclose(fp_ou
)==EOF
) {
198 debuga(__FILE__
,__LINE__
,_("Write error in \"%s\": %s\n"),report
,strerror(errno
));