X-Git-Url: https://git.llucax.com/z.facultad/75.08/llamadas.git/blobdiff_plain/2e8b8273bba8e4016387002e5df7d994e40d7c11..8c250233daf2cf0ea36343c30bf60c0ba70760ad:/inst/afimonio?ds=sidebyside diff --git a/inst/afimonio b/inst/afimonio index a4e99db..071de72 100644 --- a/inst/afimonio +++ b/inst/afimonio @@ -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 @@ -42,50 +50,55 @@ checkfilename(){ #--------------------MAIN SCRIPT---------------------- -# Me lockeo por las dudas -lock "afimonio" - -# Busco el archivo de configuracion para recuperar las rutas hacia los archivos -# que debo leer. - -anticonf=~/sop/conf/afinstal.conf - -#anticonf=~/.antifraude/conf/antifraude.conf -#afimconf=~/.antifraude/conf/afimonio.conf - # Recupero las rutas a todos los directorios y archivos que necesito # Del antifraude -DATADIR=`grep -n "DATADIR" $anticonf | sed "s?.*DATADIR\ =\ ??"` -SOURCEDIR="$DATADIR/aprocesar/" -ACEPTDIR="$DATADIR/enproceso/" -REJECTDIR="$DATADIR/rechazadas/" -BINDIR=`grep -n "BINDIR" $anticonf | sed "s?.*BINDIR\ =\ ??"` +DATADIR=$ANTI_DATADIR +SOURCEDIR=$DATADIR/aprocesar/ +ACEPTDIR=$DATADIR/enproceso/ +REJECTDIR=$DATADIR/rechazadas/ +BINDIR=$ANTI_BINDIR # Del afimonio -LOGDIR=`grep -n "LOGDIR" $afimconf | sed "s?.*LOGDIR\ =\ ??"` -LOGNAME=`grep -n "LOGFILE" $afimconf | sed "s?.*LOGFILE\ =\ ??"` -logfile=$LOGDIR/$LOGNAME +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 + 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 + 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 # me fijo si el antifraude esta corriendo y si no lo esta lo arranco - if ! is_lock "antifraude.pl" ; then - echo "DISPARANDO ANTIFRAUDE" - $BINDIR/antifraude.pl + if [ -n $files ] && ! is_lock "antifraude.pl"; then + $BINDIR/antifraude.pl & fi - break - # sleep 60 + sleep 5 done #while