[3753] | 1 | #!/bin/bash |
---|
| 2 | |
---|
| 3 | set -e # Para caso de erro |
---|
| 4 | |
---|
| 5 | if [ $UID != 0 ]; then { |
---|
| 6 | echo "Este script deve ser executado como superusuario, root ou sudo"; |
---|
| 7 | exit 1; |
---|
| 8 | } |
---|
| 9 | fi |
---|
| 10 | |
---|
| 11 | apt-get update || { echo "Falha ao atualizar o apt-get"; exit 1; } |
---|
| 12 | |
---|
| 13 | apt-get install -y dialog debconf-utils |
---|
| 14 | |
---|
| 15 | ## Mudamos o debconf para critical, para que nao sejam feitas perguntas desnecessarias. |
---|
| 16 | debconf-set-selections ./arqs-conf/debconf.critical |
---|
| 17 | ## Fim da configuracao do DebConf |
---|
| 18 | |
---|
| 19 | BACKTITLE='Instalacao do ExpressoLivre 2.2' |
---|
| 20 | INTRO=' |
---|
| 21 | Bem-Vindo(a) a instalacao do ExpressoLivre! |
---|
| 22 | |
---|
| 23 | 3 (tres) perguntas serao feitas a voce. |
---|
| 24 | - Escolha uma senha. |
---|
| 25 | - Escolha uma organizacao. |
---|
| 26 | - Escolha um dominio. |
---|
| 27 | |
---|
| 28 | Com estas informacoes o script podera |
---|
| 29 | instalar e configurar o ExpressoLivre. |
---|
| 30 | ' |
---|
| 31 | #..................................................................... |
---|
| 32 | dialog --backtitle "$BACKTITLE" \ |
---|
| 33 | --cr-wrap \ |
---|
| 34 | --msgbox "$INTRO" \ |
---|
| 35 | 17 55 && |
---|
| 36 | #..................................................................... |
---|
| 37 | LDAP_PWD=$( dialog --stdout --inputbox 'Digite uma senha:' 0 0 ) |
---|
| 38 | #..................................................................... |
---|
| 39 | ORG=$( dialog --stdout --inputbox 'Digite uma organizacao:(ex.: celepar)' 0 55 ) |
---|
| 40 | #..................................................................... |
---|
| 41 | DOMAIN=$( dialog --stdout --inputbox 'Digite seu dominio:(ex.: '$ORG'.com.br)' 0 55 ) |
---|
| 42 | |
---|
| 43 | #..................................................................... |
---|
| 44 | dialog --backtitle "$BACKTITLE" --cr-wrap --msgbox \ |
---|
| 45 | "A instalacao dos pacotes necessarios para o ExpressoLivre ira comecar agora." 10 65 && |
---|
| 46 | #..................................................................... |
---|
| 47 | |
---|
| 48 | 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.7-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; } |
---|
| 49 | |
---|
| 50 | ############################################################################################ |
---|
| 51 | # GET VARs |
---|
| 52 | LDAP_DN=`php ./arqs-conf/makedn.php $DOMAIN` |
---|
| 53 | LDAP_DC=`php ./arqs-conf/makedc.php $DOMAIN` |
---|
| 54 | LDAP_PWD_MD5=`slappasswd -v -s $LDAP_PWD -h {MD5}` |
---|
| 55 | LDAP_PWD_MD5=`php ./arqs-conf/regexp.php $LDAP_PWD_MD5` |
---|
| 56 | HEADER_PWD=`php ./arqs-conf/pass.php $LDAP_PWD` |
---|
| 57 | ############################################################################################ |
---|
| 58 | # APACHE |
---|
| 59 | # descomente para gerar o certificado para o https |
---|
| 60 | #apache2-ssl-certificate; |
---|
| 61 | |
---|
| 62 | a2enmod rewrite |
---|
| 63 | a2enmod ssl |
---|
| 64 | |
---|
| 65 | cp -r -p ../../../expresso/ /var/www/ |
---|
| 66 | cp ./arqs-conf/etc/apache2/apache2.conf.lenny /etc/apache2/apache2.conf |
---|
| 67 | cp ./arqs-conf/etc/apache2/sites-available/default.lenny /etc/apache2/sites-available/expresso |
---|
| 68 | cp ./arqs-conf/etc/apache2/ports.conf.lenny /etc/apache2/ports.conf |
---|
| 69 | cp -r -p ./arqs-conf/etc/apache2/ssl/ /etc/apache2/ |
---|
| 70 | |
---|
| 71 | cp ./arqs-conf/etc/php5/apache2/php.ini /etc/php5/apache2/ |
---|
| 72 | mkdir /php_sessions/ || { echo "Diretorio ja existe. [OK]"; } |
---|
[5101] | 73 | chown -R www-data. /php_sessions/ |
---|
[4623] | 74 | chmod -R 770 /php_sessions/ |
---|
[3753] | 75 | |
---|
| 76 | a2ensite expresso |
---|
| 77 | a2dissite default |
---|
| 78 | |
---|
| 79 | # Linha adicionada para resolver alguns warnings quando "apache2ctl configtest" |
---|
| 80 | 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 |
---|
| 81 | |
---|
| 82 | /etc/init.d/apache2 restart |
---|
| 83 | |
---|
| 84 | ############################################################################################ |
---|
| 85 | # OPENLDAP |
---|
| 86 | /etc/init.d/slapd stop |
---|
| 87 | 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 |
---|
| 88 | cp ./arqs-conf/etc/ldap/schema_utf8/* /etc/ldap/schema/ |
---|
| 89 | cp ./arqs-conf/etc/default/slapd /etc/default/slapd |
---|
| 90 | |
---|
| 91 | rm -rf /var/lib/ldap |
---|
| 92 | mkdir /var/lib/ldap |
---|
| 93 | |
---|
| 94 | chown -R openldap:openldap /var/lib/ldap/ |
---|
| 95 | |
---|
| 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 -f /etc/ldap/slapd.conf |
---|
| 104 | chown -R openldap. /var/lib/ldap/* |
---|
| 105 | |
---|
| 106 | sleep 2 |
---|
| 107 | /etc/init.d/slapd start |
---|
| 108 | rm /tmp/expresso.ldif |
---|
| 109 | |
---|
| 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 "Diretorio ja existe. [OK]"; } |
---|
| 141 | cp ./arqs-conf/home/expressolivre/* /home/expressolivre/ |
---|
| 142 | chown -R www-data:www-data /home/expressolivre/ |
---|
| 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 |
---|
| 146 | chown www-data:www-data /var/www/expresso/header.inc.php |
---|
| 147 | |
---|
| 148 | ############################################################################################ |
---|
| 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 servico e fazendo backup |
---|
| 152 | /etc/init.d/postgresql stop |
---|
| 153 | mv /var/lib/postgresql/8.4/main /var/lib/postgresql/8.4/main_backup_$(date +%s) |
---|
| 154 | |
---|
| 155 | su - postgres -c 'export LANG=pt_BR.ISO-8859-1;/usr/lib/postgresql/8.4/bin/initdb -E latin1 -D /var/lib/postgresql/8.4/main' |
---|
| 156 | |
---|
| 157 | # Link Simbolico para Server.crt |
---|
| 158 | ln -sf /etc/ssl/certs/ssl-cert-snakeoil.pem /var/lib/postgresql/8.4/main/server.crt |
---|
| 159 | |
---|
| 160 | # Link Simbolico para Server.key |
---|
| 161 | ln -sf /etc/ssl/private/ssl-cert-snakeoil.key /var/lib/postgresql/8.4/main/server.key |
---|
| 162 | |
---|
| 163 | echo "COPIANDO ARQUIVOS DE CONFIGURACAO DO EXPRESSO PARA O PGSQL...." |
---|
| 164 | cp ./arqs-conf/etc/postgresql/8.4/main/postgresql.conf /etc/postgresql/8.4/main/ |
---|
| 165 | cp ./arqs-conf/etc/postgresql/8.4/main/pg_hba.conf /etc/postgresql/8.4/main/ |
---|
| 166 | |
---|
| 167 | #restaurando o proprietario para postgres |
---|
| 168 | chown postgres:postgres /etc/postgresql/8.4/main/postgresql.conf |
---|
| 169 | chown postgres:postgres /etc/postgresql/8.4/main/pg_hba.conf |
---|
| 170 | |
---|
| 171 | /etc/init.d/postgresql start |
---|
| 172 | |
---|
| 173 | su - postgres -c 'dropdb expresso' || { echo "Banco expresso nao existia. [OK]"; } |
---|
| 174 | su - postgres -c 'createdb -E LATIN1 expresso' || { echo "Problemas na criacao do banco expresso. [Falhou]"; exit 1;} |
---|
| 175 | |
---|
| 176 | 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 |
---|
| 177 | |
---|
| 178 | su - postgres -c 'psql -f /tmp/expresso.dump expresso' |
---|
| 179 | |
---|
| 180 | rm /tmp/expresso.dump |
---|
| 181 | |
---|
| 182 | ##### CREATE WORKFLOW DATABASE |
---|
| 183 | #cp ./arqs-conf/workflow.dump /tmp |
---|
| 184 | #su - postgres -c 'psql < /tmp/workflow.dump -U postgres' |
---|
| 185 | #rm /tmp/workflow.dump |
---|
| 186 | #### END CREATE |
---|
| 187 | |
---|
| 188 | /etc/init.d/postgresql restart |
---|
| 189 | |
---|
| 190 | ############################################################################################ |
---|
| 191 | echo Acerta permissoes das pastas crls e temp em /var/www/expresso/security: |
---|
| 192 | chown www-data:www-data /var/www/expresso/security/temp |
---|
| 193 | chown www-data:www-data /var/www/expresso/logs |
---|
| 194 | chown -R www-data:www-data /var/www/expresso/security/crls |
---|
| 195 | chown www-data:www-data /var/www/expresso/security/crl_admin/crl_admin.py |
---|
| 196 | chmod 755 /var/www/expresso/security/temp |
---|
| 197 | chmod 755 /var/www/expresso/security/crls |
---|
| 198 | chmod 755 /var/www/expresso/security/crl_admin/crl_admin.py |
---|
| 199 | |
---|
| 200 | ############################################################################################ |
---|
| 201 | |
---|
| 202 | ## Mudamos o debconf para high, default do Debian Squeeze. |
---|
| 203 | debconf-set-selections ./arqs-conf/debconf.high |
---|
| 204 | ## Fim da configuracao do DebConf |
---|
| 205 | |
---|
| 206 | dialog --backtitle "$BACKTITLE" --cr-wrap --msgbox "FIM. www.expressolivre.org" 7 55 && |
---|
| 207 | |
---|
| 208 | echo '.' |
---|