diff options
-rwxr-xr-x | admin/Sources/Services/ogAdmServerAux | 7 | ||||
-rwxr-xr-x | client/shared/scripts/setBootMode | 22 | ||||
-rwxr-xr-x | server/bin/setclientmode | 61 |
3 files changed, 66 insertions, 24 deletions
diff --git a/admin/Sources/Services/ogAdmServerAux b/admin/Sources/Services/ogAdmServerAux index fdc98bf2..65bea5cb 100755 --- a/admin/Sources/Services/ogAdmServerAux +++ b/admin/Sources/Services/ogAdmServerAux @@ -28,10 +28,15 @@ case "$PARM1" in #1 SET_CLIENTMODE #2 template #3 pc_name o group_pc +#4 modo temporal o permanente + TEMPLATE="$PARM2" PC="$PARM3" +#incluyo parametro de MODO + MODO="$PARM4" echolog "Ejecutar $(which setclientmode) $FILE $MCASTOPT" - setclientmode $TEMPLATE $PC &>> $SERVERLOG +#incluyo parametro de MODO + setclientmode $TEMPLATE $PC $MODO &>> $SERVERLOG exit $? ;; default) diff --git a/client/shared/scripts/setBootMode b/client/shared/scripts/setBootMode index 4ab9c816..0bfbb06c 100755 --- a/client/shared/scripts/setBootMode +++ b/client/shared/scripts/setBootMode @@ -4,11 +4,17 @@ #@brief Script to configure the PXE mode to client #@param 1 template #@date 2012-02-2-9 +#@version 1.0.1 - Recoge como parametro el nombre interno de la plantilla en vez del nombre de fichero para que funcione correctamente al llamar a setclientmode y anade un nuevo parametro de modo de trabajo (0 o 1) que indica que el cambio del fichero PXE del servidor sera temporal o permanente +#@author Juan Carlos Garcia - Univ. Zaragoza +#@date 2015-11-17 #*/ ## -REPOIP="$(ogGetRepoIp)" +#REPOIP="$(ogGetRepoIp)" + +# Asignamos la IP del servidor de administracion que es el destino del script +SERVERIP="$(ogGetServerIp)" PORT=2011 -TEMPLATE="/opt/oglive/tftpboot/menu.lst/templates/$1" +TEMPLATE=$(grep -l "^#.* $1 *$" /opt/oglive/tftpboot/menu.lst/templates/*) PCNAME="$(hostname)" PROG="$(basename $0)" @@ -21,15 +27,21 @@ fi # Control básico de errores. -if [ $# -ne 1 ]; then +if [ $# -ne 2 ]; then ogRaiseError $OG_ERR_FORMAT "$MSG_ERR_FORMAT: $PROG TEMPLATE_NAME" exit $? fi -if [ ! -e $TEMPLATE ]; then + +if [ -z "$TEMPLATE" ]; then ogRaiseError $OG_ERR_NOTFOUND "$MSG_ERR_NOTFOUND: $TEMPLATE" exit $? fi -hose $REPOIP $PORT --out sh -c "echo -ne SET_CLIENTMODE $1 $PCNAME" +if [ $2 != "0" ] && [ $2 != "1" ]; then + ogRaiseError $OG_ERR_NOTFOUND "$MSG_ERR_FORMAT: modo $2 no existe" + exit $? +fi +# Crea un pipe con el servidor de administracion que llama a setclientmode pasandole los parametros de nombre de plantilla, nombre PC y modo de trabajo (0 o 1) +hose $SERVERIP $PORT --out sh -c "echo -ne SET_CLIENTMODE $1 $PCNAME $2" diff --git a/server/bin/setclientmode b/server/bin/setclientmode index e639f053..08c0f30e 100755 --- a/server/bin/setclientmode +++ b/server/bin/setclientmode @@ -1,13 +1,20 @@ #!/bin/bash -# setclientmode: Configura el archivo de arranque de PXE para los clientes, -# ya sea un equipo o un aula, generando enlaces a archivos usados como plantilla. -# Nota: El archivo PXE por defecto "default" se deja en modo de ejecución "user" -# y se eliminan los enlaces para equipos con la plantilla por defecto. -# Uso: clienmode NombrePlatilla { NombrePC | NombreAula } -# Autores: Irina Gomez y Ramon Gomez - Univ. Sevilla, noviembre 2010 + +#/** +# setclientmode NombrePlatilla { NombrePC | NombreAula } Modo_trabajo +#@file setclientmode +#@brief Configura el archivo de arranque de PXE para los clientes, ya sea un equipo o un aula, generando enlaces a archivos usados como plantilla. +#@warning El archivo PXE por defecto "default" se deja en modo de ejecución "user" y se eliminan los enlaces para equipos con la plantilla por defecto. +#@note Modo_trabajo = { 0, 1 } +#@version 1.0 - Versión inicial. +#@author Irina Gomez y Ramon Gomez - Univ. Sevilla, noviembre 2010 #@version 1.0.1 - Identificacion de la plantilla por nombre en consola = en primera linea de la plantilla -#@author Irina Gomez - Univ. Sevilla -#@date 2013-05-31 +#@author Irina Gomez - Univ. Sevilla +#@date 2013-05-31 +#@version 1.0.2 - Cambio en la funcionalidad del script: el cambio del archivo de arranque PXE puede hacerse de manera temporal (codigo 0) modificando solo el fichero de arranque PXE durante 60 sg. y sin tocar la base de datos o permanente (codigo 1), actualizando tanto el fichero PXE como la base de datos. +#@author Juan Carlos Garcia - Univ. Zaragoza +#@date 2015-11-17 +#*/ ## # Variables. @@ -19,9 +26,9 @@ LOGFILE=$OPENGNSYS/log/opengnsys.log MYCNF=/tmp/.my.cnf.$$ # Control básico de errores. -if [ $# -ne 2 ]; then +if [ $# -ne 3 ]; then echo "$PROG: Error de ejecución" - echo "Formato: $PROG PLANTILLA [NOMBRE_PC|NOMBRE_AULA]" + echo "Formato: $PROG PLANTILLA [NOMBRE_PC|NOMBRE_AULA] MODO" exit 1 fi if [ ! -r $SERVERCONF ]; then @@ -34,6 +41,12 @@ if [ -z "$TEMPLATE" ]; then exit fi +if [ $3 != "0" ] && [ $3 != "1" ]; then + echo "$PROG: Error de ejecución" + echo "el modo debe ser 0 o 1 (temporal o permanente)" + exit 1 +fi + # Obtener datos de acceso a la Base de datos. source $SERVERCONF # Sustituir caracteres ' por \' para evitar inyección SQL. @@ -61,13 +74,14 @@ if [ -z "$ETHERNET" ]; then fi # Copiar fichero de configuración y actualizar base de datos. -date +"%b %d %T $PROG: Configurando \"$1\" en \"$2\"" | tee -a $LOGFILE +date +"%b %d %T $PROG: Configurando \"$1\" en \"$2\" en modo \"$3\"" | tee -a $LOGFILE NPC=0 for MAC in $ETHERNET; do date +"%b %d %T $PROG: Detectada ethernet \"$MAC\" en \"$2\"" | tee -a $LOGFILE - # Si existe anteriormente el fichero PXE, lo borra - PXEFILE=$PXEDIR/01-${MAC:0:2}-${MAC:2:2}-${MAC:4:2}-${MAC:6:2}-${MAC:8:2}-${MAC:10:2} - [ -e $PXEFILE ] && rm $PXEFILE + MACFILE=$(echo $MAC | tr [a-z] [A-Z]) + PXEFILE=$PXEDIR/01-${MACFILE:0:2}-${MACFILE:2:2}-${MACFILE:4:2}-${MACFILE:6:2}-${MACFILE:8:2}-${MACFILE:10:2} + # Renombra el fichero PXE original + [ -e $PXEFILE ] && mv $PXEFILE $PXEFILE.netboot if [ "$1" != "default" ]; then # Si no está definida la variable LANG, usar idioma inglés por defecto. [ -z "$LANG" -o "$LANG" == "C" ] && LANG="en" @@ -83,6 +97,7 @@ for MAC in $ETHERNET; do ' oglog=', (SELECT (@serverip:=ipserveradm) FROM entornos LIMIT 1), ' ogshare=', @serverip, ' winboot=', IFNULL (perfileshard.winboot, 'reboot'), + IF (aulas.ntp IS NULL, '', CONCAT (' ogntp=', aulas.ntp)), IF (aulas.dns IS NULL, '', CONCAT (' ogdns=', aulas.dns)), IF (aulas.proxy IS NULL, '', CONCAT (' ogproxy=', aulas.proxy)), CASE @@ -103,10 +118,20 @@ for MAC in $ETHERNET; do sed -e "s/vga=[0-9]*//g; s/INFOHOST/$DATOS/g" $TEMPLATE >$PXEFILE # Ponemos como propietario al usuario y grupo de Apache para que se pueda cambiar desde la consola web. PERMS=$(ps axho user,group,comm|awk '!/root/ && /httpd|apache/ {u=$1; g=$2} END {if (g) printf "%s:%s",u,g}') - [ -n "$PEMS" ] && chown $PERMS $PXEFILE - # Actualizar en la BD el modo de arranque asociada el cliente. - mysql --defaults-extra-file=$MYCNF -D "$CATALOG" -e \ - "UPDATE ordenadores SET arranque='$(basename $TEMPLATE)' WHERE mac='$MAC';" + [ -n "$PERMS" ] && chown $PERMS $PXEFILE + # Si el modo de trabajo es temporal (0) mete un retardo, restaura el fichero PXE a su estado original y no toca la base de datos + if [ "$3" == "0" ]; then + sleep 60 + rm $PXEFILE + [ -e $PXEFILE.netboot ] && mv $PXEFILE.netboot $PXEFILE + fi + + # Si el modo de trabajo es permanente (1) borra el fichero PXE.netboot si existe y graba los datos en la base de datos + if [ "$3" == "1" ]; then + [ -e $PXEFILE.netboot ] && rm $PXEFILE.netboot + mysql --defaults-extra-file=$MYCNF -D "$CATALOG" -e \ + "UPDATE ordenadores SET arranque='$(basename $TEMPLATE)' WHERE mac='$MAC';" + fi fi let NPC=NPC+1 done |