]> git.llucax.com Git - z.facultad/75.08/llamadas.git/blobdiff - inst/afimonio
Agrego material pulenta para el final.
[z.facultad/75.08/llamadas.git] / inst / afimonio
index 95b1ab555d74bc3d2cbe86ee1f44b9606e7652b5..2c24917ca2022e1e508b64251cf1431235c030c2 100644 (file)
@@ -5,8 +5,6 @@ BASE_DIR=$HOME/.antifraude
 . "$HOME/.antifraude/conf/afimonio.conf"
 . "$HOME/.antifraude/conf/antifraude.conf"
 
 . "$HOME/.antifraude/conf/afimonio.conf"
 . "$HOME/.antifraude/conf/antifraude.conf"
 
-trap "finalize" INT
-
 # Es llamada por los trap para deslockear el afimonio 
 finalize() {
        unlock "afimonio" 
 # Es llamada por los trap para deslockear el afimonio 
 finalize() {
        unlock "afimonio" 
@@ -52,15 +50,6 @@ checkfilename(){
 
 #--------------------MAIN SCRIPT----------------------
 
 
 #--------------------MAIN SCRIPT----------------------
 
-# Verifico no correr 2 veces
-if is_lock "afimonio" ; then
-       echo "Ya hay una instancia de afimonio corriendo"
-       exit 1
-fi
-
-# Me lockeo por las dudas
-lock "afimonio" 
-
 # Recupero las rutas a todos los directorios y archivos que necesito
 # Del antifraude
 DATADIR=$ANTI_DATADIR
 # Recupero las rutas a todos los directorios y archivos que necesito
 # Del antifraude
 DATADIR=$ANTI_DATADIR
@@ -74,32 +63,34 @@ LOGDIR=$AFIM_LOGDIR
 LOGNAME=$AFIM_LOGFILE
 LOGFILE=$LOGDIR/$LOGNAME
 
 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
 # Comienza el ciclo infinito que mueve los archivos
-while [ true ]; do 
+while true; do 
+       files=
        for file in `ls $SOURCEDIR` ; do
        for file in `ls $SOURCEDIR` ; do
+               files=1
                checkfilename $file     
                if [ "$?" -eq 0 ]; then
                checkfilename $file     
                if [ "$?" -eq 0 ]; then
-                       mv $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
                else 
                        fecha=$(date +%d/%m/%Y-%H:%M)
                        echo "$fecha $USER afimonio:\"Se detecta archivo de llamadas $file\"" >> $LOGFILE
                else 
-                       mv $SOURCEDIR$file $REJECTDIR #cambiar copiar por mover
+                       mv "$SOURCEDIR$file" "$REJECTDIR"
                        fecha=$(date +%d/%m/%Y-%H:%M)
                        fecha=$(date +%d/%m/%Y-%H:%M)
-                       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
-                       tail -n 100 $LOGFILE > "$BINDIR/temp"   
-                       rm $LOGFILE
-                       mv "$BINDIR/temp" $LOGFILE
+                       echo "$fecha $USER afimonio:\"Se rechaza el archivo $file\"" >> $LOGFILE
                fi
                fi
+               clean_log "$LOGFILE" "$AFIM_LOGSIZE"
        done #for
        # me fijo si el antifraude esta corriendo y si no lo esta lo arranco
        done #for
        # me fijo si el antifraude esta corriendo y si no lo esta lo arranco
-       if ! is_lock "antifraude.pl" ; then
-               $BINDIR/antifraude.pl
+       if [ -n $files ] && ! is_lock "antifraude.pl"; then
+               $BINDIR/antifraude.pl &
        fi
        fi
-       sleep 10
+       sleep 5
 done #while 
 
 done #while