]> git.llucax.com Git - z.facultad/75.08/llamadas.git/blobdiff - inst/afimonio
Se agrega función para truncar logs: clean_log.
[z.facultad/75.08/llamadas.git] / inst / afimonio
index f474b5acd1c4947940303e4d25e967541d3904bb..071de72f58cad4227d1606d2f1297dc4f2bff2fd 100644 (file)
@@ -1,7 +1,15 @@
 #!/bin/bash
+BASE_DIR=$HOME/.antifraude
 # uso las funciones de util.sh
-. ../util.sh
+. "$HOME/.antifraude/util.sh"
+. "$HOME/.antifraude/conf/afimonio.conf"
+. "$HOME/.antifraude/conf/antifraude.conf"
 
+# Es llamada por los trap para deslockear el afimonio 
+finalize() {
+       unlock "afimonio" 
+       exit 0
+}
 
 # filtra el nombre del archivo pasado por parametro sacandole todos los
 # caracteres que no sean numeros 
@@ -13,51 +21,84 @@ checkfilename(){
        if [ "$?" -ne 0 ]; then
                return 1
        fi
+       mes=${date:4:2}
+       validar_rango "$mes" "1" "12"
+       if [ "$?" -ne 0 ]; then
+               return 1
+       fi
+       dia=${date:6:2}
+       validar_rango "$dia" "1" "31" 
+       if [ "$?" -ne 0 ]; then
+               return 1
+       fi
+       hora=${date:8:2}
+       validar_rango "$hora" "0" "23"
+       if [ "$?" -ne 0 ]; then
+               return 1
+       fi
+       min=${date:10:2}
+       validar_rango "$min" "0" "59"
+       if [ "$?" -ne 0 ]; then
+               return 1
+       fi
        validar_solo_numeros "$central"
        if [ "$?" -ne 0 ]; then
                return 1
        fi
        return 0                
 }
-       
-# busco el archivo de configuracion para recuperar las rutas hacia los archivos
-# que debo leer.
-
-aficonf=~/sop/conf/afinstal.conf
-echo "AFICONF DIR = $aficonf"
-
-DATADIR=`grep -n "DATADIR" $aficonf | grep 15 | sed s?.*DATADIR\ =\ ??`
-SOURCEDIR="$DATADIR/aprocesar"
-ACEPTDIR="$DATADIR/enproceso"
-REJECTDIR="$DATADIR/rechazadas"
-BINDIR=`grep -n "BINDIR" $aficonf | grep 11 | sed s?.*BINDIR\ =\ ??`
-LOGDIR=`grep -n "LOGDIR" $aficonf | grep 32 | sed s?.*LOGDIR\ =\ ??`
-LOGNAME=`grep -n "LOGFILE" $aficonf | grep 13 | sed s?.*LOGFILE\ =\ ??`
-logfile=$LOGDIR/$LOGNAME
-
-echo "BINDIR = $BINDIR"
-echo "LOGDIR = $LOGDIR"
-echo "LOGNAME = $LOGNAME"
-
-while [ true ]; do 
+
+#--------------------MAIN SCRIPT----------------------
+
+# Recupero las rutas a todos los directorios y archivos que necesito
+# Del antifraude
+DATADIR=$ANTI_DATADIR
+SOURCEDIR=$DATADIR/aprocesar/
+ACEPTDIR=$DATADIR/enproceso/
+REJECTDIR=$DATADIR/rechazadas/
+BINDIR=$ANTI_BINDIR
+
+# Del afimonio
+LOGDIR=$AFIM_LOGDIR
+LOGNAME=$AFIM_LOGFILE
+LOGFILE=$LOGDIR/$LOGNAME
+
+# Capturo señales para salir bien (liberando el lock)
+trap "finalize" INT
+trap "finalize" TERM 
+
+# Me lockeo
+lock "afimonio" || die "No se puede correr, hay otra instancia corriendo o no se puede crear el lock file!"
+
+# Comienza el ciclo infinito que mueve los archivos
+while true; do 
+       files=
        for file in `ls $SOURCEDIR` ; do
+               files=1
                checkfilename $file     
                if [ "$?" -eq 0 ]; then
-                       cp $SOURCEDIR$file $ACEPTDIR #cambiar copiar por mover
+                       mv $SOURCEDIR$file $ACEPTDIR
                        fecha=$(date +%d/%m/%Y-%H:%M)
-                       echo "$fecha $USER afimonio:\"Se detecta archivo de llamadas $file\"" >> $logfile
-                       # me fijo si el antifraude esta corriendo y si no lo esta lo arranco
+                       echo "$fecha $USER afimonio:\"Se detecta archivo de llamadas $file\"" >> $LOGFILE
                else 
-                       cp $SOURCEDIR$file $REJECTDIR #cambiar copiar por mover
+                       mv $SOURCEDIR$file $REJECTDIR
                        fecha=$(date +%d/%m/%Y-%H:%M)
-                       echo "$fecha $USER afimonio:\"Se rechaza el  archivo $file\"" >> $logfile
+                       echo "$fecha $USER afimonio:\"Se rechaza el archivo $file\"" >> $LOGFILE
+               fi
+               # Verifico que el logfile no se pase del tamaño maximo
+               tam=`stat -c '%s' $LOGFILE`
+               # Si se paso del maximo dejo las ultimas 100 lineas
+               if [ "$tam" -ge "$AFIM_LOGSIZE" ]; then
+                       echo tail -n 100 $LOGFILE \> "$LOGDIR/$0.$$.temp"
+                       echo mv "$LOGDIR/$0.$$.temp" $LOGFILE
+                       tail -n 100 $LOGFILE > "$LOGDIR/$0.$$.temp"
+                       mv "$LOGDIR/$0.$$.temp" $LOGFILE
                fi
        done #for
-       if ! is_lock "antifraude.pl" ; then
-               echo "DISPARANDO ANTIFRAUDE"
-               $BINDIR/antifraude.pl
+       # me fijo si el antifraude esta corriendo y si no lo esta lo arranco
+       if [ -n $files ] && ! is_lock "antifraude.pl"; then
+               $BINDIR/antifraude.pl &
        fi
-       break
-       # sleep 60
+       sleep 5
 done #while