#!/bin/bash
+BASE_DIR=$HOME/.antifraude
# uso las funciones de util.sh
. "$HOME/.antifraude/util.sh"
. "$HOME/.antifraude/conf/afimonio.conf"
-
-trap "finalize" INT
+. "$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
#--------------------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"
-
-# Busco el archivo de configuracion para recuperar las rutas hacia los archivos
-# que debo leer.
-
-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\ =\ ??"`
+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 "$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
- 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