source: installer/opengnsys_import.sh @ 4af842a

opengnsys-1.1.0
Last change on this file since 4af842a was 7332a3f, checked in by ramon <ramongomez@…>, 7 years ago

#730: Copiar OpenGnsys 1.1.0 en rama tags/opengnsys-1.1.0

git-svn-id: https://opengnsys.es/svn/tags/opengnsys-1.1.0@5607 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 12.6 KB
Line 
1#!/bin/bash
2#         importclient str_backupfile
3#@file    importclient
4#@brief   Importa los datos de OpenGnsys de un archivo de backup: dhcp, pxe, páginas de inicio y configuración de la consola.
5#@param 1 str_backupfile fichero de backup (creado con exportclient)
6#@exception 1 Error de formato
7#@exception 2 Sólo ejecutable por usuario root
8#@exception 3 Sin acceso al fichero de backup
9#@exception 4 Sin acceso a la configuración de OpenGnsys
10#@exception 5 Errores al importar o exportar de la bd auxiliar
11#@exception 6 Errores al importar los archivos de actualización de la BD desde opengnsys.es
12#@exception 7 El archivo de backup ha sido crearo con una versión incompatible de opengnsys_export. Usar 1.1.0-5594 o posterior.
13#@note En las versiones de desarrollo (pre) no se modifica la estructura de la base de datos.
14#@version 1.1.0 - Versión inicial.
15#@author  Irina Gómez - ETSII Univ. Sevilla
16#@date    2016-10-18
17#@version 1.1.0 - Permite importar de versiones de OpenGnsys anteriores. Cambia la importación de la base de datos.
18#@note    Incompatible con versiones de opengnsys_export.sh anteriores a esta fecha.
19#@date    2018-02-14
20#*/ ##
21
22# Variables globales.
23PROG="$(basename $0)"
24
25DATE=$(date +%Y%m%d)
26BACKUPFILE=$1
27TMPDIR=/tmp/opengnsys_export
28OPENGNSYS="/opt/opengnsys"
29MYCNF=$(mktemp /tmp/.my.cnf.XXXXX)
30CATALOG="ogAdmBD"
31AUXCATALOG="og_import"
32MYSQLFILE="$TMPDIR/$CATALOG.sql"
33MYSQLBCK="$OPENGNSYS/doc/$CATALOG.sql-$DATE"
34
35LOG_FILE=$OPENGNSYS/log/${PROG%.sh}.log
36OPENGNSYS_SERVER="opengnsys.es"
37DEFAULT_MYSQL_ROOT_PASSWORD="passwordroot"      # Clave por defecto root de MySQL
38
39# Si se solicita, mostrar ayuda.
40if [ "$*" == "help" ]; then
41    echo -e "$PROG: Importa los datos de OpenGnsys desde un archivo de backup:" \
42           " dhcp, pxe, páginas de inicio y configuración de la consola.\n" \
43           "    Formato: $PROG backup_file\n" \
44           "    Ejemplo: $PROG backup.tgz"
45    exit
46fi
47
48# Comprobamos número de parámetros
49if [ $# -ne 1 ]; then
50    echo "$PROG: ERROR: Error de formato: $PROG backup_file"
51    exit 1
52fi
53
54# Comprobar parámetros.
55if [ "$USER" != "root" ]; then
56        echo "$PROG: Error: solo ejecutable por root." >&2
57        exit 2
58fi
59
60# Comprobamos acceso al fichero de backup
61if ! [ -r $BACKUPFILE ]; then
62    echo "$PROG: ERROR: Sin acceso al fichero de backup." | tee -a $FILESAL
63    exit 3
64fi
65
66# Comprobamos  acceso a ficheros de configuración
67if ! [ -r $OPENGNSYS/etc/ogAdmServer.cfg ]; then
68    echo "$PROG: ERROR: Sin acceso a la configuración de OpenGnsys." | tee -a $FILESAL
69    exit 4
70fi
71
72# Si existe el directorio auxiliar lo borramos
73[ -d $TMPDIR ] && rm -rf $TMPDIR
74
75####### Funciones ##############################################
76# Al salir elimina archivos y base de datos temporal
77function clean()
78{
79        mysql --defaults-extra-file=$MYCNF  -e "DROP DATABASE IF EXISTS $AUXCATALOG"
80        rm -f $MYCNF
81}
82
83function getDateTime()
84{
85        date "+%Y%m%d-%H%M%S"
86}
87
88# Escribe a fichero y muestra por pantalla
89function echoAndLog()
90{
91        echo "      $1"
92        DATETIME=`getDateTime`
93        echo "$DATETIME;$SSH_CLIENT;$1" >> $LOG_FILE
94}
95
96function errorAndLog()
97{
98        echo "      ERROR: $1"
99        DATETIME=`getDateTime`
100        echo "$DATETIME;$SSH_CLIENT;ERROR: $1" >> $LOG_FILE
101}
102
103function mysqlPassword()
104{
105    # Clave root de MySQL
106    while : ; do
107        echo -n -e "\\nEnter root password for MySQL (${DEFAULT_MYSQL_ROOT_PASSWORD}): ";
108        read -r MYSQL_ROOT_PASSWORD
109        if [ -n "${MYSQL_ROOT_PASSWORD//[a-zA-Z0-9]/}" ]; then # Comprobamos que sea un valor alfanumerico
110                echo -e "\\aERROR: Must be alphanumeric, try again..."
111        else
112                # Si esta vacio ponemos el valor por defecto
113                MYSQL_ROOT_PASSWORD="${MYSQL_ROOT_PASSWORD:-$DEFAULT_MYSQL_ROOT_PASSWORD}"
114                break
115        fi
116    done
117    cat << EOT > $MYCNF
118[client]
119user=root
120password=$MYSQL_ROOT_PASSWORD
121EOT
122}
123
124# Actualización incremental de la BD (versión actual a actual+1, hasta final-1 a final).
125function updateSqlFile()
126{
127        local DBDIR="$TMPDIR/Database"
128        local file FILES=""
129
130        echoAndLog "${FUNCNAME}(): looking for database updates"
131        pushd $DBDIR >/dev/null
132        # Bucle de actualización incremental desde versión actual a la final.
133        for file in $CATALOG-*-*.sql; do
134                case "$file" in
135                        $CATALOG-$OLDVERSION-$NEWVERSION.sql)
136                                # Actualización única de versión inicial y final.
137                                FILES="$FILES $file"
138                                break
139                                ;;
140                        $CATALOG-*-postinst.sql)
141                                # Ignorar fichero específico de post-instalación.
142                                ;;
143                        $CATALOG-$OLDVERSION-*.sql)
144                                # Actualización de versión n a n+1.
145                                FILES="$FILES $file"
146                                OLDVERSION="$(echo $file | cut -f3 -d-)"
147                                ;;
148                        $CATALOG-*-$NEWVERSION.sql)
149                                # Última actualización de versión final-1 a final.
150                                if [ -n "$FILES" ]; then
151                                        FILES="$FILES $file"
152                                        break
153                                fi
154                                ;;
155                esac
156        done
157        # Aplicar posible actualización propia para la versión final.
158        file=$CATALOG-$NEWVERSION.sql
159        if [ -n "$FILES" -o "$OLDVERSION" = "$NEWVERSION" -a -r $file ]; then
160                FILES="$FILES $file"
161        fi
162
163        popd >/dev/null
164        if [ -n "$FILES" ]; then
165                mysql --defaults-extra-file=$MYCNF  -e "CREATE DATABASE $AUXCATALOG"
166                [ $? != 0 ] && errorAndLog "${FUNCNAME}: Can't create database $AUXCATALOG" && exit 5
167                mysql --defaults-extra-file=$MYCNF -D "$AUXCATALOG" < $MYSQLFILE &>/dev/null
168                [ $? != 0 ] && errorAndLog "${FUNCNAME}: Can't import $MYSQLFILE in  $AUXCATALOG" && exit 5
169
170                for file in $FILES; do
171                        importSqlFile $DBDIR/$file
172                done
173
174                cp $MYSQLFILE $MYSQLFILE.backup
175                mysqldump --defaults-extra-file=$MYCNF --opt $AUXCATALOG > $MYSQLFILE
176                [ $? != 0 ] && errorAndLog "${FUNCNAME}: Can't export  $AUXCATALOG in  $MYSQLFILE" && exit 5
177
178                mysql --defaults-extra-file=$MYCNF  -e "DROP DATABASE $AUXCATALOG"
179                echoAndLog "${FUNCNAME}(): sqlfile update"
180        else
181                echoAndLog "${FUNCNAME}(): sqlfile unchanged"
182        fi
183}
184
185
186# Actualizar la base datos
187function importSqlFile()
188{
189        local sqlfile="$1"
190
191        if [ ! -r $sqlfile ]; then
192                errorAndLog "${FUNCNAME}(): Unable to read $sqlfile!!"
193                exit 5
194        fi
195
196        echoAndLog "${FUNCNAME}(): importing SQL file..."
197        # Ejecutar actualización y borrar fichero de credenciales.
198        mysql --defaults-extra-file=$MYCNF --default-character-set=utf8 -D "$AUXCATALOG" < $sqlfile
199        if [ $? -ne 0 ]; then
200                errorAndLog "${FUNCNAME}(): error importing ${sqlfile##*/} in temporal database"
201                exit 5
202        fi
203        echoAndLog "${FUNCNAME}(): file ${sqlfile##*/} imported to temporal database"
204        return 0
205}
206
207##################################################################
208# Al salir borramos MYCNF y la db tamporal
209trap "clean" 1 2 3 6 9 14 15 EXIT
210
211# Descomprimimos backup
212tar -xvzf $BACKUPFILE --directory /tmp &>/dev/null
213
214# Comprueba que opengnsys_export sea compatible
215grep "CREATE TABLE.*usuarios" $MYSQLFILE &>/dev/null
216if [ $? -ne 0 ]; then
217    errorAndLog "Backup file created with old version opengnsys_export. Use version 1.1.0-5594 or later."
218    exit 7
219fi
220
221# Comprobamos si es la misma versión
222OLDVERSION=$(awk '{print $2}' $TMPDIR/VERSION.txt)
223NEWVERSION=$(awk '{print $2}' $OPENGNSYS/doc/VERSION.txt)
224# FALTA: Comprobar que la versión OLD es menor que la NEW
225if [ $OLDVERSION != $NEWVERSION ] ; then
226    echo "La versión del servidor no coincide con la del backup."
227    cat $OPENGNSYS/doc/VERSION.txt $TMPDIR/VERSION.txt
228    read -p "¿Quiere continuar? (y/n): " ANSWER
229    if [ "${ANSWER^^}" != "Y" ]; then
230        echo "Operación cancelada."
231        exit 0
232    fi
233    # Nos bajamos los archivos de actualización de la base de datos
234    SVN_URL="https://$OPENGNSYS_SERVER/svn/tags/opengnsys-$NEWVERSION/admin/Database"
235    [[ "$NEWVERSION" =~ pre ]] && SVN_URL="https://$OPENGNSYS_SERVER/svn/branches/version${NEWVERSION%.*}/admin/Database"
236    svn checkout "$SVN_URL" $TMPDIR/Database
237    [ $? -ne 0 ] && errorAndLog "$PROG: Error getting code from $SVN_URL" && exit 6
238   
239    # Solicitamos la clave de mysql.
240    mysqlPassword
241    DIFFVERSION=TRUE
242fi
243
244# MYSQL
245echo "   * Importamos informacion mysql."
246source $OPENGNSYS/etc/ogAdmServer.cfg
247# Crear fichero temporal de acceso a la BD
248if [ ! -r $MYCNF ]; then
249    chmod 600 $MYCNF
250    trap "rm -f $MYCNF" 1 2 3 6 9 15
251    cat << EOT > $MYCNF
252[client]
253user=$USUARIO
254password=$PASSWORD
255EOT
256fi
257
258# Si la BD tiene no definido el trigger necesitamos permisos de root
259mysql --defaults-extra-file=$MYCNF -e "SHOW TRIGGERS FROM $CATALOG;" |grep "Trigger" &>/dev/null
260if [ $? -eq 0 ]; then
261    # Existe el trigger: eliminamos líneas del trigger en $CATALOG.sql
262    read INI END <<< $(grep -n -e TRIGGER -e "END.*;;" $MYSQLFILE |cut -d: -f1)
263    [ -n "$INI" ] && sed -i "$INI,${END}d" $MYSQLFILE
264else
265    # No existe: necesitamos privilegios de root
266    grep "user=root" $MYCNF &>/dev/null || mysqlPassword
267fi
268
269# Si la versión es diferente usamos una tabla auxiliar para actualizar el .sql
270[ "$DIFFVERSION" == TRUE ] &&  updateSqlFile
271
272# Eliminamos las tablas que no importamos: repositorios, entorno
273#     y añadimos los usuarios, sólo si no existen.
274cp $MYSQLFILE $MYSQLFILE.prueba
275sed -i -e '/Table structure.* `repositorios`/,/Table structure/d' \
276       -e '/Table structure.* `entornos`/,/Table structure/d' \
277       -e '/Table structure.*`usuarios`/,/CHARSET/d' \
278       -e '/usuarios/s/IGNORE//g' \
279       -e '/usuarios/s/^INSERT /\nALTER TABLE usuarios ADD UNIQUE (usuario);\n\nINSERT IGNORE /g' $MYSQLFILE
280
281# Copia de seguridad del estado de la base de datos
282mysqldump --defaults-extra-file=$MYCNF --opt $CATALOG > $MYSQLBCK
283# Importamos los datos nuevos
284mysql --defaults-extra-file=$MYCNF -D "$CATALOG" < $MYSQLFILE &>/dev/null
285[ $? -ne 0 ] && echo "ERROR: Error al importar la información de la base de datos."
286
287# Copiamos los archivos a su sitio correcto
288# DHCP
289echo "   * Componemos la configuración del dhcp."
290for DHCPCFGDIR in /etc/dhcp /etc/dhcp3; do
291    if [ -r $DHCPCFGDIR/dhcpd.conf ]; then
292        # Tomamos las variables globales de la configuración actual y las declaraciones host del backup
293        # Inicio declaraciones host
294        OLDHOSTINI=$(grep -n -m1 -e "^[[:blank:]]*host" -e "^#[[:blank:]]*host" $TMPDIR/dhcpd.conf|cut -d: -f1)
295        let BEFOREHOST=$(grep -n -m1 -e "^[[:blank:]]*host" -e "^#[[:blank:]]*host" $DHCPCFGDIR/dhcpd.conf| cut -d: -f1)-1
296        # Copia de seguridad de la configuración anterior
297        cp $DHCPCFGDIR/dhcpd.conf $DHCPCFGDIR/dhcpd.conf-LAST
298        mv $DHCPCFGDIR/dhcpd.conf $DHCPCFGDIR/dhcpd.conf-$DATE
299        # Nuevo fichero
300        sed ${BEFOREHOST}q $DHCPCFGDIR/dhcpd.conf-LAST > $DHCPCFGDIR/dhcpd.conf
301        sed -n -e "$OLDHOSTINI,\$p" $TMPDIR/dhcpd.conf >> $DHCPCFGDIR/dhcpd.conf
302        break
303    fi
304done
305
306# TFTP
307echo "   * Guardamos los ficheros PXE de los clientes."
308mv $OPENGNSYS/tftpboot/menu.lst $OPENGNSYS/tftpboot/menu.lst-$DATE
309cp -r $TMPDIR/menu.lst  $OPENGNSYS/tftpboot
310chown -R www-data:www-data $OPENGNSYS/tftpboot/menu.lst
311
312# Configuración de los clientes
313echo "   * Guardamos la configuración de los clientes."
314mv $OPENGNSYS/client/etc/engine.cfg $OPENGNSYS/client/etc/engine.cfg-$DATE
315cp $TMPDIR/engine.cfg $OPENGNSYS/client/etc/engine.cfg
316
317# Páginas de inicio
318echo "   * Guardamos las páginas de inicio."
319mv $OPENGNSYS/www/menus $OPENGNSYS/www/menus-$DATE
320cp -r $TMPDIR/menus $OPENGNSYS/www
321
322echo -e "Se ha terminado de importar los datos del backup. \n\nSe han realizado copias de seguridad de los archivos antiguos:"
323echo    "  - $DHCPCFGDIR/dhcpd.conf-$DATE"
324echo    "  - $OPENGNSYS/tftpboot/menu.lst-$DATE"
325echo    "  - $OPENGNSYS/client/etc/engine.cfg-$DATE"
326echo    "  - $OPENGNSYS/www/menus-$DATE"
327echo -e "  - $MYSQLBCK \n"
328
329echo "Hay que revisar la configuración del dhcp. En la consola es necesario configurar los valores de las ips de repositorios, servidores ntp, etc y lanzar el \"netBoot Avanzado\" a todas las aulas"
330
331echo "Es necesario probar todos los procedimientos y en caso de error borrarlos y generarlos de nuevo."
Note: See TracBrowser for help on using the repository browser.