source: installer/opengnsys_installer.sh @ 695c8e6

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since 695c8e6 was 7829e4e, checked in by ramon <ramongomez@…>, 10 years ago

#708: Integrar código del ticket:708 en versión 1.1.

git-svn-id: https://opengnsys.es/svn/branches/version1.1@4652 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100755
File size: 55.8 KB
RevLine 
[a01156a]1#!/bin/bash
2
3#####################################################################
[6ef01d9]4####### Script instalador OpenGnSys
[a01156a]5####### autor: Luis Guillén <lguillen@unizar.es>
6#####################################################################
7
8
[9672640]9####  AVISO: Puede editar configuración de acceso por defecto.
10####  WARNING: Edit default access configuration if you wish.
11DEFAULT_MYSQL_ROOT_PASSWORD="passwordroot"      # Clave por defecto root de MySQL
12DEFAULT_OPENGNSYS_DB_USER="usuog"                   # Usuario por defecto de acceso a la base de datos
13DEFAULT_OPENGNSYS_DB_PASSWD="passusuog"         # Clave por defecto de acceso a la base de datos
14DEFAULT_OPENGNSYS_CLIENT_PASSWD="og"            # Clave por defecto de acceso del cliente       
[4a3cd1f]15
[1e7eaab]16# Sólo ejecutable por usuario root
[6ef01d9]17if [ "$(whoami)" != 'root' ]; then
[1e7eaab]18        echo "ERROR: this program must run under root privileges!!"
19        exit 1
20fi
[9672640]21
22echo -e "\\nOpenGnSys Installation"
23echo "=============================="
24
25# Clave root de MySQL
26while : ; do
27        echo -n -e "\\nEnter root password for MySQL (${DEFAULT_MYSQL_ROOT_PASSWORD}): ";
28        read MYSQL_ROOT_PASSWORD
29        if [ -n "${MYSQL_ROOT_PASSWORD//[a-zA-Z0-9]/}" ]; then # Comprobamos que sea un valor alfanumerico
30                echo -e "\\aERROR: Must be alphanumeric, try again..."
31        else
32                if [ -z $MYSQL_ROOT_PASSWORD ]; then # Si esta vacio ponemos el valor por defecto
33                        MYSQL_ROOT_PASSWORD=$DEFAULT_MYSQL_ROOT_PASSWORD
34                fi
35                break
36        fi
37done
38
39# Usuario de acceso a la base de datos
40while : ; do
41        echo -n -e "\\nEnter username for OpenGnSys console (${DEFAULT_OPENGNSYS_DB_USER}): "
42        read OPENGNSYS_DB_USER
43        if [ -n "${OPENGNSYS_DB_USER//[a-zA-Z0-9]/}" ]; then # Comprobamos que sea un valor alfanumerico
44                echo -e "\\aERROR: Must be alphanumeric, try again..."
45        else
46                if [ -z $OPENGNSYS_DB_USER ]; then # Si esta vacio ponemos el valor por defecto
47                        OPENGNSYS_DB_USER=$DEFAULT_OPENGNSYS_DB_USER
48                fi
49                break
50        fi
51done
52
53# Clave de acceso a la base de datos
54while : ; do
55        echo -n -e "\\nEnter password for OpenGnSys console (${DEFAULT_OPENGNSYS_DB_PASSWD}): "
56        read OPENGNSYS_DB_PASSWD
57        if [ -n "${OPENGNSYS_DB_PASSWD//[a-zA-Z0-9]/}" ]; then # Comprobamos que sea un valor alfanumerico
58                echo -e "\\aERROR: Must be alphanumeric, try again..."
59        else
60                if [ -z $OPENGNSYS_DB_PASSWD ]; then # Si esta vacio ponemos el valor por defecto
61                        OPENGNSYS_DB_PASSWD=$DEFAULT_OPENGNSYS_DB_PASSWD
62                fi
63                break
64        fi
65done
66
67# Clave de acceso del cliente
68while : ; do
69        echo -n -e "\\nEnter root password for OpenGnSys client (${DEFAULT_OPENGNSYS_CLIENT_PASSWD}): "
70        read OPENGNSYS_CLIENT_PASSWD
71        if [ -n "${OPENGNSYS_CLIENT_PASSWD//[a-zA-Z0-9]/}" ]; then # Comprobamos que sea un valor alfanumerico
72                echo -e "\\aERROR: Must be alphanumeric, try again..."
73        else
74                if [ -z $OPENGNSYS_CLIENT_PASSWD ]; then # Si esta vacio ponemos el valor por defecto
75                        OPENGNSYS_CLIENT_PASSWD=$DEFAULT_OPENGNSYS_CLIENT_PASSWD
76                fi
77                break
78        fi
79done
80
81echo -e "\\n=============================="
[1e7eaab]82
83# Comprobar si se ha descargado el paquete comprimido (USESVN=0) o sólo el instalador (USESVN=1).
[49c6891]84PROGRAMDIR=$(readlink -e $(dirname "$0"))
[35b0ef1]85PROGRAMNAME=$(basename "$0")
[07c3a59]86OPENGNSYS_SERVER="www.opengnsys.es"
[1e7eaab]87if [ -d "$PROGRAMDIR/../installer" ]; then
[6ef01d9]88        USESVN=0
[1e7eaab]89else
[6ef01d9]90        USESVN=1
[1e7eaab]91fi
[1a2fa9d8]92SVN_URL="http://$OPENGNSYS_SERVER/svn/branches/version1.1/"
[1e7eaab]93
[a01156a]94WORKDIR=/tmp/opengnsys_installer
[1e7eaab]95mkdir -p $WORKDIR
96
[42a0e41]97# Directorio destino de OpenGnSys.
[1e7eaab]98INSTALL_TARGET=/opt/opengnsys
[42a0e41]99
100# Registro de incidencias.
101OGLOGFILE=$INSTALL_TARGET/log/${PROGRAMNAME%.sh}.log
[acfb07d]102LOG_FILE=/tmp/$(basename $OGLOGFILE)
[a01156a]103
[fd021b0]104# Usuario del cliente para acceso remoto.
105OPENGNSYS_CLIENT_USER="opengnsys"
106
107# Nombre de la base datos y fichero SQL para su creación.
108OPENGNSYS_DATABASE="ogAdmBD"
109OPENGNSYS_DB_CREATION_FILE=opengnsys/admin/Database/${OPENGNSYS_DATABASE}.sql
[3aaf91d]110
[a01156a]111
112#####################################################################
[d168a46]113####### Funciones de configuración
114#####################################################################
115
116# Generar variables de configuración del instalador
117# Variables globales:
[5cc52295]118# - OSDISTRIB, OSVERSION - tipo y versión de la distribución GNU/Linux
[d168a46]119# - DEPENDENCIES - array de dependencias que deben estar instaladas
120# - UPDATEPKGLIST, INSTALLPKGS, CHECKPKGS - comandos para gestión de paquetes
[109e8b2]121# - INSTALLEXTRADEPS - instalar dependencias no incluidas en la distribución
[53fba30]122# - STARTSERVICE, ENABLESERVICE - iniciar y habilitar un servicio
[109e8b2]123# - STOPSERVICE, DISABLESERVICE - parar y deshabilitar un servicio
[53fba30]124# - APACHESERV, APACHECFGDIR, APACHESITESDIR, APACHEUSER, APACHEGROUP - servicio y configuración de Apache
[7825e9e]125# - APACHESSLMOD, APACHEENABLESSL, APACHEMAKECERT - habilitar módulo Apache y certificado SSL
[53fba30]126# - APACHEENABLEOG, APACHEOGSITE, - habilitar sitio web de OpenGnSys
127# - INETDSERV - servicio Inetd
[09ac3b8]128# - FIREWALLSERV - servicio de cortabuegos IPTables/FirewallD
[53fba30]129# - DHCPSERV, DHCPCFGDIR - servicio y configuración de DHCP
[0f8100d]130# - MYSQLSERV, TMPMYCNF - servicio MySQL y fichero temporal con credenciales de acceso
131# - MARIADBSERV - servicio MariaDB (sustituto de MySQL en algunas distribuciones)
[e70925a]132# - RSYNCSERV, RSYNCCFGDIR - servicio y configuración de Rsync
[53fba30]133# - SAMBASERV, SAMBACFGDIR - servicio y configuración de Samba
[297df16]134# - TFTPSERV, TFTPCFGDIR, SYSLINUXDIR - servicio y configuración de TFTP/PXE
[d168a46]135function autoConfigure()
136{
[44f6582]137# Detectar sistema operativo del servidor (compatible con fichero os-release y con LSB).
138if [ -f /etc/os-release ]; then
139        source /etc/os-release
[eb7b39d]140        OSDISTRIB="$ID"
[5cc52295]141        OSVERSION="$VERSION_ID"
[44f6582]142else
143        OSDISTRIB=$(lsb_release -is 2>/dev/null)
[5cc52295]144        OSVERSION=$(lsb_release -rs 2>/dev/null)
[44f6582]145fi
[5cc52295]146# Convertir distribución a minúsculas y obtener solo el 1er número de versión.
[eb7b39d]147OSDISTRIB="${OSDISTRIB,,}"
[5cc52295]148OSVERSION="${OSVERSION%%.*}"
[d168a46]149
[eb7b39d]150# Configuración según la distribución GNU/Linux (usar minúsculas).
[d168a46]151case "$OSDISTRIB" in
[eb7b39d]152        ubuntu|debian|linuxmint)
[c49ef02]153                DEPENDENCIES=( subversion apache2 php5 php5-ldap libapache2-mod-php5 mysql-server php5-mysql isc-dhcp-server bittorrent tftp-hpa tftpd-hpa syslinux xinetd build-essential g++-multilib libmysqlclient15-dev wget doxygen graphviz bittornado ctorrent samba rsync unzip netpipes debootstrap schroot squashfs-tools btrfs-tools procps arp-scan )
[d168a46]154                UPDATEPKGLIST="apt-get update"
155                INSTALLPKG="apt-get -y install --force-yes"
156                CHECKPKG="dpkg -s \$package 2>/dev/null | grep Status | grep -qw install"
[53fba30]157                if which service &>/dev/null; then
[7ba85a4]158                        STARTSERVICE="eval service \$service restart"
[109e8b2]159                        STOPSERVICE="eval service \$service stop"
[53fba30]160                else
[7ba85a4]161                        STARTSERVICE="eval /etc/init.d/\$service restart"
[109e8b2]162                        STOPSERVICE="eval /etc/init.d/\$service stop"
[53fba30]163                fi
[7ba85a4]164                ENABLESERVICE="eval update-rc.d \$service defaults"
[109e8b2]165                DISABLESERVICE="eval update-rc.d \$service disable"
[53fba30]166                APACHESERV=apache2
[d168a46]167                APACHECFGDIR=/etc/apache2
[643ca8c]168                APACHESITESDIR=sites-available
[53fba30]169                APACHEOGSITE=opengnsys
[d168a46]170                APACHEUSER="www-data"
171                APACHEGROUP="www-data"
[7ba85a4]172                APACHESSLMOD="a2enmod ssl"
[7829e4e]173                APACHEREWRITEMOD="a2enmod rewrite"
[7ba85a4]174                APACHEENABLESSL="a2ensite default-ssl"
[53fba30]175                APACHEENABLEOG="a2ensite $APACHEOGSITE"
[643ca8c]176                APACHEMAKECERT="make-ssl-cert generate-default-snakeoil --force-overwrite"
[53fba30]177                DHCPSERV=isc-dhcp-server
[83518d5]178                DHCPCFGDIR=/etc/dhcp
[f243a47]179                INETDSERV=xinetd
180                INETDCFGDIR=/etc/xinetd.d
[53fba30]181                MYSQLSERV=mysql
[0f8100d]182                MARIADBSERV=mariadb
[e70925a]183                RSYNCSERV=rsync
184                RSYNCCFGDIR=/etc
[53fba30]185                SAMBASERV=smbd
[d168a46]186                SAMBACFGDIR=/etc/samba
[297df16]187                SYSLINUXDIR=/usr/lib/syslinux
[d168a46]188                TFTPCFGDIR=/var/lib/tftpboot
189                ;;
[eb7b39d]190        fedora|centos)
191                DEPENDENCIES=( subversion httpd mod_ssl php php-ldap mysql-server mysql-devel mysql-devel.i686 php-mysql dhcp tftp-server tftp syslinux xinetd binutils gcc gcc-c++ glibc-devel glibc-devel.i686 glibc-static glibc-static.i686 libstdc++ libstdc++.i686 libstdc++-devel.i686 make wget doxygen graphviz ctorrent samba samba-client rsync unzip debootstrap schroot squashfs-tools python-crypto arp-scan )
[109e8b2]192                INSTALLEXTRADEPS=( 'rpm -Uv ftp://ftp.altlinux.org/pub/distributions/ALTLinux/5.1/branch/files/i586/RPMS/netpipes-4.2-alt1.i586.rpm'
[b8969db]193                                   'pushd /tmp; wget -t3 http://download.bittornado.com/download/BitTornado-0.3.18.tar.gz && tar xvzf BitTornado-0.3.18.tar.gz && cd BitTornado-CVS && python setup.py install && ln -fs btlaunchmany.py /usr/bin/btlaunchmany && ln -fs bttrack.py /usr/bin/bttrack; popd' )
[eb7b39d]194                if [ "$OSDISTRIB" == "centos" ]; then
[03cfd6e]195                        UPDATEPKGLIST='test rpm -q --quiet epel-release || echo -e "[epel]\nname=EPEL temporal\nmirrorlist=https://mirrors.fedoraproject.org/metalink?repo=epel-\$releasever&arch=\$basearch\nenabled=1\ngpgcheck=0" >/etc/yum.repos.d/epel.repo'
196                fi
[d168a46]197                INSTALLPKG="yum install -y"
[c79a2b3]198                CHECKPKG="rpm -q --quiet \$package"
[03cfd6e]199                SYSTEMD=$(which systemctl 2>/dev/null)
200                if [ -n "$SYSTEMD" ]; then
201                        STARTSERVICE="eval systemctl start \$service.service"
202                        STOPSERVICE="eval systemctl stop \$service.service"
203                        ENABLESERVICE="eval systemctl enable \$service.service"
204                        DISABLESERVICE="eval systemctl disable \$service.service"
205                else
206                        STARTSERVICE="eval service \$service start"
207                        STOPSERVICE="eval service \$service stop"
208                        ENABLESERVICE="eval chkconfig \$service on"
209                        DISABLESERVICE="eval chkconfig \$service off"
210                fi
[53fba30]211                APACHESERV=httpd
[d168a46]212                APACHECFGDIR=/etc/httpd/conf.d
[53fba30]213                APACHEOGSITE=opengnsys.conf
[d168a46]214                APACHEUSER="apache"
215                APACHEGROUP="apache"
[53fba30]216                DHCPSERV=dhcpd
[d168a46]217                DHCPCFGDIR=/etc/dhcp
[09ac3b8]218                if firewall-cmd --state &>/dev/null; then
219                        FIREWALLSERV=firewalld
220                else
221                        FIREWALLSERV=iptables
222                fi
[53fba30]223                INETDSERV=xinetd
[f243a47]224                INETDCFGDIR=/etc/xinetd.d
[53fba30]225                MYSQLSERV=mysqld
[0f8100d]226                MARIADBSERV=mariadb
[e70925a]227                RSYNCSERV=rsync
228                RSYNCCFGDIR=/etc
[53fba30]229                SAMBASERV=smb
[d168a46]230                SAMBACFGDIR=/etc/samba
[297df16]231                SYSLINUXDIR=/usr/share/syslinux
[53fba30]232                TFTPSERV=tftp
[d168a46]233                TFTPCFGDIR=/var/lib/tftpboot
234                ;;
235        "")     echo "ERROR: Unknown Linux distribution, please install \"lsb_release\" command."
236                exit 1 ;;
237        *)      echo "ERROR: Distribution not supported by OpenGnSys."
238                exit 1 ;;
239esac
[09bf701]240
241# Fichero de credenciales de acceso a MySQL.
242TMPMYCNF=/tmp/.my.cnf.$$
[d168a46]243}
244
[09ac3b8]245
[ff6c349]246# Modificar variables de configuración tras instalar paquetes del sistema.
247function autoConfigurePost()
248{
[09ac3b8]249local f
250
[44f6582]251# Configuraciones específicas para Samba y TFTP en Debian 6.
252[ -z "$SYSTEMD" -a ! -e /etc/init.d/$SAMBASERV ] && SAMBASERV=samba
253[ ! -e $TFTPCFGDIR ] && TFTPCFGDIR=/srv/tftp
254
[09ac3b8]255# Configuraciones específicas para SELinux permisivo en distintas versiones.
[44f6582]256[ -f /selinux/enforce ] && echo 0 > /selinux/enforce
[e5f9c147]257for f in /etc/sysconfig/selinux /etc/selinux/config; do
[4fdf2b1]258        [ -f $f ] && perl -pi -e 's/SELINUX=enforcing/SELINUX=permissive/g' $f
[09ac3b8]259done
260selinuxenabled 2>/dev/null && setenforce 0 2>/dev/null
[ff6c349]261}
262
263
[83518d5]264# Cargar lista de paquetes del sistema y actualizar algunas variables de configuración
265# dependiendo de la versión instalada.
266function updatePackageList()
267{
268local DHCPVERSION
269
270# Si es necesario, actualizar la lista de paquetes disponibles.
271[ -n "$UPDATEPKGLIST" ] && eval $UPDATEPKGLIST
272
273# Configuración personallizada de algunos paquetes.
274case "$OSDISTRIB" in
[eb7b39d]275        ubuntu|linuxmint)       # Postconfiguación personalizada para Ubuntu.
[83518d5]276                # Configuración para DHCP v3.
[e4b1572]277                DHCPVERSION=$(apt-cache show $(apt-cache pkgnames|egrep "dhcp.?-server$") | \
[83518d5]278                              awk '/Version/ {print substr($2,1,1);}' | \
279                              sort -n | tail -1)
280                if [ $DHCPVERSION = 3 ]; then
[e4b1572]281                        DEPENDENCIES=( ${DEPENDENCIES[@]/isc-dhcp-server/dhcp3-server} )
[53fba30]282                        DHCPSERV=dhcp3-server
[83518d5]283                        DHCPCFGDIR=/etc/dhcp3
284                fi
285                ;;
[eb7b39d]286        centos) # Postconfiguación personalizada para CentOS.
[c525453]287                # Incluir repositorio de paquetes EPEL y paquetes específicos.
288                DEPENDENCIES=( ${DEPENDENCIES[@]} epel-release procps )
[2c8b9ed]289                # Cambios a aplicar a partir de CentOS 7.
290                if [ $OSVERSION -ge 7 ]; then
291                        # Sustituir MySQL por MariaDB.
292                        DEPENDENCIES=( ${DEPENDENCIES[*]/mysql-/mariadb-} )
293                        # Instalar arp-scan de CentOS 6 (no disponible en CentOS 7).
294                        DEPENDENCIES=( ${DEPENDENCIES[*]/arp-scan/http://dag.wieers.com/redhat/el6/en/$(arch)/dag/RPMS/arp-scan-1.9-1.el6.rf.$(arch).rpm} )
295                fi
[c525453]296                ;;
[eb7b39d]297        fedora) # Postconfiguación personalizada para Fedora.
[c525453]298                # Incluir paquetes específicos.
299                DEPENDENCIES=( ${DEPENDENCIES[@]} libstdc++-static.i686 btrfs-progs procps-ng )
[5cc52295]300                # Sustituir MySQL por MariaDB a partir de Fedora 20.
301                [ $OSVERSION -ge 20 ] && DEPENDENCIES=( ${DEPENDENCIES[*]/mysql-/mariadb-} )
[c79a2b3]302                ;;
[83518d5]303esac
304}
305
[d168a46]306
307#####################################################################
[a01156a]308####### Algunas funciones útiles de propósito general:
309#####################################################################
[d168a46]310
[13a01a7]311function getDateTime()
[a01156a]312{
[d168a46]313        date "+%Y%m%d-%H%M%S"
[a01156a]314}
315
316# Escribe a fichero y muestra por pantalla
[13a01a7]317function echoAndLog()
[a01156a]318{
[d168a46]319        local DATETIME=`getDateTime`
[87c7b02]320        echo "$1"
[d168a46]321        echo "$DATETIME;$SSH_CLIENT;$1" >> $LOG_FILE
[a01156a]322}
323
[87c7b02]324# Escribe a fichero y muestra mensaje de error
[13a01a7]325function errorAndLog()
[a01156a]326{
[d168a46]327        local DATETIME=`getDateTime`
[87c7b02]328        echo "ERROR: $1"
[d168a46]329        echo "$DATETIME;$SSH_CLIENT;ERROR: $1" >> $LOG_FILE
[a01156a]330}
331
[346eaee]332# Escribe a fichero y muestra mensaje de aviso
333function warningAndLog()
334{
335        local DATETIME=`getDateTime`
[cd86637]336        echo "Warning: $1"
[346eaee]337        echo "$DATETIME;$SSH_CLIENT;Warning: $1" >> $LOG_FILE
338}
339
[87c7b02]340# Comprueba si el elemento pasado en $2 está en el array $1
[13a01a7]341function isInArray()
[a01156a]342{
343        if [ $# -ne 2 ]; then
[13a01a7]344                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]345                exit 1
346        fi
347
348        local deps
[87c7b02]349        local is_in_array=1
350        local element="$2"
351
352        echoAndLog "${FUNCNAME}(): checking if $2 is in $1"
[5c33840]353        eval "deps=( \"\${$1[@]}\" )"
[a01156a]354
[87c7b02]355        # Copia local del array del parámetro 1.
356        for (( i = 0 ; i < ${#deps[@]} ; i++ )); do
357                if [ "${deps[$i]}" = "${element}" ]; then
358                        echoAndLog "isInArray(): $element found in array"
[a01156a]359                        is_in_array=0
360                fi
361        done
362
363        if [ $is_in_array -ne 0 ]; then
[87c7b02]364                echoAndLog "${FUNCNAME}(): $element NOT found in array"
[a01156a]365        fi
366
367        return $is_in_array
368}
369
[87c7b02]370
[a01156a]371#####################################################################
372####### Funciones de manejo de paquetes Debian
373#####################################################################
374
[13a01a7]375function checkPackage()
[a01156a]376{
377        package=$1
378        if [ -z $package ]; then
[73cfa0a]379                errorAndLog "${FUNCNAME}(): parameter required"
[a01156a]380                exit 1
381        fi
[73cfa0a]382        echoAndLog "${FUNCNAME}(): checking if package $package exists"
[d168a46]383        eval $CHECKPKG
[a01156a]384        if [ $? -eq 0 ]; then
[73cfa0a]385                echoAndLog "${FUNCNAME}(): package $package exists"
[a01156a]386                return 0
387        else
[73cfa0a]388                echoAndLog "${FUNCNAME}(): package $package doesn't exists"
[a01156a]389                return 1
390        fi
391}
392
[87c7b02]393# Recibe array con dependencias
[a01156a]394# por referencia deja un array con las dependencias no resueltas
395# devuelve 1 si hay alguna dependencia no resuelta
[13a01a7]396function checkDependencies()
[a01156a]397{
398        if [ $# -ne 2 ]; then
[73cfa0a]399                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]400                exit 1
401        fi
402
[73cfa0a]403        echoAndLog "${FUNCNAME}(): checking dependences"
[a01156a]404        uncompletedeps=0
405
406        # copia local del array del parametro 1
407        local deps
[5c33840]408        eval "deps=( \"\${$1[@]}\" )"
[a01156a]409
410        declare -a local_notinstalled
[5c33840]411
[a01156a]412        for (( i = 0 ; i < ${#deps[@]} ; i++ ))
413        do
414                checkPackage ${deps[$i]}
415                if [ $? -ne 0 ]; then
416                        local_notinstalled[$uncompletedeps]=$package
417                        let uncompletedeps=uncompletedeps+1
418                fi
419        done
420
421        # relleno el array especificado en $2 por referencia
422        for (( i = 0 ; i < ${#local_notinstalled[@]} ; i++ ))
423        do
424                eval "${2}[$i]=${local_notinstalled[$i]}"
425        done
426
427        # retorna el numero de paquetes no resueltos
[73cfa0a]428        echoAndLog "${FUNCNAME}(): dependencies uncompleted: $uncompletedeps"
[a01156a]429        return $uncompletedeps
430}
431
432# Recibe un array con las dependencias y lo instala
[13a01a7]433function installDependencies()
[a01156a]434{
435        if [ $# -ne 1 ]; then
[813f617]436                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]437                exit 1
438        fi
[813f617]439        echoAndLog "${FUNCNAME}(): installing uncompleted dependencies"
[a01156a]440
441        # copia local del array del parametro 1
442        local deps
[5c33840]443        eval "deps=( \"\${$1[@]}\" )"
[a01156a]444
445        local string_deps=""
446        for (( i = 0 ; i < ${#deps[@]} ; i++ ))
447        do
448                string_deps="$string_deps ${deps[$i]}"
449        done
450
451        if [ -z "${string_deps}" ]; then
[813f617]452                errorAndLog "${FUNCNAME}(): array of dependeces is empty"
[a01156a]453                exit 1
454        fi
455
[c79a2b3]456        OLD_DEBIAN_FRONTEND=$DEBIAN_FRONTEND            # Debian/Ubuntu
[a01156a]457        export DEBIAN_FRONTEND=noninteractive
458
[d168a46]459        echoAndLog "${FUNCNAME}(): now $string_deps will be installed"
460        eval $INSTALLPKG $string_deps
[a01156a]461        if [ $? -ne 0 ]; then
[813f617]462                errorAndLog "${FUNCNAME}(): error installing dependencies"
[a01156a]463                return 1
464        fi
465
[c79a2b3]466        DEBIAN_FRONTEND=$OLD_DEBIAN_FRONTEND            # Debian/Ubuntu
[8244351]467        test grep -q "EPEL temporal" /etc/yum.repos.d/epel.repo 2>/dev/null ] || mv -f /etc/yum.repos.d/epel.repo.rpmnew /etc/yum.repos.d/epel.repo 2>/dev/null # CentOS/RedHat EPEL
[c79a2b3]468
[813f617]469        echoAndLog "${FUNCNAME}(): dependencies installed"
[a01156a]470}
471
[13a01a7]472# Hace un backup del fichero pasado por parámetro
473# deja un -last y uno para el día
474function backupFile()
475{
476        if [ $# -ne 1 ]; then
477                errorAndLog "${FUNCNAME}(): invalid number of parameters"
478                exit 1
479        fi
480
[d168a46]481        local file="$1"
482        local dateymd=`date +%Y%m%d`
[13a01a7]483
[d168a46]484        if [ ! -f "$file" ]; then
[346eaee]485                warningAndLog "${FUNCNAME}(): file $file doesn't exists"
[13a01a7]486                return 1
487        fi
488
[d168a46]489        echoAndLog "${FUNCNAME}(): making $file backup"
[13a01a7]490
491        # realiza una copia de la última configuración como last
[d168a46]492        cp -a "$file" "${file}-LAST"
[13a01a7]493
494        # si para el día no hay backup lo hace, sino no
[d168a46]495        if [ ! -f "${file}-${dateymd}" ]; then
496                cp -a "$file" "${file}-${dateymd}"
[13a01a7]497        fi
498
[d168a46]499        echoAndLog "${FUNCNAME}(): $file backup success"
[13a01a7]500}
501
[a01156a]502#####################################################################
503####### Funciones para el manejo de bases de datos
504#####################################################################
505
506# This function set password to root
[13a01a7]507function mysqlSetRootPassword()
[a01156a]508{
509        if [ $# -ne 1 ]; then
[813f617]510                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]511                exit 1
512        fi
513
[e0edc14]514        local root_mysql="$1"
[813f617]515        echoAndLog "${FUNCNAME}(): setting root password in MySQL server"
[e0edc14]516        mysqladmin -u root password "$root_mysql"
[a01156a]517        if [ $? -ne 0 ]; then
[813f617]518                errorAndLog "${FUNCNAME}(): error while setting root password in MySQL server"
[a01156a]519                return 1
520        fi
[813f617]521        echoAndLog "${FUNCNAME}(): root password saved!"
[a01156a]522        return 0
523}
524
[892606b9]525# Si el servicio mysql esta ya instalado cambia la variable de la clave del root por la ya existente
[e0edc14]526function mysqlGetRootPassword()
527{
[892606b9]528        local pass_mysql
529        local pass_mysql2
[7c54b49]530        # Comprobar si MySQL está instalado con la clave de root por defecto.
531        if mysql -u root -p"$MYSQL_ROOT_PASSWORD" <<<"quit" 2>/dev/null; then
532                echoAndLog "${FUNCNAME}(): Using default mysql root password."
533        else
534                stty -echo
[e0edc14]535                echo "There is a MySQL service already installed."
536                read -p "Enter MySQL root password: " pass_mysql
[7c54b49]537                echo ""
[e0edc14]538                read -p "Confrim password:" pass_mysql2
[7c54b49]539                echo ""
540                stty echo
541                if [ "$pass_mysql" == "$pass_mysql2" ] ;then
[e0edc14]542                        MYSQL_ROOT_PASSWORD="$pass_mysql"
[7c54b49]543                        return 0
544                else
[e0edc14]545                        echo "The keys don't match. Do not configure the server's key,"
546                        echo "transactions in the database will give error."
[7c54b49]547                        return 1
548                fi
[892606b9]549        fi
550}
551
[a01156a]552# comprueba si puede conectar con mysql con el usuario root
553function mysqlTestConnection()
554{
555        if [ $# -ne 1 ]; then
[e0edc14]556                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]557                exit 1
558        fi
559
[09bf701]560        local root_password="$1"
[e0edc14]561        echoAndLog "${FUNCNAME}(): checking connection to mysql..."
[09bf701]562        # Componer fichero con credenciales de conexión a MySQL.
563        touch $TMPMYCNF
564        chmod 600 $TMPMYCNF
565        cat << EOT > $TMPMYCNF
[c073224]566[client]
[09bf701]567user=root
568password=$root_password
569EOT
570        # Borrar el fichero temporal si termina el proceso de instalación.
571        trap "rm -f $TMPMYCNF" 0 1 2 3 6 9 15
572        # Comprobar conexión a MySQL.
573        echo "" | mysql --defaults-extra-file=$TMPMYCNF
[a01156a]574        if [ $? -ne 0 ]; then
[e0edc14]575                errorAndLog "${FUNCNAME}(): connection to mysql failed, check root password and if daemon is running!"
[a01156a]576                return 1
577        else
[e0edc14]578                echoAndLog "${FUNCNAME}(): connection success"
[a01156a]579                return 0
580        fi
581}
582
583# comprueba si la base de datos existe
584function mysqlDbExists()
585{
[09bf701]586        if [ $# -ne 1 ]; then
[e0edc14]587                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]588                exit 1
589        fi
590
[09bf701]591        local database="$1"
[e0edc14]592        echoAndLog "${FUNCNAME}(): checking if $database exists..."
[09bf701]593        echo "show databases" | mysql --defaults-extra-file=$TMPMYCNF | grep "^${database}$"
[a01156a]594        if [ $? -ne 0 ]; then
[e0edc14]595                echoAndLog "${FUNCNAME}():database $database doesn't exists"
[a01156a]596                return 1
597        else
[e0edc14]598                echoAndLog "${FUNCNAME}():database $database exists"
[a01156a]599                return 0
600        fi
601}
602
[0a735488]603# Comprueba si la base de datos está vacía.
[a01156a]604function mysqlCheckDbIsEmpty()
605{
[09bf701]606        if [ $# -ne 1 ]; then
[e0edc14]607                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]608                exit 1
609        fi
610
[09bf701]611        local database="$1"
[e0edc14]612        echoAndLog "${FUNCNAME}(): checking if $database is empty..."
[09bf701]613        num_tablas=`echo "show tables" | mysql --defaults-extra-file=$TMPMYCNF "${database}" | wc -l`
[a01156a]614        if [ $? -ne 0 ]; then
[e0edc14]615                errorAndLog "${FUNCNAME}(): error executing query, check database and root password"
[a01156a]616                exit 1
617        fi
618
619        if [ $num_tablas -eq 0 ]; then
[e0edc14]620                echoAndLog "${FUNCNAME}():database $database is empty"
[a01156a]621                return 0
622        else
[e0edc14]623                echoAndLog "${FUNCNAME}():database $database has tables"
[a01156a]624                return 1
625        fi
626
627}
628
[0a735488]629# Importa un fichero SQL en la base de datos.
630# Parámetros:
631# - 1: nombre de la BD.
632# - 2: fichero a importar.
633# Nota: el fichero SQL puede contener las siguientes palabras reservadas:
634# - SERVERIP: se sustituye por la dirección IP del servidor.
635# - DBUSER: se sustituye por usuario de conexión a la BD definido en este script.
636# - DBPASSWD: se sustituye por la clave de conexión a la BD definida en este script.
[a01156a]637function mysqlImportSqlFileToDb()
638{
[09bf701]639        if [ $# -ne 2 ]; then
[c5ce04c]640                errorAndLog "${FNCNAME}(): invalid number of parameters"
[a01156a]641                exit 1
642        fi
643
[09bf701]644        local database="$1"
645        local sqlfile="$2"
[c4321ae]646        local tmpfile=$(mktemp)
[d168a46]647        local i=0
648        local dev=""
[c4321ae]649        local status
[7829e4e]650        # Clave aleatoria para acceso a la API REST.
651        local OPENGNSYS_APIKEY=$(php -r 'echo md5(uniqid(rand(), true));')
[a01156a]652
653        if [ ! -f $sqlfile ]; then
[c5ce04c]654                errorAndLog "${FUNCNAME}(): Unable to locate $sqlfile!!"
[a01156a]655                return 1
656        fi
657
[d168a46]658        echoAndLog "${FUNCNAME}(): importing SQL file to ${database}..."
[c4321ae]659        chmod 600 $tmpfile
[d168a46]660        for dev in ${DEVICE[*]}; do
[73a1bd6]661                if [ "${DEVICE[i]}" == "$DEFAULTDEV" ]; then
[d168a46]662                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
663                            -e "s/DBUSER/$OPENGNSYS_DB_USER/g" \
664                            -e "s/DBPASSWORD/$OPENGNSYS_DB_PASSWD/g" \
[7829e4e]665                            -e "s/APIKEY/$OPENGNSYS_APIKEY/g" \
[d168a46]666                                $sqlfile > $tmpfile
667                fi
668                let i++
669        done
[09bf701]670        mysql --defaults-extra-file=$TMPMYCNF --default-character-set=utf8 "${database}" < $tmpfile
[c4321ae]671        status=$?
672        rm -f $tmpfile
673        if [ $status -ne 0 ]; then
[c5ce04c]674                errorAndLog "${FUNCNAME}(): error while importing $sqlfile in database $database"
[a01156a]675                return 1
676        fi
[c5ce04c]677        echoAndLog "${FUNCNAME}(): file imported to database $database"
[a01156a]678        return 0
679}
680
681# Crea la base de datos
682function mysqlCreateDb()
683{
[09bf701]684        if [ $# -ne 1 ]; then
[a555f49]685                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]686                exit 1
687        fi
688
[09bf701]689        local database="$1"
[a01156a]690
[a555f49]691        echoAndLog "${FUNCNAME}(): creating database..."
[09bf701]692        mysqladmin --defaults-extra-file=$TMPMYCNF create $database
[a01156a]693        if [ $? -ne 0 ]; then
[a555f49]694                errorAndLog "${FUNCNAME}(): error while creating database $database"
[a01156a]695                return 1
696        fi
[a555f49]697        echoAndLog "${FUNCNAME}(): database $database created"
[a01156a]698        return 0
699}
700
[0a735488]701# Comprueba si ya está definido el usuario de acceso a la BD.
[a01156a]702function mysqlCheckUserExists()
703{
[09bf701]704        if [ $# -ne 1 ]; then
[e0edc14]705                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]706                exit 1
707        fi
708
[09bf701]709        local userdb="$1"
[a01156a]710
[e0edc14]711        echoAndLog "${FUNCNAME}(): checking if $userdb exists..."
[09bf701]712        echo "select user from user where user='${userdb}'\\G" |mysql --defaults-extra-file=$TMPMYCNF mysql | grep user
[a01156a]713        if [ $? -ne 0 ]; then
[e0edc14]714                echoAndLog "${FUNCNAME}(): user doesn't exists"
[a01156a]715                return 1
716        else
[e0edc14]717                echoAndLog "${FUNCNAME}(): user already exists"
[a01156a]718                return 0
719        fi
720
721}
722
723# Crea un usuario administrativo para la base de datos
724function mysqlCreateAdminUserToDb()
725{
[09bf701]726        if [ $# -ne 3 ]; then
[e0edc14]727                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]728                exit 1
729        fi
730
[09bf701]731        local database="$1"
732        local userdb="$2"
733        local passdb="$3"
[a01156a]734
[e0edc14]735        echoAndLog "${FUNCNAME}(): creating admin user ${userdb} to database ${database}"
[a01156a]736
737        cat > $WORKDIR/create_${database}.sql <<EOF
738GRANT USAGE ON *.* TO '${userdb}'@'localhost' IDENTIFIED BY '${passdb}' ;
739GRANT ALL PRIVILEGES ON ${database}.* TO '${userdb}'@'localhost' WITH GRANT OPTION ;
740FLUSH PRIVILEGES ;
741EOF
[09bf701]742        mysql --defaults-extra-file=$TMPMYCNF < $WORKDIR/create_${database}.sql
[a01156a]743        if [ $? -ne 0 ]; then
[e0edc14]744                errorAndLog "${FUNCNAME}(): error while creating user in mysql"
[a01156a]745                rm -f $WORKDIR/create_${database}.sql
746                return 1
747        else
[e0edc14]748                echoAndLog "${FUNCNAME}(): user created ok"
[a01156a]749                rm -f $WORKDIR/create_${database}.sql
750                return 0
751        fi
752}
753
754
755#####################################################################
756####### Funciones para el manejo de Subversion
757#####################################################################
758
[0a735488]759# Obtiene el código fuente del proyecto desde el servidor SVN.
[13a01a7]760function svnExportCode()
761{
762        if [ $# -ne 1 ]; then
763                errorAndLog "${FUNCNAME}(): invalid number of parameters"
764                exit 1
765        fi
766
[6090a2d]767        local url="$1"
[13a01a7]768
769        echoAndLog "${FUNCNAME}(): downloading subversion code..."
770
[6090a2d]771        svn export --force "$url" opengnsys
[13a01a7]772        if [ $? -ne 0 ]; then
[6090a2d]773                errorAndLog "${FUNCNAME}(): error getting OpenGnSys code from $url"
[13a01a7]774                return 1
775        fi
776        echoAndLog "${FUNCNAME}(): subversion code downloaded"
777        return 0
778}
779
780
[892606b9]781############################################################
[7586ca3]782###  Detectar red
783############################################################
784
[07c3a59]785# Comprobar si existe conexión.
786function checkNetworkConnection()
787{
[09ac3b8]788        echoAndLog "${FUNCNAME}(): Disabling Firewall: $FIREWALLSERV."
789        if [ -n "$FIREWALLSERV" ]; then
790                service=$FIREWALLSERV
[b83843c]791                $STOPSERVICE; $DISABLESERVICE
792        fi
[109e8b2]793
794        echoAndLog "${FUNCNAME}(): Checking OpenGnSys server conectivity."
[07c3a59]795        OPENGNSYS_SERVER=${OPENGNSYS_SERVER:-"www.opengnsys.es"}
[225e859]796        if which wget &>/dev/null; then
797                wget --spider -q $OPENGNSYS_SERVER
798        elif which curl &>/dev/null; then
799                curl --connect-timeout 10 -s $OPENGNSYS_SERVER -o /dev/null
800        else
801                echoAndLog "${FUNCNAME}(): Cannot execute \"wget\" nor \"curl\"."
802                return 1
803        fi
[07c3a59]804}
805
806# Obtener los parámetros de red de la interfaz por defecto.
[7586ca3]807function getNetworkSettings()
808{
[d168a46]809        # Arrays globales definidas:
810        # - DEVICE:     nombres de dispositivos de red activos.
811        # - SERVERIP:   IPs locales del servidor.
812        # - NETIP:      IPs de redes.
813        # - NETMASK:    máscaras de red.
814        # - NETBROAD:   IPs de difusión de redes.
815        # - ROUTERIP:   IPs de routers.
816        # Otras variables globales:
817        # - DEFAULTDEV: dispositivo de red por defecto.
818        # - DNSIP:      IP del servidor DNS principal.
819
820        local i=0
821        local dev=""
822
[109e8b2]823        echoAndLog "${FUNCNAME}(): Detecting network parameters."
[d168a46]824        DEVICE=( $(ip -o link show up | awk '!/loopback/ {sub(/:.*/,"",$2); print $2}') )
825        if [ -z "$DEVICE" ]; then
826                errorAndLog "${FUNCNAME}(): Network devices not detected."
[62e3bcf]827                exit 1
828        fi
[d168a46]829        for dev in ${DEVICE[*]}; do
830                SERVERIP[i]=$(ip -o addr show dev $dev | awk '$3~/inet$/ {sub (/\/.*/, ""); print ($4)}')
831                if [ -n "${SERVERIP[i]}" ]; then
[03cfd6e]832                        NETMASK[i]=$(LANG=C ifconfig $dev | \
833                                                awk '/Mask/ {sub(/.*:/,"",$4); print $4}
834                                                     /netmask/ {print $4}')
[d168a46]835                        NETBROAD[i]=$(ip -o addr show dev $dev | awk '$3~/inet$/ {print ($6)}')
[826d576]836                        NETIP[i]=$(ip route | awk -v d="$dev" '$3==d && /src/ {sub (/\/.*/,""); print $1}')
837                        ROUTERIP[i]=$(ip route | awk -v d="$dev" '$1=="default" && $5==d {print $3}')
[d168a46]838                        DEFAULTDEV=${DEFAULTDEV:-"$dev"}
839                fi
[ce85ae8]840                let i++
[d168a46]841        done
[a555f49]842        DNSIP=$(awk '/nameserver/ {print $2}' /etc/resolv.conf | head -n1)
[03cfd6e]843        if [ -z "${NETIP[*]}" -o -z "${NETMASK[*]}" ]; then
[62e3bcf]844                errorAndLog "${FUNCNAME}(): Network not detected."
[7586ca3]845                exit 1
846        fi
[cc7eab7]847
848        # Variables de ejecución de Apache
849        # - APACHE_RUN_USER
850        # - APACHE_RUN_GROUP
[d168a46]851        if [ -f $APACHECFGDIR/envvars ]; then
852                source $APACHECFGDIR/envvars
[cc7eab7]853        fi
[d168a46]854        APACHE_RUN_USER=${APACHE_RUN_USER:-"$APACHEUSER"}
855        APACHE_RUN_GROUP=${APACHE_RUN_GROUP:-"$APACHEGROUP"}
[73a1bd6]856
857        echoAndLog "${FUNCNAME}(): Default network device: $DEFAULTDEV."
[7586ca3]858}
859
860
861############################################################
[892606b9]862### Esqueleto para el Servicio pxe y contenedor tftpboot ###
863############################################################
864
[e0edc14]865function tftpConfigure()
866{
[109e8b2]867        echoAndLog "${FUNCNAME}(): Configuring TFTP service."
868        # Habilitar TFTP y reiniciar Inetd.
[8244351]869        if [ -n "$TFTPSERV" ]; then
[584b103]870                if [ -f $INETDCFGDIR/$TFTPSERV ]; then
871                        perl -pi -e 's/disable.*/disable = no/' $INETDCFGDIR/$TFTPSERV
872                else
873                        service=$TFTPSERV
[b8969db]874                        $ENABLESERVICE; $STARTSERVICE
[584b103]875                fi
[8244351]876        fi
[53fba30]877        service=$INETDSERV
878        $ENABLESERVICE; $STARTSERVICE
[892606b9]879
[beaebf8]880        # Copiar ficheros de Syslinux.
[297df16]881        cp -a $SYSLINUXDIR $TFTPCFGDIR/syslinux
[beaebf8]882
[297df16]883        # comprobamos el servicio tftp
884        sleep 1
885        testPxe
[892606b9]886}
887
[0a735488]888# Comprueba que haya conexión al servicio TFTP/PXE.
[e0edc14]889function testPxe ()
890{
[297df16]891        echoAndLog "${FUNCNAME}(): Checking TFTP service... please wait."
[beaebf8]892        echo "test" >$TFTPCFGDIR/testpxe
893        tftp -v 127.0.0.1 -c get testpxe /tmp/testpxe && echoAndLog "TFTP service is OK." || errorAndLog "TFTP service is down."
894        rm -f $TFTPCFGDIR/testpxe /tmp/testpxe
[e4b1572]895}
896
897
898########################################################################
[813f617]899## Configuracion servicio Samba
[8fc9552]900########################################################################
[e4b1572]901
902# Configurar servicios Samba.
[8fc9552]903function smbConfigure()
904{
[e0edc14]905        echoAndLog "${FUNCNAME}(): Configuring Samba service."
[8fc9552]906
[d168a46]907        backupFile $SAMBACFGDIR/smb.conf
[8fc9552]908       
[813f617]909        # Copiar plantailla de recursos para OpenGnSys
[c1e00e4]910        sed -e "s/OPENGNSYSDIR/${INSTALL_TARGET//\//\\/}/g" \
[d168a46]911                $WORKDIR/opengnsys/server/etc/smb-og.conf.tmpl > $SAMBACFGDIR/smb-og.conf
[813f617]912        # Configurar y recargar Samba"
[6addf73]913        perl -pi -e "s/WORKGROUP/OPENGNSYS/; s/server string \=.*/server string \= OpenGnSys Samba Server/" $SAMBACFGDIR/smb.conf
[03cfd6e]914        if ! grep -q "smb-og" $SAMBACFGDIR/smb.conf; then
915                echo "include = $SAMBACFGDIR/smb-og.conf" >> $SAMBACFGDIR/smb.conf
916        fi
[53fba30]917        service=$SAMBASERV
918        $ENABLESERVICE; $STARTSERVICE
[8fc9552]919        if [ $? -ne 0 ]; then
[813f617]920                errorAndLog "${FUNCNAME}(): error while configure Samba"
[8fc9552]921                return 1
922        fi
[eb9424f]923        # Crear clave para usuario de acceso a los recursos.
[813f617]924        echo -ne "$OPENGNSYS_CLIENT_PASSWD\n$OPENGNSYS_CLIENT_PASSWD\n" | smbpasswd -a -s $OPENGNSYS_CLIENT_USER
[8fc9552]925
[813f617]926        echoAndLog "${FUNCNAME}(): Added Samba configuration."
[8fc9552]927        return 0
928}
929
930
[b6906f7]931########################################################################
[e70925a]932## Configuracion servicio Rsync
933########################################################################
934
935# Configurar servicio Rsync.
936function rsyncConfigure()
937{
938        echoAndLog "${FUNCNAME}(): Configuring Rsync service."
939
940        backupFile $RSYNCCFGDIR/rsyncd.conf
941
942        # Configurar acceso a Rsync.
943        sed -e "s/CLIENTUSER/$OPENGNSYS_CLIENT_USER/g" \
944                $WORKDIR/opengnsys/repoman/etc/rsyncd.conf.tmpl > $RSYNCCFGDIR/rsyncd.conf
945        sed -e "s/CLIENTUSER/$OPENGNSYS_CLIENT_USER/g" \
946            -e "s/CLIENTPASSWORD/$OPENGNSYS_CLIENT_PASSWD/g" \
947                $WORKDIR/opengnsys/repoman/etc/rsyncd.secrets.tmpl > $RSYNCCFGDIR/rsyncd.secrets
948        chown root.root $RSYNCCFGDIR/rsyncd.secrets
949        chmod 600 $RSYNCCFGDIR/rsyncd.secrets
950
951        # Habilitar Rsync y reiniciar Inetd.
952        if [ -n "$RSYNCSERV" ]; then
[4666588]953                if [ -f /etc/default/rsync ]; then
954                        perl -pi -e 's/RSYNC_ENABLE=.*/RSYNC_ENABLE=inetd/' /etc/default/rsync
955                fi
[f243a47]956                if [ -f $INETDCFGDIR/rsync ]; then
957                        perl -pi -e 's/disable.*/disable = no/' $INETDCFGDIR/rsync
958                else
959                        cat << EOT > $INETDCFGDIR/rsync
960service rsync
961{
962        disable = no
963        socket_type = stream
964        wait = no
965        user = root
966        server = $(which rsync)
967        server_args = --daemon
968        log_on_failure += USERID
969        flags = IPv6
970}
971EOT
972                fi
[e70925a]973                service=$RSYNCSERV $ENABLESERVICE
974                service=$INETDSERV $STARTSERVICE
975        fi
976
977        echoAndLog "${FUNCNAME}(): Added Rsync configuration."
978        return 0
979}
980
981       
982########################################################################
[b6906f7]983## Configuracion servicio DHCP
984########################################################################
985
[e4b1572]986# Configurar servicios DHCP.
[7586ca3]987function dhcpConfigure()
988{
[836a7597]989        echoAndLog "${FUNCNAME}(): Sample DHCP configuration."
[a555f49]990
[d168a46]991        local errcode=0
992        local i=0
993        local dev=""
994
995        backupFile $DHCPCFGDIR/dhcpd.conf
996        for dev in ${DEVICE[*]}; do
[01a9904]997                if [ -n "${SERVERIP[i]}" ]; then
[d168a46]998                        backupFile $DHCPCFGDIR/dhcpd-$dev.conf
[e4b1572]999                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
1000                            -e "s/NETIP/${NETIP[i]}/g" \
1001                            -e "s/NETMASK/${NETMASK[i]}/g" \
1002                            -e "s/NETBROAD/${NETBROAD[i]}/g" \
1003                            -e "s/ROUTERIP/${ROUTERIP[i]}/g" \
[d168a46]1004                            -e "s/DNSIP/$DNSIP/g" \
1005                            $WORKDIR/opengnsys/server/etc/dhcpd.conf.tmpl > $DHCPCFGDIR/dhcpd-$dev.conf || errcode=1
1006                fi
1007                let i++
1008        done
1009        if [ $errcode -ne 0 ]; then
[b25fc47]1010                errorAndLog "${FUNCNAME}(): error while configuring DHCP server"
[a555f49]1011                return 1
1012        fi
[d168a46]1013        ln -f $DHCPCFGDIR/dhcpd-$DEFAULTDEV.conf $DHCPCFGDIR/dhcpd.conf
[53fba30]1014        service=$DHCPSERV
1015        $ENABLESERVICE; $STARTSERVICE
[d168a46]1016        echoAndLog "${FUNCNAME}(): Sample DHCP configured in \"$DHCPCFGDIR\"."
[a555f49]1017        return 0
[892606b9]1018}
1019
1020
[a01156a]1021#####################################################################
1022####### Funciones específicas de la instalación de Opengnsys
1023#####################################################################
1024
[49c6891]1025# Copiar ficheros del OpenGnSys Web Console.
[7586ca3]1026function installWebFiles()
1027{
[2b793a8]1028        local COMPATDIR f
[7829e4e]1029        local XAJAXFILE="xajax_0.5_standard.zip"
1030        local SLIMFILE="slim-2.6.1.zip"
[2b793a8]1031
[dce072b]1032        echoAndLog "${FUNCNAME}(): Installing web files..."
[2b793a8]1033        # Copiar ficheros.
1034        cp -a $WORKDIR/opengnsys/admin/WebConsole/* $INSTALL_TARGET/www   #*/ comentario para Doxygen.
[7586ca3]1035        if [ $? != 0 ]; then
[dce072b]1036                errorAndLog "${FUNCNAME}(): Error copying web files."
[7586ca3]1037                exit 1
1038        fi
1039        find $INSTALL_TARGET/www -name .svn -type d -exec rm -fr {} \; 2>/dev/null
[7829e4e]1040
1041        # Descomprimir librerías XAJAX y SLIM.
1042        unzip -o $WORKDIR/opengnsys/admin/$XAJAXFILE -d $INSTALL_TARGET/www/xajax
1043        unzip -o $WORKDIR/opengnsys/admin/$SLIMFILE -d $INSTALL_TARGET/www/rest
1044
[2b793a8]1045        # Compatibilidad con dispositivos móviles.
1046        COMPATDIR="$INSTALL_TARGET/www/principal"
1047        for f in acciones administracion aula aulas hardwares imagenes menus repositorios softwares; do
1048                sed 's/clickcontextualnodo/clicksupnodo/g' $COMPATDIR/$f.php > $COMPATDIR/$f.device.php
1049        done
1050        cp -a $COMPATDIR/imagenes.device.php $COMPATDIR/imagenes.device4.php
[7586ca3]1051        # Cambiar permisos para ficheros especiales.
[e6d22c6]1052        chown -R $APACHE_RUN_USER:$APACHE_RUN_GROUP $INSTALL_TARGET/www/images/{fotos,iconos}
[b7bd0df]1053        chown -R $APACHE_RUN_USER:$APACHE_RUN_GROUP $INSTALL_TARGET/www/tmp/
[2b793a8]1054
[dce072b]1055        echoAndLog "${FUNCNAME}(): Web files installed successfully."
[7586ca3]1056}
1057
1058# Configuración específica de Apache.
[73a1bd6]1059function installWebConsoleApacheConf()
[a01156a]1060{
1061        if [ $# -ne 2 ]; then
[dce072b]1062                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]1063                exit 1
1064        fi
1065
[f9e3393]1066        local path_opengnsys_base="$1"
1067        local path_apache2_confd="$2"
[30837bb]1068        local CONSOLEDIR=${path_opengnsys_base}/www
[a01156a]1069
[892606b9]1070        if [ ! -d $path_apache2_confd ]; then
[dce072b]1071                errorAndLog "${FUNCNAME}(): path to apache2 conf.d can not found, verify your server installation"
[892606b9]1072                return 1
1073        fi
1074
[7586ca3]1075        mkdir -p $path_apache2_confd/{sites-available,sites-enabled}
[892606b9]1076
[dce072b]1077        echoAndLog "${FUNCNAME}(): creating apache2 config file.."
[a01156a]1078
[3ce53a7]1079        # Activar HTTPS.
[7825e9e]1080        $APACHESSLMOD
[643ca8c]1081        $APACHEENABLESSL
1082        $APACHEMAKECERT
[7829e4e]1083        # Activar módulo Rewrite.
1084        $APACHEREWRITEMOD
[d725a41]1085
[30837bb]1086        # Genera configuración de consola web a partir del fichero plantilla.
[f9e3393]1087        if [ -n "$(apachectl -v | grep "2\.[0-2]")" ]; then
1088                # Configuración para versiones anteriores de Apache.
1089                sed -e "s/CONSOLEDIR/${CONSOLEDIR//\//\\/}/g" \
[f3dde7e]1090                        $WORKDIR/opengnsys/server/etc/apache-prev2.4.conf.tmpl > $path_apache2_confd/$APACHESITESDIR/${APACHEOGSITE}
[f9e3393]1091        else
1092                # Configuración específica a partir de Apache 2.4
1093                sed -e "s/CONSOLEDIR/${CONSOLEDIR//\//\\/}/g" \
[f3dde7e]1094                        $WORKDIR/opengnsys/server/etc/apache.conf.tmpl > $path_apache2_confd/$APACHESITESDIR/${APACHEOGSITE}.conf
[f9e3393]1095        fi
[643ca8c]1096        $APACHEENABLEOG
[a01156a]1097        if [ $? -ne 0 ]; then
[dce072b]1098                errorAndLog "${FUNCNAME}(): config file can't be linked to apache conf, verify your server installation"
[a01156a]1099                return 1
1100        else
[dce072b]1101                echoAndLog "${FUNCNAME}(): config file created and linked, restarting apache daemon"
[53fba30]1102                service=$APACHESERV
1103                $ENABLESERVICE; $STARTSERVICE
[a01156a]1104                return 0
1105        fi
1106}
1107
[8fc9552]1108
[5d6bf97]1109# Crear documentación Doxygen para la consola web.
1110function makeDoxygenFiles()
1111{
1112        echoAndLog "${FUNCNAME}(): Making Doxygen web files..."
1113        $WORKDIR/opengnsys/installer/ogGenerateDoc.sh \
1114                        $WORKDIR/opengnsys/client/engine $INSTALL_TARGET/www
1115        if [ ! -d "$INSTALL_TARGET/www/html" ]; then
1116                errorAndLog "${FUNCNAME}(): unable to create Doxygen web files."
[ead38fb]1117                return 1
[5d6bf97]1118        fi
1119        mv "$INSTALL_TARGET/www/html" "$INSTALL_TARGET/www/api"
1120        chown -R $APACHE_RUN_USER:$APACHE_RUN_GROUP $INSTALL_TARGET/www/api
1121        echoAndLog "${FUNCNAME}(): Doxygen web files created successfully."
1122}
1123
1124
[a01156a]1125# Crea la estructura base de la instalación de opengnsys
[eb9424f]1126function createDirs()
[a01156a]1127{
1128        if [ $# -ne 1 ]; then
[dce072b]1129                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[a01156a]1130                exit 1
1131        fi
1132
[eb9424f]1133        local path_opengnsys_base="$1"
[a01156a]1134
[eb9424f]1135        # Crear estructura de directorios.
[dce072b]1136        echoAndLog "${FUNCNAME}(): creating directory paths in $path_opengnsys_base"
[a01156a]1137        mkdir -p $path_opengnsys_base
1138        mkdir -p $path_opengnsys_base/bin
[5c33840]1139        mkdir -p $path_opengnsys_base/client
[49c6891]1140        mkdir -p $path_opengnsys_base/doc
[5c33840]1141        mkdir -p $path_opengnsys_base/etc
[a01156a]1142        mkdir -p $path_opengnsys_base/lib
[1cc5697]1143        mkdir -p $path_opengnsys_base/log/clients
[eb9424f]1144        ln -fs $path_opengnsys_base/log /var/log/opengnsys
[7586ca3]1145        mkdir -p $path_opengnsys_base/sbin
[a01156a]1146        mkdir -p $path_opengnsys_base/www
[5c33840]1147        mkdir -p $path_opengnsys_base/images
[87c7b02]1148        mkdir -p $TFTPCFGDIR
[63fd1ba]1149        ln -fs $TFTPCFGDIR $path_opengnsys_base/tftpboot
[cfad47b]1150        mkdir -p $path_opengnsys_base/tftpboot/menu.lst
[a01156a]1151        if [ $? -ne 0 ]; then
[dce072b]1152                errorAndLog "${FUNCNAME}(): error while creating dirs. Do you have write permissions?"
[a01156a]1153                return 1
1154        fi
1155
[eb9424f]1156        # Crear usuario ficticio.
1157        if id -u $OPENGNSYS_CLIENT_USER &>/dev/null; then
1158                echoAndLog "${FUNCNAME}(): user \"$OPENGNSYS_CLIENT_USER\" is already created"
1159        else
1160                echoAndLog "${FUNCNAME}(): creating OpenGnSys user"
1161                useradd $OPENGNSYS_CLIENT_USER 2>/dev/null
1162                if [ $? -ne 0 ]; then
1163                        errorAndLog "${FUNCNAME}(): error creating OpenGnSys user"
1164                        return 1
1165                fi
1166        fi
1167
1168        # Establecer los permisos básicos.
1169        echoAndLog "${FUNCNAME}(): setting directory permissions"
[5eb61a6]1170        chmod -R 775 $path_opengnsys_base/{log/clients,images}
1171        chown -R :$OPENGNSYS_CLIENT_USER $path_opengnsys_base/{log/clients,images}
[eb9424f]1172        if [ $? -ne 0 ]; then
1173                errorAndLog "${FUNCNAME}(): error while setting permissions"
1174                return 1
1175        fi
1176
[7669bca]1177        # Mover el fichero de registro de instalación al directorio de logs.
[acfb07d]1178        echoAndLog "${FUNCNAME}(): moving installation log file"
1179        mv $LOG_FILE $OGLOGFILE && LOG_FILE=$OGLOGFILE
[7669bca]1180        chmod 600 $LOG_FILE
[acfb07d]1181
[dce072b]1182        echoAndLog "${FUNCNAME}(): directory paths created"
[a01156a]1183        return 0
1184}
1185
[463a1d49]1186# Copia ficheros de configuración y ejecutables genéricos del servidor.
[73a1bd6]1187function copyServerFiles ()
[e0edc14]1188{
[463a1d49]1189        if [ $# -ne 1 ]; then
[879689f]1190                errorAndLog "${FUNCNAME}(): invalid number of parameters"
[463a1d49]1191                exit 1
1192        fi
1193
[7caf5a7c]1194        local path_opengnsys_base="$1"
[463a1d49]1195
[a43e90d]1196        # Lista de ficheros y directorios origen y de directorios destino.
[cfad47b]1197        local SOURCES=( server/tftpboot \
[7caf5a7c]1198                        server/bin \
1199                        repoman/bin \
[42a0e41]1200                        admin/Sources/Services/ogAdmServerAux
1201                        admin/Sources/Services/ogAdmRepoAux
[7caf5a7c]1202                        installer/opengnsys_uninstall.sh \
1203                        installer/opengnsys_update.sh \
1204                        doc )
[cfad47b]1205        local TARGETS=( tftpboot \
[7caf5a7c]1206                        bin \
1207                        bin \
[42a0e41]1208                        sbin \
1209                        sbin \
[7caf5a7c]1210                        lib \
1211                        lib \
1212                        doc )
[463a1d49]1213
1214        if [ ${#SOURCES[@]} != ${#TARGETS[@]} ]; then
[879689f]1215                errorAndLog "${FUNCNAME}(): inconsistent number of array items"
[463a1d49]1216                exit 1
1217        fi
1218
[a43e90d]1219        # Copiar ficheros.
[879689f]1220        echoAndLog "${FUNCNAME}(): copying files to server directories"
[f2bb433]1221
[8457092]1222        pushd $WORKDIR/opengnsys
[463a1d49]1223        local i
1224        for (( i = 0; i < ${#SOURCES[@]}; i++ )); do
1225                if [ -f "${SOURCES[$i]}" ]; then
[879689f]1226                        echoAndLog "Copying ${SOURCES[$i]} to $path_opengnsys_base/${TARGETS[$i]}"
[b5aae72]1227                        cp -a "${SOURCES[$i]}" "${path_opengnsys_base}/${TARGETS[$i]}"
[8457092]1228                elif [ -d "${SOURCES[$i]}" ]; then
[879689f]1229                        echoAndLog "Copying content of ${SOURCES[$i]} to $path_opengnsys_base/${TARGETS[$i]}"
[8457092]1230                        cp -a "${SOURCES[$i]}"/* "${path_opengnsys_base}/${TARGETS[$i]}"
1231        else
[346eaee]1232                        warningAndLog "Unable to copy ${SOURCES[$i]} to $path_opengnsys_base/${TARGETS[$i]}"
[463a1d49]1233                fi
1234        done
[a43e90d]1235
[7586ca3]1236        popd
[892606b9]1237}
1238
[7586ca3]1239####################################################################
[5eb61a6]1240### Funciones de compilación de código fuente de servicios
[7586ca3]1241####################################################################
1242
[5eb61a6]1243# Compilar los servicios de OpenGnSys
[7586ca3]1244function servicesCompilation ()
1245{
[13a01a7]1246        local hayErrores=0
[0795938]1247
[49c6891]1248        # Compilar OpenGnSys Server
1249        echoAndLog "${FUNCNAME}(): Compiling OpenGnSys Admin Server"
[7b61735]1250        pushd $WORKDIR/opengnsys/admin/Sources/Services/ogAdmServer
[d168a46]1251        make && mv ogAdmServer $INSTALL_TARGET/sbin
[13a01a7]1252        if [ $? -ne 0 ]; then
[49c6891]1253                echoAndLog "${FUNCNAME}(): error while compiling OpenGnSys Admin Server"
[13a01a7]1254                hayErrores=1
1255        fi
[7586ca3]1256        popd
[49c6891]1257        # Compilar OpenGnSys Repository Manager
1258        echoAndLog "${FUNCNAME}(): Compiling OpenGnSys Repository Manager"
[7b61735]1259        pushd $WORKDIR/opengnsys/admin/Sources/Services/ogAdmRepo
[d168a46]1260        make && mv ogAdmRepo $INSTALL_TARGET/sbin
[13a01a7]1261        if [ $? -ne 0 ]; then
[49c6891]1262                echoAndLog "${FUNCNAME}(): error while compiling OpenGnSys Repository Manager"
[13a01a7]1263                hayErrores=1
1264        fi
[8125e7c]1265        popd
[4984660]1266        # Compilar OpenGnSys Agent
1267        echoAndLog "${FUNCNAME}(): Compiling OpenGnSys Agent"
[7b61735]1268        pushd $WORKDIR/opengnsys/admin/Sources/Services/ogAdmAgent
[d168a46]1269        make && mv ogAdmAgent $INSTALL_TARGET/sbin
[4984660]1270        if [ $? -ne 0 ]; then
1271                echoAndLog "${FUNCNAME}(): error while compiling OpenGnSys Agent"
1272                hayErrores=1
1273        fi
1274        popd   
[49c6891]1275        # Compilar OpenGnSys Client
1276        echoAndLog "${FUNCNAME}(): Compiling OpenGnSys Admin Client"
[7b61735]1277        pushd $WORKDIR/opengnsys/admin/Sources/Clients/ogAdmClient
[2338c95f]1278        make && mv ogAdmClient ../../../../client/shared/bin
[13a01a7]1279        if [ $? -ne 0 ]; then
[49c6891]1280                echoAndLog "${FUNCNAME}(): error while compiling OpenGnSys Admin Client"
[13a01a7]1281                hayErrores=1
1282        fi
[318efac]1283        popd
[13a01a7]1284
1285        return $hayErrores
[b6906f7]1286}
1287
[7b61735]1288####################################################################
1289### Funciones de copia de la Interface de administración
1290####################################################################
1291
1292# Copiar carpeta de Interface
[c1e00e4]1293function copyInterfaceAdm ()
[7b61735]1294{
1295        local hayErrores=0
1296       
[fbd9bcc]1297        # Crear carpeta y copiar Interface
[7b61735]1298        echoAndLog "${FUNCNAME}(): Copying Administration Interface Folder"
[fbd9bcc]1299        cp -ar $WORKDIR/opengnsys/admin/Interface $INSTALL_TARGET/client/interfaceAdm
[7b61735]1300        if [ $? -ne 0 ]; then
1301                echoAndLog "${FUNCNAME}(): error while copying Administration Interface Folder"
1302                hayErrores=1
1303        fi
[b6f1726]1304        chown $OPENGNSYS_CLIENT_USER:$OPENGNSYS_CLIENT_USER $INSTALL_TARGET/client/interfaceAdm/CambiarAcceso
[f6c1d2b]1305        chmod 700 $INSTALL_TARGET/client/interfaceAdm/CambiarAcceso
[7b61735]1306
1307        return $hayErrores
1308}
[b6906f7]1309
[892606b9]1310####################################################################
1311### Funciones instalacion cliente opengnsys
1312####################################################################
1313
[73a1bd6]1314function copyClientFiles()
[7586ca3]1315{
[d168a46]1316        local errstatus=0
[a555f49]1317
[49c6891]1318        echoAndLog "${FUNCNAME}(): Copying OpenGnSys Client files."
[73a1bd6]1319        cp -a $WORKDIR/opengnsys/client/shared/* $INSTALL_TARGET/client
[d47d38d]1320        if [ $? -ne 0 ]; then
[9ef8920]1321                errorAndLog "${FUNCNAME}(): error while copying client estructure"
[d168a46]1322                errstatus=1
[9ef8920]1323        fi
[d47d38d]1324        find $INSTALL_TARGET/client -name .svn -type d -exec rm -fr {} \; 2>/dev/null
[9ef8920]1325       
[49c6891]1326        echoAndLog "${FUNCNAME}(): Copying OpenGnSys Cloning Engine files."
[d47d38d]1327        mkdir -p $INSTALL_TARGET/client/lib/engine/bin
[73a1bd6]1328        cp -a $WORKDIR/opengnsys/client/engine/*.lib* $INSTALL_TARGET/client/lib/engine/bin
[a555f49]1329        if [ $? -ne 0 ]; then
1330                errorAndLog "${FUNCNAME}(): error while copying engine files"
[d168a46]1331                errstatus=1
[a555f49]1332        fi
[9ef8920]1333       
[1a2fa9d8]1334        # Si el servidor tiene instalado Rsync > 3.0.9, renombrar el ejecutable
1335        # compilado para el cliente.
1336        if [ -n "$(rsync --version | awk '/version/ {if ($3>="3.1.0") print $3}')" ]; then
1337                [ -e $INSTALL_TARGET/client/bin/rsync-3.1.0 ] && mv -f $INSTALL_TARGET/client/bin/rsync-3.1.0 $INSTALL_TARGET/client/bin/rsync
1338        fi
1339
[d168a46]1340        if [ $errstatus -eq 0 ]; then
[9ef8920]1341                echoAndLog "${FUNCNAME}(): client copy files success."
1342        else
1343                errorAndLog "${FUNCNAME}(): client copy files with errors"
1344        fi
1345
[d168a46]1346        return $errstatus
[463a1d49]1347}
1348
1349
[e70925a]1350# Crear cliente OpenGnSys 1.0.2 y posteriores.
[5ad5dcc]1351function clientCreate()
[813f617]1352{
[89179ff]1353        local DOWNLOADURL="http://$OPENGNSYS_SERVER/downloads"
[130bdbf]1354        local FILENAME=ogLive-precise-3.2.0-23-generic-r4311.iso        # 1.0.6-kernel3.2
1355        #local FILENAME=ogLive-precise-3.11.0-26-generic-r4413.iso      # 1.0.6-kernel3.11
[0b85cc93]1356        local TARGETFILE=$INSTALL_TARGET/lib/$FILENAME
1357        local TMPDIR=/tmp/${FILENAME%.iso}
[d168a46]1358 
[79c26a8]1359        # Descargar cliente, si es necesario.
1360        if [ -s $PROGRAMDIR/$FILENAME ]; then
1361                echoAndLog "${FUNCNAME}(): Moving $PROGRAMDIR/$FILENAME file to $(dirname $TARGETFILE)"
1362                mv $PROGRAMDIR/$FILENAME $TARGETFILE
1363        else
1364                echoAndLog "${FUNCNAME}(): Loading Client"
1365                wget $DOWNLOADURL/$FILENAME -O $TARGETFILE
1366        fi
[0b85cc93]1367        if [ ! -s $TARGETFILE ]; then
[6ef9f23]1368                errorAndLog "${FUNCNAME}(): Error loading OpenGnSys Client"
[813f617]1369                return 1
1370        fi
[79c26a8]1371        # Montar imagen, copiar cliente ogclient y desmontar.
[5ad5dcc]1372        echoAndLog "${FUNCNAME}(): Copying Client files"
[d168a46]1373        mkdir -p $TMPDIR
[0b85cc93]1374        mount -o loop,ro $TARGETFILE $TMPDIR
[73a1bd6]1375        cp -av $TMPDIR/ogclient $INSTALL_TARGET/tftpboot
[5ad5dcc]1376        umount $TMPDIR
1377        rmdir $TMPDIR
[6ef01d9]1378        # Asignar la clave cliente para acceso a Samba.
1379        echoAndLog "${FUNCNAME}(): Set client access key"
1380        echo -ne "$OPENGNSYS_CLIENT_PASSWD\n$OPENGNSYS_CLIENT_PASSWD\n" | \
1381                        $INSTALL_TARGET/bin/setsmbpass
[0b85cc93]1382
[813f617]1383        # Establecer los permisos.
[19fdf38]1384        find -L $INSTALL_TARGET/tftpboot -type d -exec chmod 755 {} \;
1385        find -L $INSTALL_TARGET/tftpboot -type f -exec chmod 644 {} \;
[813f617]1386        chown -R :$OPENGNSYS_CLIENT_USER $INSTALL_TARGET/tftpboot/ogclient
[beaebf8]1387        chown -R $APACHE_RUN_USER:$APACHE_RUN_GROUP $INSTALL_TARGET/tftpboot/menu.lst
[6ef01d9]1388
[e8963d0]1389        # Ofrecer md5 del kernel y vmlinuz para ogupdateinitrd en cache
[73a1bd6]1390        cp -av $INSTALL_TARGET/tftpboot/ogclient/ogvmlinuz* $INSTALL_TARGET/tftpboot
1391        cp -av $INSTALL_TARGET/tftpboot/ogclient/oginitrd.img* $INSTALL_TARGET/tftpboot
[6ef01d9]1392
[813f617]1393        echoAndLog "${FUNCNAME}(): Client generation success"
1394}
1395
1396
[49c6891]1397# Configuración básica de servicios de OpenGnSys
[cc7eab7]1398function openGnsysConfigure()
1399{
[d168a46]1400        local i=0
1401        local dev=""
[7d4ce64]1402        local CONSOLEURL
[d168a46]1403
[9ee62ad]1404        echoAndLog "${FUNCNAME}(): Copying init files."
[42a0e41]1405        cp -a $WORKDIR/opengnsys/admin/Sources/Services/opengnsys.init /etc/init.d/opengnsys
1406        cp -a $WORKDIR/opengnsys/admin/Sources/Services/opengnsys.default /etc/default/opengnsys
[b8969db]1407        # Deshabilitar servicios de BitTorrent si no están instalados.
1408        if [ ! -e /usr/bin/bttrack ]; then
[fdab5d0]1409                sed -i 's/RUN_BTTRACKER="yes"/RUN_BTTRACKER="no"/; s/RUN_BTSEEDER="yes"/RUN_BTSEEDER="no"/' \
[b8969db]1410                        /etc/default/opengnsys
1411        fi
[9ee62ad]1412        echoAndLog "${FUNCNAME}(): Creating cron files."
[57cf15b]1413        echo "* * * * *   root   [ -x $INSTALL_TARGET/bin/opengnsys.cron ] && $INSTALL_TARGET/bin/opengnsys.cron" > /etc/cron.d/opengnsys
[9ee62ad]1414        echo "* * * * *   root   [ -x $INSTALL_TARGET/bin/torrent-creator ] && $INSTALL_TARGET/bin/torrent-creator" > /etc/cron.d/torrentcreator
[8fc9552]1415        echo "5 * * * *   root   [ -x $INSTALL_TARGET/bin/torrent-tracker ] && $INSTALL_TARGET/bin/torrent-tracker" > /etc/cron.d/torrenttracker
[dc762088]1416        echo "* * * * *   root   [ -x $INSTALL_TARGET/bin/deletepreimage ] && $INSTALL_TARGET/bin/deletepreimage" > /etc/cron.d/imagedelete
[d168a46]1417
[700299b]1418        echoAndLog "${FUNCNAME}(): Creating logrotate configuration file."
1419        sed -e "s/OPENGNSYSDIR/${INSTALL_TARGET//\//\\/}/g" \
1420                $WORKDIR/opengnsys/server/etc/logrotate.tmpl > /etc/logrotate.d/opengnsys
1421
[d168a46]1422        echoAndLog "${FUNCNAME}(): Creating OpenGnSys config files."
1423        for dev in ${DEVICE[*]}; do
1424                if [ -n "${SERVERIP[i]}" ]; then
1425                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
1426                            -e "s/DBUSER/$OPENGNSYS_DB_USER/g" \
1427                            -e "s/DBPASSWORD/$OPENGNSYS_DB_PASSWD/g" \
1428                            -e "s/DATABASE/$OPENGNSYS_DATABASE/g" \
1429                                $WORKDIR/opengnsys/admin/Sources/Services/ogAdmServer/ogAdmServer.cfg > $INSTALL_TARGET/etc/ogAdmServer-$dev.cfg
1430                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
1431                                $WORKDIR/opengnsys/admin/Sources/Services/ogAdmRepo/ogAdmRepo.cfg > $INSTALL_TARGET/etc/ogAdmRepo-$dev.cfg
1432                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
1433                            -e "s/DBUSER/$OPENGNSYS_DB_USER/g" \
1434                            -e "s/DBPASSWORD/$OPENGNSYS_DB_PASSWD/g" \
1435                            -e "s/DATABASE/$OPENGNSYS_DATABASE/g" \
1436                                $WORKDIR/opengnsys/admin/Sources/Services/ogAdmAgent/ogAdmAgent.cfg > $INSTALL_TARGET/etc/ogAdmAgent-$dev.cfg
[1a2fa9d8]1437                        CONSOLEURL="https://${SERVERIP[i]}/opengnsys"
[d168a46]1438                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
1439                            -e "s/DBUSER/$OPENGNSYS_DB_USER/g" \
1440                            -e "s/DBPASSWORD/$OPENGNSYS_DB_PASSWD/g" \
1441                            -e "s/DATABASE/$OPENGNSYS_DATABASE/g" \
[b22305e]1442                            -e "s/OPENGNSYSURL/${CONSOLEURL//\//\\/}/g" \
[d168a46]1443                                $INSTALL_TARGET/www/controlacceso.php > $INSTALL_TARGET/www/controlacceso-$dev.php
1444                        sed -e "s/SERVERIP/${SERVERIP[i]}/g" \
[d7f8305]1445                            -e "s/OPENGNSYSURL/${CONSOLEURL//\//\\/}/g" \
[d168a46]1446                                $WORKDIR/opengnsys/admin/Sources/Clients/ogAdmClient/ogAdmClient.cfg > $INSTALL_TARGET/client/etc/ogAdmClient-$dev.cfg
[7d4ce64]1447                        if [ "$dev" == "$DEFAULTDEV" ]; then
[1a2fa9d8]1448                                OPENGNSYS_CONSOLEURL="$CONSOLEURL"
[7d4ce64]1449                        fi
[d168a46]1450                fi
1451                let i++
1452        done
1453        ln -f $INSTALL_TARGET/etc/ogAdmServer-$DEFAULTDEV.cfg $INSTALL_TARGET/etc/ogAdmServer.cfg
1454        ln -f $INSTALL_TARGET/etc/ogAdmRepo-$DEFAULTDEV.cfg $INSTALL_TARGET/etc/ogAdmRepo.cfg
1455        ln -f $INSTALL_TARGET/etc/ogAdmAgent-$DEFAULTDEV.cfg $INSTALL_TARGET/etc/ogAdmAgent.cfg
1456        ln -f $INSTALL_TARGET/client/etc/ogAdmClient-$DEFAULTDEV.cfg $INSTALL_TARGET/client/etc/ogAdmClient.cfg
1457        ln -f $INSTALL_TARGET/www/controlacceso-$DEFAULTDEV.php $INSTALL_TARGET/www/controlacceso.php
1458        chown root:root $INSTALL_TARGET/etc/{ogAdmServer,ogAdmAgent}*.cfg
1459        chmod 600 $INSTALL_TARGET/etc/{ogAdmServer,ogAdmAgent}*.cfg
1460        chown $APACHE_RUN_USER:$APACHE_RUN_GROUP $INSTALL_TARGET/www/controlacceso*.php
1461        chmod 600 $INSTALL_TARGET/www/controlacceso*.php
[1f7b2d0]1462
1463        # Revisar permisos generales.
1464        if [ -x $INSTALL_TARGET/bin/checkperms ]; then
1465                echoAndLog "${FUNCNAME}(): Checking permissions."
1466                OPENGNSYS_DIR="$INSTALL_TARGET" OPENGNSYS_USER="$OPENGNSYS_CLIENT_USER" APACHE_USER="$APACHE_RUN_USER" APACHE_GROUP="$APACHE_RUN_GROUP" $INSTALL_TARGET/bin/checkperms
1467        fi
1468
[4e19f13]1469        # Evitar inicio de duplicado en Ubuntu 14.04 (Upstart y SysV Init).
1470        if [ -f /etc/init/${MYSQLSERV}.conf ]; then
1471                service=$MYSQLSERV
1472                $DISABLESERVICE
1473        fi
1474
[9ee62ad]1475        echoAndLog "${FUNCNAME}(): Starting OpenGnSys services."
[53fba30]1476        service="opengnsys"
1477        $ENABLESERVICE; $STARTSERVICE
[cc7eab7]1478}
1479
[b6906f7]1480
[a01156a]1481#####################################################################
[180a07dd]1482#######  Función de resumen informativo de la instalación
1483#####################################################################
1484
[813f617]1485function installationSummary()
1486{
[eb9424f]1487        # Crear fichero de versión y revisión, si no existe.
1488        local VERSIONFILE="$INSTALL_TARGET/doc/VERSION.txt"
[130bdbf]1489        [ -f $VERSIONFILE ] || echo "OpenGnSys Server" >$VERSIONFILE
1490        # Incluir datos de revisión, si se está instaladno desde el repositorio
1491        # de código o si no está incluida en el fichero de versión.
1492        if [ $USESVN -eq 1 ] || [ -z "$(awk '$3~/r[0-9]*/ {print}' $VERSIONFILE)" ]; then
1493                local REVISION=$(LANG=C svn info $SVN_URL|awk '/Rev:/ {print "r"$4}')
1494                perl -pi -e "s/($| r[0-9]*)/ $REVISION/" $VERSIONFILE
1495        fi
[eb9424f]1496
1497        # Mostrar información.
[180a07dd]1498        echo
[49c6891]1499        echoAndLog "OpenGnSys Installation Summary"
[180a07dd]1500        echo       "=============================="
[eb9424f]1501        echoAndLog "Project version:                  $(cat $VERSIONFILE 2>/dev/null)"
[49c6891]1502        echoAndLog "Installation directory:           $INSTALL_TARGET"
[acfb07d]1503        echoAndLog "Installation log file:            $LOG_FILE"
[49c6891]1504        echoAndLog "Repository directory:             $INSTALL_TARGET/images"
[d168a46]1505        echoAndLog "DHCP configuration directory:     $DHCPCFGDIR"
[87c7b02]1506        echoAndLog "TFTP configuration directory:     $TFTPCFGDIR"
1507        echoAndLog "Samba configuration directory:    $SAMBACFGDIR"
[49c6891]1508        echoAndLog "Web Console URL:                  $OPENGNSYS_CONSOLEURL"
[35b0ef1]1509        echoAndLog "Web Console access data:          specified in installer script"
[b8969db]1510        if grep -q "^RUN_BTTRACK.*no" /etc/default/opengnsys; then
1511                echoAndLog "BitTorrent service is disabled."
1512        fi
[180a07dd]1513        echo
1514        echoAndLog "Post-Installation Instructions:"
1515        echo       "==============================="
[663c6625]1516        echoAndLog "Firewall service has been disabled and SELinux mode set to"
1517        echoAndLog "   permissive during OpenGnSys installation. Please check"
[64f4ada]1518        echoAndLog "   ${FIREWALLSERV:-firewall} and SELinux configuration, if needed."
[180a07dd]1519        echoAndLog "Review or edit all configuration files."
[c5ce04c]1520        echoAndLog "Insert DHCP configuration data and restart service."
[af5efd6]1521        echoAndLog "Optional: Log-in as Web Console admin user."
1522        echoAndLog " - Review default Organization data and assign access to users."
[180a07dd]1523        echoAndLog "Log-in as Web Console organization user."
[e4b1572]1524        echoAndLog " - Insert OpenGnSys data (labs, computers, menus, etc)."
[180a07dd]1525echo
1526}
1527
1528
1529
1530#####################################################################
[49c6891]1531####### Proceso de instalación de OpenGnSys
[a01156a]1532#####################################################################
1533
[49c6891]1534echoAndLog "OpenGnSys installation begins at $(date)"
[6090a2d]1535pushd $WORKDIR
[cc7eab7]1536
[af5efd6]1537# Detectar datos iniciales de auto-configuración del instalador.
[d168a46]1538autoConfigure
1539
1540# Detectar parámetros de red y comprobar si hay conexión.
1541getNetworkSettings
1542if [ $? -ne 0 ]; then
1543        errorAndLog "Error reading default network settings."
1544        exit 1
1545fi
[07c3a59]1546checkNetworkConnection
1547if [ $? -ne 0 ]; then
1548        errorAndLog "Error connecting to server. Causes:"
1549        errorAndLog " - Network is unreachable, review devices parameters."
1550        errorAndLog " - You are inside a private network, configure the proxy service."
1551        errorAndLog " - Server is temporally down, try agian later."
1552        exit 1
1553fi
[7586ca3]1554
[e0edc14]1555# Detener servicios de OpenGnSys, si están activos previamente.
1556[ -f /etc/init.d/opengnsys ] && /etc/init.d/opengnsys stop
1557
[318efac]1558# Actualizar repositorios
[83518d5]1559updatePackageList
[318efac]1560
[b6906f7]1561# Instalación de dependencias (paquetes de sistema operativo).
[a01156a]1562declare -a notinstalled
1563checkDependencies DEPENDENCIES notinstalled
1564if [ $? -ne 0 ]; then
1565        installDependencies notinstalled
1566        if [ $? -ne 0 ]; then
1567                echoAndLog "Error while installing some dependeces, please verify your server installation before continue"
1568                exit 1
1569        fi
1570fi
[109e8b2]1571if [ -n "$INSTALLEXTRADEPS" ]; then
1572        echoAndLog "Installing extra dependencies"
1573        for (( i=0; i<${#INSTALLEXTRADEPS[*]}; i++ )); do
1574                eval ${INSTALLEXTRADEPS[i]}
1575        done
1576fi     
[a01156a]1577
[ff6c349]1578# Detectar datos de auto-configuración después de instalar paquetes.
1579autoConfigurePost
1580
[49c6891]1581# Arbol de directorios de OpenGnSys.
[eb9424f]1582createDirs ${INSTALL_TARGET}
[a01156a]1583if [ $? -ne 0 ]; then
1584        errorAndLog "Error while creating directory paths!"
1585        exit 1
1586fi
[b6906f7]1587
[1e7eaab]1588# Si es necesario, descarga el repositorio de código en directorio temporal
[49c6891]1589if [ $USESVN -eq 1 ]; then
[1e7eaab]1590        svnExportCode $SVN_URL
1591        if [ $? -ne 0 ]; then
1592                errorAndLog "Error while getting code from svn"
1593                exit 1
1594        fi
1595else
1596        ln -fs "$(dirname $PROGRAMDIR)" opengnsys
[a01156a]1597fi
1598
[49c6891]1599# Compilar código fuente de los servicios de OpenGnSys.
[b6906f7]1600servicesCompilation
[13a01a7]1601if [ $? -ne 0 ]; then
1602        errorAndLog "Error while compiling OpenGnsys services"
1603        exit 1
1604fi
[b6906f7]1605
[7b61735]1606# Copiar carpeta Interface entre administración y motor de clonación.
[c1e00e4]1607copyInterfaceAdm
[7b61735]1608if [ $? -ne 0 ]; then
[c1e00e4]1609        errorAndLog "Error while copying Administration Interface"
[7b61735]1610        exit 1
1611fi
1612
[e70925a]1613# Configuración de TFTP.
[318efac]1614tftpConfigure
[b6906f7]1615
[e70925a]1616# Configuración de Samba.
[8fc9552]1617smbConfigure
1618if [ $? -ne 0 ]; then
[c1e00e4]1619        errorAndLog "Error while configuring Samba server!"
[8fc9552]1620        exit 1
1621fi
1622
[e70925a]1623# Configuración de Rsync.
1624rsyncConfigure
1625
1626# Configuración ejemplo DHCP.
[b6906f7]1627dhcpConfigure
[a555f49]1628if [ $? -ne 0 ]; then
1629        errorAndLog "Error while copying your dhcp server files!"
1630        exit 1
1631fi
[b6906f7]1632
[49c6891]1633# Copiar ficheros de servicios OpenGnSys Server.
[73a1bd6]1634copyServerFiles ${INSTALL_TARGET}
[463a1d49]1635if [ $? -ne 0 ]; then
1636        errorAndLog "Error while copying the server files!"
1637        exit 1
1638fi
1639
[094ac0d]1640# Instalar base de datos de OpenGnSys Admin.
[5cc52295]1641isInArray notinstalled "mysql-server" || isInArray notinstalled "mariadb-server"
[b6906f7]1642if [ $? -eq 0 ]; then
[094ac0d]1643        # Habilitar gestor de base de datos (MySQL, si falla, MariaDB).
1644        service=$MYSQLSERV
1645        $ENABLESERVICE
1646        if [ $? != 0 ]; then
1647                service=$MARIADBSERV
1648                $ENABLESERVICE
1649        fi
1650        # Activar gestor de base de datos.
[0f8100d]1651        $STARTSERVICE
[094ac0d]1652        # Asignar clave del usuario "root".
[09bf701]1653        mysqlSetRootPassword "${MYSQL_ROOT_PASSWORD}"
[b6906f7]1654else
[094ac0d]1655        # Si ya está instalado el gestor de bases de datos, obtener clave de "root",
[b6906f7]1656        mysqlGetRootPassword
1657fi
[463a1d49]1658
[09bf701]1659mysqlTestConnection "${MYSQL_ROOT_PASSWORD}"
[a01156a]1660if [ $? -ne 0 ]; then
1661        errorAndLog "Error while connection to mysql"
1662        exit 1
1663fi
[09bf701]1664mysqlDbExists ${OPENGNSYS_DATABASE}
[a01156a]1665if [ $? -ne 0 ]; then
[cc7eab7]1666        echoAndLog "Creating Web Console database"
[09bf701]1667        mysqlCreateDb ${OPENGNSYS_DATABASE}
[a01156a]1668        if [ $? -ne 0 ]; then
[cc7eab7]1669                errorAndLog "Error while creating Web Console database"
[a01156a]1670                exit 1
1671        fi
1672else
[cc7eab7]1673        echoAndLog "Web Console database exists, ommiting creation"
[a01156a]1674fi
1675
[09bf701]1676mysqlCheckUserExists ${OPENGNSYS_DB_USER}
[a01156a]1677if [ $? -ne 0 ]; then
1678        echoAndLog "Creating user in database"
[09bf701]1679        mysqlCreateAdminUserToDb ${OPENGNSYS_DATABASE} ${OPENGNSYS_DB_USER} "${OPENGNSYS_DB_PASSWD}"
[a01156a]1680        if [ $? -ne 0 ]; then
[cc7eab7]1681                errorAndLog "Error while creating database user"
[a01156a]1682                exit 1
1683        fi
1684
1685fi
1686
[09bf701]1687mysqlCheckDbIsEmpty ${OPENGNSYS_DATABASE}
[a01156a]1688if [ $? -eq 0 ]; then
1689        echoAndLog "Creating tables..."
[892606b9]1690        if [ -f $WORKDIR/$OPENGNSYS_DB_CREATION_FILE ]; then
[09bf701]1691                mysqlImportSqlFileToDb ${OPENGNSYS_DATABASE} $WORKDIR/$OPENGNSYS_DB_CREATION_FILE
[a01156a]1692        else
[892606b9]1693                errorAndLog "Unable to locate $WORKDIR/$OPENGNSYS_DB_CREATION_FILE!!"
[a01156a]1694                exit 1
1695        fi
[bc7dfe7]1696else
1697        # Si existe fichero ogBDAdmin-VersLocal-VersRepo.sql; aplicar cambios.
1698        INSTVERSION=$(awk '{print $2}' $INSTALL_TARGET/doc/VERSION.txt)
1699        REPOVERSION=$(awk '{print $2}' $WORKDIR/opengnsys/doc/VERSION.txt)
[295b4ab]1700        OPENGNSYS_DB_UPDATE_FILE="opengnsys/admin/Database/$OPENGNSYS_DATABASE-$INSTVERSION-$REPOVERSION.sql"
1701        if [ -f $WORKDIR/$OPENGNSYS_DB_UPDATE_FILE ]; then
[bc7dfe7]1702                echoAndLog "Updating tables from version $INSTVERSION to $REPOVERSION"
[09bf701]1703                mysqlImportSqlFileToDb ${OPENGNSYS_DATABASE} $WORKDIR/$OPENGNSYS_DB_UPDATE_FILE
[bc7dfe7]1704        else
1705                echoAndLog "Database unchanged."
1706        fi
[a01156a]1707fi
[09bf701]1708# Eliminar fichero temporal con credenciales de acceso a MySQL.
1709rm -f $TMPMYCNF
[a01156a]1710
1711# copiando paqinas web
[7586ca3]1712installWebFiles
[5d6bf97]1713# Generar páqinas web de documentación de la API
1714makeDoxygenFiles
[a01156a]1715
1716# creando configuracion de apache2
[5fcf180]1717installWebConsoleApacheConf $INSTALL_TARGET $APACHECFGDIR
[a01156a]1718if [ $? -ne 0 ]; then
[87c7b02]1719        errorAndLog "Error configuring Apache for OpenGnSys Admin"
[a01156a]1720        exit 1
1721fi
1722
1723popd
[892606b9]1724
[9ef8920]1725# Crear la estructura de los accesos al servidor desde el cliente (shared)
[73a1bd6]1726copyClientFiles
[9ef8920]1727if [ $? -ne 0 ]; then
1728        errorAndLog "Error creating client structure"
1729fi
1730
[d168a46]1731# Crear la estructura del cliente de OpenGnSys
[5ad5dcc]1732clientCreate
[a555f49]1733if [ $? -ne 0 ]; then
[813f617]1734        errorAndLog "Error creating client"
[a555f49]1735        exit 1
1736fi
[892606b9]1737
[65245d1]1738# Configuración de servicios de OpenGnSys
1739openGnsysConfigure
1740
[180a07dd]1741# Mostrar sumario de la instalación e instrucciones de post-instalación.
1742installationSummary
1743
[077dd7c5]1744#rm -rf $WORKDIR
[49c6891]1745echoAndLog "OpenGnSys installation finished at $(date)"
[05d2e03]1746exit 0
[2308fc7]1747
Note: See TracBrowser for help on using the repository browser.