# Crea un archivo de lock para un script
# Devuelve: 0 si ok, 1 si ya esta lockeado, 2 si no pudo crear lock.
+# Uso: lock programa
lock () {
# si ya esta loqueado, no lo vuelvo a crear
is_lock "$1" && return 1
}
# Desbloquea el script
+# Uso: unlock programa
unlock () {
rm -rf "$LOCK_DIR/$1.pid"
}
# Consulta si un script esta lockeado
+# Uso: is_lock programa
is_lock () {
if [ -e "$LOCK_DIR/$1.pid" ] ; then
# Lock file encontrado!
return 1
}
+# Obtiene el pid de un programa lockeado
+# Uso: lock_pid programa
+lock_pid()
+{
+ is_lock "$1" && cat "$LOCK_DIR/$1.pid"
+}
+
# Verifica que un valor este entre otros 2 .... $1 pertecezca a [$2,$3]
# $1 Numero a validar
# $2 Cota inferior
echo $@ >&2
}
+
+# Pone un MSG en el log
+# Parametros :
+# $1 = Archivo del log
+# $2 = Comando
+# $3 = Mensaje
+# $4 = Tamaño maximo
+put_log() {
+ fecha=$(date +%d/%m/%Y-%H:%M)
+ echo "$fecha $USER $2:\"$3\"" >> $1
+
+ clean_log "$1" "$4"
+}
+
+# Trunca un archivo de log si pasa el tamaño máximo.
+# Uso: clean_log log_filename max_log_size_bytes
+clean_log()
+{
+ LOGFILE="$1"
+ LOGSIZE="$2"
+ # Archivo temporal
+ tmp=`dirname "$LOGFILE"`"/`basename $0`.$$.temp"
+ # 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" > "$tmp"
+ mv "$tmp" "$LOGFILE"
+ fi
+}
+