[685] | 1 | #!/bin/bash |
---|
| 2 | |
---|
| 3 | # Criado por João Alfredo Knopik Junior <jakjr@celepar.pr.gov.br> |
---|
| 4 | # Colaborações: |
---|
[3018] | 5 | # "William Fernando Merlotto" <william@prognus.com.br> |
---|
| 6 | # "Alexandre Felipe Muller de Souza" <amuller@celepar.pr.gov.br> |
---|
[685] | 7 | |
---|
| 8 | set -e # Para caso de erro |
---|
| 9 | |
---|
| 10 | if [ $UID != 0 ]; then { |
---|
[3018] | 11 | echo "Este script deve ser executado como superusuario, root ou sudo"; |
---|
| 12 | exit 1; |
---|
| 13 | } |
---|
[685] | 14 | fi |
---|
| 15 | |
---|
| 16 | apt-get update || { echo "Falha ao atualizar o apt-get"; exit 1; } |
---|
| 17 | |
---|
| 18 | apt-get install -y dialog debconf-utils |
---|
| 19 | |
---|
| 20 | ## Mudamos o debconf para critical, para que não sejam feitas perguntas desnecessárias. |
---|
| 21 | debconf-set-selections ./arqs-conf/debconf.critical |
---|
| 22 | ## Fim da configuração do DebConf |
---|
| 23 | |
---|
[1331] | 24 | BACKTITLE='Instalação do ExpressoLivre 2.0' |
---|
[685] | 25 | INTRO=' |
---|
| 26 | Bem-Vindo(a) a instalação do ExpressoLivre! |
---|
| 27 | |
---|
| 28 | 3 (três) perguntas serão feitas a você. |
---|
| 29 | - Escolha uma senha. |
---|
| 30 | - Escolha uma organização. |
---|
| 31 | - Escolha um domÃnio. |
---|
| 32 | |
---|
| 33 | Com estas informações o script poderá |
---|
| 34 | instalar e configurar o ExpressoLivre. |
---|
| 35 | ' |
---|
| 36 | #..................................................................... |
---|
| 37 | dialog --backtitle "$BACKTITLE" \ |
---|
| 38 | --cr-wrap \ |
---|
| 39 | --msgbox "$INTRO" \ |
---|
| 40 | 17 55 && |
---|
| 41 | #..................................................................... |
---|
| 42 | LDAP_PWD=$( dialog --stdout --inputbox 'Digite uma senha:' 0 0 ) |
---|
| 43 | #..................................................................... |
---|
| 44 | ORG=$( dialog --stdout --inputbox 'Digite uma organização:(ex.: celepar)' 0 55 ) |
---|
| 45 | #..................................................................... |
---|
| 46 | DOMAIN=$( dialog --stdout --inputbox 'Digite seu domÃnio:(ex.: '$ORG'.com.br)' 0 55 ) |
---|
| 47 | |
---|
| 48 | #..................................................................... |
---|
| 49 | dialog --backtitle "$BACKTITLE" --cr-wrap --msgbox \ |
---|
| 50 | "A instalação dos pacotes necessários para o ExpressoLivre começará agora." 10 65 && |
---|
[3018] | 51 | #..................................................................... |
---|
[685] | 52 | |
---|
[745] | 53 | apt-get install -y apache2-mpm-prefork libapache2-mod-php5 apache2-utils php5 php5-common php5-dev php5-gd php5-imap php5-ldap php5-pgsql php5-cgi php5-cli slapd ldap-utils db4.2-util cyrus-admin-2.2 cyrus-clients-2.2 cyrus-common-2.2 cyrus-doc-2.2 cyrus-imapd-2.2 libcyrus-imap-perl22 postfix postfix-ldap libsasl2-2 libsasl2-modules sasl2-bin nmap vim libmail-imapclient-perl libparse-recdescent-perl libterm-readkey-perl libterm-readline-perl-perl zip unzip graphviz lsb-base openssl ssl-cert || { echo "ImpossÃvel continuar, erro no nome dos pacotes"; exit 1; } |
---|
[685] | 54 | |
---|
| 55 | ############################################################################################ |
---|
| 56 | # GET VARs |
---|
| 57 | LDAP_DN=`php ./arqs-conf/makedn.php $DOMAIN` |
---|
| 58 | LDAP_DC=`php ./arqs-conf/makedc.php $DOMAIN` |
---|
| 59 | LDAP_PWD_MD5=`slappasswd -v -s $LDAP_PWD -h {MD5}` |
---|
| 60 | LDAP_PWD_MD5=`php ./arqs-conf/regexp.php $LDAP_PWD_MD5` |
---|
| 61 | HEADER_PWD=`php ./arqs-conf/pass.php $LDAP_PWD` |
---|
| 62 | ############################################################################################ |
---|
| 63 | # APACHE |
---|
| 64 | # descomente para gerar o certificado para o https |
---|
| 65 | #apache2-ssl-certificate; |
---|
| 66 | |
---|
[3018] | 67 | a2enmod rewrite |
---|
| 68 | a2enmod ssl |
---|
[685] | 69 | |
---|
| 70 | cp -r -p ../../../expresso/ /var/www/ |
---|
[3018] | 71 | cp ./arqs-conf/etc/apache2/apache2.conf.lenny /etc/apache2/apache2.conf |
---|
| 72 | cp ./arqs-conf/etc/apache2/sites-available/default.lenny /etc/apache2/sites-available/expresso |
---|
| 73 | cp ./arqs-conf/etc/apache2/ports.conf.lenny /etc/apache2/ports.conf |
---|
[1113] | 74 | cp -r -p ./arqs-conf/etc/apache2/ssl/ /etc/apache2/ |
---|
[685] | 75 | |
---|
| 76 | cp ./arqs-conf/etc/php5/apache2/php.ini /etc/php5/apache2/ |
---|
| 77 | mkdir /php_sessions/ || { echo "Diretório já existe. [OK]"; } |
---|
| 78 | chmod -R 777 /php_sessions/ |
---|
| 79 | |
---|
[3018] | 80 | a2ensite expresso |
---|
| 81 | a2dissite default |
---|
| 82 | |
---|
| 83 | # Linha adicionada para resolver alguns warnings quando "apache2ctl configtest" |
---|
| 84 | HOST=`hostname` ; mv /etc/hosts /etc/hosts.ori ; echo 127.0.0.1 $DOMAIN localhost $HOST > /etc/hosts ; cat /etc/hosts.ori >> /etc/hosts ; rm /etc/hosts.ori |
---|
| 85 | |
---|
[685] | 86 | /etc/init.d/apache2 restart |
---|
| 87 | |
---|
| 88 | ############################################################################################ |
---|
| 89 | # OPENLDAP |
---|
| 90 | /etc/init.d/slapd stop |
---|
| 91 | sed -e "s/LDAP_DN/$LDAP_DN/g" -e "s/LDAP_PWD_MD5/$LDAP_PWD_MD5/g" ./arqs-conf/etc/ldap/slapd.conf.lenny > /etc/ldap/slapd.conf |
---|
| 92 | cp ./arqs-conf/etc/ldap/schema/* /etc/ldap/schema/ |
---|
| 93 | rm -rf /var/lib/ldap |
---|
| 94 | mkdir /var/lib/ldap |
---|
[3018] | 95 | chown -R openldap:openldap /var/lib/ldap/ |
---|
[685] | 96 | /etc/init.d/slapd start |
---|
| 97 | /etc/init.d/slapd stop |
---|
| 98 | |
---|
| 99 | sleep 2 |
---|
| 100 | sed -e "s/LDAP_DN/$LDAP_DN/g" -e "s/LDAP_PWD_MD5/$LDAP_PWD_MD5/g" -e "s/ORG/$ORG/g" -e "s/DOMAIN/$DOMAIN/g" -e "s/LDAP_DC/$LDAP_DC/g" ./arqs-conf/expresso.ldif > /tmp/expresso.ldif |
---|
| 101 | |
---|
| 102 | sleep 2 |
---|
| 103 | slapadd -v -l /tmp/expresso.ldif |
---|
| 104 | chown -R openldap. /var/lib/ldap/* |
---|
| 105 | |
---|
| 106 | sleep 2 |
---|
| 107 | /etc/init.d/slapd start |
---|
| 108 | rm /tmp/expresso.ldif |
---|
[3018] | 109 | |
---|
[685] | 110 | ############################################################################################ |
---|
| 111 | # CYRUS |
---|
| 112 | cp ./arqs-conf/etc/imapd.conf /etc/ |
---|
| 113 | cp ./arqs-conf/etc/cyrus.conf /etc/ |
---|
| 114 | sed -e "s/LDAP_DN/$LDAP_DN/g" ./arqs-conf/etc/saslauthd.conf > /etc/saslauthd.conf |
---|
| 115 | cp ./arqs-conf/etc/default/saslauthd-lenny /etc/default/saslauthd |
---|
| 116 | |
---|
| 117 | cp -p ./arqs-conf/usr/bin/cyradm_expresso /usr/bin/ |
---|
| 118 | |
---|
| 119 | /etc/init.d/saslauthd restart |
---|
| 120 | sleep 4 |
---|
| 121 | |
---|
| 122 | /etc/init.d/cyrus2.2 restart |
---|
| 123 | |
---|
| 124 | sleep 4 |
---|
| 125 | ./arqs-conf/cyrus.pl $LDAP_PWD |
---|
| 126 | |
---|
| 127 | ############################################################################################ |
---|
| 128 | # POSTFIX |
---|
| 129 | sed -e "s/LDAP_DN/$LDAP_DN/g" -e "s/DOMAIN/$DOMAIN/g" ./arqs-conf/etc/postfix/main.cf > /etc/postfix/main.cf |
---|
| 130 | sed -e "s/DOMAIN/$DOMAIN/g" ./arqs-conf/etc/postfix/expresso-dominios > /etc/postfix/expresso-dominios |
---|
| 131 | cp ./arqs-conf/etc/postfix/master.cf /etc/postfix/ |
---|
| 132 | adduser postfix mail |
---|
| 133 | /etc/init.d/postfix restart |
---|
| 134 | postmap /etc/postfix/expresso-dominios |
---|
| 135 | |
---|
| 136 | sleep 10 |
---|
| 137 | |
---|
| 138 | ############################################################################################ |
---|
| 139 | # mkpasswd |
---|
| 140 | mkdir /home/expressolivre || { echo "Diretório já existe. [OK]"; } |
---|
| 141 | cp ./arqs-conf/home/expressolivre/* /home/expressolivre/ |
---|
[3018] | 142 | chown -R www-data:www-data /home/expressolivre/ |
---|
[685] | 143 | ############################################################################################ |
---|
| 144 | # HEADER_INC_PHP |
---|
| 145 | sed -e "s/HEADER_PWD/$HEADER_PWD/g" ./arqs-conf/header.inc.php > /var/www/expresso/header.inc.php |
---|
[3018] | 146 | chown www-data:www-data /var/www/expresso/header.inc.php |
---|
[685] | 147 | |
---|
| 148 | ############################################################################################ |
---|
[745] | 149 | # POSTGRES |
---|
| 150 | apt-get install -y postgresql postgresql-common postgresql-client postgresql-client-common || { echo "Erro ao iniciar. Sem problema.[OK]";} |
---|
| 151 | #parando o serviço e fazendo backup |
---|
| 152 | /etc/init.d/postgresql-8.3 stop |
---|
| 153 | mv /var/lib/postgresql/8.3/main /var/lib/postgresql/8.3/main_backup_$(date +%s) |
---|
[685] | 154 | |
---|
[745] | 155 | #alterando o proprietário do diretório temporariamente |
---|
| 156 | chown postgres\: /var/lib/postgresql/8.3 |
---|
| 157 | |
---|
| 158 | su - postgres -c 'export LANG=pt_BR.ISO-8859-1;/usr/lib/postgresql/8.3/bin/initdb -E latin1 -D /var/lib/postgresql/8.3/main' |
---|
| 159 | |
---|
| 160 | #restaurando o proprietário do diretório |
---|
| 161 | chown root\: /var/lib/postgresql/8.3 |
---|
| 162 | echo "COPIANDO ARQUIVOS DE CONFIGURACAO DO EXPRESSO PARA O PGSQL...." |
---|
| 163 | cp ./arqs-conf/etc/postgresql/8.3/main/postgresql.conf /etc/postgresql/8.3/main/ |
---|
| 164 | cp ./arqs-conf/etc/postgresql/8.3/main/pg_hba.conf /etc/postgresql/8.3/main/ |
---|
| 165 | /etc/init.d/postgresql-8.3 start |
---|
| 166 | |
---|
| 167 | su - postgres -c 'dropdb expresso' || { echo "Banco expresso não existia. [OK]"; } |
---|
| 168 | su - postgres -c 'createdb -E LATIN1 expresso' || { echo "Problemas na criação do banco expresso. [Falhou]"; exit 1;} |
---|
| 169 | |
---|
| 170 | sed -e "s/LDAP_DN/$LDAP_DN/g" -e "s/LDAP_PWD/$LDAP_PWD/g" -e "s/ORG/$ORG/g" -e "s/DOMAIN/$DOMAIN/g" ./arqs-conf/expresso.dump > /tmp/expresso.dump |
---|
| 171 | |
---|
| 172 | su - postgres -c 'psql -f /tmp/expresso.dump expresso' |
---|
| 173 | |
---|
| 174 | rm /tmp/expresso.dump |
---|
| 175 | |
---|
[1255] | 176 | ##### CREATE WORKFLOW DATABASE |
---|
| 177 | cp ./arqs-conf/workflow.dump /tmp |
---|
| 178 | su - postgres -c 'psql < /tmp/workflow.dump -U postgres' |
---|
| 179 | rm /tmp/workflow.dump |
---|
| 180 | #### END CREATE |
---|
| 181 | |
---|
[745] | 182 | /etc/init.d/postgresql-8.3 restart |
---|
| 183 | |
---|
[1113] | 184 | ############################################################################################ |
---|
[1174] | 185 | echo Acerta permissoes das pastas crls e temp em /var/www/expresso/security: |
---|
| 186 | chown www-data:www-data /var/www/expresso/security/temp |
---|
[3018] | 187 | chown www-data:www-data /var/www/expresso/logs |
---|
[1174] | 188 | chown -R www-data:www-data /var/www/expresso/security/crls |
---|
[3018] | 189 | chown www-data:www-data /var/www/expresso/security/crl_admin/crl_admin.py |
---|
[1174] | 190 | chmod 755 /var/www/expresso/security/temp |
---|
| 191 | chmod 755 /var/www/expresso/security/crls |
---|
| 192 | chmod 755 /var/www/expresso/security/crl_admin/crl_admin.py |
---|
[745] | 193 | |
---|
[1113] | 194 | ############################################################################################ |
---|
| 195 | |
---|
[3753] | 196 | ## Mudamos o debconf para high, default do Debian Lenny. |
---|
[685] | 197 | debconf-set-selections ./arqs-conf/debconf.high |
---|
| 198 | ## Fim da configuração do DebConf |
---|
| 199 | |
---|
| 200 | dialog --backtitle "$BACKTITLE" --cr-wrap --msgbox "FIM. www.expressolivre.org" 7 55 && |
---|
| 201 | |
---|
[3753] | 202 | echo '.' |
---|