source: client/engine/System.lib @ 6539ab9

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 6539ab9 was 16ac86e, checked in by ramon <ramongomez@…>, 14 years ago

Versión 1.0: Scripts para interfaz web soporte inicial de crear imágenes en modo no administrador.
Modificado #291.

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

  • Property mode set to 100755
File size: 5.4 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  0.9
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#@note    El nivel de ayuda \c (help) no se registra en el fichero de incidencias.
19#@version 0.9 - Primera versión para OpenGnSys
20#@author  Ramon Gomez, ETSII Universidad de Sevilla
21#@date    2009-07-23
22#*/
23function ogEcho () {
24
25# Variables locales
26local LOGLEVEL LOGFILE DATETIME
27
28# Selección del nivel de registro (opcional).
29case "$1" in
30     help)    shift ;;
31     info)    LOGLEVEL=$1; shift ;;
32     warning) LOGLEVEL=$1; shift ;;
33     error)   LOGLEVEL=$1; shift ;;
34     *)       ;;
35esac
36# Pendiente en cliente Initrd.
37#DATETIME=$(date +"%F %T")
38
39if [ -n "$LOGLEVEL" ]; then
40    logger -s -t "OpenGnSys $LOGLEVEL" $LOGFILE "$DATETIME $*"
41else
42    echo "$*"
43fi
44}
45
46
47#/**
48#         ogRaiseError int_errcode ["str_errmessage" ...]
49#@brief   Devuelve el mensaje y el código de error correspondiente.
50#@param   int_errcode    código de error.
51#@param   str_errmessage mensajes complementarios de error.
52#@return  str_message - Mensaje de error.
53#@warning No definidas
54#@note    Mensajes internacionales del fichero de idiomas.
55#@version 0.9 - Primera versión para OpenGnSys.
56#@author  Ramon Gomez, ETSII Universidad de Sevilla
57#@date    2009-07-21
58#*/
59function ogRaiseError () {
60
61# Variables locales
62local MSG CODE
63
64# Obtener código y mensaje de error.
65CODE=$1
66case "$CODE" in
67     $OG_ERR_FORMAT)     MSG="$MSG_ERR_FORMAT \"$2\"" ;;
68     $OG_ERR_NOTFOUND)   MSG="$MSG_ERR_NOTFOUND \"$2\"" ;;
69     $OG_ERR_OUTOFLIMIT) MSG="$MSG_ERR_OUTOFLIMIT \"$2\"" ;;
70     $OG_ERR_PARTITION)  MSG="$MSG_ERR_PARTITION \"$2\"" ;;
71     $OG_ERR_LOCKED)     MSG="$MSG_ERR_LOCKED \"$2\"" ;;
72     $OG_ERR_CACHE)      MSG="$MSG_ERR_CACHE \"$2\"" ;;
73     $OG_ERR_FILESYS)    MSG="$MSG_ERR_FILESYS \"$2\"" ;;
74     $OG_ERR_IMAGE)      MSG="$MSG_ERR_IMAGE \"$2\"" ;;
75     $OG_ERR_NOTOS)      MSG="$MSG_ERR_NOTOS \"$2\"" ;;
76     $OG_ERR_NOTEXEC)    MSG="$MSG_ERR_NOTEXEC \"$2\"" ;;
77     *)                  MSG="$MSG_ERR_GENERIC"; CODE=$OG_ERR_GENERIC ;;
78esac
79
80# Mostrar mensaje de error y salir con el código indicado.
81ogEcho error "${FUNCNAME[1]}: $MSG" >&2
82return $CODE
83}
84
85
86#/**
87#         ogGetCaller
88#@brief   Devuelve nombre del programa o script ejecutor (padre).
89#@param   No.
90#@return  str_name - Nombre del programa ejecutor.
91#@version 0.10 - Primera versión para OpenGnSys.
92#@author  Ramon Gomez, ETSII Universidad de Sevilla
93#@date    2011-01-17
94#*/
95function ogGetCaller () {
96
97# Obtener el nombre del programa o del script que ha llamado al proceso actual.
98basename $(ps hlp $PPID | awk '{if ($13~/bash/ && $14!="") print $14;
99                                else print $13;}')
100}
101
102
103#/**
104#         ogIsRepoLocked
105#@brief   Comprueba si el repositorio está siendo usado (tiene ficheros abiertos).
106#@param   No.
107#@return  Código de salida: 0 - sin bloquear (libre), 1 - bloqueado.
108#@version 0.10 - Primera versión para OpenGnSys.
109#@author  Ramon Gomez, ETSII Universidad de Sevilla
110#@date    2011-01-17
111#*/
112function ogIsRepoLocked () {
113
114# Variables locales.
115local f FILES
116
117# No hacer nada, si no está definido el punto de montaje del repositorio.
118[ -z "$OGIMG" ] && return
119
120# Comprobar si alguno de los ficheros abiertos por los procesos activos está en el
121# punto de montaje del repositorio de imágenes.
122FILES=$(for f in /proc/[0-9]*/fd/*; do readlink -f "$f"; done | grep "^$OGIMG")   # */ (comentario Doxygen)
123[ -n "$FILES" ]
124}
125
126
127
128#/**
129#         ogHelp ["str_function" ["str_format" ["str_example" ... ]]]
130#@brief   Muestra mensaje de ayuda para una función determinda.
131#@param   str_function Nombre de la función.
132#@param   str_format   Formato de ejecución de la función.
133#@param   str_example  Ejemplo de ejecución de la función.
134#@return  str_help - Salida de ayuda.
135#@note    Si no se indican parámetros, la función se toma de la variable \c $FUNCNAME
136#@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.
137#@note    Pueden especificarse varios mensajes con ejemplos.
138#@version 0.9 - Primera versión para OpenGnSys.
139#@author  Ramon Gomez, ETSII Universidad de Sevilla
140#@date    2009-07-27
141#*/
142function ogHelp () {
143
144# Variables locales.
145local FUNC MSG
146
147# Mostrar función, descripción y formato.
148FUNC="${1:-${FUNCNAME[${#FUNCNAME[*]}-1]}}"
149MSG="MSG_HELP_$FUNC"
150ogEcho help "$MSG_FUNCTION $FUNC: ${!MSG}"
151[ -n "$2" ] && ogEcho help "    $MSG_FORMAT: $2"
152# Mostrar ejemplos (si existen).
153shift 2
154while [ $# -gt 0 ]; do
155    ogEcho help "    $MSG_EXAMPLE: $1"
156    shift
157done
158}
159
160ogCheckProgram ()
161{
162# Si se solicita, mostrar ayuda.
163if [ "$*" == "help" ]; then
164    ogHelp "$FUNCNAME \"str_program1 program2 programN\" " \
165                   "$FUNCNAME \"partimage partclone mbuffer\" "
166    return
167fi
168
169# Error si no se recibe 1 parámetro.
170[ $# == 1 ] || ogRaiseError $OG_ERR_FORMAT || return $?
171
172local PERROR PLOG
173PERROR=0
174PLOG=" "
175for i in `echo $1`
176do
177  if [ ! `which $i` ]
178     then
179        PERROR=1
180        PLOG="$PLOG $i"
181     fi
182done
183if [ "$PERROR" == "1" ]
184then
185        ogRaiseError $OG_ERR_NOTEXEC "$PLOG" || return $?
186else           
187        return 0
188fi
189}
Note: See TracBrowser for help on using the repository browser.