diff --git a/config-dynamic/postfixadmin/.keep b/config-dynamic/postfixadmin/.keep new file mode 100644 index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 diff --git a/deployment/postfixadmin/pwgen.php b/deployment/postfixadmin/pwgen.php deleted file mode 100644 index 81ccca9986fd9544bac86b063a2b25985f9407ef..0000000000000000000000000000000000000000 --- a/deployment/postfixadmin/pwgen.php +++ /dev/null @@ -1,16 +0,0 @@ - \ No newline at end of file diff --git a/scripts/postinstall.sh b/scripts/postinstall.sh index b4b5c71d3c06607e9e78ec08006c07a59c70611d..76658958db0ae247a16d4b65c64496d922a18826 100755 --- a/scripts/postinstall.sh +++ b/scripts/postinstall.sh @@ -11,7 +11,7 @@ do printf "." sleep 0.1 done -while docker-compose exec --user www-data nextcloud php occ | grep -q "Nextcloud is not installed"; +while docker-compose exec -T --user www-data nextcloud php occ | grep -q "Nextcloud is not installed"; do printf "." sleep 0.1 @@ -25,29 +25,32 @@ cat /mnt/repo-base/templates/nextcloud/plugin-config/user_sql_raw_config.conf | touch /mnt/repo-base/volumes/nextcloud/data/.ocdata echo "Installing nextcloud plugin" -docker-compose exec --user www-data nextcloud php /var/www/html/occ app:install user_backend_sql_raw -docker-compose exec --user www-data nextcloud php /var/www/html/occ upgrade +docker-compose exec -T --user www-data nextcloud php /var/www/html/occ app:install user_backend_sql_raw +docker-compose exec -T --user www-data nextcloud php /var/www/html/occ app:install rainloop +docker-compose exec -T --user www-data nextcloud php /var/www/html/occ config:app:set rainloop rainloop-autologin --value 1 +docker-compose exec -T --user www-data nextcloud php /var/www/html/occ upgrade echo "Restarting Nextcloud container" docker-compose restart nextcloud +echo "Configuring Rainloop" +mkdir -p "/mnt/repo-base/volumes/nextcloud/data/rainloop-storage/_data_/_default_/domains/" +echo "$ADD_DOMAINS" | tr "," "\n" | while read add_domain; do + cat "templates/rainloop/domain-config.ini" | sed "s/@@@EMAIL_DOMAIN@@@/$DOMAIN/g" > "/mnt/repo-base/volumes/nextcloud/data/rainloop-storage/_data_/_default_/domains/$add_domain.ini" +done +chown www-data:www-data /mnt/repo-base/volumes/nextcloud/ -R + echo "Creating postfix database schema" curl --silent -L https://mail.$DOMAIN/setup.php > /dev/null -echo "Setting Postfix admin setup password" -docker cp /mnt/repo-base/deployment/postfixadmin/pwgen.php postfixadmin:/postfixadmin -SETUPPW_HASH=$(docker-compose exec postfixadmin php /postfixadmin/pwgen.php "$PFA_SETUP_PASSWORD" | tail -n1) -docker-compose exec postfixadmin sed -i "s|\($CONF\['setup_password'\].*=\).*|\1 '${SETUPPW_HASH}';|" /postfixadmin/config.inc.php -docker-compose exec postfixadmin rm /postfixadmin/pwgen.php - echo "Adding Postfix admin superadmin account" -docker-compose exec postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php admin add $ALT_EMAIL --password $PFA_SUPERADMIN_PASSWORD --password2 $PFA_SUPERADMIN_PASSWORD --superadmin +docker-compose exec -T postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php admin add $ALT_EMAIL --password $PFA_SUPERADMIN_PASSWORD --password2 $PFA_SUPERADMIN_PASSWORD --superadmin echo "Adding domains to Postfix" -echo "$ADD_DOMAINS" | tr "," "\n" | while read line; do docker-compose exec postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php domain add $line; done +echo "$ADD_DOMAINS" | tr "," "\n" | while read line; do docker-compose exec -T postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php domain add $line; done echo "Adding email accounts used by system senders (drive, ...)" -docker-compose exec postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php mailbox add drive@$DOMAIN --password $DRIVE_SMTP_PASSWORD --password2 $DRIVE_SMTP_PASSWORD --name "drive" --email-other $ALT_EMAIL +docker-compose exec -T postfixadmin php /postfixadmin/scripts/postfixadmin-cli.php mailbox add drive@$DOMAIN --password $DRIVE_SMTP_PASSWORD --password2 $DRIVE_SMTP_PASSWORD --name "drive" --email-other $ALT_EMAIL # display DKIM DNS setup info/instructions to the user echo -e "\n\n\n" diff --git a/templates/docker-compose/docker-compose-base.yml b/templates/docker-compose/docker-compose-base.yml index a16168aaace97d2c8834087d3dfbe00cd4f31462..4dabc44f6f102be07b220751f860314b7343b914 100644 --- a/templates/docker-compose/docker-compose-base.yml +++ b/templates/docker-compose/docker-compose-base.yml @@ -59,23 +59,9 @@ services: environment: - DBPASS=${DBPASS} - POSTFIXADMIN_SSH_PASSWORD=${POSTFIXADMIN_SSH_PASSWORD} - depends_on: - - eelomailserver - - mariadb - - # Webmail (Optional) - # https://github.com/hardware/rainloop - # https://www.rainloop.net/ - # Configuration : https://github.com/hardware/mailserver/wiki/Rainloop-initial-configuration - rainloop: - #image: hardware/rainloop - image: registry.gitlab.e.foundation:5000/e/infra/docker-rainloop:0.1.1 - container_name: rainloop - restart: unless-stopped - networks: - - serverbase + - POSTFIXADMIN_SETUP_PASSWORD=${PFA_SETUP_PASSWORD} volumes: - - /mnt/repo-base/volumes/rainloop/data:/rainloop/data + - /mnt/repo-base/config-dynamic/postfixadmin/config.local.php:/postfixadmin/config.local.php depends_on: - eelomailserver - mariadb diff --git a/templates/nginx/sites-enabled/webmail b/templates/nginx/sites-enabled/webmail deleted file mode 100644 index cc7277ea1a79758ad833441a26ec939e9dfddaff..0000000000000000000000000000000000000000 --- a/templates/nginx/sites-enabled/webmail +++ /dev/null @@ -1,31 +0,0 @@ -server { - listen 8000; - server_name webmail.@@@DOMAIN@@@; - return 301 https://$host$request_uri; -} - -server { - listen 4430 ssl http2; - server_name webmail.@@@DOMAIN@@@; - - ssl_certificate /certs/live/webmail.@@@DOMAIN@@@/fullchain.pem; - ssl_certificate_key /certs/live/webmail.@@@DOMAIN@@@/privkey.pem; - - include /etc/nginx/params/ssl_params; - include /etc/nginx/params/headers_params; - - #add_header Strict-Transport-Security "max-age=;"; - #client_max_body_size M; - - #auth_basic "Who's this?"; - #auth_basic_user_file /passwds/.htpasswd; - - location / { - proxy_pass http://rainloop:8888; - include /etc/nginx/params/proxy_params; - } - - location /.well-known/acme-challenge/ { - alias /etc/letsencrypt/acme-challenge/.well-known/acme-challenge/; - } -} diff --git a/templates/postfixadmin/config.local.php b/templates/postfixadmin/config.local.php new file mode 100644 index 0000000000000000000000000000000000000000..58af54de6c1f8f06fd114d1da62332b59f1d1948 --- /dev/null +++ b/templates/postfixadmin/config.local.php @@ -0,0 +1,3 @@ + diff --git a/templates/rainloop/domain-config.ini b/templates/rainloop/domain-config.ini new file mode 100644 index 0000000000000000000000000000000000000000..a36e2aa23d857f27f197edec09098924b67067f5 --- /dev/null +++ b/templates/rainloop/domain-config.ini @@ -0,0 +1,16 @@ +imap_host = "@@@EMAIL_DOMAIN@@@" +imap_port = 143 +imap_secure = "TLS" +imap_short_login = Off +sieve_use = Off +sieve_allow_raw = Off +sieve_host = "" +sieve_port = 4190 +sieve_secure = "None" +smtp_host = "@@@EMAIL_DOMAIN@@@" +smtp_port = 587 +smtp_secure = "TLS" +smtp_short_login = Off +smtp_auth = On +smtp_php_mail = Off +white_list = ""