summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xadmin/Sources/Services/ogAdmRepoAux15
-rw-r--r--client/shared/etc/lang.ca_ES.conf1
-rw-r--r--client/shared/etc/lang.en_GB.conf1
-rw-r--r--client/shared/etc/lang.es_ES.conf1
-rwxr-xr-xserver/bin/clean-mountdirimage38
-rwxr-xr-xserver/bin/createfileimage2
-rwxr-xr-xserver/bin/partclone2sync174
7 files changed, 229 insertions, 3 deletions
diff --git a/admin/Sources/Services/ogAdmRepoAux b/admin/Sources/Services/ogAdmRepoAux
index 1fc3e770..d6e5dac1 100755
--- a/admin/Sources/Services/ogAdmRepoAux
+++ b/admin/Sources/Services/ogAdmRepoAux
@@ -31,7 +31,12 @@ KERNEL=$(file $BASEDIR/tftpboot/ogclient/ogvmlinuz |awk -F . '{print $2}')
# Añade registro de incidencias.
function echolog () {
- date +"%Y%m%d-%H%M%S $*" >> $REPOLOG
+ 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 () {
@@ -104,6 +109,7 @@ case "$PARM1" in
# 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" ")
@@ -161,7 +167,12 @@ case "$PARM1" in
fi
# Montamos la imagen.
mountImage "$IMGFILE" "$DIRMOUNT"
- [ "$?" == "0" ] || (echo salida=$?; echolog "Error al crear/redimensionar la imagen"; exit 1)
+ RETVAL=$?
+ if [ $RETVAL -ne 0 ]; then
+ rmdir "$DIRMOUNT"
+ echolog -o "Error al crear/redimensionar la imagen"
+ exit $RETVAL
+ fi
touch "$DIRMOUNT/ogimg.info"
TIME2=$[SECONDS-TIME]
diff --git a/client/shared/etc/lang.ca_ES.conf b/client/shared/etc/lang.ca_ES.conf
index 63d2907e..48c03212 100644
--- a/client/shared/etc/lang.ca_ES.conf
+++ b/client/shared/etc/lang.ca_ES.conf
@@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen
MSG_HELP_configureOs="Post-configura de arranque del sistema"
MSG_HELP_createBaseImage="Genera imagen basica de la particion"
MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica"
+MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable."
MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion"
MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion"
MSG_HELP_updateCache="Realiza la actualizacion de la cache"
diff --git a/client/shared/etc/lang.en_GB.conf b/client/shared/etc/lang.en_GB.conf
index eda6c932..71bc88a6 100644
--- a/client/shared/etc/lang.en_GB.conf
+++ b/client/shared/etc/lang.en_GB.conf
@@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen
MSG_HELP_configureOs="Post-configura de arranque del sistema"
MSG_HELP_createBaseImage="Genera imagen basica de la particion"
MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica"
+MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable."
MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion"
MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion"
MSG_HELP_updateCache="Realiza la actualizacion de la cache"
diff --git a/client/shared/etc/lang.es_ES.conf b/client/shared/etc/lang.es_ES.conf
index ec092422..bc19362c 100644
--- a/client/shared/etc/lang.es_ES.conf
+++ b/client/shared/etc/lang.es_ES.conf
@@ -202,6 +202,7 @@ MSG_HELP_ogWaitMountImage="Se espera un tiempo estimado a que se monte la imagen
MSG_HELP_configureOs="Post-configura de arranque del sistema"
MSG_HELP_createBaseImage="Genera imagen basica de la particion"
MSG_HELP_createDiffImage="Genera imagen diferencial de la particion respecto a la imagen basica"
+MSG_HELP_partclone2sync="Convierte imagen de partclone en imagen sincronizable."
MSG_HELP_restoreBaseImage="Restaura una imagen basica en una particion"
MSG_HELP_restoreDiffImage="Restaura una imagen diferencial en una particion"
MSG_HELP_updateCache="Realiza la actualizacion de la cache"
diff --git a/server/bin/clean-mountdirimage b/server/bin/clean-mountdirimage
new file mode 100755
index 00000000..a47861ff
--- /dev/null
+++ b/server/bin/clean-mountdirimage
@@ -0,0 +1,38 @@
+#!/bin/bash
+#/**
+# clean-mountdirimage
+#@brief Borra los directorios de montaje de las imagenes que no se estén usando.
+#@param No
+#@return Información sobre los directorios borrardos o no.
+#@exception # Usuario distinto de root.
+#@version 1.0
+#@author Irina Gomez
+#@date 2014-01-20
+#*/ ##
+
+BASEDIR="/opt/opengnsys/images/mount"
+DIR=$(ls $BASEDIR)
+if [ "$USER" != "root" ]; then
+ echo "$PROG: Error: solo ejecutable por root" >&2
+ exit 1
+fi
+
+# Desmontamos los directorios que no se esten usando.
+umount /opt/opengnsys/images/mount/* &>/dev/null
+# Guardamos los directorios que siguen montados.
+MOUNTEDDIR=$(df |grep /opt/opengnsys/images/mount)
+# Comprobamos que no esta montado y borramos.
+echo "Borrando los directorios de montaje de las imagenes:"
+for IMGDIR in $DIR
+do
+ echo -n " $IMGDIR:"
+ if ! echo $MOUNTEDDIR |grep -e "$BASEDIR/$IMGDIR " -e "$BASEDIR/$IMGDIR$" >/dev/null ; then
+ rm -rf $BASEDIR/$IMGDIR
+ echo "directorio borrado."
+ else
+ echo "directorio ocupado, no se puede borrar."
+
+ fi
+done
+
+
diff --git a/server/bin/createfileimage b/server/bin/createfileimage
index b4ba405d..73c57711 100755
--- a/server/bin/createfileimage
+++ b/server/bin/createfileimage
@@ -55,7 +55,7 @@ SIZEREQUIRED=$3
[ $SIZEREQUIRED -lt 300000 ] && SIZEREQUIRED=300000
echo CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED
-echo -ne CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED| /opt/opengnsys/sbin/ogAdmRepoAux
+echo -ne CREATE_IMAGE "$1" $IMGEXT $SIZEREQUIRED| /opt/opengnsys/sbin/ogAdmRepoAux || exit $?
echo "Los resultado se registran en $REPOLOG. "
rm $IMGFILE.lock
diff --git a/server/bin/partclone2sync b/server/bin/partclone2sync
new file mode 100755
index 00000000..4272cf06
--- /dev/null
+++ b/server/bin/partclone2sync
@@ -0,0 +1,174 @@
+#!/bin/bash
+#/**
+# partclone2sync
+#@brief Convierte imagen de partclone en imagen sincronizable.
+#@param 1 imagen partclone.
+#@param 2 imagen sincronizable.
+#@param 3 tipo de sincronización y formato de la imagen SYNC1 (directorio) y SYNC2 (fichero)
+#@exception OG_ERR_FORMAT # 1 formato incorrecto.
+#@exception OG_ERR_NOTFOUND # 2 Fichero o dispositivo no encontrado
+#@exception OG_ERR_LOCKED # 4 Imagen de partclone bloqueada.
+#@exception OG_ERR_IMAGE # 5 Error al crear la imagen.
+#@exception OG_CACHESIZE # 16 No hay espacio suficiente en el disco.
+#@note Necesita tener instalado partclone-utils y lzop
+#@version 1.0 -
+#@author Irina Gomez
+#@date 2014-01-22
+#*/ ##
+trap "onexit \"$1\" \"$2\" $3" 0 5 16 9 15
+
+function onexit() {
+ local exit_status=$?
+ # Desmontamos el cliente de opengnsys y la imagen temporal.
+ umount $OGCLIENTDIR/ogclientmount $AUXDIR
+ rm -rf $IMGINFO $FILEHEAD $TMPLOG
+
+ # Borramos los ficheros de bloqueo de las imagenes nuevas.
+ rm -rf $RSYNCIMG.img.lock $AUXIMG.lock
+ # Borramos los ficheros de bloqueo dela imagen de partclone si no estaba bloqueada.
+ [ $exit_status -eq 4 ] || rm -rf $PARTCLONEIMG.lock
+
+ # Borramos las imagenes y directorios temporales.
+ rm $AUXIMG
+ rmdir $AUXDIR $OGCLIENTDIR/ogclientmount
+
+ exit $exit_status
+}
+
+TIME1=$SECONDS
+
+BASEDIR=/opt/opengnsys
+REPODIR="$BASEDIR/images"
+BINDIR="$BASEDIR/bin"
+PROG="$(basename $0)"
+# Cargamos los mensajes en el idioma del sistema.
+source $BASEDIR/client/etc/lang.$LANG.conf
+
+# Sistema de fichero de la imagen según kernel, menor que 3.7 EXT4. comparamos revision
+[ $(uname -r|cut -d. -f2) -lt 7 ] && IMGFS="EXT4" || IMGFS="BTRFS"
+
+# Mostrar ayuda: Si se solicita, si faltan parametros o $3 no es SYNC1 o SYNC2.
+if [ "$*" == "help" -o $# -lt 3 ] && ! [[ "$3" == SYNC[1,2] ]]; then
+ echo -e "$PROG: $MSG_HELP_partclone2sync \n" \
+ "$MSG_FORMAT: $PROG image_partclone image_rsync [ SYNC1 | SYNC2 ] \n" \
+ " $PROG Windows7 Windows72013 SYNC1 "
+ exit 0
+fi
+
+if [ "$USER" != "root" ]; then
+ echo "$PROG: Error: solo ejecutable por root" >&2
+ exit 1
+fi
+
+
+PARTCLONEIMG="$REPODIR/$1.img"
+RSYNCIMG="$REPODIR/$2"
+AUXIMG="$REPODIR/$1.tmp.img"
+AUXDIR="/tmp/partclone2rsync$$"
+TYPE="$3"
+TMPLOG=/tmp/rsync$$.sal
+
+# Comprobamos que exista la imagen.
+! [ -f $PARTCLONEIMG ] && echo "$MSG_ERR_NOTFOUND: $1" && exit 2
+
+# Comprobamos que la imagen no este bloqueada.
+[ -f $PARTCLONEIMG.lock ] && echo "$MSG_ERR_LOCKED: $1" && exit 4
+
+# Usamos el partclone del ogclient.
+OGCLIENTDIR=$BASEDIR/tftpboot/ogclient
+[ -d $OGCLIENTDIR/ogclientmount ] || mkdir $OGCLIENTDIR/ogclientmount
+mount $OGCLIENTDIR/ogclient.sqfs $OGCLIENTDIR/ogclientmount
+PATHPARTCLONE=$OGCLIENTDIR/ogclientmount/usr/sbin
+
+# Creamos fichero de bloqueo
+touch $PARTCLONEIMG.lock $AUXIMG.lock
+
+
+# Datos imagen.
+echo [10] Obtenemos datos del partclone.
+FILEHEAD=/tmp/$(basename $PARTCLONEIMG).infohead
+COMPRESSOR=`file $PARTCLONEIMG | awk '{print $2}'`
+$COMPRESSOR -dc $PARTCLONEIMG 2>/dev/null | head > $FILEHEAD
+PARTCLONEINFO=$(LC_ALL=C partclone.info $FILEHEAD 2>&1)
+if `echo $PARTCLONEINFO | grep size > /dev/null`
+then
+ FS=$(echo $PARTCLONEINFO | awk '{gsub(/\: /,"\n"); print toupper($8);}')
+ echo $PARTCLONEINFO | grep GB > /dev/null && SIZEFACTOR=1000000 || SIZEFACTOR=1024
+ IMGSIZE=$(echo $PARTCLONEINFO | awk -v FACTOR=$SIZEFACTOR '{gsub(/\: /,"\n"); printf "%d\n", $11*FACTOR;}')
+else
+ echo "Error: partclone.info no detecta la imagen"
+ exit 5
+fi
+[ "$FS" == "NTFS" ] && echo "Error: Todavia no podemos convertir imagenes de Windows" && exit 6
+
+# Calculamos el espacio disponible en la particion de opengnsys.
+echo -n "[20]$MSG_SCRIPTS_CREATE_SIZE "
+for DIR in "/" "/opt" "/opt/opengnsys" "/opt/opengnsys/images"
+do
+ AUXSIZE=$(df|grep $DIR$|awk '{print $3}')
+ [ "$AUXSIZE" != "" ] && PARTSIZE=$AUXSIZE
+done
+let REQUIRESIZE=2*$IMGSIZE
+if [ $PARTSIZE -lt $REQUIRESIZE ]; then
+ echo "No hay espacio suficiente para descomprimir y crear la imagen: $REQUIRESIZE."
+ exit 16
+fi
+echo "$REQUIRESIZE $PARTSIZE"
+
+# Descomprimimos la imagen de partclone.
+echo [30] Descomprimimos la imagen de partclone.
+$COMPRESSOR -dc $PARTCLONEIMG | $PATHPARTCLONE/partclone.restore -C -s - -O $AUXIMG
+
+TIME2=$[SECONDS-TIME1]
+echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME2/60]m $[TIME2%60]s"
+
+# Montamos la imagen:
+mkdir -p $AUXDIR
+mount $AUXIMG $AUXDIR
+
+# Sincronizamos de la imagen del partclone a la del rsync.
+echo "[60] Sincronizamos desde la imagen de partclone a la de rsync."
+if [ "$TYPE" == "SYNC1" ]; then
+ mkdir -p $RSYNCIMG
+ echo " * Log temporal en: $TMPLOG"
+ echo rsync -aHAX $AUXDIR/ $RSYNCIMG --- log: $TMPLOG
+ rsync -aHAXv $AUXDIR/ $RSYNCIMG >> $TMPLOG
+TIME3=$[SECONDS-TIME2]
+echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME3/60]m $[TIME3%60]s"
+else
+ IMGINFO="/tmp/ogimg.info$$"
+ IMGDIR="$REPODIR/mount/$(basename $RSYNCIMG)"
+ # Calculamos el tamaño de la imagen
+ SIZE=$(df -k|awk -v P="$AUXDIR" '{if ($6==P) print $3}')
+ # Creo fichero de informacion de la imagen
+ echo "#$FSIMG:LZO:$FS:$SIZE" > $IMGINFO
+ # Factor de compresion de la imagen
+ [ "$FS" == "NTFS" ] && ZFACTOR=120 || ZFACTOR=110
+ [ "$FSIMG" == "BTRFS" ] && let ZFACTOR=$ZFACTOR-30
+ let SIZE=$SIZE*$ZFACTOR/100
+
+ # Creamos el fichero de la imagen vacio (queda montado)
+ echo " * $MSG_HELP_ogCreateFileImage"
+ $BINDIR/createfileimage $(basename $RSYNCIMG) img $SIZE || exit 5
+ touch $RSYNCIMG.img.lock
+ TIME3=$[SECONDS-TIME2]
+ echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME3/60]m $[TIME3%60]s"
+
+ # Sincronizo las imagenes antigua y nueva.
+ echo " * Sincroniza las imagenes antigua y nueva. log temporal en: $TMPLOG"
+ echo rsync -aHAX $AUXDIR/ $IMGDIR
+ rsync -aHAXv $AUXDIR/ $IMGDIR >> $TMPLOG
+ TIME4=$[SECONDS-TIME3]
+ echo " $MSG_SCRIPTS_TASK_END: $MSG_SCRIPTS_TIME_PARTIAL: $[TIME4/60]m $[TIME4%60]s"
+ # copiamos el fichero de informacion dentro de la imagen.
+ mv $IMGINFO $IMGDIR/ogimg.info
+ # Desmontamos la imagen y la reducimos al minimo.
+ $BINDIR/unmountimage $(basename $RSYNCIMG) img
+ echo " * $MSG_HELP_ogReduceImage."
+ rm $RSYNCIMG.img.lock
+ $BINDIR/reduceimage $(basename $RSYNCIMG) img
+
+fi
+
+TIME=$[SECONDS-TIME1]
+echo " $MSG_SCRIPTS_END: $MSG_SCRIPTS_TIME_TOTAL: $[TIME/60]m $[TIME%60]s"