#!/bin/bash
+BASE_DIR=$HOME/.antifraude
+# uso las funciones de util.sh
+. "$HOME/.antifraude/util.sh"
+. "$HOME/.antifraude/conf/afimonio.conf"
+. "$HOME/.antifraude/conf/antifraude.conf"
-# Funciones auxiliares
-
-is_number(){
- num=`echo $1 | sed 's/[0-9]*//g'`
- if [ -n "$num" ]; then
- return 1
- fi
- return 0
+# 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
checkfilename(){
date=`echo $1 | cut -d "." -f 1`
central=`echo $1 | cut -d "." -f 2`
- is_number "$date"
+ validar_solo_numeros "$date"
+ if [ "$?" -ne 0 ]; then
+ return 1
+ fi
+ mes=${date:4:2}
+ validar_rango "$mes" "1" "12"
+ if [ "$?" -ne 0 ]; then
+ return 1
+ fi
+ dia=${date:6:2}
+ validar_rango "$dia" "1" "31"
+ if [ "$?" -ne 0 ]; then
+ return 1
+ fi
+ hora=${date:8:2}
+ validar_rango "$hora" "0" "23"
+ if [ "$?" -ne 0 ]; then
+ return 1
+ fi
+ min=${date:10:2}
+ validar_rango "$min" "0" "59"
if [ "$?" -ne 0 ]; then
return 1
fi
- is_number "$central"
+ validar_solo_numeros "$central"
if [ "$?" -ne 0 ]; then
return 1
fi
return 0
}
-
-# busco el archivo de configuracion para recuperar las rutas hacia los archivos
-# que debo leer.
-
-DATADIR='/home/nico/sop/'
-sourcedir=$DATADIR'util/'
-aceptdir=$DATADIR'/llamadas/enproceso'
-rejectdir=$DATADIR'/llamadas/rechazadas'
-LOGDIR='/home/nico/sop/log/'
-logfile=$LOGDIR/afimonio.log
-
-while [ true ]; do
- for file in `ls $sourcedir` ; do
-
+
+#--------------------MAIN SCRIPT----------------------
+
+# 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
+
+# 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
+ files=
+ for file in `ls $SOURCEDIR` ; do
+ files=1
checkfilename $file
if [ "$?" -eq 0 ]; then
- cp $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
- cp $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
- sleep 2
done #for
+ # me fijo si el antifraude esta corriendo y si no lo esta lo arranco
+ if [ -n $files ] && ! is_lock "antifraude.pl"; then
+ $BINDIR/antifraude.pl &
+ fi
+ sleep 5
done #while