]>
git.ipfire.org Git - thirdparty/sarg.git/blob - dansguardian_report.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"
30 void dansguardian_report(void)
32 FILE *fp_in
= NULL
, *fp_ou
= NULL
;
36 char dansguardian_in
[MAXLEN
];
49 struct getwordstruct gwarea
;
53 snprintf(dansguardian_in
,sizeof(dansguardian_in
),"%s/dansguardian.log",tmp
);
54 if(!dansguardian_count
) {
55 unlink(dansguardian_in
);
59 sprintf(report
,"%s/dansguardian.html",outdirname
);
61 if((fp_in
=MY_FOPEN(dansguardian_in
,"r"))==NULL
) {
62 debuga(_("(dansguardian_report) Cannot open log file %s\n"),dansguardian_in
);
66 if((fp_ou
=MY_FOPEN(report
,"w"))==NULL
) {
67 debuga(_("(dansguardian_report) Cannot open log file %s\n"),report
);
71 write_html_header(fp_ou
,(IndexTree
== INDEX_TREE_DATE
) ? 3 : 1,_("DansGuardian"),HTML_JS_NONE
);
72 fputs("<tr><td class=\"header_c\">",fp_ou
);
73 fprintf(fp_ou
,_("Period: %s"),period
.html
);
74 fputs("</td></tr>\n",fp_ou
);
75 fprintf(fp_ou
,"<tr><th class=\"header_c\">%s</th></tr>\n",_("DansGuardian"));
76 close_html_header(fp_ou
);
78 fputs("<div class=\"report\"><table cellpadding=\"1\" cellspacing=\"2\">\n",fp_ou
);
79 fprintf(fp_ou
,"<tr><th class=\"header_l\">%s</th><th class=\"header_l\">%s</th><th class=\"header_l\">%s</th><th class=\"header_l\">%s</th><th class=\"header_l\">%s</th></tr>\n",_("USERID"),_("IP/NAME"),_("DATE/TIME"),_("ACCESSED SITE"),_("CAUSE"));
81 while(fgets(buf
,sizeof(buf
),fp_in
)!=NULL
) {
82 getword_start(&gwarea
,buf
);
83 if (getword(user
,sizeof(user
),&gwarea
,'\t')<0 || getword(date2
,sizeof(date2
),&gwarea
,'\t')<0 ||
84 getword(hour
,sizeof(hour
),&gwarea
,'\t')<0 || getword(ip
,sizeof(ip
),&gwarea
,'\t')<0) {
85 debuga(_("Maybe you have a broken record or garbage in your %s file\n"),dansguardian_in
);
88 if (getword_ptr(buf
,&url
,&gwarea
,'\t')<0) {
89 debuga(_("Maybe you have a broken url in your %s file\n"),dansguardian_in
);
92 if (getword(rule
,sizeof(rule
),&gwarea
,'\n')<0) {
93 debuga(_("Maybe you have a broken rule in your %s file\n"),dansguardian_in
);
101 if(strncmp(df
,"u",1) != 0) {
102 strncpy(date
,date2
+6,2);
104 strncat(date
,date2
+4,2);
106 strncat(date
,date2
,4);
108 strncpy(date
,date2
+4,2);
110 strncat(date
,date2
+6,2);
112 strncat(date
,date2
,4);
116 ip2name(ip
,sizeof(ip
));
123 if(strcmp(ouser
,user
) == 0)
127 if(strcmp(oip
,ip
) == 0)
133 user_find(name
, sizeof(name
), user
);
135 if(DansGuardianReportLimit
) {
136 if(strcmp(ouser2
,name
) == 0) {
142 if(count
>= DansGuardianReportLimit
)
146 fprintf(fp_ou
,"<tr><td class=\"data2\">%s</td><td class=\"data2\">%s</td><td class=\"data2\">%s-%s</td><td class=\"data2\"><a href=\"http://",name
,ip
,date
,hour
);
147 output_html_url(fp_ou
,url
);
149 output_html_string(fp_ou
,url
,100);
150 fprintf(fp_ou
,"</a></td><td class=\"data2\">%s</td></tr>\n",rule
);
154 fputs("</table></div>\n",fp_ou
);
155 if (write_html_trailer(fp_ou
)<0)
156 debuga(_("Write error in file %s\n"),report
);
157 if (fclose(fp_ou
)==EOF
)
158 debuga(_("Failed to close file %s - %s\n"),report
,strerror(errno
));
160 if (unlink(dansguardian_in
)) {
161 debuga(_("Cannot delete %s - %s\n"),dansguardian_in
,strerror(errno
));