1,13 → 1,17 |
#!/bin/bash |
|
########################################################################################### |
## ALCASAR SERVICE MAIL INSTALL |
## ALCASAR MAIL SERVICE CONFIGURATION |
## |
## Script by K@M3L & T3RRY (LaPlateform), joss_p & Rexy |
## This script configure the mail conf file and execute the configuration from the acc. |
## This script configure PostFix |
## 0 : no email autoregistration |
## 1 : PostFix is the SMTP server |
## 2 : PostFix relay to an other SMTP server |
## 2 : PostFix use an external email address (with SASL) |
########################################################################################### |
|
# ****** Paths - chemin des commandes ******* |
# ****** Paths ******* |
SED="/bin/sed -i" |
CONF_FILE="/usr/local/etc/alcasar.conf" |
POSTFIX_CONF_FILE="/etc/postfix/main.cf" |
14,17 → 18,30 |
LOCAL_IPTABLE_FILE="/usr/local/etc/alcasar-iptables-local.sh" |
SASLPATH="/etc/postfix/sasl" |
smtpIP="0.0.0.0/0" |
usage="Usage: alcasar-mail_install.sh -h|-0|-1|-2|-3" |
|
usage="Usage: alcasar-mail_install.sh 0|1|2|3" |
nb_args=$# |
if [ $nb_args -eq 0 ] |
if [ $nb_args -eq 0 ] # apply alcasar.conf |
then |
echo "$usage" |
exit 0 |
fi |
if [[ ${#} -ne 0 ]] |
then |
while getopts ":s:p:r:m:o:a:w:0123" option |
mail=`grep ^MAIL= $CONF_FILE|cut -d"=" -f2` |
if [ "$mail" = "off" ]; then |
TYPE_MAIL=0 |
else |
TYPE_MAIL=`grep ^MAIL_TYPE= $CONF_FILE|cut -d"=" -f2` |
smtp=`grep ^MAIL_SMTP= $CONF_FILE|cut -d"=" -f2` |
port=`grep ^MAIL_PORT= $CONF_FILE|cut -d"=" -f2` |
smtpIP=`grep ^MAIL_SMTP_IP= $CONF_FILE|cut -d"=" -f2` |
mailAddr=`grep ^MAIL_ADDR= $CONF_FILE|cut -d"=" -f2` |
mailMdp=`grep ^MAIL_PASSWORD= $CONF_FILE|cut -d"=" -f2` |
adminMail=`grep ^MAIL_ADMIN= $CONF_FILE|cut -d"=" -f2` |
whiteDomain=`grep ^MAIL_WHTEDOMAIN= $CONF_FILE|cut -d"=" -f2` |
fi |
else # apply args |
if [ "$1" = "-h" ] || [ "$1" = "--h" ]; then |
echo $usage |
exit 0 |
fi |
while getopts ":h:s:p:r:m:o:a:w:0123" option |
do |
case $option in |
0) |
71,6 → 88,7 |
esac |
done |
fi |
echo "Type=$TYPE_MAIL - smtp=$smtp - port=$port - smtpIP=$smtpIP - mailAddr=$mailAddr - mailMdp=$mailMdp - adminMail=$adminMail - whitedomain=$whiteDomain" |
if [[ $TYPE_MAIL -eq 0 ]]; then # disable mail service |
$SED "s/^MAIL=.*/MAIL=off/" $CONF_FILE |
$SED "s/^MAIL_TYPE=.*/MAIL_TYPE=/" $CONF_FILE |
78,12 → 96,13 |
$SED "s/^MAIL_SMTP_IP=.*/MAIL_SMTP_IP=/" $CONF_FILE |
$SED "s/^MAIL_PORT=.*/MAIL_PORT=/" $CONF_FILE |
$SED "s/^MAIL_ADDR=.*/MAIL_ADDR=/" $CONF_FILE |
$SED "s/^MAIL_PASSWORD=.*/MAIL_PASSWORD=/" $CONF_FILE |
$SED "s/^MAIL_WHITEDOMAIN=.*/MAIL_WHITEDOMAIN=/" $CONF_FILE |
$SED "s/^MAIL_ADMIN=.*/MAIL_ADMIN=/" $CONF_FILE |
$SED "/^SMTP_IP=/ s/^/#/" $LOCAL_IPTABLE_FILE |
$SED "/^SMTP_PORT=/ s/^/#/" $LOCAL_IPTABLE_FILE |
$SED "/^\$IPTABLES -A OUTPUT -p tcp --dport \$SMTP_PORT.*/#\$IPTABLES -A OUTPUT -p tcp --dport \$SMTP_PORT -d \$SMTP_IP -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT/" $LOCAL_IPTABLE_FILE |
$SED "/^\$IPTABLES -A INPUT -p tcp --sport \$SMTP_PORT.*/#\$IPTABLES -A INPUT -p tcp --sport \$SMTP_PORT -s \$SMTP_IP -m conntrack --ctstate ESTABLISHED -j ACCEPT/" $LOCAL_IPTABLE_FILE |
$SED "s/^\$IPTABLES -A OUTPUT -p tcp --dport \$SMTP_PORT.*/#\$IPTABLES -A OUTPUT -p tcp --dport \$SMTP_PORT -d \$SMTP_IP -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT/" $LOCAL_IPTABLE_FILE |
$SED "s/^\$IPTABLES -A INPUT -p tcp --sport \$SMTP_PORT.*/#\$IPTABLES -A INPUT -p tcp --sport \$SMTP_PORT -s \$SMTP_IP -m conntrack --ctstate ESTABLISHED -j ACCEPT/" $LOCAL_IPTABLE_FILE |
$SED "s/^relayhost =.*/relayhost =/" $POSTFIX_CONF_FILE |
[ -e ${SASLPATH}/sasl_passwd ] && rm -f ${SASLPATH}/sasl_passwd |
elif [[ $TYPE_MAIL -eq 2 ]]; then # Enable mail service (relaying to an extern mail server) |
93,6 → 112,7 |
$SED "s/^MAIL_SMTP_IP=.*/MAIL_SMTP_IP=$smtpIP/" $CONF_FILE |
$SED "s/^MAIL_PORT=.*/MAIL_PORT=$port/" $CONF_FILE |
$SED "s/^MAIL_ADDR=.*/MAIL_ADDR=/" $CONF_FILE |
$SED "s/^MAIL_PASSWORD=.*/MAIL_PASSWORD=/" $CONF_FILE |
$SED "s/^MAIL_WHITEDOMAIN=.*/MAIL_WHITEDOMAIN=$whiteDomain/" $CONF_FILE |
$SED "s/^MAIL_ADMIN=.*/MAIL_ADMIN=$adminMail/" $CONF_FILE |
$SED "s/^#SMTP_IP=.*/SMTP_IP=$smtpIP/" $LOCAL_IPTABLE_FILE |
108,6 → 128,7 |
$SED "s/^MAIL_SMTP_IP=.*/MAIL_SMTP_IP=$smtpIP/" $CONF_FILE |
$SED "s/^MAIL_PORT=.*/MAIL_PORT=$port/" $CONF_FILE |
$SED "s/^MAIL_ADDR=.*/MAIL_ADDR=$mailAddr/" $CONF_FILE |
$SED "s/^MAIL_PASSWORD=.*/MAIL_PASSWORD=$mailMdp/" $CONF_FILE |
$SED "s/^MAIL_WHITEDOMAIN=.*/MAIL_WHITEDOMAIN=$whiteDomain/" $CONF_FILE |
$SED "s/^MAIL_ADMIN=.*/MAIL_ADMIN=$adminMail/" $CONF_FILE |
$SED "s/^#SMTP_IP=.*/SMTP_IP=$smtpIP/" $LOCAL_IPTABLE_FILE |