diff options
Diffstat (limited to 'client/shared/scripts/deployGitImage')
-rwxr-xr-x | client/shared/scripts/deployGitImage | 179 |
1 files changed, 179 insertions, 0 deletions
diff --git a/client/shared/scripts/deployGitImage b/client/shared/scripts/deployGitImage new file mode 100755 index 00000000..31fcec61 --- /dev/null +++ b/client/shared/scripts/deployGitImage @@ -0,0 +1,179 @@ +#!/bin/bash +#/** +#@file deployGitImage +#@brief Proceso completo de despliegue de imagen, incluyendo actualización de la caché, restauración y post-configuración (este script es llamado por la interfaz RestaurarBaseImagen). +#@param $1 Repositorio (CACHE, REPO o dirección IP) +#@param $2 Nombre canónico de la imagen (sin extensión) +#@param $3 Número de disco +#@param $4 Número de particion +#@param $5 Protocolo (Git) +#@param $6 Opciones del protocolo str_modo_git:str_modo_acl str_modo_git=clone|checkout str_modo_acl:total|user +#@exception OG_ERR_FORMAT 1 formato incorrecto. +#@exception OG_ERR_NOTFOUND 2 fichero de imagen o partición no detectados. +#@exception OG_ERR_PARTITION 3 # Error en partición de disco. +#@exception OG_ERR_LOCKED 4 partición bloqueada por otra operación. +#@exception OG_ERR_IMAGE 5 error al restaurar la imagen del sistema. +#@exception OG_ERR_IMGSIZEPARTITION 30 Tamaño de la particion es menor al tamaño de la imagen. +#@exception OG_ERR_NOTCACHE No existe cache -15- +#@exception OG_ERR_CACHESIZE Tamaño de la paticion menor al archivo a descargar -16- +#@version 1.2 - primera versión basada en deployImagen y script de GIT de UGR +#@date 2020/07/07 +#**/ + + +#Descripcion: +# Si Repositorio es el global (REPO) realiza un deploy. +# Si Repositorio es local (CACHE) realiza un restoreGitImage CACHE +# El deploy, si detecta que el cliente no tiene una CACHE o no tiene espacio suficiente consulta el engine.cfg RESTOREPROTOCOLNOCACHE + + + +PROG="$(basename $0)" +# Si se solicita, mostrar ayuda. +if [ "$*" == "help" ]; then + ogHelp "$PROG" "$PROG [REPO|CACHE] imagen ndisk npart GIT [clone|checkout]:[total|user]" \ + "$PROG REPO Ubuntu20 1 2 GIT clone:total" \ + "$PROG CACHE Windows20 1 1 GIT checkout:user" + exit 0 +fi + + +if [ $# -lt 4 ]; then + ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $PROG REPO imagen ndisco nparticion GIT [opciones protocolo] ]" + exit $? +fi + +# El protocolo tiene que se GIT +[ "${5^^}" == "GIT" ] || ogRaiseError $OG_ERR_OUTOFLIMIT "$PROG: único protocolo permitido GIT" || exit $? + +# Asignación de variables (repositorio y protocolo se convierten a mayúsculas). +TIME1=$SECONDS +REPO="${1^^}" +REPO=${REPO:-"REPO"} +IMGNAME="$2" +DISK="$3" +PART="$4" +PROTO="${5^^}" +PROTOOPT="${6:-checkout:total}" + +# Unidad organizativa. +[ "$ogunit" != "" ] && OGUNIT="$ogunit" + +#Load engine configurator from engine.cfg file. +#Carga el configurador del engine desde el fichero engine.cfg +[ -z $OGENGINECONFIGURATE ] && source /opt/opengnsys/etc/engine.cfg + +# Clear temporary file used as log track by httpdlog +# Limpia los ficheros temporales usados como log de seguimiento para httpdlog +echo " " > $OGLOGCOMMAND +[ "$(ogGetCaller)" == "EjecutarScript" ] || echo -n "" > $OGLOGSESSION + +# Registro de inicio de ejecución +ogEcho log session "[1] $MSG_SCRIPTS_START $0 $*" + +# Si el origen(pariticion) esta bloqueada salir. +ogIsLocked $DISK $PART && exit $(ogRaiseError session $OG_ERR_LOCKED "$MSG_PARTITION, $DISK $PART"; echo $?) + +#ogEcho log session "$MSG_HELP_ogUnmount $DISK $PART" +#ogUnmount $DISK $PART 2>/dev/null + +# Valor por defecto para el repositorio. +if [ "$REPO" == "$(ogGetIpAddress)" -o "$REPO" == "CACHE" ]; then + REPO="CACHE" +else + ogCheckIpAddress "$REPO" + if [ $? -eq 0 -o "$REPO" == "REPO" ]; then + # Si falla el cambio -> salimos con error repositorio no valido + ogChangeRepo $REPO ${OGUNIT} || exit $(ogRaiseError $OG_ERR_NOTFOUND "$REPO $OGUNIT"; echo $?) + REPO="REPO" + fi +fi + +# Comprobamos que existe la imagen +ogExistGitImage $REPO "$IMGNAME" || ogRaiseError log session $OG_ERR_NOTFOUND "$REPO $IMGNAME" || exit $? + +#Informacioin previa de la imagen +INFOFILE=$(ogGetPath $REPO ".$IMGNAME.img.json") +IMGSIZE=$(jq .size $INFOFILE|tr -d \") + +ogEcho log session "[1] REPO=$REPO IMG-BRANCH=$IMGNAME SIZE=$IMGSIZE (KB)" + +# Procesar repositorio. +if [ $REPO == "REPO" ]; then + ogEcho log session "[2] updateGitCache "$REPO" \"/$IMGNAME\" $PROTO $PROTOOPT" + TIME2=$SECONDS + updateGitCache "$REPO" "$IMGNAME" "$PROTO" "$PROTOOPT" + RETVAL=$? + TIME2=$[SECONDS-TIME2] + ogEcho log session " [ ] $MSG_SCRIPTS_TIME_PARTIAL updateGitCache $[TIME2/60]m $[TIME2%60]s" + case $RETVAL in + 0) + ogEcho log session "[50] updateGitCache (OK)" + ;; + 15|16) + # no se permite usar la cache (no existe(15) o no espacio sufiente (16). Se consulta engine.cfg para RESTOREPROTOCOLNOCACHE [ multicast unicast none ] + ogEcho log session "[50] $MSG_ERR_NOTCACHE ; $MSG_ERR_CACHESIZE " + ogEcho log session "[50] $MSG_SCRIPTS_CHECK_ENGINE: RESTOREPROTOCOLNOTCACHE=$RESTOREPROTOCOLNOTCACHE " + case $RETVAL in + 15) + ogEcho log session "[100] $MSG_ERR_NOTCACHE" + ogRaiseError session $OG_ERR_NOTCACHE "NOT CACHE" + exit $? + ;; + 16) + ogEcho log session "[100] $MSG_ERR_CACHESIZE " + ogRaiseError session $OG_ERR_CACHESIZE "CACHE FULL" + exit $? + ;; + esac # del segundo RETAVAL + ;; + *) + # Error desconocido + exit $RETVAL + ;; + esac +fi + +TIME3=$SECONDS + +# Si existe, ejecuta script personalizado "restoreImageCustom"; si no, llama al genérico "restoreImage". +if which restoreGitImageCustom &>/dev/null; then + ogEcho log session "[55] $MSG_HELP_ogRestoreGitImage: restoreGitImageCustom CACHE \"$IMGNAME\" $DISK $PART $PROTO $PROTOOPT" + restoreGitImageCustom "$IMGNAME" $DISK $PART $PROTO $PROTOOPT +else + ogEcho log session "[55] $MSG_HELP_ogRestoreGitImage: restoreGitImage CACHE \"$IMGNAME\" $DISK $PART $PROTO $PROTOOPT" + restoreGitImage CACHE "$IMGNAME" $DISK $PART $PROTO $PROTOOPT +fi +RETVAL=$? + +# Mostrar resultados. +RESUMERESTOREIMAGE=$(grep -m 1 "Total Time:" $OGLOGCOMMAND) +ogEcho log session " [ ] $RESUMERESTOREIMAGE " +# Si la transferencia ha dado error me salgo. +if [ $RETVAL -ne 0 ] ; then + ogRaiseError session $OG_ERR_IMAGE "$REPO $IMGNAME" 2>&1 + # Muestro registro de fin de ejecución si no viene de Ejecutar Script + [ "$(ogGetCaller)" == "EjecutarScript" ] || ogEcho log session "$MSG_INTERFACE_END $OG_ERR_IMAGE" + exit $OG_ERR_IMAGE +fi +TIME3=$[SECONDS-TIME3] +ogEcho log session " [ ] $MSG_SCRIPTS_TIME_PARTIAL : $[TIME3/60]m $[TIME3%60]s" + +# Si existe, ejecuta script personalizado de postconfiguración "configureOsCustom"; si no, llama al genérico "configureOs". +if which configureOsCustom &>/dev/null; then + ogEcho log session "[90] configureOsCustom" + configureOsCustom "$DISK" "$PART" "$REPO" "$IMGNAME" +else + ogEcho log session "[90] $MSG_SCRIPTS_OS_CONFIGURE " + configureOs "$DISK" "$PART" +fi + +TIME=$[SECONDS-TIME1] +ogEcho log session "[100] $MSG_SCRIPTS_TIME_TOTAL $[TIME/60]m $[TIME%60]s" + +# Registro de fin de ejecución +# Si se ha llamado desde ejecutar script no lo muestro para no repetir. +if [ "$(ogGetCaller)" != "EjecutarScript" ] ; then + ogEcho log session "$MSG_INTERFACE_END $RETVAL" + exit $RETVAL +fi |