2016-04-28 20:34:44 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2016-09-08 08:20:33 +00:00
|
|
|
# This installation script works on Ubuntu 14.04 and 16.04
|
|
|
|
# Run as root!
|
|
|
|
|
|
|
|
if [[ $EUID -ne 0 ]]; then
|
|
|
|
echo "This script must be run as root" 1>&2
|
|
|
|
exit 1
|
|
|
|
fi
|
2016-04-28 20:34:44 +00:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
|
|
|
export DEBIAN_FRONTEND=noninteractive
|
|
|
|
|
|
|
|
apt-add-repository -y ppa:chris-lea/redis-server
|
|
|
|
|
|
|
|
curl -sL https://deb.nodesource.com/setup_6.x | bash -
|
2016-09-08 08:20:33 +00:00
|
|
|
apt-get -q -y install mariadb-server pwgen redis-server nodejs git ufw build-essential dnsutils
|
2016-04-28 20:34:44 +00:00
|
|
|
apt-get clean
|
|
|
|
|
2016-09-08 08:20:33 +00:00
|
|
|
PUBLIC_IP=`curl -s https://api.ipify.org`
|
|
|
|
if [ ! -z "$PUBLIC_IP" ]; then
|
|
|
|
HOSTNAME=`dig +short -x $PUBLIC_IP | sed 's/\.$//'`
|
|
|
|
HOSTNAME="${HOSTNAME:-$PUBLIC_IP}"
|
|
|
|
fi
|
|
|
|
HOSTNAME="${HOSTNAME:-`hostname`}"
|
|
|
|
|
2016-04-28 20:34:44 +00:00
|
|
|
MYSQL_PASSWORD=`pwgen -1`
|
2016-09-08 12:31:38 +00:00
|
|
|
DKIM_API_KEY=`pwgen -1`
|
2016-04-28 20:34:44 +00:00
|
|
|
|
|
|
|
# Setup MySQL user for Mailtrain
|
|
|
|
mysql -u root -e "CREATE USER 'mailtrain'@'localhost' IDENTIFIED BY '$MYSQL_PASSWORD';"
|
2016-06-02 10:05:44 +00:00
|
|
|
mysql -u root -e "GRANT ALL PRIVILEGES ON mailtrain.* TO 'mailtrain'@'localhost';"
|
2016-04-28 20:34:44 +00:00
|
|
|
mysql -u mailtrain --password="$MYSQL_PASSWORD" -e "CREATE database mailtrain;"
|
|
|
|
|
|
|
|
# Enable firewall, allow connections to SSH, HTTP, HTTPS and SMTP
|
|
|
|
ufw allow 22/tcp
|
|
|
|
ufw allow 80/tcp
|
|
|
|
ufw allow 443/tcp
|
|
|
|
ufw allow 25/tcp
|
|
|
|
ufw --force enable
|
|
|
|
|
|
|
|
# Fetch Mailtrain files
|
2016-06-02 09:16:08 +00:00
|
|
|
mkdir -p /opt/mailtrain
|
|
|
|
cd /opt/mailtrain
|
|
|
|
git clone git://github.com/andris9/mailtrain.git .
|
2016-04-28 20:34:44 +00:00
|
|
|
|
2016-09-08 08:20:33 +00:00
|
|
|
# Normally we would let Mailtrain itself to import the initial SQL data but in this case
|
|
|
|
# we need to modify it, before we start Mailtrain
|
|
|
|
mysql -u mailtrain -p"$MYSQL_PASSWORD" mailtrain < setup/sql/mailtrain.sql
|
|
|
|
|
|
|
|
mysql -u mailtrain -p"$MYSQL_PASSWORD" mailtrain <<EOT
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('admin_email','admin@$HOSTNAME') ON DUPLICATE KEY UPDATE \`value\`='admin@$HOSTNAME';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('default_address','admin@$HOSTNAME') ON DUPLICATE KEY UPDATE \`value\`='admin@$HOSTNAME';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('smtp_hostname','localhost') ON DUPLICATE KEY UPDATE \`value\`='localhost';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('smtp_disable_auth','on') ON DUPLICATE KEY UPDATE \`value\`='on';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('smtp_encryption','NONE') ON DUPLICATE KEY UPDATE \`value\`='NONE';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('smtp_port','587') ON DUPLICATE KEY UPDATE \`value\`='587';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('default_homepage','http://$HOSTNAME/') ON DUPLICATE KEY UPDATE \`value\`='http://$HOSTNAME/';
|
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('service_url','http://$HOSTNAME/') ON DUPLICATE KEY UPDATE \`value\`='http://$HOSTNAME/';
|
2016-09-08 12:31:38 +00:00
|
|
|
INSERT INTO \`settings\` (\`key\`, \`value\`) VALUES ('dkim_api_key','http://$DKIM_API_KEY/') ON DUPLICATE KEY UPDATE \`value\`='http://$DKIM_API_KEY/';
|
2016-09-08 08:20:33 +00:00
|
|
|
EOT
|
|
|
|
|
|
|
|
# Add new user for the mailtrain daemon to run as
|
2016-04-28 20:34:44 +00:00
|
|
|
useradd mailtrain || true
|
|
|
|
|
|
|
|
# Setup installation configuration
|
|
|
|
cat >> config/production.toml <<EOT
|
|
|
|
user="mailtrain"
|
|
|
|
group="mailtrain"
|
|
|
|
[log]
|
|
|
|
level="error"
|
|
|
|
[www]
|
|
|
|
port=80
|
|
|
|
secret="`pwgen -1`"
|
|
|
|
[mysql]
|
|
|
|
password="$MYSQL_PASSWORD"
|
|
|
|
[redis]
|
|
|
|
enabled=true
|
|
|
|
[verp]
|
2016-09-08 08:20:33 +00:00
|
|
|
enabled=true
|
2016-04-28 20:34:44 +00:00
|
|
|
EOT
|
|
|
|
|
|
|
|
# Install required node packages
|
|
|
|
npm install --no-progress --production
|
2016-09-08 08:20:33 +00:00
|
|
|
chown -R mailtrain:mailtrain .
|
2016-04-28 20:34:44 +00:00
|
|
|
|
|
|
|
# Setup log rotation to not spend up entire storage on logs
|
|
|
|
cat <<EOM > /etc/logrotate.d/mailtrain
|
|
|
|
/var/log/mailtrain.log {
|
|
|
|
daily
|
|
|
|
rotate 12
|
|
|
|
compress
|
|
|
|
delaycompress
|
|
|
|
missingok
|
|
|
|
notifempty
|
|
|
|
copytruncate
|
|
|
|
nomail
|
|
|
|
}
|
|
|
|
EOM
|
|
|
|
|
2016-06-02 10:25:49 +00:00
|
|
|
if [ -d "/run/systemd/system" ]; then
|
2016-06-02 09:52:14 +00:00
|
|
|
# Set up systemd service script
|
|
|
|
cp setup/mailtrain.service /etc/systemd/system/
|
|
|
|
systemctl enable mailtrain.service
|
|
|
|
else
|
|
|
|
# Set up upstart service script
|
|
|
|
cp setup/mailtrain.conf /etc/init/
|
|
|
|
fi
|
|
|
|
|
2016-09-08 08:20:33 +00:00
|
|
|
# Fetch ZoneMTA files
|
|
|
|
mkdir -p /opt/zone-mta
|
|
|
|
cd /opt/zone-mta
|
|
|
|
git clone git://github.com/zone-eu/zone-mta.git .
|
|
|
|
|
|
|
|
# Ensure queue folder
|
|
|
|
mkdir -p /var/data/mailtrain
|
|
|
|
|
|
|
|
# Setup installation configuration
|
|
|
|
cat >> config/production.json <<EOT
|
|
|
|
{
|
|
|
|
"user": "mailtrain",
|
|
|
|
"group": "mailtrain",
|
|
|
|
"queue": {
|
|
|
|
"db": "/var/data/mailtrain"
|
|
|
|
},
|
|
|
|
"feeder": {
|
|
|
|
"port": 587
|
|
|
|
},
|
|
|
|
"log": {
|
|
|
|
"level": "info"
|
|
|
|
},
|
|
|
|
"bounces": {
|
|
|
|
"enabled": false,
|
|
|
|
"url": "http://localhost/webhooks/zone-mta"
|
2016-09-08 12:31:38 +00:00
|
|
|
},
|
|
|
|
"getSenderConfig": 'http://localhost/webhooks/zone-mta/sender-config?api_token=$DKIM_API_KEY',
|
|
|
|
"zones": {
|
|
|
|
"transactional": {
|
|
|
|
"processes": 1,
|
|
|
|
"connections": 1
|
|
|
|
}
|
2016-09-08 08:20:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
EOT
|
|
|
|
|
|
|
|
# Install required node packages
|
|
|
|
npm install --no-progress --production
|
|
|
|
|
|
|
|
# Setup log rotation to not spend up entire storage on logs
|
|
|
|
cat <<EOM > /etc/logrotate.d/zone-mta
|
|
|
|
/var/log/zone-mta.log {
|
|
|
|
daily
|
|
|
|
rotate 12
|
|
|
|
compress
|
|
|
|
delaycompress
|
|
|
|
missingok
|
|
|
|
notifempty
|
|
|
|
copytruncate
|
|
|
|
nomail
|
|
|
|
}
|
|
|
|
EOM
|
|
|
|
|
|
|
|
chown -R mailtrain:mailtrain .
|
|
|
|
chown -R mailtrain:mailtrain /var/data/mailtrain
|
|
|
|
|
|
|
|
if [ -d "/run/systemd/system" ]; then
|
|
|
|
# Set up systemd service script
|
|
|
|
cp setup/zone-mta.service /etc/systemd/system/
|
|
|
|
systemctl enable zone-mta.service
|
|
|
|
else
|
|
|
|
# Set up upstart service script
|
|
|
|
cp setup/zone-mta.conf /etc/init/
|
|
|
|
fi
|
|
|
|
|
2016-04-28 20:34:44 +00:00
|
|
|
# Start the service
|
2016-09-08 08:20:33 +00:00
|
|
|
service zone-mta start
|
2016-04-28 20:34:44 +00:00
|
|
|
service mailtrain start
|
|
|
|
|
2016-09-08 08:20:33 +00:00
|
|
|
echo "Success! Open http://$HOSTNAME/ and log in as admin:test";
|