]> git.ipfire.org Git - thirdparty/sarg.git/blob - getconf.c
df6795c9e2c2fbf909221a98f67a2fd411867f95
[thirdparty/sarg.git] / getconf.c
1 /*
2 * SARG Squid Analysis Report Generator http://sarg.sourceforge.net
3 * 1998, 2012
4 *
5 * SARG donations:
6 * please look at http://sarg.sourceforge.net/donations.php
7 * Support:
8 * http://sourceforge.net/projects/sarg/forums/forum/363374
9 * ---------------------------------------------------------------------
10 *
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.
15 *
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.
20 *
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.
24 *
25 */
26
27 #include "include/conf.h"
28 #include "include/defs.h"
29
30 #define SET_LIST(list) list,sizeof(list)/sizeof(list[0])
31
32 extern numlist hours, weekdays;
33
34 struct param_list
35 {
36 //! The name of the value of the parameter.
37 const char *name;
38 //! The bit to set if the value is found.
39 unsigned long int value;
40 //! The value is invalid if any bit of this mask is set in the parameter.
41 unsigned long int exclude;
42 };
43
44 struct sort_list
45 {
46 //! The name of the value of the parameter.
47 const char *name;
48 //! The bit to set if the value is found.
49 unsigned long int value;
50 };
51
52 static struct param_list report_type_values[]=
53 {
54 {"users_sites",REPORT_TYPE_USERS_SITES,0},
55 {"topusers",REPORT_TYPE_TOPUSERS,0},
56 {"topsites",REPORT_TYPE_TOPSITES,0},
57 {"sites_users",REPORT_TYPE_SITES_USERS,0},
58 {"date_time",REPORT_TYPE_DATE_TIME,0},
59 {"denied",REPORT_TYPE_DENIED,0},
60 {"auth_failures",REPORT_TYPE_AUTH_FAILURES,0},
61 {"site_user_time_date",REPORT_TYPE_SITE_USER_TIME_DATE,0},
62 {"downloads",REPORT_TYPE_DOWNLOADS,0},
63 };
64
65 static struct param_list data_field_values[]=
66 {
67 {"user",DATA_FIELD_USER,0},
68 {"date",DATA_FIELD_DATE,0},
69 {"time",DATA_FIELD_TIME,0},
70 {"url",DATA_FIELD_URL,0},
71 {"connect",DATA_FIELD_CONNECT,0},
72 {"bytes",DATA_FIELD_BYTES,0},
73 {"in_cache",DATA_FIELD_IN_CACHE,0},
74 {"out_cache",DATA_FIELD_OUT_CACHE,0},
75 {"elapsed",DATA_FIELD_ELAPSED,0},
76 };
77
78 static struct param_list topuserfields_values[]=
79 {
80 {"NUM",TOPUSERFIELDS_NUM,0},
81 {"DATE_TIME",TOPUSERFIELDS_DATE_TIME,0},
82 {"USERID",TOPUSERFIELDS_USERID,0},
83 {"CONNECT",TOPUSERFIELDS_CONNECT,0},
84 {"BYTES",TOPUSERFIELDS_BYTES,0},
85 {"%BYTES",TOPUSERFIELDS_SETYB,0},
86 {"SETYB",TOPUSERFIELDS_SETYB,0},
87 {"IN-CACHE-OUT",TOPUSERFIELDS_IN_CACHE_OUT,0},
88 {"USED_TIME",TOPUSERFIELDS_USED_TIME,0},
89 {"MILISEC",TOPUSERFIELDS_MILISEC,0},
90 {"%TIME",TOPUSERFIELDS_PTIME,0},
91 {"TOTAL",TOPUSERFIELDS_TOTAL,0},
92 {"AVERAGE",TOPUSERFIELDS_AVERAGE,0},
93 };
94
95 static struct param_list userreportfields_values[]=
96 {
97 {"CONNECT",USERREPORTFIELDS_CONNECT,0},
98 {"BYTES",USERREPORTFIELDS_BYTES,0},
99 {"%BYTES",USERREPORTFIELDS_SETYB,0},
100 {"SETYB",USERREPORTFIELDS_SETYB,0},
101 {"IN-CACHE-OUT",USERREPORTFIELDS_IN_CACHE_OUT,0},
102 {"USED_TIME",USERREPORTFIELDS_USED_TIME,0},
103 {"MILISEC",USERREPORTFIELDS_MILISEC,0},
104 {"%TIME",USERREPORTFIELDS_PTIME,0},
105 {"TOTAL",USERREPORTFIELDS_TOTAL,0},
106 {"AVERAGE",USERREPORTFIELDS_AVERAGE,0},
107 };
108
109 static struct param_list index_values[]=
110 {
111 {"yes",INDEX_YES,~INDEX_YES},
112 {"no",INDEX_NO,~INDEX_NO},
113 {"only",INDEX_ONLY,~INDEX_ONLY},
114 };
115
116 static struct param_list index_tree_values[]=
117 {
118 {"date",INDEX_TREE_DATE,~INDEX_TREE_DATE},
119 {"file",INDEX_TREE_FILE,~INDEX_TREE_FILE},
120 };
121
122 static struct param_list indexfields_values[]=
123 {
124 {"DIRSIZE",INDEXFIELDS_DIRSIZE,0},
125 };
126
127 static struct param_list ntml_userformat_values[]=
128 {
129 {"user",NTLMUSERFORMAT_USER,~NTLMUSERFORMAT_USER},
130 {"domainname+username",NTLMUSERFORMAT_DOMAINUSER,~NTLMUSERFORMAT_DOMAINUSER},
131 };
132
133 static struct param_list recnouser_values[]=
134 {
135 {"ip",RECORDWITHOUTUSER_IP,~RECORDWITHOUTUSER_IP},
136 {"ignore",RECORDWITHOUTUSER_IGNORE,~RECORDWITHOUTUSER_IGNORE},
137 {"everybody",RECORDWITHOUTUSER_EVERYBODY,~RECORDWITHOUTUSER_EVERYBODY},
138 };
139
140 static struct param_list datafileurl_values[]=
141 {
142 {"ip",DATAFILEURL_IP,~DATAFILEURL_IP},
143 {"name",DATAFILEURL_NAME,~DATAFILEURL_NAME},
144 };
145
146 static struct param_list displayvalue_values[]=
147 {
148 {"bytes",DISPLAY_BYTES,~DISPLAY_BYTES},
149 {"abbreviation",DISPLAY_ABBREV,~DISPLAY_ABBREV},
150 };
151
152 static struct param_list datetime_values[]=
153 {
154 {"elap",DATETIME_ELAP,0},
155 {"bytes",DATETIME_BYTE,0},
156 };
157
158 static struct param_list realtime_unauth_values[]=
159 {
160 {"show",REALTIME_UNAUTH_REC_SHOW,~REALTIME_UNAUTH_REC_SHOW},
161 {"ignore",REALTIME_UNAUTH_REC_IGNORE,~REALTIME_UNAUTH_REC_IGNORE},
162 };
163
164 struct sort_list topuser_sort[]=
165 {
166 {"BYTES",TOPUSER_SORT_BYTES},
167 {"USER",TOPUSER_SORT_USER},
168 {"CONNECT",TOPUSER_SORT_CONNECT},
169 {"TIME",TOPUSER_SORT_TIME},
170 };
171
172 struct sort_list topsite_sort[]=
173 {
174 {"BYTES",TOPSITE_SORT_BYTES},
175 {"CONNECT",TOPSITE_SORT_CONNECT},
176 {"TIME",TOPSITE_SORT_TIME},
177 {"USER",TOPSITE_SORT_USER},
178 };
179
180 struct sort_list user_sort[]=
181 {
182 {"BYTES",USER_SORT_BYTES},
183 {"SITE",USER_SORT_SITE},
184 {"CONNECT",USER_SORT_CONNECT},
185 {"TIME",USER_SORT_TIME},
186 };
187
188 static int is_param(const char *param,const char *buf)
189 {
190 int plen;
191
192 plen=strlen(param);
193 if (strncmp(buf,param,plen) != 0) return(0);
194 buf+=plen;
195 if ((unsigned char)*buf>' ') return(0);
196 return(1);
197 }
198
199 static int getparam_string(const char *param,char *buf,char *value,int value_size)
200 {
201 int plen;
202
203 plen=strlen(param);
204 if (strncmp(buf,param,plen) != 0) return(0);
205 buf+=plen;
206 if ((unsigned char)*buf>' ') return(0);
207 while (*buf && (unsigned char)*buf<=' ') buf++;
208
209 if (strlen(buf)>=value_size) {
210 debuga(_("The string value of parameter \"%s\" is too long\n"),param);
211 exit(EXIT_FAILURE);
212 }
213 strcpy(value,buf);
214 fixnone(value);
215 return(1);
216 }
217
218 static int getparam_quoted(const char *param,char *buf,char *value,int value_size)
219 {
220 int plen;
221 int i;
222
223 plen=strlen(param);
224 if (strncmp(buf,param,plen) != 0) return(0);
225 buf+=plen;
226 if ((unsigned char)*buf>' ') return(0);
227 while (*buf && (unsigned char)*buf<=' ') buf++;
228
229 if (*buf != '\"') {
230 debuga(_("Missing double quote after parameter \"%s\"\n"),param);
231 exit(EXIT_FAILURE);
232 }
233 buf++;
234
235 value_size--;
236 for (i=0 ; i<value_size && *buf && *buf!='\"' ; i++) {
237 value[i]=*buf++;
238 }
239 value[i]='\0';
240
241 if (*buf != '\"') {
242 debuga(_("Missing double quote after parameter \"%s\" or value is more than %d bytes long\n"),param,value_size);
243 exit(EXIT_FAILURE);
244 }
245 fixnone(value);
246 return(1);
247 }
248
249 static int getparam_2words(const char *param,char *buf,char *word1,int word1_size,char *word2,int word2_size)
250 {
251 int plen;
252 int i;
253
254 plen=strlen(param);
255 if (strncmp(buf,param,plen) != 0) return(0);
256 buf+=plen;
257 if ((unsigned char)*buf>' ') return(0);
258 while (*buf && (unsigned char)*buf<=' ') buf++;
259
260 for (i=0 ; i<word1_size && *buf && (unsigned char)*buf>' ' ; i++)
261 word1[i]=*buf++;
262 if (i>=word1_size) {
263 debuga(_("The first word of parameter \"%s\" is more than %d bytes long\n"),param,word1_size-1);
264 exit(EXIT_FAILURE);
265 }
266 if (*buf!=' ') {
267 debuga(_("Missing second word for parameter \"%s\"\n"),param);
268 exit(EXIT_FAILURE);
269 }
270 word1[i]=0;
271
272 while (*buf && (unsigned char)*buf<=' ') buf++;
273
274 for (i=0 ; i<word2_size && *buf && (unsigned char)*buf>' ' ; i++)
275 word2[i]=*buf++;
276 if (i>=word2_size) {
277 debuga(_("The second word of parameter \"%s\" is more than %d bytes long\n"),param,word2_size-1);
278 exit(EXIT_FAILURE);
279 }
280 word2[i]=0;
281
282 fixnone(word1);
283 fixnone(word2);
284 return(1);
285 }
286
287 static int getparam_int(const char *param,char *buf,int *value)
288 {
289 int plen;
290 int next;
291
292 plen=strlen(param);
293 if (strncmp(buf,param,plen) != 0) return(0);
294 buf+=plen;
295 if ((unsigned char)*buf>' ') return(0);
296 while (*buf && (unsigned char)*buf<=' ') buf++;
297
298 next=0;
299 if (sscanf(buf,"%d%n",value,&next) != 1 || (unsigned char)buf[next] > ' ') {
300 debuga(_("The integer value of parameter \"%s\" is invalid\n"),param);
301 exit(EXIT_FAILURE);
302 }
303 return(1);
304 }
305
306 static int getparam_bool(const char *param,char *buf,bool *value)
307 {
308 int plen;
309 int i;
310 const char *bool_str="yes,true,on,1";
311
312 plen=strlen(param);
313 if (strncmp(buf,param,plen) != 0) return(0);
314 buf+=plen;
315 if ((unsigned char)*buf>' ') return(0);
316 while (*buf && (unsigned char)*buf<=' ') buf++;
317
318 *value=false;
319 for ( ; *bool_str ; bool_str+=i) {
320 for (i=0 ; bool_str[i] && bool_str[i]!=',' ; i++);
321 if (strncasecmp(bool_str,buf,i)==0) {
322 *value=true;
323 break;
324 }
325 if (bool_str[i]==',') i++;
326 }
327 return(1);
328 }
329
330 static int getparam_list(const char *param,struct param_list *options,int noptions,char *buf,unsigned long int *value)
331 {
332 int plen;
333 char *str;
334 int i;
335
336 plen=strlen(param);
337 if (strncmp(buf,param,plen) != 0) return(0);
338 buf+=plen;
339 if ((unsigned char)*buf>' ') return(0);
340 while (*buf && (unsigned char)*buf<=' ') buf++;
341
342 *value=0UL;
343 while (*buf) {
344 str=buf;
345 while (*str && (unsigned char)*str>' ' && *str!=';') str++;
346 if (*str) {
347 *str++='\0';
348 while (*str && ((unsigned char)*str<=' ' || *str==';')) str++;
349 }
350 for (i=0 ; i<noptions && strcasecmp(buf,options[i].name) ; i++);
351 if (i>=noptions) {
352 debuga(_("Unknown value \"%s\" for parameter \"%s\"\n"),buf,param);
353 exit(EXIT_FAILURE);
354 }
355 if ((*value & options[i].exclude)!=0) {
356 debuga(_("Value \"%s\" conflicts with other selected values for parameter \"%s\"\n"),buf,param);
357 exit(EXIT_FAILURE);
358 }
359 *value|=options[i].value;
360 buf=str;
361 }
362 return(1);
363 }
364
365 static int getparam_sort(const char *param,struct sort_list *options,int noptions,char *buf,unsigned long int *value)
366 {
367 int plen;
368 char *str, *order;
369 int i;
370
371 plen=strlen(param);
372 if (strncmp(buf,param,plen) != 0) return(0);
373 buf+=plen;
374 if ((unsigned char)*buf>' ') return(0);
375 while (*buf && (unsigned char)*buf<=' ') buf++;
376
377 str=buf;
378 order=NULL;
379 while (*str && (unsigned char)*str>' ') str++;
380 if (*str) {
381 *str++='\0';
382 while (*str && (unsigned char)*str<=' ') str++;
383 order=str;
384 }
385 for (i=0 ; i<noptions && strcasecmp(buf,options[i].name) ; i++);
386 if (i>=noptions) {
387 debuga(_("Unknown sort criterion \"%s\" for parameter \"%s\"\n"),buf,param);
388 exit(EXIT_FAILURE);
389 }
390 *value=options[i].value;
391
392 if (order) {
393 str=order;
394 while (*str && (unsigned char)*str>' ') str++;
395 if (*str) {
396 *str++='\0';
397 while (*str && (unsigned char)*str<=' ') str++;
398 }
399 if (strcasecmp(order,"reverse")==0 || strcasecmp(order,"D")==0) {
400 *value|=SORT_REVERSE;
401 } else if (strcasecmp(order,"normal")!=0 && strcasecmp(order,"A")!=0) {
402 debuga(_("Unknown sort order \"%s\" for parameter \"%s\"\n"),order,param);
403 exit(EXIT_FAILURE);
404 }
405 }
406
407 buf=str;
408 return(1);
409 }
410
411 static void parmtest(char *buf)
412 {
413 char wbuf[2048];
414 struct getwordstruct gwarea;
415
416 while (*buf && (unsigned char)*buf<=' ') buf++;
417
418 if(*buf == '#' || *buf == '\0')
419 return;
420
421 if(debugz)
422 printf(_("SARG: TAG: %s\n"),buf);
423
424 if (getparam_string("background_color",buf,BgColor,sizeof(BgColor))>0) return;
425
426 if (getparam_string("text_color",buf,TxColor,sizeof(TxColor))>0) return;
427
428 if (getparam_string("text_bgcolor",buf,TxBgColor,sizeof(TxBgColor))>0) return;
429
430 if (getparam_string("title_color",buf,TiColor,sizeof(TiColor))>0) return;
431
432 if (getparam_string("logo_image",buf,LogoImage,sizeof(LogoImage))>0) return;
433
434 if (getparam_quoted("logo_text",buf,LogoText,sizeof(LogoText))>0) return;
435
436 if (getparam_string("logo_text_color",buf,LogoTextColor,sizeof(LogoTextColor))>0) return;
437
438 if (getparam_string("background_image",buf,BgImage,sizeof(BgImage))>0) return;
439
440 if (getparam_bool("show_sarg_info",buf,&ShowSargInfo)>0) return;
441
442 if (getparam_bool("show_sarg_logo",buf,&ShowSargLogo)>0) return;
443
444 if (getparam_string("font_face",buf,FontFace,sizeof(FontFace))>0) return;
445
446 if (getparam_string("header_color",buf,HeaderColor,sizeof(HeaderColor))>0) return;
447
448 if (getparam_string("header_bgcolor",buf,HeaderBgColor,sizeof(HeaderBgColor))>0) return;
449
450 if (getparam_string("font_size",buf,FontSize,sizeof(FontSize))>0) return;
451
452 if (getparam_string("header_font_size",buf,HeaderFontSize,sizeof(HeaderFontSize))>0) return;
453
454 if (getparam_string("title_font_size",buf,TitleFontSize,sizeof(TitleFontSize))>0) return;
455
456 if (getparam_2words("image_size",buf,Width,sizeof(Width),Height,sizeof(Height))>0) return;
457
458 if (getparam_quoted("title",buf,Title,sizeof(Title))>0) return;
459
460 if (strncasecmp(buf,"resolve_ip",10)==0) {
461 if (ip2name_config(buf+10)>0) return;
462 }
463
464 if (getparam_bool("user_ip",buf,&UserIp)>0) return;
465
466 if (getparam_string("max_elapsed",buf,MaxElapsed,sizeof(MaxElapsed))>0) return;
467
468 if (is_param("date_format",buf)) {
469 getword_start(&gwarea,buf);
470 if (getword_multisep(wbuf,sizeof(wbuf),&gwarea,' ')<0) {
471 debuga(_("Maybe you have a broken record or garbage in \"date_format\" parameter\n"));
472 exit(EXIT_FAILURE);
473 }
474 DateFormat=gwarea.current[0];
475 return;
476 }
477
478 if (is_param("hours",buf)) {
479 if( getnumlist( buf, &hours, 24, 24 ) ) {
480 debuga(_("Error: Invalid syntax in hours tag!\n"));
481 exit( 1 );
482 }
483 return;
484 }
485
486 if (is_param("weekdays",buf)) {
487 if( getnumlist( buf, &weekdays, 7, 7 ) ) {
488 debuga(_("Error: Invalid syntax in weekdays tag!\n"));
489 exit( 1 );
490 }
491 return;
492 }
493
494 if (getparam_sort("topuser_sort_field",SET_LIST(topuser_sort),buf,&TopuserSort)>0) return;
495
496 if (getparam_sort("user_sort_field",SET_LIST(user_sort),buf,&UserSort)>0) return;
497
498 if (is_param("access_log",buf)>0) {
499 if (AccessLogFromCmdLine==0) {
500 if (NAccessLog>=MAXLOGS) {
501 debuga(_("Too many log files in configuration file\n"));
502 exit(EXIT_FAILURE);
503 }
504 getparam_string("access_log",buf,AccessLog[NAccessLog],MAX_LOG_FILELEN);
505 NAccessLog++;
506 }
507 return;
508 }
509
510 if (is_param("redirector_log",buf)>0) {
511 if (RedirectorLogFromCmdLine==0) {
512 if (NRedirectorLogs>=MAX_REDIRECTOR_LOGS) {
513 debuga(_("Too many redirector log files in configuration file\n"));
514 exit(EXIT_FAILURE);
515 }
516 getparam_string("redirector_log",buf,RedirectorLogs[NRedirectorLogs],MAX_REDIRECTOR_FILELEN);
517 NRedirectorLogs++;
518 }
519 return;
520 }
521
522 if (getparam_string("useragent_log",buf,UserAgentLog,sizeof(UserAgentLog))>0) return;
523
524 if (getparam_string("exclude_hosts",buf,ExcludeHosts,sizeof(ExcludeHosts))>0) return;
525
526 if (getparam_string("exclude_codes",buf,ExcludeCodes,sizeof(ExcludeCodes))>0) return;
527
528 if (getparam_string("exclude_users",buf,ExcludeUsers,sizeof(ExcludeUsers))>0) return;
529
530 if (getparam_string("password",buf,PasswdFile,sizeof(PasswdFile))>0) return;
531
532 if (getparam_string("temporary_dir",buf,TempDir,sizeof(TempDir))>0) return;
533
534 if (getparam_list("report_type",SET_LIST(report_type_values),buf,&ReportType)>0) return;
535
536 if (getparam_string("output_dir",buf,OutputDir,sizeof(OutputDir))>0) return;
537
538 if (getparam_bool("anonymous_output_files",buf,&AnonymousOutputFiles)>0) return;
539
540 if (getparam_string("output_email",buf,OutputEmail,sizeof(OutputEmail))>0) return;
541
542 if (getparam_2words("per_user_limit",buf,PerUserLimitFile,sizeof(PerUserLimitFile),wbuf,sizeof(wbuf))>0) {
543 PerUserLimit=atoi(wbuf);
544 return;
545 }
546
547 if (getparam_int("lastlog",buf,&LastLog)>0) return;
548
549 if (getparam_bool("remove_temp_files",buf,&RemoveTempFiles)>0) return;
550
551 if (getparam_string("replace_index",buf,ReplaceIndex,sizeof(ReplaceIndex))>0) return;
552
553 if (getparam_list("index_tree",SET_LIST(index_tree_values),buf,&IndexTree)>0) return;
554
555 if (getparam_list("index",SET_LIST(index_values),buf,&Index)>0) return;
556
557 if (getparam_list("index_fields",SET_LIST(indexfields_values),buf,&IndexFields)>0) return;
558
559 if (getparam_bool("overwrite_report",buf,&OverwriteReport)>0) return;
560
561 if (getparam_list("records_without_userid",SET_LIST(recnouser_values),buf,&RecordsWithoutUser)>0) return;
562
563 if (getparam_bool("use_comma",buf,&UseComma)>0) return;
564
565 if (getparam_string("mail_utility",buf,MailUtility,sizeof(MailUtility))>0) return;
566
567 if (getparam_int("topsites_num",buf,&TopSitesNum)>0) return;
568
569 if (getparam_int("topuser_num",buf,&TopUsersNum)>0) return;
570
571 if (getparam_string("usertab",buf,UserTabFile,sizeof(UserTabFile))>0) return;
572
573 if (getparam_string("index_sort_order",buf,IndexSortOrder,sizeof(IndexSortOrder))>0) return;
574
575 if (getparam_sort("topsites_sort_order",SET_LIST(topsite_sort),buf,&TopsitesSort)>0) return;
576
577 if (getparam_bool("long_url",buf,&LongUrl)>0) return;
578
579 if (getparam_string("dansguardian_conf",buf,DansGuardianConf,sizeof(DansGuardianConf))>0) return;
580
581 if (getparam_string("squidguard_conf",buf,SquidGuardConf,sizeof(SquidGuardConf))>0) return;
582
583 if (getparam_list("date_time_by",SET_LIST(datetime_values),buf,&datetimeby)>0) return;
584
585 if (getparam_string("charset",buf,CharSet,sizeof(CharSet))>0) {
586 ccharset(CharSet);
587 return;
588 }
589
590 if (getparam_quoted("user_invalid_char",buf,UserInvalidChar,sizeof(UserInvalidChar))>0) return;
591
592 if (getparam_quoted("include_users",buf,IncludeUsers+1,sizeof(IncludeUsers)-2)>0) {
593 IncludeUsers[0]=':';
594 strcat(IncludeUsers,":");
595 return;
596 }
597
598 if (getparam_quoted("exclude_string",buf,ExcludeString,sizeof(ExcludeString))>0) return;
599
600 if (getparam_bool("privacy",buf,&Privacy)>0) return;
601
602 if (getparam_quoted("privacy_string",buf,PrivacyString,sizeof(PrivacyString))>0) return;
603
604 if (getparam_string("privacy_string_color",buf,PrivacyStringColor,sizeof(PrivacyStringColor))>0) return;
605
606 if (getparam_bool("show_successful_message",buf,&SuccessfulMsg)>0) return;
607
608 if (getparam_bool("show_read_statistics",buf,&ShowReadStatistics)>0) return;
609
610 if (getparam_bool("show_read_percent",buf,&ShowReadPercent)>0) return;
611
612 if (getparam_list("topuser_fields",SET_LIST(topuserfields_values),buf,&TopUserFields)>0) return;
613
614 if (getparam_bool("bytes_in_sites_users_report",buf,&BytesInSitesUsersReport)>0) return;
615
616 if (getparam_list("user_report_fields",SET_LIST(userreportfields_values),buf,&UserReportFields)>0) return;
617
618 if (getparam_string("datafile",buf,DataFile,sizeof(DataFile))>0) return;
619
620 if (getparam_quoted("datafile_delimiter",buf,DataFileDelimiter,sizeof(DataFileDelimiter))>0) return;
621
622 if (getparam_list("datafile_fields",SET_LIST(data_field_values),buf,&DataFileFields)>0) return;
623
624 if (getparam_list("datafile_url",SET_LIST(datafileurl_values),buf,&DataFileUrl)>0) return;
625
626 if (getparam_string("parsed_output_log",buf,ParsedOutputLog,sizeof(ParsedOutputLog))>0) return;
627
628 if (getparam_string("parsed_output_log_compress",buf,ParsedOutputLogCompress,sizeof(ParsedOutputLogCompress))>0) return;
629
630 if (getparam_list("displayed_values",SET_LIST(displayvalue_values),buf,&DisplayedValues)>0) return;
631
632 if (getparam_int("authfail_report_limit",buf,&AuthfailReportLimit)>0) return;
633
634 if (getparam_int("denied_report_limit",buf,&DeniedReportLimit)>0) return;
635
636 if (getparam_int("siteusers_report_limit",buf,&SiteUsersReportLimit)>0) return;
637
638 if (getparam_int("dansguardian_report_limit",buf,&DansGuardianReportLimit)>0) return;
639
640 if (getparam_int("squidguard_report_limit",buf,&SquidGuardReportLimit)>0) return;
641
642 if (getparam_int("user_report_limit",buf,&UserReportLimit)>0) return;
643
644 if (getparam_int("download_report_limit",buf,&DownloadReportLimit)>0) return;
645
646 if (getparam_string("www_document_root",buf,wwwDocumentRoot,sizeof(wwwDocumentRoot))>0) return;
647
648 if (getparam_string("block_it",buf,BlockIt,sizeof(BlockIt))>0) return;
649
650 if (getparam_string("external_css_file",buf,ExternalCSSFile,sizeof(ExternalCSSFile))>0) return;
651
652 if (getparam_bool("user_authentication",buf,&UserAuthentication)>0) return;
653
654 if (getparam_string("AuthUserTemplateFile",buf,wbuf,sizeof(wbuf))>0) {
655 char dir[MAXLEN];
656
657 if (is_absolute(wbuf)) {
658 if (strlen(wbuf)>=sizeof(AuthUserTemplateFile)) {
659 debuga(_("Template file name is too long in parameter \"AuthUserTemplateFile\"\n"));
660 exit(EXIT_FAILURE);
661 }
662 safe_strcpy(AuthUserTemplateFile,wbuf,sizeof(AuthUserTemplateFile));
663 } else {
664 safe_strcpy(dir,ConfigFile,sizeof(dir));
665 if (snprintf(AuthUserTemplateFile,sizeof(AuthUserTemplateFile),"%s/%s",dirname(dir),wbuf)>=sizeof(AuthUserTemplateFile)) {
666 debuga(_("Template file name is too long in parameter \"AuthUserTemplateFile\"\n"));
667 exit(EXIT_FAILURE);
668 }
669 }
670 return;
671 }
672
673 if (is_param("download_suffix",buf)) {
674 char warea[MAXLEN];
675
676 getparam_quoted("download_suffix",buf,warea,sizeof(warea));
677 set_download_suffix(warea);
678 return;
679 }
680
681 if (getparam_bool("graphs",buf,&Graphs)>0) {
682 #ifndef HAVE_GD
683 if (Graphs)
684 debugaz(_("No graphs available as sarg was not compiled with libgd. Set \"graphs\" to \"no\" in %s to disable this warning\n"),
685 ConfigFile);
686 #endif
687 return;
688 }
689
690 if (getparam_string("graph_days_bytes_bar_color",buf,GraphDaysBytesBarColor,sizeof(GraphDaysBytesBarColor))>0) return;
691
692 if (getparam_string("redirector_log_format",buf,RedirectorLogFormat,sizeof(RedirectorLogFormat))>0) return;
693 if (getparam_string("squidguard_log_format",buf,RedirectorLogFormat,sizeof(RedirectorLogFormat))>0) {
694 debuga(_("squidguard_log_format is deprecated and has been replaced by redirector_log_format. Please update your configuration file.\n"));
695 return;
696 }
697
698 if (getparam_bool("redirector_filter_out_date",buf,&RedirectorFilterOutDate)>0) return;
699 if (getparam_bool("redirector_ignore_date",buf,&RedirectorFilterOutDate)>0) {
700 /*
701 Due to an old bug in sarg before version 2.3, the option was having the opposite action than implied by the name.
702 */
703 debuga(_("redirector_ignore_date is deprecated and has been replaced by redirector_filter_out_date that does the action implied by its name as opposed to redirector_ignore_date. Please update your configuration file.\n"));
704 RedirectorFilterOutDate=!RedirectorFilterOutDate;
705 return;
706 }
707 if (getparam_bool("squidguard_ignore_date",buf,&RedirectorFilterOutDate)>0) {
708 debuga(_("squidguard_ignore_date is deprecated and has been replaced by redirector_filter_out_date that does the action implied by its name as opposed to squidguard_ignore_date. Please update your configuration file.\n"));
709 RedirectorFilterOutDate=!RedirectorFilterOutDate;
710 return;
711 }
712
713 if (getparam_bool("dansguardian_filter_out_date",buf,&DansguardianFilterOutDate)>0) return;
714 if (getparam_bool("dansguardian_ignore_date",buf,&DansguardianFilterOutDate)>0) {
715 debuga(_("dansguardian_ignore_date is deprecated and has been replaced by dansguardian_filter_out_date that does the action implied by its name as opposed to dansguardian_ignore_date. Please update your configuration file.\n"));
716 DansguardianFilterOutDate=!DansguardianFilterOutDate;
717 return;
718 }
719
720 if (getparam_string("ulimit",buf,Ulimit,sizeof(Ulimit))>0) return;
721
722 if (getparam_list("ntlm_user_format",SET_LIST(ntml_userformat_values),buf,&NtlmUserFormat)>0) return;
723
724 if (getparam_string("realtime_types",buf,RealtimeTypes,sizeof(RealtimeTypes))>0) return;
725
726 if (getparam_list("realtime_unauthenticated_records",SET_LIST(realtime_unauth_values),buf,&RealtimeUnauthRec)>0) return;
727
728 if (getparam_int("realtime_refresh_time",buf,&realtime_refresh)>0) return;
729
730 if (getparam_int("realtime_access_log_lines",buf,&realtime_access_log_lines)>0) return;
731
732 if (getparam_string("LDAPHost",buf,LDAPHost,sizeof(LDAPHost))>0) return;
733
734 if (getparam_int("LDAPPort",buf,&LDAPPort)>0) return;
735
736 if (getparam_int("LDAPProtocolVersion",buf,&LDAPProtocolVersion)>0) return;
737
738 if (getparam_string("LDAPBindDN",buf,LDAPBindDN,sizeof(LDAPBindDN))>0) return;
739
740 if (getparam_string("LDAPBindPW",buf,LDAPBindPW,sizeof(LDAPBindPW))>0) return;
741
742 if (getparam_string("LDAPBaseSearch",buf,LDAPBaseSearch,sizeof(LDAPBaseSearch))>0) return;
743
744 if (getparam_string("LDAPFilterSearch",buf,LDAPFilterSearch,sizeof(LDAPFilterSearch))>0) return;
745
746 if (getparam_string("LDAPTargetAttr",buf,LDAPTargetAttr,sizeof(LDAPTargetAttr))>0) return;
747
748 if (getparam_string("graph_font",buf,GraphFont,sizeof(GraphFont))>0) return;
749
750 if (getparam_string("sorttable",buf,SortTableJs,sizeof(SortTableJs))>0) return;
751
752 if (getparam_string("hostalias",buf,HostAliasFile,sizeof(HostAliasFile))>0) return;
753
754 if (getparam_bool("keep_temp_log",buf,&KeepTempLog)>0) return;
755
756 if (getparam_int("max_successive_log_errors",buf,&NumLogSuccessiveErrors)>0) return;
757
758 if (getparam_int("max_total_log_errors",buf,&NumLogTotalErrors)>0) return;
759
760 if(strstr(buf,"squid24") != 0) {
761 squid24=true;
762 return;
763 }
764
765 if(strstr(buf,"byte_cost") != 0) {
766 getword_start(&gwarea,buf);
767 if (getword_multisep(wbuf,sizeof(wbuf),&gwarea,' ')<0) {
768 debuga(_("The \"byte_cost\" parameter of the configuration file is invalid\n"));
769 exit(EXIT_FAILURE);
770 }
771 cost=atol(gwarea.current);
772 if (getword_multisep(wbuf,sizeof(wbuf),&gwarea,' ')<0) {
773 debuga(_("The \"byte_cost\" parameter of the configuration file is invalid\n"));
774 exit(EXIT_FAILURE);
775 }
776 nocost=my_atoll(gwarea.current);
777 return;
778 }
779
780 printf(_("SARG: Unknown option %s\n"),buf);
781 }
782
783 void getconf(void)
784 {
785 FILE *fp_in;
786 char buf[MAXLEN];
787
788 if(debug)
789 debuga(_("Loading configuration from %s\n"),ConfigFile);
790
791 if ((fp_in = fopen(ConfigFile, "r")) == NULL) {
792 debuga(_("(getconf) Cannot open file %s\n"),ConfigFile);
793 exit(EXIT_FAILURE);
794 }
795
796 while (fgets(buf, sizeof(buf), fp_in) != NULL) {
797 fixendofline(buf);
798
799 if(debugm)
800 printf("SYSCONFDIR %s\n",buf);
801
802 parmtest(buf);
803
804 }
805
806 fclose(fp_in);
807 return;
808 }