source: client/engine/System.lib @ 21c226b

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since 21c226b was a4f7a1a0, checked in by irina <irinagomez@…>, 11 years ago

#636 #565 correccion errata nombre variable OG_ERR_NOTDIFFERENT y utf8 en log en tiempo real

git-svn-id: https://opengnsys.es/svn/branches/version1.0@4155 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 7.2 KB
Line 
1#!/bin/bash
2#/**
3#@file     System.lib
4#@brief    Librería o clase System
5#@class    System
6#@brief    Funciones básicas del sistema.
7#@version  1.0.4
8#@warning  License: GNU GPLv3+
9#*/
10
11
12#/**
13#         ogEcho [str_loglevel] "str_message..."
14#@brief   Muestra mensajes en consola y lo registra en fichero de incidencias.
15#@param   str_loglevel nivel de registro de incidencias.
16#@param   str_message  mensaje (puede recibir más de 1 parámetro.
17#@return  Mensaje mostrado.
18#@warning Si no se indica nivel de registro, solo muestra mensaje en pantalla.
19#@note    El nivel de ayuda \c (help) no se registra en el fichero de incidencias.
20#@version 0.9 - Primera versión para OpenGnSys
21#@author  Ramon Gomez, ETSII Universidad de Sevilla
22#@date    2009-07-23
23#*/
24function ogEcho () {
25
26# Variables locales
27local LOGLEVEL DATETIME
28
29# Selección del nivel de registro (opcional).
30case "$1" in
31     help)    shift ;;
32     info)    LOGLEVEL="$1"; shift ;;
33     warning) LOGLEVEL="$1"; shift ;;
34     error)   LOGLEVEL="$1"; shift ;;
35     *)       ;;
36esac
37DATETIME=$(date +"%F %T")
38
39if [ -n "$LOGLEVEL" ]; then
40    logger -s -t "OpenGnSys $LOGLEVEL" -f $OGLOGFILE "$DATETIME $*"
41    logger -t "OpenGnSys $LOGLEVEL" -f $OGLOGCOMMAND "$DATETIME $*"
42    logger -t "OpenGnSys $LOGLEVEL" -f $OGLOGSESSION "$DATETIME $*"
43else
44    echo "$*"
45fi
46}
47
48
49#/**
50#         ogRaiseError int_errcode ["str_errmessage" ...]
51#@brief   Devuelve el mensaje y el código de error correspondiente.
52#@param   int_errcode    código de error.
53#@param   str_errmessage mensajes complementarios de error.
54#@return  str_message - Mensaje de error.
55#@warning No definidas
56#@note    Mensajes internacionales del fichero de idiomas.
57#@version 0.9 - Primera versión para OpenGnSys.
58#@author  Ramon Gomez, ETSII Universidad de Sevilla
59#@date    2009-07-21
60#*/
61function ogRaiseError () {
62
63# Variables locales
64local MSG CODE
65
66# Obtener código y mensaje de error.
67CODE=$1
68case "$CODE" in
69     $OG_ERR_FORMAT)     MSG="$MSG_ERR_FORMAT \"$2\"" ;;
70     $OG_ERR_NOTFOUND)   MSG="$MSG_ERR_NOTFOUND \"$2\"" ;;
71     $OG_ERR_OUTOFLIMIT) MSG="$MSG_ERR_OUTOFLIMIT \"$2\"" ;;
72     $OG_ERR_PARTITION)  MSG="$MSG_ERR_PARTITION \"$2\"" ;;
73     $OG_ERR_LOCKED)     MSG="$MSG_ERR_LOCKED \"$2\"" ;;
74     $OG_ERR_CACHE)      MSG="$MSG_ERR_CACHE \"$2\"" ;;
75     $OG_ERR_NOGPT)      MSG="$MSG_ERR_NOGPT \"$2\"" ;;
76     $OG_ERR_FILESYS)    MSG="$MSG_ERR_FILESYS \"$2\"" ;;
77     $OG_ERR_IMAGE)      MSG="$MSG_ERR_IMAGE \"$2\"" ;;
78     $OG_ERR_NOTOS)      MSG="$MSG_ERR_NOTOS \"$2\"" ;;
79     $OG_ERR_NOTEXEC)    MSG="$MSG_ERR_NOTEXEC \"$2\"" ;;
80     $OG_ERR_NOTWRITE)   MSG="$MSG_ERR_NOTWRITE \"$2\"" ;;
81     $OG_ERR_NOTCACHE)   MSG="$MSG_ERR_NOTCACHE \"$2\"" ;;
82     $OG_ERR_CACHESIZE)  MSG="$MSG_ERR_CACHESIZE \"$2\"" ;;
83     $OG_ERR_REDUCEFS)   MSG="$MSG_ERR_REDUCEFS \"$2\"" ;;
84     $OG_ERR_EXTENDFS)   MSG="$MSG_ERR_EXTENDFS \"$2\"" ;;
85     $OG_ERR_IMGSIZEPARTITION)   MSG="$MSG_ERR_IMGSIZEPARTITION \"$2\"" ;;   
86     $OG_ERR_UCASTSYNTAXT)   MSG="$MSG_ERR_UCASTSYNTAXT \"$2\"" ;;
87     $OG_ERR_UCASTSENDPARTITION)   MSG="$MSG_ERR_UCASTSENDPARTITION \"$2\"" ;;   
88     $OG_ERR_UCASTSENDFILE)   MSG="$MSG_ERR_UCASTSENDFILE \"$2\"" ;; 
89     $OG_ERR_UCASTRECEIVERPARTITION)   MSG="$MSG_ERR_UCASTRECEIVERPARTITION \"$2\"" ;;   
90     $OG_ERR_UCASTRECEIVERFILE)   MSG="$MSG_ERR_UCASTRECEIVERFILE \"$2\"" ;; 
91     $OG_ERR_MCASTSYNTAXT)   MSG="$MSG_ERR_MCASTSYNTAXT \"$2\"" ;;
92     $OG_ERR_MCASTSENDFILE)   MSG="$MSG_ERR_MCASTSENDFILE \"$2\"" ;;
93     $OG_ERR_MCASTRECEIVERFILE)   MSG="$MSG_ERR_MCASTRECEIVERFILE \"$2\"" ;;
94     $OG_ERR_MCASTSENDPARTITION)   MSG="$MSG_ERR_MCASTSENDPARTITION \"$2\"" ;;
95     $OG_ERR_MCASTRECEIVERPARTITION)   MSG="$MSG_ERR_MCASTRECEIVERPARTITION \"$2\"" ;;
96     $OG_ERR_PROTOCOLJOINMASTER)   MSG="$MSG_ERR_PROTOCOLJOINMASTER \"$2\"" ;;
97     $OG_ERR_DONTMOUNT_IMAGE)   MSG="$MSG_ERR_DONTMOUNT_IMAGE \"$2\"" ;;
98     $OG_ERR_DONTUNMOUNT_IMAGE)   MSG="$MSG_ERR_DONTUNMOUNT_IMAGE \"$2\"" ;;
99     $OG_ERR_DONTSYNC_IMAGE)    MSG="$MSG_ERR_DONTSYNC_IMAGE \"$2\"" ;;
100     $OG_ERR_NOTDIFFERENT)      MSG="$MSG_ERR_NOTDIFFERENT \"$2\"" ;;
101     *)                  MSG="$MSG_ERR_GENERIC"; CODE=$OG_ERR_GENERIC ;;
102esac
103
104# Mostrar mensaje de error y salir con el código indicado.
105ogEcho error "${FUNCNAME[1]}: $MSG" >&2
106return $CODE
107}
108
109
110#/**
111#         ogGetCaller
112#@brief   Devuelve nombre del programa o script ejecutor (padre).
113#@param   No.
114#@return  str_name - Nombre del programa ejecutor.
115#@version 0.10 - Primera versión para OpenGnSys.
116#@author  Ramon Gomez, ETSII Universidad de Sevilla
117#@date    2011-01-17
118#*/
119function ogGetCaller () {
120
121# Obtener el nombre del programa o del script que ha llamado al proceso actual.
122basename "$(ps hlp $PPID | awk '{if ($13~/bash/ && $14!="") print $14;
123                                 else { sub(/^-/,"",$13); print $13; } }')"
124}
125
126
127#/**
128#         ogIsRepoLocked
129#@brief   Comprueba si el repositorio está siendo usado (tiene ficheros abiertos).
130#@param   No.
131#@return  Código de salida: 0 - bloqueado, 1 - sin bloquear o error.
132#@version 0.10 - Primera versión para OpenGnSys.
133#@author  Ramon Gomez, ETSII Universidad de Sevilla
134#@date    2011-01-17
135#@version 1.0.1 - Devolver falso en caso de error.
136#@author  Ramon Gomez, ETSII Universidad de Sevilla
137#@date    2011-05-18
138#*/
139function ogIsRepoLocked ()
140{
141# Variables locales.
142local f FILES
143
144# No hacer nada, si no está definido el punto de montaje del repositorio.
145[ -z "$OGIMG" ] && return 1
146
147# Comprobar si alguno de los ficheros abiertos por los procesos activos está en el
148# punto de montaje del repositorio de imágenes.
149FILES=$(for f in /proc/[0-9]*/fd/*; do readlink -f "$f"; done | grep "^$OGIMG")   # */ (comentario Doxygen)
150test -n "$FILES"
151}
152
153
154
155#/**
156#         ogHelp ["str_function" ["str_format" ["str_example" ... ]]]
157#@brief   Muestra mensaje de ayuda para una función determinda.
158#@param   str_function Nombre de la función.
159#@param   str_format   Formato de ejecución de la función.
160#@param   str_example  Ejemplo de ejecución de la función.
161#@return  str_help - Salida de ayuda.
162#@note    Si no se indican parámetros, la función se toma de la variable \c $FUNCNAME
163#@note    La descripción de la función se toma de la variable compuesta por \c MSG_FUNC_$función incluida en el fichero de idiomas.
164#@note    Pueden especificarse varios mensajes con ejemplos.
165#@version 0.9 - Primera versión para OpenGnSys.
166#@author  Ramon Gomez, ETSII Universidad de Sevilla
167#@date    2009-07-27
168#*/
169function ogHelp () {
170
171# Variables locales.
172local FUNC MSG
173
174# Mostrar función, descripción y formato.
175FUNC="${1:-${FUNCNAME[${#FUNCNAME[*]}-1]}}"
176MSG="MSG_HELP_$FUNC"
177ogEcho help "$MSG_FUNCTION $FUNC: ${!MSG}"
178[ -n "$2" ] && ogEcho help "    $MSG_FORMAT: $2"
179# Mostrar ejemplos (si existen).
180shift 2
181while [ $# -gt 0 ]; do
182    ogEcho help "    $MSG_EXAMPLE: $1"
183    shift
184done
185}
186
187
188function ogCheckProgram ()
189{
190# Si se solicita, mostrar ayuda.
191if [ "$*" == "help" ]; then
192    ogHelp "$FUNCNAME \"str_program ...\"" \
193           "$FUNCNAME \"partimage partclone mbuffer\""
194    return
195fi
196
197# Error si no se recibe 1 parámetro.
198[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
199
200local PERROR PLOG i
201PERROR=0
202PLOG=" "
203for i in `echo $1`
204do
205  if [ ! `which $i` ]
206     then
207        PERROR=1
208        PLOG="$PLOG $i"
209     fi
210done
211if [ "$PERROR" == "1" ]
212then
213        ogRaiseError $OG_ERR_NOTEXEC "$PLOG" || return $?
214else           
215        return 0
216fi
217}
218
Note: See TracBrowser for help on using the repository browser.