X-Git-Url: https://git.llucax.com/z.facultad/75.08/llamadas.git/blobdiff_plain/a544d76b16b2bb4ce84c3d9f45a464c4cc0498a2..740b6fd4701082cda789d4a30f127a8744d31468:/inst/afimonio?ds=sidebyside diff --git a/inst/afimonio b/inst/afimonio index 88a6de6..95b1ab5 100644 --- a/inst/afimonio +++ b/inst/afimonio @@ -1,7 +1,17 @@ #!/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" +trap "finalize" INT + +# 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 @@ -41,21 +51,29 @@ checkfilename(){ } #--------------------MAIN SCRIPT---------------------- -# busco el archivo de configuracion para recuperar las rutas hacia los archivos -# que debo leer. -aficonf=~/sop/conf/afinstal.conf +# 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 +SOURCEDIR=$DATADIR/aprocesar/ +ACEPTDIR=$DATADIR/enproceso/ +REJECTDIR=$DATADIR/rechazadas/ +BINDIR=$ANTI_BINDIR + +# Del afimonio +LOGDIR=$AFIM_LOGDIR +LOGNAME=$AFIM_LOGFILE +LOGFILE=$LOGDIR/$LOGNAME -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 33 | sed s?.*LOGFILE\ =\ ??` -logfile=$LOGDIR/$LOGNAME -echo $logfile # Comienza el ciclo infinito que mueve los archivos while [ true ]; do for file in `ls $SOURCEDIR` ; do @@ -63,19 +81,25 @@ while [ true ]; do if [ "$?" -eq 0 ]; then mv $SOURCEDIR$file $ACEPTDIR #cambiar copiar por mover 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 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 + tail -n 100 $LOGFILE > "$BINDIR/temp" + rm $LOGFILE + mv "$BINDIR/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 fi - break - # sleep 60 + sleep 10 done #while