summaryrefslogtreecommitdiffstats
path: root/admin/Sources/Services/ogAdmRepoAux
blob: 4d245dafaa452426496b2c8d7477935a4405fca3 (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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
#!/bin/bash
PARM=`cat`
#PARM=$@


#TODO:  ticket 379
#buscar parametro de identificador de operacion.
#usar parametro de identificacion para anexarlo al nombre de log
#Comprobar si la variable está seteas.
#Si no lo está setearla.
#Si esta seteada (en progreso) salir.


TIME=$SECONDS

BASEDIR=/opt/opengnsys
PATH=$PATH:$BASEDIR/bin
REPONAME=ogAdmRepo
REPOLOG=$BASEDIR/log/$REPONAME.log
MCASTLOGBASE=$BASEDIR/log/mcastlog
MCASTLOG=$MCASTLOGBASE/ogAdmRepoMcast.`date +%Y%m%d-%H%M%S`
REPODIR="$BASEDIR/images/"

# Para las sincronizadas 
# BACKUP: Define si se realiza copia de seguridad al crear una imagen (true|false).
eval $(grep BACKUP $BASEDIR/client/etc/engine.cfg)
# FS segun kernel. ext4 para < 3.7, para >= BTRFS
KERNEL=$(file -bkr /opt/opengnsys/tftpboot/ogclient/ogvmlinuz |awk '/Linux/ {for(i=1;i<=NF;i++) if($i~/version/) {v=$(i+1);printf("%d",v);sub(/[0-9]*\./,"",v);printf(".%02d",v)}}')
[ $KERNEL \< 3.07 ] && IMGFS="EXT4" || IMGFS="BTRFS"


# Añade registro de incidencias.
function echolog () {
	if [ "$1" == "-o" ]; then
		shift
		date +"%Y%m%d-%H%M%S $*"|tee -a $REPOLOG
	else
		date +"%Y%m%d-%H%M%S $*" >> $REPOLOG
	fi
}

function mountImage () {
	#@param 1 image_file
	#@param 2 mount_dir
	#@param 3 openciones mount
 	[ "$3" != "" ] && OPTMOUNT=" -o $3 "	
	# Si está montado nada que hacer
	df |grep "$2$"  2>&1 >/dev/null  && return 0
	if [ $IMGFS == "EXT4" ]; then
		echolog "mount $OPTMOUNT -t ext4 $1 $2"
		mount $OPTMOUNT -t ext4 $1 $2
	else
		echolog "mount $OPTMOUNT -o compress=lzo  $1 $2"
		mount $OPTMOUNT -o compress=lzo  "$1" "$2"
	fi
	return $?
}

mkdir -p $MCASTLOGBASE


PARM1=$(echo $PARM | cut -f1 -d" ")
PARM2=$(echo $PARM | cut -f2 -d" ")
PARM3=$(echo $PARM | cut -f3 -d" ")
PARM4=$(echo $PARM | cut -f4 -d" ")

# Determinamos el tipo de sistema de fichero de las imagenes segun el kernel que tenga


case "$PARM1" in
	START_MULTICAST)
		#1 START_MULTICAST
		#2 fichero a enviar
		#3 opciones de multicast
		FILE="$PARM2"
		MCASTOPT="$PARM3"
		echolog "Ejecutar $(which sendFileMcast) $FILE $MCASTOPT"
		sendFileMcast $FILE $MCASTOPT &>> $MCASTLOG
		case $? in
			1)  echolog "Parametros insuficientes"
			    exit 1 ;;
			2)  echolog "Fichero no accesible"
			    exit 2 ;;
			3)  echolog "Sesion multicast no valida"
			    exit 3 ;;
		esac
	;;
	CREATE_IMAGE)
		# Creamos/Redimensionamos el fichero de imagen y lo montamos para que se pueda escribir sobre el
		#1 CREATE_IMAGE
		#2 nombre imagen
		#3 tipo de imagen [ img | diff ]
		#4 tamaño imagen 
		LOOPDEVICE=$(losetup -f)
		DIRMOUNT="$REPODIR/mount/$PARM2"
		if [ "$PARM3" == "img" ] ; then
			IMGEXT="img" 
		else
			IMGEXT="img.diff"
			DIRMOUNT="$DIRMOUNT.diff"
		fi
		IMGFILE="$REPODIR/$PARM2.$IMGEXT"
		IMGDIR="$(dirname $IMGFILE)"
		[ -d  $IMGDIR ] || mkdir -p $IMGDIR
		mkdir -p "$DIRMOUNT"

		LOCKFILE="$IMGFILE.lock"

		SIZEREQUIRED="$PARM4"

		# Si existe la imagen hacemos copia de seguridad y la redimesionamos 
		if [ -f "$IMGFILE" ]; then
		    echolog "La imagen $IMGFILE ya existe."
		    # TODO modificar ogGetImageSize
		    IMGSIZE=$(ls -l --block-size=1024 $IMGFILE| cut -f5 -d" ")

		    if [ "$BACKUP" == "true" -o "$BACKUP" == "TRUE"  -o $IMGSIZE -lt $SIZEREQUIRED ]; then
		        # Si la imagen esta montada la desmonto
			if [ -r "$DIRMOUNT/ogimg.info" ]; then
                                echolog "umount $DIRMOUNT"
                                umount "$DIRMOUNT"
                                [ $? -ne 0 ] && echolog "Error: No podemos desmontar la imagen para hacer copia de seguridad o redimensionar" && exit 1
                        fi
		    fi

		    # Copia de seguridad de la imagen 
		    if [ "$BACKUP" == "true" -o "$BACKUP" == "TRUE" ]; then
		    	echolog "Copia de seguridad de la imagen anterior"
		    	echolog "cp  $IMGFILE $IMGFILE.ant" 
		    	cp  "$IMGFILE" "$IMGFILE.ant" 
		    	echolog mv -f "$IMGFILE.torrent" "$IMGFILE.torrent.ant" 2>/dev/null
		    	mv -f "$IMGFILE.torrent" "$IMGFILE.torrent.ant" 2>/dev/null
		    fi

		    # Redimensionamos la imagen al tamaño necesario
		    if [ $IMGSIZE -lt $SIZEREQUIRED ];then
		        echolog "Redimensionamos la imagen $IMGFILE al tamaño necesario: $SIZEREQUIRED"
		        echolog "truncate --size=\">$SIZEREQUIRED\"k $IMGFILE" 
		        truncate --size=">$SIZEREQUIRED"k $IMGFILE 2>&1 > $REPOLOG
			# Montamos la imagen, si da error nos salimos
			if [ $IMGFS == "EXT4" ]; then
			   losetup $LOOPDEVICE "$IMGFILE"
			   echolog "resize2fs -f $LOOPDEVICE"
			   resize2fs -f $LOOPDEVICE &> $REPOLOG
			else
		    	   mount -o compress=lzo  "$IMGFILE" "$DIRMOUNT"
			   echolog "btrfs filesystem resize max $DIRMOUNT"
			   btrfs filesystem resize max "$DIRMOUNT"  2>&1 > $REPOLOG
			fi
		    fi


		# Si no existe la imagen creamos el fichero.	
		else
		    echolog "Creamos la imagen $IMGFILE al tamaño necesario: $SIZEREQUIRED"
		    echolog dd if=/dev/zero of=$IMGFILE bs=1024 count=$SIZEREQUIRED 
		    dd if=/dev/zero of=$IMGFILE bs=1024 count=$SIZEREQUIRED
		    #Formateamos imagen
		    echo losetup $LOOPDEVICE "$IMGFILE"
		    losetup $LOOPDEVICE "$IMGFILE"
		    if [ $IMGFS == "EXT4" ] ; then
			echolog "      mkfs.ext4 -i 4096  -b 4096 -L ${PARM2##*\/} $LOOPDEVICE"
			mkfs.ext4 -i 4096  -b 4096 -L ${PARM2##*\/} $LOOPDEVICE
		    else
			echolog mkfs.btrfs  -L ${PARM2##*\/} $LOOPDEVICE 
		    	mkfs.btrfs  -L ${PARM2##*\/} $LOOPDEVICE #&> $OGLOGCOMMAND
		    fi
		fi
		# Montamos la imagen.
		mountImage "$IMGFILE" "$DIRMOUNT" 
		RETVAL=$?
		if [ $RETVAL -ne 0 ]; then
			rmdir "$DIRMOUNT"
			echolog -o "Error al crear/redimensionar la imagen" 
			exit $RETVAL
		fi

		#touch "$DIRMOUNT/ogimg.info"
		echo "mounted"> "$LOCKFILE"
		TIME2=$[SECONDS-TIME]
		echolog "Fin creación/redimension de la  imagen: $[TIME2/60]m $[TIME2%60]s"
		# Si existe dispositivo loop lo borramos.
 		[ $LOOPDEVICE ] && losetup -a| grep $LOOPDEVICE &> /dev/null  &&  losetup -d $LOOPDEVICE
		# TODO: comprobar que no se quede el losetup bloqueado.

	;;
	MOUNT_IMAGE)
		# Montamos el fichero imagen para que se pueda 
		#1 MOUNT_IMAGE
		#2 nombre imagen
		#3 tipo de imagen [ img | diff ]
		DIRMOUNT="$REPODIR""mount/$PARM2"
		if [ "$PARM3" == "img" ] ; then
			IMGEXT="img" 
		else
			IMGEXT="img.diff"
			DIRMOUNT="$DIRMOUNT.diff"
		fi
		IMGFILE="$REPODIR/$PARM2.$IMGEXT"
		LOCKFILE="$IMGFILE.lock"
		echolog "Montamos la imagen $IMGFILE "
		mkdir -p "$DIRMOUNT"
		mountImage "$IMGFILE" "$DIRMOUNT"  ro || (echolog "Error al montar la imagen"; exit 1)
	;;
	UMOUNT_IMAGE)
                # Desmontamos el fichero imagen.
		# Si el directorio esta ocupado no se desmontará
                #1 UMOUNT_IMAGE
                #2 nombre imagen
                #3 tipo de imagen [ img | diff ]
		IMGTYPE="$PARM3"
		DIRMOUNT="$REPODIR/mount/$PARM2"
		if [ "$IMGTYPE" == "img" ]; then
			IMGEXT="img"
		else
			DIRMOUNT="$DIRMOUNT.$IMGTYPE"
			IMGEXT="img.diff"
		fi
		LOCKFILE="$REPODIR/$PARM2.$IMGEXT.lock"
		echolog "Desmontamos la imagen $PARM2 $PARM3 "
		umount $DIRMOUNT
		rmdir $DIRMOUNT
		[ -f $LOCKFILE ] && sed -i s/mounted//g $LOCKFILE

	;;
	REDUCE_IMAGE)
		# Reduce el archivo de la imagen a tamaño datos + 500M
		#1 REDUCE_IMAGE
		#2 Nombre Imagen
		#3 Tipo de imagen [ img |diff ]
		DIRMOUNT="${REPODIR}mount/${PARM2}"
		if [ "$PARM3" == "img" ] ; then
			IMGEXT="img" 
		else
			IMGEXT="img.diff"
			DIRMOUNT="$DIRMOUNT.diff"
		fi
                IMGFILE="$REPODIR$PARM2.$IMGEXT"
		LOCKFILE="$IMGFILE.lock"
		[ ! -f $IMGFILE ] && echolog "Imagen $IMGFILE no existe" && exit 1 

		# Solo funciona si la imagen es ext4, si no nos salimos sin error
		file $IMGFILE |grep -i -e " ext4 filesystem " 2>&1 > /dev/null || exit 0

		[ -d $DIRMOUNT ] || mkdir $DIRMOUNT
		mountImage "$IMGFILE" "$DIRMOUNT" || (echolog "Error al montar la imagen $IMGFILE"; exit 1)
		
        	# Si el espacio libre menor que 500Mb desmontamos la imagen y nos salimos
		AVAILABLE=$(df -k|grep $DIRMOUNT|awk '{print $4}')
        	if [ $AVAILABLE -lt 200000 ]; then
        	     echolog "reducir imagen REPO $PARM2 $IMGEXT. tamaño minimo, nada que hacer"
		     umount $DIRMOUNT 
		     rmdir $DIRMOUNT
		     exit 0
		fi

		# Calculamos la diferencia entre el tamaño interno y externo
		EXTSIZE=$(ls -l --block-size=1024 $IMGFILE | cut -f5 -d" ")
		INTSIZE=$(df -k|grep "$DIRMOUNT"|awk '{print $2}')
		let EDGESIZE=$EXTSIZE-$INTSIZE

        	echolog "reducir imagen REPO $PARM2 $IMGEXT, tamaño final: $ENDSIZE"
		umount $DIRMOUNT
		LOOPDEVICE=$(losetup -f)
           	losetup $LOOPDEVICE "$IMGFILE"

		# Redimensiono sistema de ficheros
           	echolog "resize2fs -fpM $LOOPDEVICE "
           	resize2fs -fpM $LOOPDEVICE # 2>&1 > $REPOLOG
		mountImage "$IMGFILE" "$DIRMOUNT" 
		# Calculamos el tamaño final del archivo
		INTSIZE=$(df -k|grep "$DIRMOUNT"|awk '{print $2}')
		let EXTSIZE=$INTSIZE+$EDGESIZE
		umount $DIRMOUNT  || (echolog "Error al desmontar la imagen $IMGFILE"; exit 1)
		# Si existe dispositivo loop lo borramos.
		[ $LOOPDEVICE ] && losetup -a| grep $LOOPDEVICE &> /dev/null  &&  losetup -d $LOOPDEVICE
		# Corto el archivo al tamaño del sistema de ficheros
		echo "truncate --size=\"$EXTSIZE\"k $IMGFILE"
		echolog "truncate --size=\"$EXTSIZE\"k $IMGFILE"
        	truncate --size="$EXTSIZE"k $IMGFILE
		rmdir $DIRMOUNT
		echo "reduced" >$LOCKFILE

	;;
	default)
	    echolog "Solicitud con parametros  \"$PARM\"  no realizada, no registrada o con errores"
	;;
esac