summaryrefslogtreecommitdiffstats
path: root/admin/Interface/CrearImagen
blob: b18fbea0a51c84e3f2bf1b98a8dda49f3c1bd7e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
#!/bin/bash

#___________________________________________________
#
# PARAMETROS RECIBIDOS DESDE EL CLIENTE:
# $1 Número de disco
# $2 Número de particion
# $3 Nombre canónico de la imagen (sin extensión)
# $4 Dirección del repositorio (REPO, por defecto)
#___________________________________________________


#$OG_ERR_NOTEXEC    Si no es llamada por OG client
#$OG_ERR_LOCKED=4    Si la particion está bloqueada.


#Codigos de error del scripts createImage
#@exception OG_ERR_FORMAT     # 1 formato incorrecto.
#@exception OG_ERR_PARTITION  # 3 Error en partición de disco o en su sistema de archivos
#@exception OG_ERR_IMAGE      # 5 Error en funcion ogCreateImage o ogRestoreImage.
#@exception OG_ERR_NOTWRITE   # 14 error de escritura
#@exception OG_ERR_NOTCACHE   # 15 si cache no existe 15
#@exception OG_ERR_CACHESIZE  # 16 si espacio de la cache local o remota no tiene espacio 16
#@exception OG_ERR_REDUCEFS   # 17 error al reducir sistema de archivos.
#@exception OG_ERR_EXTENDFS   # 18 Errror al expandir el sistema de archivos.
#@version 1.2 - Soporta imágenes de disco.
#@author  Irina Gomez, ETSII Universidad de Sevilla.
#@date    2020/06/19



#Códigos de error de la funcion ogCreateImage



TIME1=$SECONDS

#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 " " > $OGLOGSESSION; echo " " > $OGLOGCOMMAND; echo " " > ${OGLOGCOMMAND}.tmp

# Registro de inicio de ejecución
ogEcho log session "$MSG_INTERFACE_START $0 $*"

# Solo ejecutable por OpenGnsys Client.
PATH=$PATH:$(dirname $0)
PROG=$(basename $0)
CALLER=$(ogGetCaller)
#if [ "$CALLER" != "ogAdmClient" ]; then
#	ogRaiseError $OG_ERR_NOTEXEC "$CALLER -> $PROG"
#	exit $?
#fi

# Valor por defecto para el repositorio.
REPO=${4:-"REPO"}
[ "$REPO" == "$(ogGetIpAddress)" ] && REPO="CACHE"
# Si es una ip y es distinta a la del recurso samba cambiamos de REPO.
ogCheckIpAddress $REPO
if [ $? == 0 -o $REPO == "REPO" ] ; then
	# Unidad organizativa
	[ "$ogunit" != "" ] && OGUNIT="$ogunit"
        # Si falla el cambio -> salimos con error repositorio no valido
        ogChangeRepo $REPO $OGUNIT || exit $(ogRaiseError $OG_ERR_NOTFOUND '$REPO'; echo $?)
        REPO="REPO"
fi

# Si el destino es REPO y el cliente no está en modo "admin"; activar repositorio para escritura,
if [ "$REPO" == "REPO" -a "$boot" != "admin"  ] 
then 
	CambiarAcceso admin &>> $OGLOGFILE
	RETVAL=$?
	[ $RETVAL -gt 0 ] && exit $RETVAL 	
fi

# Distinguimos entre imágenes de disco y de partición.
if [ "$2" == 0 ]; then
	PARAMS=( "$1" "$4" "$3" )
	SCRIPTCREATE=createDiskImage
else
	PARAMS=( "$1" "$2" "$4" "$3" )
	SCRIPTCREATE=createImage
fi

ogEcho	createImage "$1" "$2" "$4" /"$3" 
# Si existe, ejecuta script personalizado "createImageCustom"; si no, llama al genérico "createImage".
if which ${SCRIPTCREATE}Custom &>/dev/null; then
	eval ${SCRIPTCREATE}Custom ${PARAMS[*]} &>> $OGLOGCOMMAND
else
	eval ${SCRIPTCREATE} ${PARAMS[*]} &>> $OGLOGCOMMAND
fi
RETVAL=$?

# Cambiar acceso a modo usuario, si es necesario.
[ "$REPO" == "REPO" -a "$boot" != "admin" ] && CambiarAcceso user

# Registro de fin de ejecución
ogEcho log session "$MSG_INTERFACE_END $RETVAL"

exit $RETVAL