Update to 2.2.7.1

Feature safe:	yes
This commit is contained in:
Renato Botelho 2010-02-22 17:06:04 +00:00
parent f52ceeeb1a
commit 88eeede684
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=250176
6 changed files with 40 additions and 994 deletions

View file

@ -6,8 +6,7 @@
#
PORTNAME= sarg
PORTVERSION= 2.2.5
PORTREVISION= 3
PORTVERSION= 2.2.7.1
CATEGORIES= www
MASTER_SITES= SF/${PORTNAME}/${PORTNAME}/${PORTNAME}-${PORTVERSION}
@ -16,31 +15,31 @@ COMMENT= Squid log analyzer and HTML report generator
OPTIONS= GD "Enable GD support" on
USE_GCC= 4.2+
USE_ICONV= yes
USE_GETTEXT= yes
GNU_CONFIGURE= yes
MAKE_JOBS_SAFE= yes
CFLAGS+= -I${LOCALBASE}/include
LDFLAGS+= -L${LOCALBASE}/lib
CONFIGURE_ENV= CC=gcc CFLAGS="${CFLAGS}" LDFLAGS="${LDFLAGS}"
CONFIGURE_ARGS= --enable-bindir="${PREFIX}/bin" \
--enable-sysconfdir="${PREFIX}/etc/${PORTNAME}" \
--enable-htmldir="${PREFIX}/www/${PORTNAME}" \
--enable-mandir="${MAN1PREFIX}/man/man1"
CONFIGURE_ENV= CC="${CC}" LDFLAGS="${LDFLAGS}"
CONFIGURE_ARGS= --sysconfdir="${PREFIX}/etc/${PORTNAME}" \
--enable-sargphp="${PREFIX}/etc/${PORTNAME}" \
--enable-languagedir="${PREFIX}/etc/${PORTNAME}/languages" \
--enable-fontdir="${PREFIX}/etc/${PORTNAME}/fonts" \
--enable-imagedir="${PREFIX}/etc/${PORTNAME}/images"
MAN1= sarg.1
.include <bsd.port.pre.mk>
.if ${CC} == "cc"
CC= gcc
.endif
.if !defined(WITHOUT_GD)
GD_PORT?= graphics/gd
LIB_DEPENDS+= gd.4:${PORTSDIR}/${GD_PORT}
.endif
post-extract:
@${CHMOD} +x ${WRKSRC}/sarg-php/locale
post-patch:
@${REINPLACE_CMD} -e '/^LDFLAGS=/d' ${WRKSRC}/${CONFIGURE_SCRIPT}
.include <bsd.port.post.mk>

View file

@ -1,3 +1,3 @@
MD5 (sarg-2.2.5.tar.gz) = 0f4481e375dedf9ab8c682c9407162ff
SHA256 (sarg-2.2.5.tar.gz) = 4798d8219c3d8e06fe122f0ae49754d18abfb901463e5edd71f4b7a529c1e81d
SIZE (sarg-2.2.5.tar.gz) = 639563
MD5 (sarg-2.2.7.1.tar.gz) = 0ce83323978e715ce70a6d2ab4f0daa4
SHA256 (sarg-2.2.7.1.tar.gz) = 209398e7690876ef9df04ba7f0b4b47c91ea8cdcfd7a54d78f15b5548a2dd32e
SIZE (sarg-2.2.7.1.tar.gz) = 713786

View file

