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]"; } |
---|
73 | chmod -R 770 /php_sessions/ |
---|
74 | |
---|
75 | a2ensite expresso |
---|
76 | a2dissite default |
---|
77 | |
---|
78 | # Linha adicionada para resolver alguns warnings quando "apache2ctl configtest" |
---|
79 | 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 |
---|
80 | |
---|
81 | /etc/init.d/apache2 restart |
---|
82 | |
---|
83 | ############################################################################################ |
---|
84 | # OPENLDAP |
---|
85 | /etc/init.d/slapd stop |
---|
86 | 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 |
---|
87 | cp ./arqs-conf/etc/ldap/schema_utf8/* /etc/ldap/schema/ |
---|
88 | cp ./arqs-conf/etc/default/slapd /etc/default/slapd |
---|
89 | |
---|
90 | rm -rf /var/lib/ldap |
---|
91 | mkdir /var/lib/ldap |
---|
92 | |
---|
93 | chown -R openldap:openldap /var/lib/ldap/ |
---|
94 | |
---|
95 | /etc/init.d/slapd start |
---|
96 | /etc/init.d/slapd stop |
---|
97 | |
---|
98 | sleep 2 |
---|
99 | 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 |
---|
100 | |
---|
101 | sleep 2 |
---|
102 | slapadd -v -l /tmp/expresso.ldif -f /etc/ldap/slapd.conf |
---|
103 | chown -R openldap. /var/lib/ldap/* |
---|
104 | |
---|
105 | sleep 2 |
---|
106 | /etc/init.d/slapd start |
---|
107 | rm /tmp/expresso.ldif |
---|
108 | |
---|
109 | ############################################################################################ |
---|
110 | # CYRUS |
---|
111 | cp ./arqs-conf/etc/imapd.conf /etc/ |
---|
112 | cp ./arqs-conf/etc/cyrus.conf /etc/ |
---|
113 | sed -e "s/LDAP_DN/$LDAP_DN/g" ./arqs-conf/etc/saslauthd.conf > /etc/saslauthd.conf |
---|
114 | cp ./arqs-conf/etc/default/saslauthd-lenny /etc/default/saslauthd |
---|
115 | |
---|
116 | cp -p ./arqs-conf/usr/bin/cyradm_expresso /usr/bin/ |
---|
117 | |
---|
118 | /etc/init.d/saslauthd restart |
---|
119 | sleep 4 |
---|
120 | |
---|
121 | /etc/init.d/cyrus2.2 restart |
---|
122 | |
---|
123 | sleep 4 |
---|
124 | ./arqs-conf/cyrus.pl $LDAP_PWD |
---|
125 | |
---|
126 | ############################################################################################ |
---|
127 | # POSTFIX |
---|
128 | sed -e "s/LDAP_DN/$LDAP_DN/g" -e "s/DOMAIN/$DOMAIN/g" ./arqs-conf/etc/postfix/main.cf > /etc/postfix/main.cf |
---|
129 | sed -e "s/DOMAIN/$DOMAIN/g" ./arqs-conf/etc/postfix/expresso-dominios > /etc/postfix/expresso-dominios |
---|
130 | cp ./arqs-conf/etc/postfix/master.cf /etc/postfix/ |
---|
131 | adduser postfix mail |
---|
132 | /etc/init.d/postfix restart |
---|
133 | postmap /etc/postfix/expresso-dominios |
---|
134 | |
---|
135 | sleep 10 |
---|
136 | |
---|
137 | ############################################################################################ |
---|
138 | # mkpasswd |
---|
139 | mkdir /home/expressolivre || { echo "Diretorio ja existe. [OK]"; } |
---|
140 | cp ./arqs-conf/home/expressolivre/* /home/expressolivre/ |
---|
141 | chown -R www-data:www-data /home/expressolivre/ |
---|
142 | ############################################################################################ |
---|
143 | # HEADER_INC_PHP |
---|
144 | sed -e "s/HEADER_PWD/$HEADER_PWD/g" ./arqs-conf/header.inc.php > /var/www/expresso/header.inc.php |
---|
145 | chown www-data:www-data /var/www/expresso/header.inc.php |
---|
146 | |
---|
147 | ############################################################################################ |
---|
148 | # POSTGRES |
---|
149 | apt-get install -y postgresql postgresql-common postgresql-client postgresql-client-common || { echo "Erro ao iniciar. Sem problema.[OK]";} |
---|
150 | #parando o servico e fazendo backup |
---|
151 | /etc/init.d/postgresql stop |
---|
152 | mv /var/lib/postgresql/8.4/main /var/lib/postgresql/8.4/main_backup_$(date +%s) |
---|
153 | |
---|
154 | 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' |
---|
155 | |
---|
156 | # Link Simbolico para Server.crt |
---|
157 | ln -sf /etc/ssl/certs/ssl-cert-snakeoil.pem /var/lib/postgresql/8.4/main/server.crt |
---|
158 | |
---|
159 | # Link Simbolico para Server.key |
---|
160 | ln -sf /etc/ssl/private/ssl-cert-snakeoil.key /var/lib/postgresql/8.4/main/server.key |
---|
161 | |
---|
162 | echo "COPIANDO ARQUIVOS DE CONFIGURACAO DO EXPRESSO PARA O PGSQL...." |
---|
163 | cp ./arqs-conf/etc/postgresql/8.4/main/postgresql.conf /etc/postgresql/8.4/main/ |
---|
164 | cp ./arqs-conf/etc/postgresql/8.4/main/pg_hba.conf /etc/postgresql/8.4/main/ |
---|
165 | |
---|
166 | #restaurando o proprietario para postgres |
---|
167 | chown postgres:postgres /etc/postgresql/8.4/main/postgresql.conf |
---|
168 | chown postgres:postgres /etc/postgresql/8.4/main/pg_hba.conf |
---|
169 | |
---|
170 | /etc/init.d/postgresql start |
---|
171 | |
---|
172 | su - postgres -c 'dropdb expresso' || { echo "Banco expresso nao existia. [OK]"; } |
---|
173 | su - postgres -c 'createdb -E LATIN1 expresso' || { echo "Problemas na criacao do banco expresso. [Falhou]"; exit 1;} |
---|
174 | |
---|
175 | 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 |
---|
176 | |
---|
177 | su - postgres -c 'psql -f /tmp/expresso.dump expresso' |
---|
178 | |
---|
179 | rm /tmp/expresso.dump |
---|
180 | |
---|
181 | ##### CREATE WORKFLOW DATABASE |
---|
182 | #cp ./arqs-conf/workflow.dump /tmp |
---|
183 | #su - postgres -c 'psql < /tmp/workflow.dump -U postgres' |
---|
184 | #rm /tmp/workflow.dump |
---|
185 | #### END CREATE |
---|
186 | |
---|
187 | /etc/init.d/postgresql restart |
---|
188 | |
---|
189 | ############################################################################################ |
---|
190 | echo Acerta permissoes das pastas crls e temp em /var/www/expresso/security: |
---|
191 | chown www-data:www-data /var/www/expresso/security/temp |
---|
192 | chown www-data:www-data /var/www/expresso/logs |
---|
193 | chown -R www-data:www-data /var/www/expresso/security/crls |
---|
194 | chown www-data:www-data /var/www/expresso/security/crl_admin/crl_admin.py |
---|
195 | chmod 755 /var/www/expresso/security/temp |
---|
196 | chmod 755 /var/www/expresso/security/crls |
---|
197 | chmod 755 /var/www/expresso/security/crl_admin/crl_admin.py |
---|
198 | |
---|
199 | ############################################################################################ |
---|
200 | |
---|
201 | ## Mudamos o debconf para high, default do Debian Squeeze. |
---|
202 | debconf-set-selections ./arqs-conf/debconf.high |
---|
203 | ## Fim da configuracao do DebConf |
---|
204 | |
---|
205 | dialog --backtitle "$BACKTITLE" --cr-wrap --msgbox "FIM. www.expressolivre.org" 7 55 && |
---|
206 | |
---|
207 | echo '.' |
---|