2022-07-03 10:00:19 +00:00
|
|
|
#!/bin/bash
|
2022-07-02 16:35:35 +00:00
|
|
|
set -e
|
|
|
|
|
|
|
|
export LANG=C.UTF-8
|
|
|
|
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin"
|
2022-07-03 10:00:19 +00:00
|
|
|
cd $(dirname "${BASH_SOURCE[0]}")
|
|
|
|
workingdir=$(pwd)
|
|
|
|
|
2022-07-02 16:35:35 +00:00
|
|
|
# install all required packages
|
|
|
|
DEBIAN_FRONTEND=noninteractive apt-get update
|
2024-06-02 12:29:51 +00:00
|
|
|
DEBIAN_FRONTEND=noninteractive apt-get --no-install-recommends install -y apt-transport-tor bash-completion bind9 ca-certificates clamav-daemon clamav-freshclam curl dovecot-imapd dovecot-lmtpd dovecot-pop3d git gnupg haveged iptables libsasl2-modules locales locales-all logrotate lsb-release mariadb-server mercurial nano nginx openssl php8.2-cli php8.2-curl php8.2-fpm php8.2-gd php8.2-gmp php8.2-gnupg php8.2-imap php8.2-intl php8.2-mbstring php8.2-mysql php8.2-pspell php8.2-readline postfix postfix-mysql prosody redis rspamd tor vim wget unzip wireguard wireguard-tools
|
2022-07-02 16:35:35 +00:00
|
|
|
|
|
|
|
# install composer
|
2024-06-02 10:20:28 +00:00
|
|
|
curl -sSL https://github.com/composer/composer/releases/download/2.7.6/composer.phar > /usr/bin/composer
|
2022-07-02 16:35:35 +00:00
|
|
|
chmod +x /usr/bin/composer
|
|
|
|
composer self-update
|
|
|
|
|
2022-07-02 19:14:28 +00:00
|
|
|
# mysql encryption
|
|
|
|
if [ ! -e /etc/mysql/encryption/keyfile.enc ]; then
|
|
|
|
mkdir -p /etc/mysql/encryption/
|
|
|
|
openssl rand -hex 128 > /etc/mysql/encryption/keyfile.key
|
|
|
|
echo "1;"$(openssl rand -hex 32) | openssl enc -aes-256-cbc -md sha1 -pass file:/etc/mysql/encryption/keyfile.key -out /etc/mysql/encryption/keyfile.enc
|
|
|
|
fi
|
2024-06-02 11:20:53 +00:00
|
|
|
# dovecot encryption
|
|
|
|
if [ ! -e /etc/dovecot/ecprivkey.pem ]; then
|
|
|
|
mkdir -p /etc/dovecot/
|
|
|
|
openssl ecparam -name secp521r1 -genkey | openssl pkey -out /etc/dovecot/ecprivkey.pem
|
|
|
|
openssl pkey -in /etc/dovecot/ecprivkey.pem -pubout -out /etc/dovecot/ecpubkey.pem
|
|
|
|
fi
|
|
|
|
# postifx certificates
|
|
|
|
if [ ! -e /etc/postfix/danwin1210-mail.chain ]; then
|
2024-06-02 13:33:08 +00:00
|
|
|
openssl req -x509 -nodes -days 3650 -newkey ed448 -subj "/" -keyout /etc/postfix/danwin121-mail.key -out /etc/postfix/danwin1210-mail.crt && cat /etc/postfix/danwin1210-mail.key >> /etc/postfix/danwin1210-mail.chain && cat /etc/postfix/danwin1210-mail.crt >> /etc/postfix/danwin1210-mail.chain
|
2024-06-02 11:20:53 +00:00
|
|
|
fi
|
2022-07-02 19:14:28 +00:00
|
|
|
|
2022-07-03 10:00:19 +00:00
|
|
|
#install scripts
|
|
|
|
mkdir -p /var/www/mail
|
|
|
|
mkdir -p /var/www/html
|
2024-06-02 18:50:01 +00:00
|
|
|
mkdir -p /var/lib/rspamd/dkim
|
|
|
|
chown _rspamd: /var/lib/rspamd/dkim
|
2022-07-03 10:00:19 +00:00
|
|
|
if [ ! -e /var/www/html/mail ]; then
|
|
|
|
ln -s ../mail/www /var/www/html/mail
|
|
|
|
fi
|
|
|
|
cp -r composer.json cron.php setup.php www /var/www/mail/
|
|
|
|
cd /var/www/mail/
|
|
|
|
composer install --no-dev
|
|
|
|
|
|
|
|
|
2022-07-02 19:14:28 +00:00
|
|
|
# install squirrelmail
|
2022-07-03 10:00:19 +00:00
|
|
|
if [ ! -e /var/www/mail/www/squirrelmail ]; then
|
|
|
|
mkdir -p /var/www/mail/www/squirrelmail
|
|
|
|
cd /var/www/mail/www/squirrelmail
|
2022-07-02 19:14:28 +00:00
|
|
|
git clone https://github.com/RealityRipple/squirrelmail .
|
|
|
|
mkdir -p /var/local/squirrelmail/data /var/local/squirrelmail/attach
|
|
|
|
chown www-data:www-data -R /var/local/squirrelmail
|
2022-07-03 10:00:19 +00:00
|
|
|
else
|
|
|
|
cd /var/www/mail/www/squirrelmail
|
|
|
|
git fetch --all
|
|
|
|
git pull
|
|
|
|
fi
|
|
|
|
|
2024-06-02 11:20:53 +00:00
|
|
|
# install snappymail
|
|
|
|
mkdir -p /var/www/mail/www/snappymail
|
|
|
|
cd /var/www/mail/www/snappymail
|
|
|
|
VERSION=$(curl -s https://api.github.com/repos/the-djmaze/snappymail/releases/latest | grep tag_name | cut -d '"' -f 4)
|
|
|
|
wget https://github.com/the-djmaze/snappymail/releases/download/${VERSION}/snappymail-${VERSION:1}.zip
|
|
|
|
unzip -o snappymail-${VERSION:1}.zip
|
|
|
|
mkdir -p /var/local/snappymail
|
|
|
|
chown www-data:www-data -R /var/local/snappymail
|
|
|
|
|
2022-07-03 10:00:19 +00:00
|
|
|
# copy configuration file
|
|
|
|
cd $workingdir
|
|
|
|
if [ ! -e /var/www/mail/common_config.php ]; then
|
|
|
|
cp common_config.php /var/www/mail/
|
|
|
|
else
|
|
|
|
echo "The script common_config.php was not overridden. Pleas compare manually if changes are necessary."
|
2022-07-02 19:14:28 +00:00
|
|
|
fi
|