source: installer/opengnsys_installer.sh @ e7d8e52

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 e7d8e52 was a16ce1b, checked in by ramon <ramongomez@…>, 8 years ago

#730: Dejar de soportar Syslinux.

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

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