Merge branch 'master' of git.oopen.de:install/mailsystem
This commit is contained in:
commit
7e0b7de445
@ -73,3 +73,7 @@
|
|||||||
|
|
||||||
6.) Install OpenDKIM
|
6.) Install OpenDKIM
|
||||||
- run script 'install_opendkim.sh'.
|
- run script 'install_opendkim.sh'.
|
||||||
|
|
||||||
|
|
||||||
|
7.) Install OpenDMARC
|
||||||
|
- run script 'install_opendmarc.sh'.
|
||||||
|
270
dovecot_convert_to_lmtp.sh
Executable file
270
dovecot_convert_to_lmtp.sh
Executable file
@ -0,0 +1,270 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
postfix_main_cf="/etc/postfix/main.cf"
|
||||||
|
|
||||||
|
backup_date="$(date +%Y-%m-%d-%H%M)"
|
||||||
|
changed=false
|
||||||
|
|
||||||
|
log_file="$(mktemp)"
|
||||||
|
|
||||||
|
# -------------
|
||||||
|
# - Functions an Variable
|
||||||
|
# -------------
|
||||||
|
clean_up() {
|
||||||
|
|
||||||
|
|
||||||
|
if [[ -f "$_backup_crontab_file" ]]; then
|
||||||
|
|
||||||
|
echononl "(Re)Install previously saved crontab from '$_backup_crontab_file'.."
|
||||||
|
|
||||||
|
crontab $_backup_crontab_file >> $log_file 2>&1
|
||||||
|
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo -e "$rc_done"
|
||||||
|
else
|
||||||
|
echo -e "$rc_failed"
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Perform program exit housekeeping
|
||||||
|
rm -f $log_file
|
||||||
|
blank_line
|
||||||
|
exit $1
|
||||||
|
}
|
||||||
|
|
||||||
|
fatal(){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[31m\033[1mFatal\033[m ]: \033[37m\033[1m$*\033[m"
|
||||||
|
echo ""
|
||||||
|
echo -e "\t\033[31m\033[1m Skript wird abgebrochen\033[m\033[m\n"
|
||||||
|
rm -f $log_file
|
||||||
|
clean_up 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
echononl(){
|
||||||
|
echo X\\c > /tmp/shprompt$$
|
||||||
|
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
|
||||||
|
echo -e "$*\\c" 1>&2
|
||||||
|
else
|
||||||
|
echo -en "$*" 1>&2
|
||||||
|
fi
|
||||||
|
rm /tmp/shprompt$$
|
||||||
|
}
|
||||||
|
error(){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[31m\033[1mError\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
warn(){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[33m\033[1mWarning\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
info(){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[32m\033[1mInfo\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
echo_done() {
|
||||||
|
echo -e "\033[75G[ \033[32mdone\033[m ]"
|
||||||
|
}
|
||||||
|
echo_ok() {
|
||||||
|
echo -e "\033[75G[ \033[32mok\033[m ]"
|
||||||
|
}
|
||||||
|
echo_warn() {
|
||||||
|
echo -e "\033[75G[ \033[33mwarn\033[m ]"
|
||||||
|
}
|
||||||
|
echo_failed(){
|
||||||
|
echo -e "\033[75G[ \033[1;31mfailed\033[m ]"
|
||||||
|
}
|
||||||
|
echo_skipped() {
|
||||||
|
echo -e "\033[75G[ \033[90m\033[1mskipped\033[m ]"
|
||||||
|
}
|
||||||
|
|
||||||
|
blank_line() {
|
||||||
|
if $terminal ; then
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if [[ ! -f "$postfix_main_cf" ]] ; then
|
||||||
|
fatal "Postfix configuration '${postfix_main_cf}' NOT found!"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ----------
|
||||||
|
# - Some checks ..
|
||||||
|
# ----------
|
||||||
|
# -Is systemd supported on this system?
|
||||||
|
# -
|
||||||
|
systemd_supported=false
|
||||||
|
systemd=$(which systemd)
|
||||||
|
systemctl=$(which systemctl)
|
||||||
|
|
||||||
|
if [[ -n "$systemd" ]] && [[ -n "$systemctl" ]] ; then
|
||||||
|
systemd_supported=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
blank_line
|
||||||
|
|
||||||
|
echononl " Backup Postfix Cconfiguration file '${postfix_main_cf}'.."
|
||||||
|
if [[ ! -f "${postfix_main_cf}.${backup_date}" ]] ; then
|
||||||
|
cp -a "${postfix_main_cf}" "${postfix_main_cf}.${backup_date}" > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
blank_line
|
||||||
|
|
||||||
|
# - /etc/postfix/main.cf
|
||||||
|
# -
|
||||||
|
# - comment in:
|
||||||
|
# - #virtual_transport = dovecot
|
||||||
|
# - #dovecot_destination_recipient_limit = ..
|
||||||
|
# -
|
||||||
|
# - change:
|
||||||
|
# - smtpd_sasl_auth_enable = yes
|
||||||
|
# - smtpd_sasl_type = dovecot
|
||||||
|
# - smtpd_sasl_path = private/dovecot-auth
|
||||||
|
# - virtual_transport = lmtp:unix:private/dovecot-lmtp
|
||||||
|
var="smtpd_sasl_auth_enable"
|
||||||
|
val="yes"
|
||||||
|
echononl " ${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
var="smtpd_sasl_type"
|
||||||
|
val="dovecot"
|
||||||
|
echononl " ${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
var="smtpd_sasl_path"
|
||||||
|
val="private/dovecot-auth"
|
||||||
|
echononl " ${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
var="virtual_transport"
|
||||||
|
val="lmtp:unix:private/dovecot-lmtp"
|
||||||
|
echononl " ${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
changed=true
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echononl " Comment variable 'dovecot_destination_recipient_limit'.."
|
||||||
|
if $(grep -E -q "^\s*dovecot_destination_recipient_limit" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i-n -p -e "s/^(\s*)(dovecot_destination_recipient_limit.*)/\1\#\2/" /etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
blank_line
|
||||||
|
|
||||||
|
# - restart postfix
|
||||||
|
# -
|
||||||
|
echononl " Restart Postfix Service..."
|
||||||
|
if $changed ; then
|
||||||
|
if $systemd_supported ; then
|
||||||
|
systemctl restart postfix > /dev/null 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
/etc/init.d/postfix restart > /dev/null 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
diff "${postfix_main_cf}" "${postfix_main_cf}.${backup_date}" > /dev/null 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
|
||||||
|
info "File \033[1m${postfix_main_cf}\033[m has not changed.
|
||||||
|
\033[32mGoing to remove previos created backup\033[m.."
|
||||||
|
|
||||||
|
echononl " Remove file \033[1m${postfix_main_cf}.${backup_date}\033[m .."
|
||||||
|
rm "${postfix_main_cf}.${backup_date}" > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
clean_up 0
|
523
install_opendmarc.sh
Executable file
523
install_opendmarc.sh
Executable file
@ -0,0 +1,523 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
clear
|
||||||
|
echo -e "\n \033[32mStart Installation of OpenDMARC..\033[m"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# -------------
|
||||||
|
# - Settings
|
||||||
|
# -------------
|
||||||
|
|
||||||
|
#_src_base_dir="$(realpath $(dirname $0))"
|
||||||
|
#conf_file="${_src_base_dir}/conf/install_opendmarc.conf"
|
||||||
|
|
||||||
|
_opendmarc_packages="opendmarc"
|
||||||
|
|
||||||
|
opendmarc_base_dir="/etc/opendmarc"
|
||||||
|
opendmarc_conf_file="/etc/opendmarc.conf"
|
||||||
|
|
||||||
|
postfix_spool_dir="/var/spool/postfix"
|
||||||
|
|
||||||
|
opendmarc_socket_dir="${postfix_spool_dir}/opendmarc"
|
||||||
|
opendmarc_socket_file="${opendmarc_socket_dir}/opendmarc.sock"
|
||||||
|
|
||||||
|
config_file_name_value_parameters="
|
||||||
|
AuthservID|OpenDMARC
|
||||||
|
PidFile|/run/opendmarc/opendmarc.pid
|
||||||
|
RejectFailures|true
|
||||||
|
Syslog|true
|
||||||
|
SyslogFacility|mail
|
||||||
|
TrustedAuthservIDs|$(hostname -f)
|
||||||
|
IgnoreHosts|/etc/opendmarc/ignore.hosts
|
||||||
|
IgnoreAuthenticatedClients|true
|
||||||
|
RequiredHeaders|true
|
||||||
|
UMask|002
|
||||||
|
FailureReports|false
|
||||||
|
AutoRestart|true
|
||||||
|
HistoryFile|/run/opendmarc/opendmarc.dat
|
||||||
|
SPFSelfValidate|true
|
||||||
|
Socket|${opendmarc_socket_file}
|
||||||
|
"
|
||||||
|
declare -a config_file_name_value_parameter_arr=()
|
||||||
|
for _conf in $config_file_name_value_parameters ; do
|
||||||
|
config_file_name_value_parameter_arr+=("$_conf")
|
||||||
|
done
|
||||||
|
|
||||||
|
postfix_needs_restart=false
|
||||||
|
opendmarc_needs_restart=false
|
||||||
|
|
||||||
|
backup_date="$(date +%Y-%m-%d-%H%M)"
|
||||||
|
log_file="$(mktemp)"
|
||||||
|
|
||||||
|
# -------------
|
||||||
|
# --- Some functions
|
||||||
|
# -------------
|
||||||
|
echononl(){
|
||||||
|
echo X\\c > /tmp/shprompt$$
|
||||||
|
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
|
||||||
|
echo -e -n "$*\\c" 1>&2
|
||||||
|
else
|
||||||
|
echo -e -n "$*" 1>&2
|
||||||
|
fi
|
||||||
|
rm /tmp/shprompt$$
|
||||||
|
}
|
||||||
|
|
||||||
|
fatal(){
|
||||||
|
echo ""
|
||||||
|
echo -e "fatal error: $*"
|
||||||
|
echo ""
|
||||||
|
echo -e "\t\033[31m\033[1mInstalllation will be interrupted\033[m\033[m"
|
||||||
|
echo ""
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
error(){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[31m\033[1mFehler\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
warn (){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[33m\033[1mWarning\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
info (){
|
||||||
|
echo ""
|
||||||
|
echo -e "\t[ \033[32m\033[1mInfo\033[m ]: $*"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
|
||||||
|
echo_done() {
|
||||||
|
echo -e "\033[80G[ \033[32mdone\033[m ]"
|
||||||
|
}
|
||||||
|
echo_ok() {
|
||||||
|
echo -e "\033[80G[ \033[32mok\033[m ]"
|
||||||
|
}
|
||||||
|
echo_warning() {
|
||||||
|
echo -e "\033[80G[ \033[33m\033[1mwarn\033[m ]"
|
||||||
|
}
|
||||||
|
echo_failed(){
|
||||||
|
echo -e "\033[80G[ \033[1;31mfailed\033[m ]"
|
||||||
|
}
|
||||||
|
echo_skipped() {
|
||||||
|
echo -e "\033[80G[ \033[37mskipped\033[m ]"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# -------------
|
||||||
|
# - Some pre-installation tasks
|
||||||
|
# -------------
|
||||||
|
|
||||||
|
# - Is 'systemd' supported on this system
|
||||||
|
# -
|
||||||
|
if [ "X`which systemd`" = "X" ]; then
|
||||||
|
SYSTEMD_EXISTS=false
|
||||||
|
else
|
||||||
|
SYSTEMD_EXISTS=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# =============
|
||||||
|
# - Start Installation
|
||||||
|
# =============
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# - Synchronise package index files with the repository
|
||||||
|
# -
|
||||||
|
echononl " Synchronise package index files with the repository.."
|
||||||
|
apt-get update > "$log_file" 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Install opendmarc
|
||||||
|
# -
|
||||||
|
echononl " Install needed debian packages.."
|
||||||
|
opendmarc_packages=""
|
||||||
|
packages_installed=false
|
||||||
|
for _pkg in $_opendmarc_packages ; do
|
||||||
|
if aptitude search "$_pkg" | grep " $_pkg " | grep -e "^i" > /dev/null 2>&1 ; then
|
||||||
|
continue
|
||||||
|
else
|
||||||
|
opendmarc_packages="$opendmarc_packages $_pkg"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [[ -n "$opendmarc_packages" ]]; then
|
||||||
|
DEBIAN_FRONTEND=noninteractive apt-get -y install $opendmarc_packages > /dev/null 2> "$log_file"
|
||||||
|
packages_installed=true
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Add user 'postfix' to group 'opendmarc'
|
||||||
|
# -
|
||||||
|
echononl " Add user 'postfix' to group 'opendmarc'.."
|
||||||
|
if grep -E "^opendmarc" /etc/group | grep -q postfix 2> /dev/null ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
usermod -a -G opendmarc postfix > "$log_file" 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Save configuration file from distribution
|
||||||
|
# -
|
||||||
|
echononl " Save configuration file from distribution"
|
||||||
|
if [[ -f "${opendmarc_conf_file}.ORIG" ]] ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
cp -a $opendmarc_conf_file $opendmarc_conf_file.ORIG 2> "$log_file"
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
for _val in "${config_file_name_value_parameter_arr[@]}" ; do
|
||||||
|
IFS='|' read -a _val_arr <<< "${_val}"
|
||||||
|
|
||||||
|
echononl " $opendmarc_conf_file: ${_val_arr[0]} -> ${_val_arr[1]}.."
|
||||||
|
if $(grep -E -q "^\s*${_val_arr[0]}\s+${_val_arr[1]}\s*$" $opendmarc_conf_file 2> /dev/null) ; then
|
||||||
|
echo_skipped
|
||||||
|
elif $(grep -E -q "^\s*#\s*${_val_arr[0]}\s+" $opendmarc_conf_file 2> /dev/null); then
|
||||||
|
perl -i -n -p -e "s&^(\s*#\s*${_val_arr[0]}.*)&\1\n${_val_arr[0]} ${_val_arr[1]}&" $opendmarc_conf_file > "$log_file" 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
elif $(grep -E -q "^\s*${_val_arr[0]}\s+" $opendmarc_conf_file 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*${_val_arr[0]}.*)#\#\1\n${_val_arr[0]} ${_val_arr[1]}#" $opendmarc_conf_file > "$log_file" 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
cat <<EOF >> $opendmarc_conf_file 2> "$log_file"
|
||||||
|
|
||||||
|
${_val_arr[0]} ${_val_arr[1]}
|
||||||
|
EOF
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
# - Assign ownership to the opendmarc user and restrict tthe
|
||||||
|
# - file permissions:
|
||||||
|
# -
|
||||||
|
echononl " Assign file permissions to '$opendmarc_conf_file'.."
|
||||||
|
chmod u=rw,go=r $opendmarc_conf_file 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Create the directories to hold opendmarc's data files, assign
|
||||||
|
# - ownership to the opendmarc user, and restrict the file
|
||||||
|
# - permissions:
|
||||||
|
# -
|
||||||
|
echononl " Create directory '$opendmarc_base_dir'"
|
||||||
|
if [[ -d "$opendmarc_base_dir" ]] ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
mkdir ${opendmarc_base_dir} 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
echononl " Set ownership on directory '${opendmarc_base_dir}' (recursive).."
|
||||||
|
chown -R opendmarc:opendmarc ${opendmarc_base_dir} 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# - Create the file ${opendmarc_base_dir}/ignore.hosts
|
||||||
|
# -
|
||||||
|
echononl " Create file '${opendmarc_base_dir}/ignore.hosts'.."
|
||||||
|
if [[ -f "${opendmarc_base_dir}/ignore.hosts" ]] ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
cat <<EOF > ${opendmarc_base_dir}/ignore.hosts 2> $log_file
|
||||||
|
# We are using AmaViS at 'localhost 127.0.0.1 . So we cannot bypass them
|
||||||
|
#
|
||||||
|
# 127.0.0.1
|
||||||
|
# localhost
|
||||||
|
$(hostname -f)
|
||||||
|
EOF
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Edit /etc/default/opendmarc
|
||||||
|
# -
|
||||||
|
# - Set:
|
||||||
|
# - SOCKET="local:${postfix_spool_dir}/opendmarc/opendmarc.sock"
|
||||||
|
# -
|
||||||
|
echononl " Set 'SOCKET' at file /etc/default/opendmarc.."
|
||||||
|
if grep -q -E "^\s*SOCKET" /etc/default/opendmarc 2>/dev/null ; then
|
||||||
|
if grep -q -E "^\s*SOCKET\s*=\s*\"*local:$opendmarc_socket_file" /etc/default/opendmarc 2>/dev/null ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
perl -i -n -p -e "s#^\s*SOCKET=.*#SOCKET=\"local:$opendmarc_socket_file\"#" /etc/default/opendmarc 2> $log_file
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
cat <<EOF >>/etc/default/opendmarc 2> $log_file
|
||||||
|
SOCKET="local:$opendmarc_socket_file"
|
||||||
|
EOF
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Create the opendmarc socket directory in Postfix’s work area
|
||||||
|
# - and make sure it has the correct ownership:
|
||||||
|
# -
|
||||||
|
echononl " Create the opendmarc socket directory in Postfix's work area.."
|
||||||
|
if [[ -d "${postfix_spool_dir}/opendmarc" ]] ; then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
mkdir ${postfix_spool_dir}/opendmarc 2> $log_file
|
||||||
|
opendmarc_needs_restart=true
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
echononl " Set ownership on directory '${postfix_spool_dir}/opendmarc'.."
|
||||||
|
chown opendmarc:postfix ${postfix_spool_dir}/opendmarc 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Edit /etc/postfix/main.cf and add a section to activate
|
||||||
|
# - processing of e-mail through the opendmarc daemon:
|
||||||
|
# -
|
||||||
|
echononl " Backup existing postfix configuration (main.cf).."
|
||||||
|
cp -a /etc/postfix/main.cf /etc/postfix/main.cf.$backup_date 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echononl " Set Variable non_smtpd_milters at '/etc/postfix/main.cf'.."
|
||||||
|
if $(grep -q -E "^\s*non_smtpd_milters\s*=\s*.*opendkim.sock" /etc/postfix/main.cf 2> /dev/null) ; then
|
||||||
|
if $(grep -q -E "^\s*non_smtpd_milters\s*=\s*.*$(basename "${opendmarc_socket_file}")" /etc/postfix/main.cf); then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
perl -i -n -p -e "s&^\s*(non_smtpd_milters\s*=.*opendkim.sock)&\1,local:/$(basename "${opendmarc_socket_dir}")/$(basename "${opendmarc_socket_file}")&" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
postfix_needs_restart=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
warn "Postfix is not adjusted. Complete Postfix configuration (main.cf) manually\!"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Prevent Postfix from setting the DMARC Header twice (one befor
|
||||||
|
# - and one after processing amavis
|
||||||
|
# -
|
||||||
|
# - To disable milter processing after amavis, add to your master.cf in
|
||||||
|
# - the after-amavis section:
|
||||||
|
# - 127.0.0.1:10025 inet n - - - - smtpd
|
||||||
|
# - [...]
|
||||||
|
# - -o smtpd_milters=
|
||||||
|
# -
|
||||||
|
# - If you want to run the milter after amavis, set in main.cf
|
||||||
|
# - smtpd_milters=
|
||||||
|
# - to an empty string and add the smtpd_milters configuration to master.cf
|
||||||
|
# - (after-section amavis) instead:
|
||||||
|
# - -o smtpd_milters=local:/opendmarc/opendmarc.sock
|
||||||
|
# -
|
||||||
|
echononl " Backup file '/etc/postfix/master.cf'.."
|
||||||
|
cp -a /etc/postfix/master.cf /etc/postfix/master.cf.${backup_date} 2> $log_file
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echononl " Adjust /etc/postfix/master.cf. Set DMARC after sending throuh AmaVIS.."
|
||||||
|
if $(grep -q -E "^\s*-o\s+smtpd_milters\s*=\s*.*opendkim.sock" /etc/postfix/master.cf 2> /dev/null) ; then
|
||||||
|
if $(grep -q -E "^\s*-o\s+smtpd_milters\s*=\s*.*$(basename ${opendmarc_socket_file})" /etc/postfix/master.cf); then
|
||||||
|
echo_skipped
|
||||||
|
else
|
||||||
|
perl -i -n -p -e "s&(^\s*-o\s+smtpd_milters\s*=.*)&\1,local:/$(basename "${opendmarc_socket_dir}")/$(basename "${opendmarc_socket_file}")&" \
|
||||||
|
/etc/postfix/master.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
postfix_needs_restart=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
warn "Postfix is not adjusted. Complete Postfix configuration (master.cf) manually\!"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
echononl " Enable OpenDMARC Service"
|
||||||
|
if $SYSTEMD_EXISTS ; then
|
||||||
|
systemctl enable opendmarc > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
warn "Maybe OpenDMARC Service is not enabled, because its an old non-systemd os.."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# - Restart opendmarc
|
||||||
|
# -
|
||||||
|
echononl " Restart opendmarc.."
|
||||||
|
if $opendmarc_needs_restart ; then
|
||||||
|
if $SYSTEMD_EXISTS ; then
|
||||||
|
systemctl restart opendmarc > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
/etc/init.d/opendmarc restart > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
# - Restart Postfix so it starts using opendmarc when processing mail:
|
||||||
|
# -
|
||||||
|
echononl " Restart Postfix.."
|
||||||
|
if $postfix_needs_restart ; then
|
||||||
|
if $SYSTEMD_EXISTS ; then
|
||||||
|
systemctl restart postfix > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
/etc/init.d/postfix restart > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $log_file)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
if [[ -f "/etc/postfix/master.cf.${backup_date}" ]] ; then
|
||||||
|
if $(diff "/etc/postfix/master.cf" "/etc/postfix/master.cf.${backup_date}"> /dev/null 2>&1) ; then
|
||||||
|
info "File \033[1m/etc/postfix/master.cf\033[m has not changed.\n\t Removing previos created backup.."
|
||||||
|
rm "/etc/postfix/master.cf.${backup_date}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ -f "/etc/postfix/main.cf.${backup_date}" ]] ; then
|
||||||
|
if $(diff "/etc/postfix/main.cf" "/etc/postfix/main.cf.${backup_date}"> /dev/null 2>&1) ; then
|
||||||
|
info "File \033[1m/etc/postfix/main.cf\033[m has not changed.\n\t Removing previos created backup.."
|
||||||
|
rm "/etc/postfix/main.cf.${backup_date}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
rm -f "$log_file"
|
||||||
|
exit 0
|
@ -976,6 +976,25 @@ else
|
|||||||
echo_skipped
|
echo_skipped
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
echononl " Enable Postfix firewall daemon at boot time .."
|
||||||
|
if $systemd_exists ; then
|
||||||
|
systemctl enable postfwd > /dev/null 2> $tmp_err_msg
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $tmp_err_msg)"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
update-rc.d postfwd defaults > /dev/null 2> $tmp_err_msg
|
||||||
|
if [[ $? -eq 0 ]] ; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat $tmp_err_msg)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
echononl " Restart Postfix firewall daemon 'postfwd'.."
|
echononl " Restart Postfix firewall daemon 'postfwd'.."
|
||||||
if $systemd_exists ; then
|
if $systemd_exists ; then
|
||||||
systemctl restart postfwd > /dev/null 2> $tmp_err_msg
|
systemctl restart postfwd > /dev/null 2> $tmp_err_msg
|
||||||
@ -1081,14 +1100,17 @@ mynetworks =
|
|||||||
${IPV4}/32
|
${IPV4}/32
|
||||||
[${IPV6}]/128
|
[${IPV6}]/128
|
||||||
# a.mx.oopen.de
|
# a.mx.oopen.de
|
||||||
#83.223.86.91
|
#95.217.204.247/32
|
||||||
#[2a01:30:0:13:2f7:50ff:fed2:cef7]/128
|
#[2a01:4f9:4a:47e5::247]/128
|
||||||
# b.mx.oopen.de
|
# b.mx.oopen.de
|
||||||
#83.223.86.97
|
#83.223.86.97/32
|
||||||
#[2a01:30:0:13:21f:92ff:fe00:538b]
|
#[2a01:30:0:13:21f:92ff:fe00:538b]/128
|
||||||
# d.mx.oopen.de
|
# d.mx.oopen.de
|
||||||
#83.223.86.92/32
|
#95.217.204.227/32
|
||||||
#[2a01:30:0:13:254:9eff:fed5:e7fd]/128
|
#[2a01:4f9:4a:47e5::227]/128
|
||||||
|
# e.mx.oopen.de
|
||||||
|
#95.217.204.205/32
|
||||||
|
#[2a01:4f9:4a:47e5::205]/128
|
||||||
|
|
||||||
smtp_bind_address = $IPV4
|
smtp_bind_address = $IPV4
|
||||||
smtp_bind_address6 = $IPV6
|
smtp_bind_address6 = $IPV6
|
||||||
@ -1517,6 +1539,7 @@ cat <<EOF >> /etc/postfix/main.cf
|
|||||||
## -
|
## -
|
||||||
## - using dovecot lda
|
## - using dovecot lda
|
||||||
## - virtual_transport = dovecot
|
## - virtual_transport = dovecot
|
||||||
|
## - dovecot_destination_recipient_limit = 1
|
||||||
## -
|
## -
|
||||||
## - using dovecot's lmtp service
|
## - using dovecot's lmtp service
|
||||||
## - virtual_transport = lmtp:unix:private/dovecot-lmtp
|
## - virtual_transport = lmtp:unix:private/dovecot-lmtp
|
||||||
@ -1624,6 +1647,23 @@ smtpd_client_restrictions =
|
|||||||
#
|
#
|
||||||
permit_dnswl_client dnswl.oopen.de,
|
permit_dnswl_client dnswl.oopen.de,
|
||||||
# Blacklists
|
# Blacklists
|
||||||
|
#
|
||||||
|
# - rhs stands for right hand side, i.e, the domain name.
|
||||||
|
#
|
||||||
|
# - reject_rhsbl_helo makes Postfix reject email when the client HELO or EHLO hostname is blacklisted.
|
||||||
|
#
|
||||||
|
# - reject_rhsbl_reverse_client: reject the email when the unverified reverse client hostname is
|
||||||
|
# blacklisted. Postfix will fetch the client hostname from PTR record. If the hostname is
|
||||||
|
# blacklisted, reject the email.
|
||||||
|
#
|
||||||
|
# - reject_rhsbl_sender makes Postfix reject email when the MAIL FROM domain is blacklisted.
|
||||||
|
#
|
||||||
|
# - reject_rbl_client: This is an IP-based blacklist. When the client IP address is backlisted,
|
||||||
|
# reject the email.
|
||||||
|
#
|
||||||
|
reject_rhsbl_helo dbl.spamhaus.org,
|
||||||
|
reject_rhsbl_reverse_client dbl.spamhaus.org,
|
||||||
|
reject_rhsbl_sender dbl.spamhaus.org,
|
||||||
reject_rbl_client zen.spamhaus.org,
|
reject_rbl_client zen.spamhaus.org,
|
||||||
reject_rbl_client ix.dnsbl.manitu.net,
|
reject_rbl_client ix.dnsbl.manitu.net,
|
||||||
# Greylisting check
|
# Greylisting check
|
||||||
@ -1691,6 +1731,7 @@ smtpd_sender_restrictions =
|
|||||||
permit_sasl_authenticated,
|
permit_sasl_authenticated,
|
||||||
reject_unknown_sender_domain,
|
reject_unknown_sender_domain,
|
||||||
reject_non_fqdn_sender
|
reject_non_fqdn_sender
|
||||||
|
reject_unknown_reverse_client_hostname
|
||||||
|
|
||||||
|
|
||||||
## ---
|
## ---
|
||||||
|
@ -573,7 +573,7 @@ mkdir -p $_log_dir
|
|||||||
cd ${_src_base_dir}
|
cd ${_src_base_dir}
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "Download sources.."
|
echo -e "\033[1mDownload sources\033[m.."
|
||||||
|
|
||||||
## - Downloud Dovecot 2.2.x
|
## - Downloud Dovecot 2.2.x
|
||||||
## -
|
## -
|
||||||
@ -668,7 +668,7 @@ fi
|
|||||||
## - Create Users/groups needed for dovecot
|
## - Create Users/groups needed for dovecot
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "Create required users/groups.."
|
echo -e "\033[1mCreate required users/groups\033[m.."
|
||||||
echononl "\tCreate group dovecot.."
|
echononl "\tCreate group dovecot.."
|
||||||
if ! grep dovecot /etc/group > /dev/null ; then
|
if ! grep dovecot /etc/group > /dev/null ; then
|
||||||
addgroup --system --gid 91 dovecot > ${_log_dir}/system.log 2>&1
|
addgroup --system --gid 91 dovecot > ${_log_dir}/system.log 2>&1
|
||||||
@ -773,7 +773,7 @@ fi
|
|||||||
## --- Install Base System
|
## --- Install Base System
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "Installing Base System.."
|
echo -e "\033[1mInstalling Base System\033[m.."
|
||||||
|
|
||||||
## - Unpack dovecot sources
|
## - Unpack dovecot sources
|
||||||
## -
|
## -
|
||||||
@ -950,7 +950,7 @@ fi
|
|||||||
|
|
||||||
_failed=false
|
_failed=false
|
||||||
echo ""
|
echo ""
|
||||||
echo "Configure Dovecot.."
|
echo -e "\033[1mConfigure Dovecot\033[m.."
|
||||||
|
|
||||||
## - Copy example config files to the config directory
|
## - Copy example config files to the config directory
|
||||||
## -
|
## -
|
||||||
@ -2757,7 +2757,7 @@ fi # if $_new
|
|||||||
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo -e "Change (from lda) to lmtp-service"
|
echo -e "\033[1mChange (from lda) to lmtp-service\033[m"
|
||||||
|
|
||||||
## -----------------
|
## -----------------
|
||||||
## --- Change (from lda) to lmtp-service
|
## --- Change (from lda) to lmtp-service
|
||||||
@ -2797,52 +2797,107 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
#if $_new ; then
|
# - /etc/postfix/main.cf
|
||||||
#
|
# -
|
||||||
# ## - /etc/postfix/main.cf
|
# - comment in:
|
||||||
# ## -
|
# - #virtual_transport = dovecot
|
||||||
# ## - comment in:
|
# - #dovecot_destination_recipient_limit = ..
|
||||||
# ## - #virtual_transport = dovecot
|
# -
|
||||||
# ## -
|
# - change:
|
||||||
# ## - change:
|
# - smtpd_sasl_auth_enable = yes
|
||||||
# ## - smtpd_sasl_auth_enable = yes
|
# - smtpd_sasl_type = dovecot
|
||||||
# ## - smtpd_sasl_type = dovecot
|
# - smtpd_sasl_path = private/dovecot-auth
|
||||||
# ## - smtpd_sasl_path = private/dovecot-auth
|
# - virtual_transport = lmtp:unix:private/dovecot-lmtp
|
||||||
# ## - virtual_transport = lmtp:unix:private/dovecot-lmtp
|
var="smtpd_sasl_auth_enable"
|
||||||
# _failed=false
|
val="yes"
|
||||||
# echononl "\tAdjust /etc/postfix/main.cf"
|
echononl "\t${postfix_main_cf}: adjust '${var}'.."
|
||||||
# perl -i -n -p -e "s#^(\s*)(smtpd_sasl_auth_enable\ *=.*)#smtpd_sasl_auth_enable = yes#" \
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
# /etc/postfix/main.cf || _failed=true
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
# #perl -i -n -p -e "s#^(\s*)(smtpd_sasl_type\ *=.*)#\1\#\2\n\1smtpd_sasl_type = dovecot#" \
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
# perl -i -n -p -e "s#^(\s*)(smtpd_sasl_type\ *=.*)#smtpd_sasl_type = dovecot#" \
|
if [[ $? -eq 0 ]]; then
|
||||||
# /etc/postfix/main.cf || _failed=true
|
echo_ok
|
||||||
# #perl -i -n -p -e "s#^(\s*)(smtpd_sasl_path\ *=.*)#\1\#\2\n\1smtpd_sasl_path = private/dovecot-auth#" \
|
changed=true
|
||||||
# # /etc/postfix/main.cf || _failed=true
|
else
|
||||||
# perl -i -n -p -e "s#^(\s*)(smtpd_sasl_path\ *=.*)#smtpd_sasl_path = private/dovecot-auth#" \
|
echo_failed
|
||||||
# /etc/postfix/main.cf || _failed=true
|
error "$(cat "$log_file")"
|
||||||
#
|
fi
|
||||||
#
|
else
|
||||||
#
|
echo_skipped
|
||||||
# #perl -i -n -p -e "s#^(\s*)(virtual_transport\ *=.*)#\1\#\2\n\1virtual_transport = lmtp:unix:private/dovecot-lmtp#" \
|
fi
|
||||||
# # /etc/postfix/main.cf || _failed=true
|
|
||||||
# perl -i -n -p -e "s#^(\s*)(virtual_transport\ *=.*)#virtual_transport = lmtp:unix:private/dovecot-lmtp#" \
|
var="smtpd_sasl_type"
|
||||||
# /etc/postfix/main.cf || _failed=true
|
val="dovecot"
|
||||||
# perl -i-n -p -e "s#^(\s*)(dovecot_destination_recipient_limit.*)#\1\#\2#" /etc/postfix/main.cf || _failed=true
|
echononl "\t${postfix_main_cf}: adjust '${var}'.."
|
||||||
# if ! $_failed ; then
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
# echo -e "$rc_done"
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
# else
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
# echo -e "$rc_failed"
|
if [[ $? -eq 0 ]]; then
|
||||||
# fatal "Adjusting /etc/postfix/main.cf failed"
|
echo_ok
|
||||||
# fi
|
changed=true
|
||||||
#
|
else
|
||||||
#fi
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
var="smtpd_sasl_path"
|
||||||
|
val="private/dovecot-auth"
|
||||||
|
echononl "\t${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
var="virtual_transport"
|
||||||
|
val="lmtp:unix:private/dovecot-lmtp"
|
||||||
|
echononl "\t${postfix_main_cf}: adjust '${var}'.."
|
||||||
|
if ! $(grep -E -q "^\s*${var}\s*=\s*${val}" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i -n -p -e "s#^(\s*)(${var}\ *=.*)#${var} = ${val}#" \
|
||||||
|
/etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
changed=true
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
echononl "\tComment variable 'dovecot_destination_recipient_limit'.."
|
||||||
|
if $(grep -E -q "^\s*dovecot_destination_recipient_limit" ${postfix_main_cf} 2> /dev/null) ; then
|
||||||
|
perl -i-n -p -e "s/^(\s*)(dovecot_destination_recipient_limit.*)/\1\#\2/" /etc/postfix/main.cf > $log_file 2>&1
|
||||||
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo_ok
|
||||||
|
changed=true
|
||||||
|
else
|
||||||
|
echo_failed
|
||||||
|
error "$(cat "$log_file")"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo_skipped
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## -----------------
|
## -----------------
|
||||||
## --- Configure quota support for dovecot
|
## --- Configure quota support for dovecot
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo -e "Configure quota support for dovecot"
|
echo -e "\033[1mConfigure quota support for dovecot\033[m"
|
||||||
|
|
||||||
|
|
||||||
## - take care quota plugins (quota,imap-quota) will
|
## - take care quota plugins (quota,imap-quota) will
|
||||||
|
Loading…
Reference in New Issue
Block a user