summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xadmin/Sources/Services/ogAdmServerAux7
-rwxr-xr-xclient/shared/scripts/setBootMode22
-rwxr-xr-xserver/bin/setclientmode61
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