@ -1,17 +1,26 @@
--- ./Makefile.in.orig Sat Apr 26 00:20:55 2003
+++ ./Makefile.in Mon Aug 11 18:09:33 2003
@@ -58,12 +58,11 @@
$(INSTALL_PROGRAM) sarg $(BINDIR)/sarg
chmod 755 $(BINDIR)/sarg
$(INSTALL_PROGRAM) sarg.1 $(MANDIR)/sarg.1
- chmod 755 $(MANDIR)/sarg.1
+ chmod 644 $(MANDIR)/sarg.1
+ cp sarg.conf $(SYSCONFDIR)/sarg.conf.default;
@if test ! -f $(SYSCONFDIR)/sarg.conf; then \
echo "cp $(SYSCONFDIR)/sarg.conf"; \
cp sarg.conf $(SYSCONFDIR)/sarg.conf; \
--- Makefile.in.orig 2010-01-20 09:19:16.000000000 -0200
+++ Makefile.in 2010-02-08 09:58:51.000000000 -0200
@@ -9,7 +9,7 @@
CC = @CC@
BINDIR = @bindir@
IBINDIR = -DBINDIR=\"@bindir@\"
-MANDIR = @mandir@
+MANDIR = @mandir@/man1
SYSCONFDIR = @sysconfdir@
SARGPHPDIR = @SARGPHPDIR@
LANGDIR = @LANGDIR@
@@ -84,12 +84,11 @@
$(INSTALL_PROGRAM) sarg $(DESTDIR)$(BINDIR)/sarg
chmod 755 $(DESTDIR)$(BINDIR)/sarg
$(INSTALL_PROGRAM) sarg.1 $(DESTDIR)$(MANDIR)/sarg.1
- chmod 755 $(DESTDIR)$(MANDIR)/sarg.1
+ chmod 644 $(DESTDIR)$(MANDIR)/sarg.1
+ cp sarg.conf $(DESTDIR)$(SYSCONFDIR)/sarg.conf.default
@if test ! -f $(DESTDIR)$(SYSCONFDIR)/sarg.conf; then \
echo "cp $(DESTDIR)$(SYSCONFDIR)/sarg.conf"; \
cp sarg.conf $(DESTDIR)$(SYSCONFDIR)/sarg.conf; \
- else \
- cp sarg.conf $(SYSCONFDIR)/sarg.conf.default; \
- cp sarg.conf $(DESTDIR)$(SYSCONFDIR)/sarg.conf.default; \
fi
cp -r ./languages $(SYSCONFDIR);
cp ./exclude_codes $(SYSCONFDIR);
cp -r ./languages/* $(DESTDIR)$(LANGDIR);
cp ./exclude_codes $(DESTDIR)$(SYSCONFDIR);

View file

@ -1,932 +0,0 @@
diff -Naur sarg-2.2.3.1.orig/auth.c sarg-2.2.3.1/auth.c
--- sarg-2.2.3.1.orig/auth.c 2007-01-02 22:11:26.000000000 +0300
+++ auth.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
void htaccess(char *name)
{
diff -Naur sarg-2.2.3.1.orig/authfail.c sarg-2.2.3.1/authfail.c
--- sarg-2.2.3.1.orig/authfail.c 2007-01-02 22:11:26.000000000 +0300
+++ authfail.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,13 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
void authfail_report()
{
diff -Naur sarg-2.2.3.1.orig/convlog.c sarg-2.2.3.1/convlog.c
--- sarg-2.2.3.1.orig/convlog.c 2007-01-02 22:11:26.000000000 +0300
+++ convlog.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
void convlog(char *arq, char *df, int dfrom, int duntil)
{
diff -Naur sarg-2.2.3.1.orig/css.c sarg-2.2.3.1/css.c
--- sarg-2.2.3.1.orig/css.c 2007-01-02 22:11:26.000000000 +0300
+++ css.c 2007-08-10 16:18:40.000000000 +0400
@@ -59,7 +59,7 @@
fprintf(fp_css,".data2 a:link,a:visited {font-family:%s;color:#0000FF;font-size:%s;background-color:%s;text-decoration:none;}\n", FontFace, FontSize, TxBgColor);
fprintf(fp_css,".data3 {font-family:%s;color:%s;font-size:%s;text-align:center;background-color:%s;border-right:1px solid #6A5ACD;border-bottom:1px solid #6A5ACD;}\n", FontFace, TxColor, FontSize, TxBgColor);
fprintf(fp_css,".data3 a:link,a:visited {font-family:%s;color:#0000FF;font-size:%s;text-align:center;background-color:%s;text-decoration:none;}\n", FontFace, FontSize, TxBgColor);
- fprintf(fp_css,".text {font-family:%s;color:%s;font-size:%s;text-align:right;}\n", FontFace, TxColor, FontSize, TxBgColor);
+ fprintf(fp_css,".text {font-family:%s;color:%s;font-size:%s;text-align:right;background-color:%s;}\n", FontFace, TxColor, FontSize, TxBgColor);
fprintf(fp_css,".link {font-family:%s;font-size:%s;color:#0000FF;}\n", FontFace, FontSize);
fprintf(fp_css,".link a:link,a:visited {font-family:%s;font-size:%s;color:#0000FF;text-decoration:none;}\n</style>\n", FontFace, FontSize);
}
diff -Naur sarg-2.2.3.1.orig/dansguardian_log.c sarg-2.2.3.1/dansguardian_log.c
--- sarg-2.2.3.1.orig/dansguardian_log.c 2007-01-02 22:11:26.000000000 +0300
+++ dansguardian_log.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,8 +24,11 @@
*/
#include "include/conf.h"
+void conv_month(char *month);
+void debuga(char *msg);
+void getword(char *word, char *line, int stop);
-int dansguardian_log()
+void dansguardian_log()
{
FILE *fp_in = NULL, *fp_ou = NULL, *fp_guard = NULL;
@@ -38,7 +41,6 @@
char ip[30];
char wdata[127];
int idata=0;
- int x, y;
bzero(day, 3);
bzero(mon, 4);
@@ -160,5 +162,4 @@
sprintf(tmp6,"sort -k 1,1 -k 2,2 -k 4,4 '%s' -o '%s'",guard_in, guard_ou);
system(tmp6);
unlink(guard_in);
- return;
}
diff -Naur sarg-2.2.3.1.orig/dansguardian_report.c sarg-2.2.3.1/dansguardian_report.c
--- sarg-2.2.3.1.orig/dansguardian_report.c 2007-01-02 22:11:26.000000000 +0300
+++ dansguardian_report.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,13 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
void dansguardian_report()
{
@@ -31,10 +38,8 @@
FILE *fp_in = NULL, *fp_ou = NULL;
char url[MAXLEN];
- char html[MAXLEN];
char html2[MAXLEN];
char dansguardian_in[MAXLEN];
- char dansguardian_ou[MAXLEN];
char per[MAXLEN];
char report[MAXLEN];
char period[100];
@@ -46,7 +51,6 @@
char date[15];
char date2[15];
char hour[15];
- char ftime[128];
char *str;
int z=0;
int count=0;
diff -Naur sarg-2.2.3.1.orig/datafile.c sarg-2.2.3.1/datafile.c
--- sarg-2.2.3.1.orig/datafile.c 2007-01-02 22:11:26.000000000 +0300
+++ datafile.c 2007-08-10 16:18:40.000000000 +0400
@@ -27,6 +27,12 @@
void saverecs(char *dirname, char *user, long long int nacc, char *url, long long int nbytes, char *ip, char *hora, char *dia, long long int nelap, long long int incache, long long int oucache);
void grava_SmartFilter(char *dirname, char *user, char *ip, char *data, char *hora, char *url, char *smart);
+void getword(char *word, char *line, int stop);
+void ip2name(char *ip);
+void gravatmp(char *oldaccuser, char *dirname, char *oldurl, long long int nacc, long long int nbytes, char *oldmsg, long long int nelap, int indexonly, long long int incache, long long int oucache);
+void debuga(char *msg);
+void my_lltoa(unsigned long long int n, char s[], int len);
+void name2ip(char *name);
void data_file(char *tmp)
{
@@ -70,7 +76,6 @@
exit(1);
}
strcpy(wdname,direntp->d_name);
- strip_prefix:
getword(wname2,wdname,'.');
strcat(user,wname2);
diff -Naur sarg-2.2.3.1.orig/decomp.c sarg-2.2.3.1/decomp.c
--- sarg-2.2.3.1.orig/decomp.c 2007-01-02 22:11:26.000000000 +0300
+++ decomp.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void debuga(char *msg);
void decomp(char *arq, char *zip, char *tmp)
{
diff -Naur sarg-2.2.3.1.orig/denied.c sarg-2.2.3.1/denied.c
--- sarg-2.2.3.1.orig/denied.c 2007-01-02 22:11:26.000000000 +0300
+++ denied.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,13 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
void gen_denied_report()
{
diff -Naur sarg-2.2.3.1.orig/download.c sarg-2.2.3.1/download.c
--- sarg-2.2.3.1.orig/download.c 2007-01-02 22:11:26.000000000 +0300
+++ download.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,13 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
void download_report()
{
diff -Naur sarg-2.2.3.1.orig/email.c sarg-2.2.3.1/email.c
--- sarg-2.2.3.1.orig/email.c 2007-01-02 22:11:26.000000000 +0300
+++ email.c 2007-08-10 16:18:40.000000000 +0400
@@ -25,6 +25,11 @@
#include "include/conf.h"
+char *fixnum(long long int value, int n);
+char *buildtime(long long int elap);
+void strip_latin(char *line);
+void fixip(char *ip);
+
int geramail(const char *dirname, int debug, const char *outdir, int userip, char *email, char *TempDir)
{
diff -Naur sarg-2.2.3.1.orig/exclude.c sarg-2.2.3.1/exclude.c
--- sarg-2.2.3.1.orig/exclude.c 2007-01-02 22:11:26.000000000 +0300
+++ exclude.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
int vhexclude(char *excludefile, char *url)
{
@@ -34,12 +35,12 @@
int len = strlen(excludefile);
if((str=(char *) malloc(len+1))==NULL) {
- fprintf(stderr, "SARG: %s (%ld):\n",text[59], len);
+ fprintf(stderr, "SARG: %s (%d):\n",text[59], len);
exit(1);
}
len = strlen(url);
if((wurl=(char *) malloc(len+1))==NULL) {
- fprintf(stderr, "SARG: %s (%ld):\n",text[59], len);
+ fprintf(stderr, "SARG: %s (%d):\n",text[59], len);
exit(1);
}
whost[0]='\0';
diff -Naur sarg-2.2.3.1.orig/getconf.c sarg-2.2.3.1/getconf.c
--- sarg-2.2.3.1.orig/getconf.c 2007-01-02 22:11:26.000000000 +0300
+++ getconf.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,11 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void fixnone(char *str);
+void ccharset();
+void debuga(char *msg);
+void language_load(char *language);
extern numlist hours, weekdays;
diff -Naur sarg-2.2.3.1.orig/grepday.c sarg-2.2.3.1/grepday.c
--- sarg-2.2.3.1.orig/grepday.c 2007-01-02 22:11:26.000000000 +0300
+++ grepday.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,6 +24,11 @@
*/
#include "include/conf.h"
+char *fixnum(long long int value, int n);
+char *subs(char *str, char *from, char *to);
+void fixip(char *ip);
+void ip2name(char *ip);
+void getword(char *word, char *line, int stop);
int blue;
int white;
diff -Naur sarg-2.2.3.1.orig/html.c sarg-2.2.3.1/html.c
--- sarg-2.2.3.1.orig/html.c 2007-01-02 22:11:26.000000000 +0300
+++ html.c 2007-08-10 16:18:40.000000000 +0400
@@ -24,30 +24,45 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void report_day(char *user, int *iprel, int *ipuser);
+void greport_day(char *user, int *iprel, int *ipuser);
+void fixip(char *ip);
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void debuga(char *msg);
+char *fixnum(long long int value, int n);
+char *fixnum2(long long int value, int n);
+void url_module(char *url, char *w2);
+char *buildtime(long long int elap);
+void my_lltoa(unsigned long long int n, char s[], int len);
+void show_info(FILE *fp_ou);
+void htaccess(char *name);
void htmlrel()
{
DIR *dirp;
- FILE *fp_in, *fp_ou, *fp_ip, *fp_ip2, *fp_usr, *fp_tt;
+ FILE *fp_in, *fp_ou, *fp_ip, *fp_ip2, *fp_usr;
struct dirent *direntp;
long long int nnbytes=0, unbytes=0, tnbytes=0, totbytes=0, totbytes2=0;
long long int totelap=0, totelap2=0, nnelap=0, unelap=0, tnelap=0;
long long int incache=0, oucache=0, tnincache=0, tnoucache=0, twork=0, twork2=0;
char arqin[MAXLEN], arqou[MAXLEN], arqper[MAXLEN], arqip[MAXLEN];
- char nacc[20], nbytes[20], url[1024], purl[1024], tmsg[50], tmsg2[50], nelap[20], csort[MAXLEN];
+ char nacc[20], nbytes[20], url[1024], tmsg[50], nelap[20], csort[MAXLEN];
char period[MAXLEN], usuario[MAXLEN], wusuario[MAXLEN], u2[MAXLEN], duser[MAXLEN];
char userbytes[20], userelap[20], userurl[1024], userhora[9], userdia[9];
char user_ip[MAXLEN], olduserip[MAXLEN], tmp2[MAXLEN], tmp3[MAXLEN], incac[20], oucac[20];
char denied_report[255], name2[MAXLEN];
- char ttd1[3], ttd2[3], ttd3[5], ttt1[3], ttt2[3], ttt3[3];
char *str;
- char ftime[128], warea[MAXLEN];
+ char warea[MAXLEN];
char wtemp[MAXLEN], totuser[8];
long long int tnacc=0, ttnacc=0, unacc=0;
float perc=0, perc2=0, ouperc=0, inperc=0;
char *s;
- int x, count;
+ int count;
if(strstr(ReportType,"users_sites") == 0) return;
diff -Naur sarg-2.2.3.1.orig/include/conf.h sarg-2.2.3.1/include/conf.h
--- sarg-2.2.3.1.orig/include/conf.h 2007-01-02 22:11:26.000000000 +0300
+++ include/conf.h 2007-08-10 16:18:44.000000000 +0400
@@ -118,7 +118,7 @@
char df[20];
char day[3], month[4], year[5];
char nmonth[30];
-char y1[5], y2[5];
+char Y1[5], Y2[5];
char d1[3], d2[3];
char m1[4], m2[4];
char ltext110[50];
diff -Naur sarg-2.2.3.1.orig/index.c sarg-2.2.3.1/index.c
--- sarg-2.2.3.1.orig/index.c 2007-01-02 22:11:26.000000000 +0300
+++ index.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,21 @@
*/
#include "include/conf.h"
+void mklastlog();
+void debuga(char *msg);
+void conv_month(char *month);
+void getword(char *word, char *line, int stop);
+void conv_month_name(char *month);
+char* get_size(char *path, char *file);
+void obtdate(char *dirname, char *name, char *data);
+void obtuser(char *dirname, char *name, char *tuser);
+void obttotal(char *dirname, char *name, char *tbytes, char *tuser, char *media);
+void buildymd(char *dia, char *mes, char *ano, char *wdata);
+void write_html_header(FILE *fp_ou, char * ind);
+void name_month(char *month);
+void write_html_trailer(FILE *fp_ou);
+void zdate(char *ftime, char *DateFormat);
+void show_info(FILE *fp_ou);
void make_index()
{
@@ -69,31 +84,31 @@
if(strcmp(IndexTree,"date") == 0) {
if(!isdigit(direntp->d_name[0]) && !isdigit(direntp->d_name[1])) continue;
if(strlen(direntp->d_name) > 4) {
- bzero(y1,5);
- bzero(y2,5);
+ bzero(Y1,5);
+ bzero(Y2,5);
bzero(m1,4);
bzero(m2,4);
bzero(d1,3);
bzero(d2,3);
if(strcmp(df,"u") == 0) {
- strncpy(y1,direntp->d_name,4);
+ strncpy(Y1,direntp->d_name,4);
strncpy(m1,direntp->d_name+4,3);
strncpy(d1,direntp->d_name+7,2);
- strncpy(y2,direntp->d_name+10,4);
+ strncpy(Y2,direntp->d_name+10,4);
strncpy(m2,direntp->d_name+14,3);
strncpy(d2,direntp->d_name+17,2);
} else if(strcmp(df,"e") == 0) {
- strncpy(y1,direntp->d_name+5,4);
+ strncpy(Y1,direntp->d_name+5,4);
strncpy(m1,direntp->d_name+2,3);
strncpy(d1,direntp->d_name,2);
- strncpy(y2,direntp->d_name+15,4);
+ strncpy(Y2,direntp->d_name+15,4);
strncpy(m2,direntp->d_name+12,3);
strncpy(d2,direntp->d_name+10,2);
}
conv_month(m1);
conv_month(m2);
}
- sprintf(val1,"%s%s",outdir,y1);
+ sprintf(val1,"%s%s",outdir,Y1);
if(access(val1, R_OK) != 0) mkdir(val1,0755);
if(strcmp(m1,m2) != 0) sprintf(val2,"%s/%s-%s",val1,m1,m2);
else sprintf(val2,"%s/%s",val1,m1);
@@ -110,7 +125,7 @@
} else {
if(!isdigit(direntp->d_name[0]) && !isdigit(direntp->d_name[1])) continue;
if(strlen(direntp->d_name) == 4) {
- strcpy(y1,direntp->d_name);
+ strcpy(Y1,direntp->d_name);
sprintf(val1,"%s%s",outdir,direntp->d_name);
dirp2 = opendir(val1);
while ((direntp2 = readdir( dirp2 )) != NULL) {
@@ -139,9 +154,9 @@
strcpy(d1,warea);
strcpy(d2,warea);
}
- if(strcmp(df,"u") == 0) sprintf(val4,"%s%s%s%s-%s%s%s",outdir,y1,m1,d1,y1,m2,d2);
- else if(strcmp(df,"e") == 0) sprintf(val4,"%s%s%s%s-%s%s%s",outdir,d1,m1,y1,d2,m2,y1);
- sprintf(val5,"%s%s/%s/%s",outdir,y1,direntp2->d_name,direntp3->d_name);
+ if(strcmp(df,"u") == 0) sprintf(val4,"%s%s%s%s-%s%s%s",outdir,Y1,m1,d1,Y1,m2,d2);
+ else if(strcmp(df,"e") == 0) sprintf(val4,"%s%s%s%s-%s%s%s",outdir,d1,m1,Y1,d2,m2,Y1);
+ sprintf(val5,"%s%s/%s/%s",outdir,Y1,direntp2->d_name,direntp3->d_name);
if(rename(val5,val4)) {
fprintf(stderr, "SARG: (index) rename error - %s\n",strerror(errno));
exit(1);
diff -Naur sarg-2.2.3.1.orig/ip2name.c sarg-2.2.3.1/ip2name.c
--- sarg-2.2.3.1.orig/ip2name.c 2007-01-02 22:11:26.000000000 +0300
+++ ip2name.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
void ip2name(char *ip)
{
diff -Naur sarg-2.2.3.1.orig/language.c sarg-2.2.3.1/language.c
--- sarg-2.2.3.1.orig/language.c 2007-01-02 22:11:26.000000000 +0300
+++ language.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
void language_load(char *language)
{
diff -Naur sarg-2.2.3.1.orig/lastlog.c sarg-2.2.3.1/lastlog.c
--- sarg-2.2.3.1.orig/lastlog.c 2007-01-02 22:11:26.000000000 +0300
+++ lastlog.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,8 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void debuga(char *msg);
void mklastlog()
{
diff -Naur sarg-2.2.3.1.orig/log.c sarg-2.2.3.1/log.c
--- sarg-2.2.3.1.orig/log.c 2007-01-02 22:11:26.000000000 +0300
+++ log.c 2007-08-10 16:18:44.000000000 +0400
@@ -49,6 +49,36 @@
#define _FILE_OFFSET_BITS 64
+void language_load(char *language);
+void getword(char *word, char *line, int stop);
+void date_from(char *date, char *dfrom, char *duntil);
+void usage(char *prog);
+void version();
+void debuga(char *msg);
+void getconf();
+void realtime(void);
+char *subs(char *str, char *from, char *to);
+void convlog(char *arq, char *df, int dfrom, int duntil);
+void splitlog(char *arq, char *df, int dfrom, int duntil, char *convert);
+void load_excludecodes();
+void my_mkdir(char *name);
+void decomp(char *arq, char *zip, char *tmp);
+void getword3(char *word, char *line, int stop);
+void conv_month_name(char *month);
+int vercode(char *code);
+int testvaliduserchar(char *user);
+char *strlow(char *string);
+void builddia(char *dia, char *mes, char *ano, char *df, char *wdata);
+int vhexclude(char *excludefile, char *url);
+int vuexclude(char *excludeuser, char *user);
+void fixip(char *ip);
+void fixper(char *tbuf, char *period, char *duntil);
+void debugaz(char *head, char *msg);
+void sort_users_log(char *tmp, int debug);
+void data_file(char *tmp);
+void gerarel();
+void recomp(char *arq, char *zip);
+
int main(argc,argv)
int argc;
char *argv[];
@@ -145,7 +175,7 @@
SquidGuardLogAlternate[0]='\0';
arq[0]='\0';
- strcpy(AccessLog,"/usr/local/squid/var/logs/access.log");
+ strcpy(AccessLog,"/var/log/squid/access.log");
sprintf(ExcludeCodes,"%s/exclude_codes",SYSCONFDIR);
strcpy(GraphDaysBytesBarColor,"orange");
strcpy(BgColor,"#ffffff");
@@ -160,7 +190,7 @@
strcpy(LogoTextColor,"#006699");
strcpy(FontSize,"9px");
strcpy(TempDir,"/tmp");
- strcpy(OutputDir,"/var/www/html/squid-reports");
+ strcpy(OutputDir,"/var/www/localhost/htdocs/squid-reports");
strcpy(Ip2Name,"no");
strcpy(DateFormat,"u");
strcpy(OverwriteReport,"no");
@@ -645,7 +675,7 @@
if (strlen(Ulimit) > 0) {
#if defined(RLIMIT_NOFILE)
getrlimit (RLIMIT_NOFILE, &rl);
-#else #if defined(RLIMIT_OFILE)
+#elif defined(RLIMIT_OFILE)
getrlimit (RLIMIT_OFILE, &rl);
#endif
l1 = rl.rlim_cur;
@@ -656,7 +686,7 @@
rl.rlim_max = atol(Ulimit);
#if defined(RLIMIT_NOFILE)
if(setrlimit (RLIMIT_NOFILE, &rl) == -1) {
- #else #if defined(RLIMIT_OFILE)
+ #elif defined(RLIMIT_OFILE)
if(setrlimit (RLIMIT_OFILE, &rl) == -1) {
#endif
sprintf(msg,"setrlimit error - %s\n",strerror(errno));
@@ -1216,7 +1246,7 @@
if(download_flag && strstr(code,"DENIED") == 0) {
ndownload = 1;
- sprintf(bufz, "%s %s %s %s %s %s\n",dia,hora,user,ip,download_url);
+ sprintf(bufz, "%s %s %s %s %s\n",dia,hora,user,ip,download_url);
#ifdef LEGACY_WRITE_DOWNLOAD
sprintf(tmp3,"%s/sarg/download.unsort",tmp);
@@ -1395,7 +1425,6 @@
sort_users_log(tmp, debug);
- report_gen:
if(strlen(DataFile) > 0)
data_file(tmp);
else
diff -Naur sarg-2.2.3.1.orig/realtime.c sarg-2.2.3.1/realtime.c
--- sarg-2.2.3.1.orig/realtime.c 2007-01-02 22:11:26.000000000 +0300
+++ realtime.c 2007-08-10 16:18:44.000000000 +0400
@@ -29,6 +29,12 @@
void datashow(char *);
void getlog();
void header();
+void getword(char *word, char *line, int stop);
+void debuga(char *msg);
+void getword3(char *word, char *line, int stop);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void css(FILE *fp_css);
char dat[128];
char tim[128];
@@ -37,7 +43,7 @@
char ourl[MAXLEN]="";
void
-realtime(int argc, char *argv[])
+realtime(void)
{
getlog();
diff -Naur sarg-2.2.3.1.orig/repday.c sarg-2.2.3.1/repday.c
--- sarg-2.2.3.1.orig/repday.c 2007-01-02 22:11:26.000000000 +0300
+++ repday.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,14 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+char *fixtime(long int elap);
+void show_info(FILE *fp_ou);
extern numlist hours;
diff -Naur sarg-2.2.3.1.orig/report.c sarg-2.2.3.1/report.c
--- sarg-2.2.3.1.orig/report.c 2007-01-02 22:11:26.000000000 +0300
+++ report.c 2007-08-10 16:18:44.000000000 +0400
@@ -25,6 +25,37 @@
#include "include/conf.h"
#include "include/defs.h"
+void vrfydir(char *dir, char *per1, char *addr, char *site, char *us, char *form);
+void debugaz(char *head, char *msg);
+void gperiod();
+void useragent();
+void getword(char *word, char *line, int stop);
+void ip2name(char *ip);
+void my_mkdir(char *name);
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+char *subs(char *str, char *from, char *to);
+void day_totalize(const char *tmp, char *user, int indexonly);
+void tmpsort();
+int totalger(const char *dirname, int debug, const char *outdir);
+void download_report();
+void dansguardian_log();
+void squidguard_log();
+void topuser();
+void topsites();
+void siteuser();
+void gen_denied_report();
+void authfail_report();
+void smartfilter_report();
+void dansguardian_report();
+void squidguard_report();
+void htmlrel();
+void make_index();
+int geramail(const char *dirname, int debug, const char *outdir, int userip, char *email, char *TempDir);
+void index_only();
+void removetmp(char *outdir);
+void debuga(char *msg);
+void my_lltoa(unsigned long long int n, char s[], int len);
void gerarel()
{
diff -Naur sarg-2.2.3.1.orig/siteuser.c sarg-2.2.3.1/siteuser.c
--- sarg-2.2.3.1.orig/siteuser.c 2007-01-02 22:11:26.000000000 +0300
+++ siteuser.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,15 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+char *strlow(char *string);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+char *subs(char *str, char *from, char *to);
+void ip2name(char *ip);
+char *fixnum(long long int value, int n);
+void show_info(FILE *fp_ou);
void siteuser()
{
diff -Naur sarg-2.2.3.1.orig/smartfilter.c sarg-2.2.3.1/smartfilter.c
--- sarg-2.2.3.1.orig/smartfilter.c 2007-01-02 22:11:26.000000000 +0300
+++ smartfilter.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,10 @@
*/
#include "include/conf.h"
+char *strup(char *string);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void zdate(char *ftime, char *DateFormat);
void smartfilter_report()
{
diff -Naur sarg-2.2.3.1.orig/sort.c sarg-2.2.3.1/sort.c
--- sarg-2.2.3.1.orig/sort.c 2007-01-02 22:11:26.000000000 +0300
+++ sort.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,10 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void debuga(char *msg);
+char *strup(char *string);
+char *strlow(char *string);
void tmpsort()
{
diff -Naur sarg-2.2.3.1.orig/splitlog.c sarg-2.2.3.1/splitlog.c
--- sarg-2.2.3.1.orig/splitlog.c 2007-01-02 22:11:26.000000000 +0300
+++ splitlog.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
void splitlog(char *arq, char *df, int dfrom, int duntil, char *convert)
{
diff -Naur sarg-2.2.3.1.orig/squidguard_log.c sarg-2.2.3.1/squidguard_log.c
--- sarg-2.2.3.1.orig/squidguard_log.c 2007-01-02 22:11:26.000000000 +0300
+++ squidguard_log.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,9 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void debuga(char *msg);
+void conv_month(char *month);
static char **files_done = NULL;
static int nfiles_done = 0;
@@ -159,7 +162,7 @@
}
-int squidguard_log()
+void squidguard_log()
{
FILE *fp_ou = NULL, *fp_guard = NULL;
@@ -168,7 +171,6 @@
char logdir[MAXLEN];
char year[10], day[10], mon[10];
char user[MAXLEN];
- char ip[30];
int x, y;
str2 = user;
diff -Naur sarg-2.2.3.1.orig/squidguard_report.c sarg-2.2.3.1/squidguard_report.c
--- sarg-2.2.3.1.orig/squidguard_report.c 2007-01-02 22:11:26.000000000 +0300
+++ squidguard_report.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,13 @@
*/
#include "include/conf.h"
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void getword(char *word, char *line, int stop);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
void squidguard_report()
{
@@ -31,10 +38,8 @@
FILE *fp_in = NULL, *fp_ou = NULL;
char url[MAXLEN];
- char html[MAXLEN];
char html2[MAXLEN];
char squidguard_in[MAXLEN];
- char squidguard_ou[MAXLEN];
char per[MAXLEN];
char report[MAXLEN];
char period[100];
@@ -46,7 +51,6 @@
char data[15];
char data2[15];
char hora[15];
- char ftime[128];
char *str;
int z=0;
int count=0;
diff -Naur sarg-2.2.3.1.orig/topsites.c sarg-2.2.3.1/topsites.c
--- sarg-2.2.3.1.orig/topsites.c 2007-01-02 22:11:26.000000000 +0300
+++ topsites.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,14 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void my_lltoa(unsigned long long int n, char s[], int len);
+char *strlow(char *string);
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+char *fixnum(long long int value, int n);
+char *fixtime(long int elap);
+void show_info(FILE *fp_ou);
void topsites()
{
@@ -216,7 +224,7 @@
sprintf(wwork1,"%s",fixnum(twork1,1));
sprintf(wwork2,"%s",fixnum(twork2,1));
- sprintf(wwork3,"%s",fixtime(twork3,1));
+ sprintf(wwork3,"%s",fixtime(twork3));
if(strlen(BlockIt) > 0)
sprintf(BlockImage,"<a href=\"%s%s?url=%s\"><img src=\"../images/sarg-squidguard-block.png\" border=\"0\"></a>&nbsp;",wwwDocumentRoot,BlockIt,url);
diff -Naur sarg-2.2.3.1.orig/topuser.c sarg-2.2.3.1/topuser.c
--- sarg-2.2.3.1.orig/topuser.c 2007-01-02 22:11:26.000000000 +0300
+++ topuser.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,8 +24,20 @@
*/
#include "include/conf.h"
+void my_lltoa(unsigned long long int n, char s[], int len);
+char *strup(char *string);
+char *strlow(char *string);
+void css(FILE *fp_css);
+void show_sarg(FILE *fp_ou, char *ind);
+void fixip(char *ip);
+void ip2name(char *ip);
+char *fixnum(long long int value, int n);
+char *fixnum2(long long int value, int n);
+char *buildtime(long long int elap);
+char *subs(char *str, char *from, char *to);
+void show_info(FILE *fp_ou);
-int topuser()
+void topuser()
{
FILE *fp_in = NULL, *fp_ou = NULL, *fp_top1 = NULL, *fp_top2 = NULL, *fp_top3 = NULL;
diff -Naur sarg-2.2.3.1.orig/totday.c sarg-2.2.3.1/totday.c
--- sarg-2.2.3.1.orig/totday.c 2007-01-02 22:11:26.000000000 +0300
+++ totday.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,8 @@
*/
#include "include/conf.h"
+void getword(char *word, char *line, int stop);
+void my_lltoa(unsigned long long int n, char s[], int len);
void day_totalize(const char *tmp, char *user, int indexonly)
{
diff -Naur sarg-2.2.3.1.orig/totger.c sarg-2.2.3.1/totger.c
--- sarg-2.2.3.1.orig/totger.c 2007-01-02 22:11:26.000000000 +0300
+++ totger.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,7 @@
*/
#include "include/conf.h"
+void my_lltoa(unsigned long long int n, char s[], int len);
int totalger(const char *dirname, int debug, const char *outdir)
diff -Naur sarg-2.2.3.1.orig/useragent.c sarg-2.2.3.1/useragent.c
--- sarg-2.2.3.1.orig/useragent.c 2007-01-02 22:11:26.000000000 +0300
+++ useragent.c 2007-08-10 16:18:44.000000000 +0400
@@ -24,6 +24,11 @@
*/
#include "include/conf.h"
+void debuga(char *msg);
+void getword(char *word, char *line, int stop);
+void show_sarg(FILE *fp_ou, char *ind);
+void ip2name(char *ip);
+void zdate(char *ftime, char *DateFormat);
void useragent()
{
diff -Naur sarg-2.2.3.1.orig/util.c sarg-2.2.3.1/util.c
--- sarg-2.2.3.1.orig/util.c 2007-08-10 16:19:32.000000000 +0400
+++ util.c 2007-08-10 16:18:44.000000000 +0400
@@ -31,6 +31,8 @@
static char mtab1[12][4]={"Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"};
static char mtab2[12][3]={"01","02","03","04","05","06","07","08","09","10","11","12"};
+void css(FILE *fp_css);
+
/*void fgetword(char *word, char *line, int stop)
{
//VARIANT N1
@@ -57,7 +59,7 @@
{
int x = 0, y = 0;
int limit=10000;
- char wline[MAXLEN];
+ //char wline[MAXLEN];
//strcpy(wline,line);
@@ -510,7 +512,6 @@
static char ret[MAXIMO * 2];
char *pret;
register int i, j, k;
- static char abbrev[30];
my_lltoa(value, num, 0);
bzero(buf, MAXIMO*2);
@@ -719,15 +720,15 @@
struct dirent *direntp;
if(strcmp(IndexTree,"date") == 0) {
- bzero(y1,5);
- bzero(y2,5);
+ bzero(Y1,5);
+ bzero(Y2,5);
bzero(d1,3);
bzero(d2,3);
bzero(m1,4);
bzero(m2,4);
if(strncmp(df,"u",1) == 0) {
- strncpy(y1,period,4);
- strncpy(y2,period+10,4);
+ strncpy(Y1,period,4);
+ strncpy(Y2,period+10,4);
strncpy(m1,period+4,3);
strncpy(m2,period+14,3);
strncpy(d1,period+7,2);
@@ -737,16 +738,16 @@
strncpy(d2,period+10,2);
strncpy(m1,period+2,3);
strncpy(m2,period+12,3);
- strncpy(y1,period+5,4);
- strncpy(y2,period+15,4);
+ strncpy(Y1,period+5,4);
+ strncpy(Y2,period+15,4);
}
conv_month(m1);
conv_month(m2);
- sprintf(wdir,"%s%s",outdir,y1);
- if(strcmp(y1,y2) != 0) {
+ sprintf(wdir,"%s%s",outdir,Y1);
+ if(strcmp(Y1,Y2) != 0) {
strncat(wdir,"-",1);
- strncat(wdir,y2,strlen(y2));
+ strncat(wdir,Y2,strlen(Y2));
}
if(access(wdir, R_OK) != 0)
my_mkdir(wdir);
@@ -1234,7 +1235,7 @@
if(strcmp(ShowSargLogo,"yes") == 0) fprintf(fp_ou,"<center><table cellpadding=0 cellspacing=0>\n<tr><th class=\"logo\"><a href=\"http://sarg.sourceforge.net\"><img src=\"%s/images/sarg.png\" border=\"0\" align=\"absmiddle\" title=\"SARG, Squid Analysis Report Generator. Logo by Osamu Matsuzaki\"></a>&nbsp;<font class=\"logo\">Squid Analysis Report Generator</font></th></tr>\n<tr><th class=\"title\">&nbsp</th></tr>\n<table>\n",ind);
}
-get_size(char *path, char *file)
+char* get_size(char *path, char *file)
{
FILE *fp;
char response[255];
@@ -1260,7 +1261,7 @@
}
-char url_module(char *url, char *w2)
+void url_module(char *url, char *w2)
{
int x, y;
char w[255];
@@ -1279,8 +1280,6 @@
w2[y]=w[x];
y++;
}
-
- return;
}

View file

@ -1,30 +0,0 @@
--- report.c.orig Tue Jan 2 17:11:26 2007
+++ report.c Fri Jun 8 08:13:13 2007
@@ -46,6 +46,7 @@
long long int incache=0;
long long int oucache=0;
char *s;
+ char *haystack;
DIR *dirp;
struct dirent *direntp;
@@ -73,7 +74,9 @@
dirp = opendir(tmp);
while ((direntp = readdir( dirp )) != NULL ) {
- if((strstr(direntp->d_name,".log") == 0) ||
+ haystack=direntp->d_name;
+ haystack+=(strlen(haystack)-5);
+ if((strstr(haystack,".log") == 0) ||
(strncmp(direntp->d_name,"download.log",12) == 0) ||
(strncmp(direntp->d_name,"denied.log",10) == 0) ||
(strncmp(direntp->d_name,"authfail.log.unsort",19) == 0))
@@ -89,7 +92,7 @@
getword(wname2,wdname,'.');
strcat(user,wname2);
- if(strcmp(wdname,"log") !=0) {
+ if((strcmp(wdname,"log")!=0) || (strlen(wdname)>3)) {
strcat(user,".");
goto strip_prefix;
}

View file

@ -12,7 +12,6 @@ etc/sarg/images/datetime.png
etc/sarg/images/graph.png
etc/sarg/images/sarg-squidguard-block.png
etc/sarg/images/sarg.png
etc/sarg/languages/.new
etc/sarg/languages/Bulgarian_windows1251
etc/sarg/languages/Catalan
etc/sarg/languages/Czech
@ -28,6 +27,7 @@ etc/sarg/languages/Italian
etc/sarg/languages/Japanese
etc/sarg/languages/Latvian
etc/sarg/languages/Polish
etc/sarg/languages/Polish_windows1250
etc/sarg/languages/Portuguese
etc/sarg/languages/Romanian
etc/sarg/languages/Russian_UTF-8