X-Git-Url: https://git.llucax.com/z.facultad/75.08/llamadas.git/blobdiff_plain/fb5ae83716553f8dbb1f12b3c6f7e640fe9f8be8..977da92c915bb7ed530ea64d044a3f0f038c50f0:/inst/afimonio?ds=sidebyside diff --git a/inst/afimonio b/inst/afimonio index 2c40778..90ea831 100644 --- a/inst/afimonio +++ b/inst/afimonio @@ -5,9 +5,6 @@ BASE_DIR=$HOME/.antifraude . "$HOME/.antifraude/conf/afimonio.conf" . "$HOME/.antifraude/conf/antifraude.conf" -trap "finalize" INT -trap "finalize" TERM - # Es llamada por los trap para deslockear el afimonio finalize() { unlock "afimonio" @@ -53,15 +50,6 @@ checkfilename(){ #--------------------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 @@ -75,32 +63,34 @@ 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 +while true; do + files= for file in `ls $SOURCEDIR` ; do + files=1 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 - mv $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 - 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 + clean_log "$LOGFILE" "$AFIM_LOGSIZE" 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 - sleep 10 + sleep 5 done #while