summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorJavier Sánchez Parra <jsanchez@soleta.eu>2022-03-28 13:08:49 +0200
committerOpenGnSys Support Team <soporte-og@soleta.eu>2022-04-08 13:35:07 +0200
commit843ebb0f7c822fbb6a56abad50243efc3729ae29 (patch)
treeb6a866dfe0a378b85f78d28703428b325b12c36a /server
parent395c326d75c3aa7ee15de2258bf49fa373983e1c (diff)
#915 Remove TEMPLATE_NAME from setclientmode
It is not needed for setting clients' boot mode. Replace TEMPLATE_NAME in error messages with MODE_FILE as both reference the template file.
Diffstat (limited to 'server')
-rwxr-xr-xserver/bin/setclientmode88
1 files changed, 42 insertions, 46 deletions
diff --git a/server/bin/setclientmode b/server/bin/setclientmode
index 5bb53984..a4987081 100755
--- a/server/bin/setclientmode
+++ b/server/bin/setclientmode
@@ -48,7 +48,7 @@ CALLER=$(getcaller)
[ "$USER" != "root" -a "$USER" != "$WEBUSER" -a "$CALLER" != "ogserver" ] && raiseError access "Need to be root (or webserver user)"
TEMPLATE[0]="${PXEDIR[0]}/templates/${MODE_FILE}"
TEMPLATE[1]="${PXEDIR[1]}/templates/${MODE_FILE}"
-[ -z "${TEMPLATE[0]}${TEMPLATE[1]}" ] && raiseError notfound "PXE template file \"$TEMPLATE_NAME\""
+[ -z "${TEMPLATE[0]}${TEMPLATE[1]}" ] && raiseError notfound "PXE template file \"$MODE_FILE\""
case "${MODE^^}" in
0|TEMP) MODE="TEMP" ;;
@@ -56,8 +56,6 @@ case "${MODE^^}" in
*) raiseError notfound "Unknown mode \"$MODE\"" ;;
esac
-# Sustituir caracteres ' por \' para evitar inyección SQL.
-BOOTMODE="${TEMPLATE_NAME//\'/\\\'}"
ETHERNET=$MAC
# Copiar fichero de configuración.
@@ -70,54 +68,52 @@ for MAC in $ETHERNET; do
[ -e ${PXEDIR[0]}/${PXEFILE[0]} ] && mv ${PXEDIR[0]}/${PXEFILE[0]} ${PXEDIR[0]}/${PXEFILE[0]}.netboot
[ -e ${PXEDIR[1]}/${PXEFILE[1]} ] && mv ${PXEDIR[1]}/${PXEFILE[1]} ${PXEDIR[1]}/${PXEFILE[1]}.netboot
- if [ "$TEMPLATE_NAME" != "default" ]; then
- # Si no está definida la variable LANG, usar idioma inglés por defecto.
- [ -z "$LANG" -o "$LANG" == "C" ] && LANG="en"
- DATOS=$DATA
- # Quitar tabuladores, sustituir acentos y dejar resolución por defecto.
- DATOS=$(echo ${DATOS// /} | tr 'áéíóúñçÁÉÍÓÚÑÇ' 'aeiouncAEIOUNC')
- [[ "$DATOS" =~ (vga|video) ]] || DATOS="$DATOS vga=788"
- # Obtener directorio ogLive a partir de los datos.
- OGLIVEDIR=$(echo "$DATOS" | awk -F= 'BEGIN {RS=" "} $1=="oglivedir" {print $2}')
+ # Si no está definida la variable LANG, usar idioma inglés por defecto.
+ [ -z "$LANG" -o "$LANG" == "C" ] && LANG="en"
+ DATOS=$DATA
+ # Quitar tabuladores, sustituir acentos y dejar resolución por defecto.
+ DATOS=$(echo ${DATOS// /} | tr 'áéíóúñçÁÉÍÓÚÑÇ' 'aeiouncAEIOUNC')
+ [[ "$DATOS" =~ (vga|video) ]] || DATOS="$DATOS vga=788"
+ # Obtener directorio ogLive a partir de los datos.
+ OGLIVEDIR=$(echo "$DATOS" | awk -F= 'BEGIN {RS=" "} $1=="oglivedir" {print $2}')
- # Pondremos como propietario al usuario y grupo de Apache para que se pueda cambiar desde la consola web.
- WEBGROUP=$(ps axho group,comm|awk '!/root/ && /httpd|apache/ {print $1; exit;}')
- for BOOTTYPE in 0 1; do
- # Si no existe la plantilla borramos el archivo PXE anterior continuamos
- if [ -z "${TEMPLATE[$BOOTTYPE]}" ]; then
- rm ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
- continue
- fi
- # Comprobar si existe "oglivedir" en la plantilla para evitar duplicados.
- if grep -q "oglivedir=" ${TEMPLATE[$BOOTTYPE]} 2>/dev/null; then
- DATOSAUX="${DATOS/oglivedir=$OGLIVEDIR/}"
- fi
- # Renombra el fichero PXE original
- [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ] && mv ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot
+ # Pondremos como propietario al usuario y grupo de Apache para que se pueda cambiar desde la consola web.
+ WEBGROUP=$(ps axho group,comm|awk '!/root/ && /httpd|apache/ {print $1; exit;}')
+ for BOOTTYPE in 0 1; do
+ # Si no existe la plantilla borramos el archivo PXE anterior continuamos
+ if [ -z "${TEMPLATE[$BOOTTYPE]}" ]; then
+ rm ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
+ continue
+ fi
+ # Comprobar si existe "oglivedir" en la plantilla para evitar duplicados.
+ if grep -q "oglivedir=" ${TEMPLATE[$BOOTTYPE]} 2>/dev/null; then
+ DATOSAUX="${DATOS/oglivedir=$OGLIVEDIR/}"
+ fi
+ # Renombra el fichero PXE original
+ [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ] && mv ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot
- # Crear fichero PXE a partir de la plantilla con los datos obtenidos en la BD.
- sed -e "s,vga=[0-9]*,,g; s,INFOHOST,${DATOSAUX//,/\\,},g; s,set ISODIR=.*,set ISODIR=$OGLIVEDIR,g" ${TEMPLATE[$BOOTTYPE]} >${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
- [ -n "$WEBUSER" ] && chown $WEBUSER:$WEBGROUP ${PXEDIR[$BOOTTYPE]}/${PXEFILEE[$BOOTTYPE]}
- done
+ # Crear fichero PXE a partir de la plantilla con los datos obtenidos en la BD.
+ sed -e "s,vga=[0-9]*,,g; s,INFOHOST,${DATOSAUX//,/\\,},g; s,set ISODIR=.*,set ISODIR=$OGLIVEDIR,g" ${TEMPLATE[$BOOTTYPE]} >${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
+ [ -n "$WEBUSER" ] && chown $WEBUSER:$WEBGROUP ${PXEDIR[$BOOTTYPE]}/${PXEFILEE[$BOOTTYPE]}
+ done
- # 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 [ "$MODE" == "TEMP" ]; then
- sleep 60
- for BOOTTYPE in 0 1; do
- [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ] && rm ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
- [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot ] && mv ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
- done
- fi
+ # 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 [ "$MODE" == "TEMP" ]; then
+ sleep 60
+ for BOOTTYPE in 0 1; do
+ [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]} ] && rm ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
+ [ -e ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot ] && mv ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}.netboot ${PXEDIR[$BOOTTYPE]}/${PXEFILE[$BOOTTYPE]}
+ done
+ 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 [ "$MODE" == "PERM" ]; then
- [ -e ${PXEDIR[0]}/${PXEFILE[0]}.netboot ] && rm ${PXEDIR[0]}/${PXEFILE[0]}.netboot
- [ -e ${PXEDIR[1]}/${PXEFILE[1]}.netboot ] && rm ${PXEDIR[1]}/${PXEFILE[1]}.netboot
- # Si no existe la plantilla de tipo BIOS tomo el nombre de la UEFI
- [ -z "${TEMPLATE[0]}" ] && TEMPLATE[0]=${TEMPLATE[1]}
- 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 [ "$MODE" == "PERM" ]; then
+ [ -e ${PXEDIR[0]}/${PXEFILE[0]}.netboot ] && rm ${PXEDIR[0]}/${PXEFILE[0]}.netboot
+ [ -e ${PXEDIR[1]}/${PXEFILE[1]}.netboot ] && rm ${PXEDIR[1]}/${PXEFILE[1]}.netboot
+ # Si no existe la plantilla de tipo BIOS tomo el nombre de la UEFI
+ [ -z "${TEMPLATE[0]}" ] && TEMPLATE[0]=${TEMPLATE[1]}
fi
- date +"%b %d %T $PROG: Configured \"$TEMPLATE_NAME\" on \"$MAC\", \"$MODE\" mode" | tee -a $LOGFILE
+ date +"%b %d %T $PROG: Configured \"$MODE_FILE\" on \"$MAC\", \"$MODE\" mode" | tee -a $LOGFILE
done
exit 0