scripts: housekeeping & cleanup setup (2/2) (#3123)

This commit is contained in:
Georg Lauterbach 2023-02-28 10:25:23 +01:00 committed by GitHub
parent 9ead9a54ac
commit dfc2b39308
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 152 additions and 160 deletions

View file

@ -5,7 +5,7 @@ source /usr/local/bin/helpers/log.sh
# shellcheck source=../scripts/startup/setup.d/fetchmail.sh # shellcheck source=../scripts/startup/setup.d/fetchmail.sh
source /usr/local/bin/setup.d/fetchmail.sh source /usr/local/bin/setup.d/fetchmail.sh
_setup_fetchmail ENABLE_FETCHMAIL=1 _setup_fetchmail
su -s /bin/sh -c "/usr/bin/fetchmail \ su -s /bin/sh -c "/usr/bin/fetchmail \
--verbose \ --verbose \

View file

@ -24,15 +24,6 @@ source /usr/local/bin/daemons-stack.sh
# ------------------------------------------------------------ # ------------------------------------------------------------
# ? << Sourcing helpers & stacks # ? << Sourcing helpers & stacks
# -- # --
# ? >> Early setup & environment variables setup
# ------------------------------------------------------------
_early_setup_supervisor
_early_variables_setup
# ------------------------------------------------------------
# ? << Early setup & environment variables setup
# --
# ? >> Registering functions # ? >> Registering functions
# ------------------------------------------------------------ # ------------------------------------------------------------
@ -82,8 +73,8 @@ function _register_functions
_register_setup_function '_setup_saslauthd' _register_setup_function '_setup_saslauthd'
fi fi
[[ ${POSTFIX_INET_PROTOCOLS} != 'all' ]] && _register_setup_function '_setup_postfix_inet_protocols' _register_setup_function '_setup_postfix_inet_protocols'
[[ ${DOVECOT_INET_PROTOCOLS} != 'all' ]] && _register_setup_function '_setup_dovecot_inet_protocols' _register_setup_function '_setup_dovecot_inet_protocols'
_register_setup_function '_setup_opendkim' _register_setup_function '_setup_opendkim'
_register_setup_function '_setup_opendmarc' # must come after `_setup_opendkim` _register_setup_function '_setup_opendmarc' # must come after `_setup_opendkim`
@ -103,14 +94,10 @@ function _register_functions
_register_setup_function '_setup_postfix_vhost' _register_setup_function '_setup_postfix_vhost'
_register_setup_function '_setup_postfix_dhparam' _register_setup_function '_setup_postfix_dhparam'
_register_setup_function '_setup_postfix_sizelimits' _register_setup_function '_setup_postfix_sizelimits'
_register_setup_function '_setup_fetchmail'
_register_setup_function '_setup_fetchmail_parallel'
# needs to come after _setup_postfix_aliases # needs to come after _setup_postfix_aliases
if [[ ${ENABLE_FETCHMAIL} -eq 1 ]]
then
_register_setup_function '_setup_fetchmail'
[[ ${FETCHMAIL_PARALLEL} -eq 1 ]] && _register_setup_function '_setup_fetchmail_parallel'
fi
_register_setup_function '_setup_spoof_protection' _register_setup_function '_setup_spoof_protection'
if [[ ${ENABLE_SRS} -eq 1 ]] if [[ ${ENABLE_SRS} -eq 1 ]]
@ -121,9 +108,7 @@ function _register_functions
_register_setup_function '_setup_postfix_access_control' _register_setup_function '_setup_postfix_access_control'
_register_setup_function '_setup_postfix_relay_hosts' _register_setup_function '_setup_postfix_relay_hosts'
_register_setup_function '_setup_postfix_virtual_transport'
[[ -n ${POSTFIX_DAGENT} ]] && _register_setup_function '_setup_postfix_virtual_transport'
_register_setup_function '_setup_postfix_override_configuration' _register_setup_function '_setup_postfix_override_configuration'
_register_setup_function '_setup_logrotate' _register_setup_function '_setup_logrotate'
_register_setup_function '_setup_mail_summary' _register_setup_function '_setup_mail_summary'
@ -174,13 +159,16 @@ function _register_functions
# ? >> Executing all stacks / actual start of DMS # ? >> Executing all stacks / actual start of DMS
# ------------------------------------------------------------ # ------------------------------------------------------------
_early_supervisor_setup
_early_variables_setup
_log 'info' "Welcome to docker-mailserver $(</VERSION)" _log 'info' "Welcome to docker-mailserver $(</VERSION)"
_register_functions _register_functions
_check _check
_setup _setup
[[ ${LOG_LEVEL} =~ (debug|trace) ]] && print-environment [[ ${LOG_LEVEL} =~ (debug|trace) ]] && print-environment
_setup_run_user_patches _run_user_patches
_start_daemons _start_daemons
# marker to check if container was restarted # marker to check if container was restarted

View file

@ -28,22 +28,25 @@ function _default_start_daemon
# shellcheck disable=SC2181 # shellcheck disable=SC2181
if [[ ${?} -ne 0 ]] if [[ ${?} -ne 0 ]]
then then
echo "${RESULT}" >&2 _log 'error' "${RESULT}"
dms_panic__fail_init "${1}" dms_panic__fail_init "${1}"
fi fi
} }
function _start_daemon_changedetector { _default_start_daemon 'changedetector' ; }
function _start_daemon_amavis { _default_start_daemon 'amavis' ; } function _start_daemon_amavis { _default_start_daemon 'amavis' ; }
function _start_daemon_changedetector { _default_start_daemon 'changedetector' ; }
function _start_daemon_clamav { _default_start_daemon 'clamav' ; } function _start_daemon_clamav { _default_start_daemon 'clamav' ; }
function _start_daemon_cron { _default_start_daemon 'cron' ; } function _start_daemon_cron { _default_start_daemon 'cron' ; }
function _start_daemon_dovecot { _default_start_daemon 'dovecot' ; }
function _start_daemon_fail2ban { _default_start_daemon 'fail2ban' ; }
function _start_daemon_opendkim { _default_start_daemon 'opendkim' ; } function _start_daemon_opendkim { _default_start_daemon 'opendkim' ; }
function _start_daemon_opendmarc { _default_start_daemon 'opendmarc' ; } function _start_daemon_opendmarc { _default_start_daemon 'opendmarc' ; }
function _start_daemon_postgrey { _default_start_daemon 'postgrey' ; }
function _start_daemon_postsrsd { _default_start_daemon 'postsrsd' ; } function _start_daemon_postsrsd { _default_start_daemon 'postsrsd' ; }
function _start_daemon_redis { _default_start_daemon 'redis' ; }
function _start_daemon_rspamd { _default_start_daemon 'rspamd' ; }
function _start_daemon_rsyslog { _default_start_daemon 'rsyslog' ; } function _start_daemon_rsyslog { _default_start_daemon 'rsyslog' ; }
function _start_daemon_update_check { _default_start_daemon 'update-check' ; } function _start_daemon_update_check { _default_start_daemon 'update-check' ; }
function _start_daemon_rspamd { _default_start_daemon 'rspamd' ; }
function _start_daemon_redis { _default_start_daemon 'redis' ; }
function _start_daemon_saslauthd function _start_daemon_saslauthd
{ {
@ -56,30 +59,6 @@ function _start_daemon_postfix
_default_start_daemon 'postfix' _default_start_daemon 'postfix'
} }
function _start_daemon_postgrey
{
rm -f /var/run/postgrey/postgrey.pid
_default_start_daemon 'postgrey'
}
function _start_daemon_fail2ban
{
_default_start_daemon 'fail2ban'
}
function _start_daemon_dovecot
{
if [[ ${ENABLE_POP3} -eq 1 ]]
then
_log 'debug' 'Enabling POP3 services'
mv /etc/dovecot/protocols.d/pop3d.protocol.disab /etc/dovecot/protocols.d/pop3d.protocol
fi
[[ -f /tmp/docker-mailserver/dovecot.cf ]] && cp /tmp/docker-mailserver/dovecot.cf /etc/dovecot/local.conf
_default_start_daemon 'dovecot'
}
function _start_daemon_fetchmail function _start_daemon_fetchmail
{ {
if [[ ${FETCHMAIL_PARALLEL} -eq 1 ]] if [[ ${FETCHMAIL_PARALLEL} -eq 1 ]]

View file

@ -28,7 +28,7 @@ function _setup
_prepare_for_change_detection _prepare_for_change_detection
} }
function _early_setup_supervisor function _early_supervisor_setup
{ {
SUPERVISOR_LOGLEVEL="${SUPERVISOR_LOGLEVEL:-warn}" SUPERVISOR_LOGLEVEL="${SUPERVISOR_LOGLEVEL:-warn}"
@ -78,19 +78,6 @@ function _setup_file_permissions
chmod 640 /var/log/mail/freshclam.log chmod 640 /var/log/mail/freshclam.log
} }
function _setup_run_user_patches
{
local USER_PATCHES='/tmp/docker-mailserver/user-patches.sh'
if [[ -f ${USER_PATCHES} ]]
then
_log 'debug' 'Applying user patches'
/bin/bash "${USER_PATCHES}"
else
_log 'trace' "No optional '${USER_PATCHES}' provided"
fi
}
function _setup_timezone function _setup_timezone
{ {
[[ -n ${TZ} ]] || return 0 [[ -n ${TZ} ]] || return 0
@ -113,11 +100,26 @@ function _setup_timezone
return 1 return 1
fi fi
} }
function _setup_apply_fixes_after_configuration function _setup_apply_fixes_after_configuration
{ {
_log 'trace' 'Removing leftover PID files from a stop/start' _log 'trace' 'Removing leftover PID files from a stop/start'
find /var/run/ -not -name 'supervisord.pid' -name '*.pid' -delete find /var/run/ -not -name 'supervisord.pid' -name '*.pid' -delete
touch /dev/shm/supervisor.sock touch /dev/shm/supervisor.sock
_log 'debug' 'Checking /var/mail permissions' _log 'debug' 'Checking /var/mail permissions'
_chown_var_mail_if_necessary || _shutdown 'Failed to fix /var/mail permissions' _chown_var_mail_if_necessary || _shutdown 'Failed to fix /var/mail permissions'
} }
function _run_user_patches
{
local USER_PATCHES='/tmp/docker-mailserver/user-patches.sh'
if [[ -f ${USER_PATCHES} ]]
then
_log 'debug' 'Applying user patches'
/bin/bash "${USER_PATCHES}"
else
_log 'trace' "No optional '${USER_PATCHES}' provided"
fi
}

View file

@ -87,6 +87,14 @@ function _setup_dovecot
chown docker:docker -R /usr/lib/dovecot/sieve* chown docker:docker -R /usr/lib/dovecot/sieve*
chmod 550 -R /usr/lib/dovecot/sieve* chmod 550 -R /usr/lib/dovecot/sieve*
chmod -f +x /usr/lib/dovecot/sieve-pipe/* chmod -f +x /usr/lib/dovecot/sieve-pipe/*
if [[ ${ENABLE_POP3} -eq 1 ]]
then
_log 'debug' 'Enabling POP3 services'
mv /etc/dovecot/protocols.d/pop3d.protocol.disab /etc/dovecot/protocols.d/pop3d.protocol
fi
[[ -f /tmp/docker-mailserver/dovecot.cf ]] && cp /tmp/docker-mailserver/dovecot.cf /etc/dovecot/local.conf
} }
@ -184,10 +192,11 @@ function _setup_dovecot_local_user
function _setup_dovecot_inet_protocols function _setup_dovecot_inet_protocols
{ {
local PROTOCOL [[ ${DOVECOT_INET_PROTOCOLS} == 'all' ]] && return 0
_log 'trace' 'Setting up DOVECOT_INET_PROTOCOLS option' _log 'trace' 'Setting up DOVECOT_INET_PROTOCOLS option'
local PROTOCOL
# https://dovecot.org/doc/dovecot-example.conf # https://dovecot.org/doc/dovecot-example.conf
if [[ ${DOVECOT_INET_PROTOCOLS} == "ipv4" ]] if [[ ${DOVECOT_INET_PROTOCOLS} == "ipv4" ]]
then then

View file

@ -2,7 +2,9 @@
function _setup_fetchmail function _setup_fetchmail
{ {
_log 'trace' 'Preparing Fetchmail configuration' if [[ ${ENABLE_FETCHMAIL} -eq 1 ]]
then
_log 'trace' 'Enabling and configuring Fetchmail'
local CONFIGURATION FETCHMAILRC local CONFIGURATION FETCHMAILRC
@ -18,11 +20,16 @@ function _setup_fetchmail
chmod 700 "${FETCHMAILRC}" chmod 700 "${FETCHMAILRC}"
chown fetchmail:root "${FETCHMAILRC}" chown fetchmail:root "${FETCHMAILRC}"
else
_log 'debug' 'Fetchmail is disabled'
fi
} }
function _setup_fetchmail_parallel function _setup_fetchmail_parallel
{ {
_log 'trace' 'Setting up Fetchmail parallel' if [[ ${FETCHMAIL_PARALLEL} -eq 1 ]]
then
_log 'trace' 'Enabling and configuring Fetchmail parallel'
mkdir /etc/fetchmailrc.d/ mkdir /etc/fetchmailrc.d/
# Split the content of /etc/fetchmailrc into # Split the content of /etc/fetchmailrc into
@ -100,4 +107,7 @@ EOF
supervisorctl reread supervisorctl reread
supervisorctl update supervisorctl update
else
_log 'debug' 'Fetchmail parallel is disabled'
fi
} }

View file

@ -62,13 +62,16 @@ function _setup_postfix_vhost
function _setup_postfix_inet_protocols function _setup_postfix_inet_protocols
{ {
[[ ${POSTFIX_INET_PROTOCOLS} == 'all' ]] && return 0
_log 'trace' 'Setting up POSTFIX_INET_PROTOCOLS option' _log 'trace' 'Setting up POSTFIX_INET_PROTOCOLS option'
postconf "inet_protocols = ${POSTFIX_INET_PROTOCOLS}" postconf "inet_protocols = ${POSTFIX_INET_PROTOCOLS}"
} }
function _setup_postfix_virtual_transport function _setup_postfix_virtual_transport
{ {
[[ -z ${POSTFIX_DAGENT} ]] && return 0
_log 'trace' "Changing Postfix virtual transport to '${POSTFIX_DAGENT}'" _log 'trace' "Changing Postfix virtual transport to '${POSTFIX_DAGENT}'"
# Default value in main.cf should be 'lmtp:unix:/var/run/dovecot/lmtp' # Default value in main.cf should be 'lmtp:unix:/var/run/dovecot/lmtp'
postconf "virtual_transport = ${POSTFIX_DAGENT}" postconf "virtual_transport = ${POSTFIX_DAGENT}"

View file

@ -6,14 +6,14 @@ declare -A VARS
function _early_variables_setup function _early_variables_setup
{ {
_obtain_hostname_and_domainname _obtain_hostname_and_domainname
_environment_variables_backwards_compatibility __environment_variables_backwards_compatibility
_environment_variables_general_setup __environment_variables_general_setup
} }
# This function handles variables that are deprecated. This allows a # This function handles variables that are deprecated. This allows a
# smooth transition period, without the need of removing a variable # smooth transition period, without the need of removing a variable
# completely with a single version. # completely with a single version.
function _environment_variables_backwards_compatibility function __environment_variables_backwards_compatibility
{ {
if [[ ${ENABLE_LDAP:-0} -eq 1 ]] if [[ ${ENABLE_LDAP:-0} -eq 1 ]]
then then
@ -30,31 +30,10 @@ function _environment_variables_backwards_compatibility
# fi # fi
} }
# This function Writes the contents of the `VARS` map (associative array)
# to locations where they can be sourced from (e.g. `/etc/dms-settings`)
# or where they can be used by Bash directly (e.g. `/root/.bashrc`).
function _environment_variables_export
{
_log 'debug' "Exporting environment variables now (creating '/etc/dms-settings')"
: >/root/.bashrc # make DMS variables available in login shells and their subprocesses
: >/etc/dms-settings # this file can be sourced by other scripts
local VAR
for VAR in "${!VARS[@]}"
do
echo "export ${VAR}='${VARS[${VAR}]}'" >>/root/.bashrc
echo "${VAR}='${VARS[${VAR}]}'" >>/etc/dms-settings
done
sort -o /root/.bashrc /root/.bashrc
sort -o /etc/dms-settings /etc/dms-settings
}
# This function sets almost all environment variables. This involves setting # This function sets almost all environment variables. This involves setting
# a default if no value was provided and writing the variable and its value # a default if no value was provided and writing the variable and its value
# to the VARS map. # to the VARS map.
function _environment_variables_general_setup function __environment_variables_general_setup
{ {
_log 'debug' 'Handling general environment variable setup' _log 'debug' 'Handling general environment variable setup'
@ -125,6 +104,7 @@ function _environment_variables_general_setup
VARS[POSTFIX_INET_PROTOCOLS]="${POSTFIX_INET_PROTOCOLS:=all}" VARS[POSTFIX_INET_PROTOCOLS]="${POSTFIX_INET_PROTOCOLS:=all}"
VARS[POSTFIX_MAILBOX_SIZE_LIMIT]="${POSTFIX_MAILBOX_SIZE_LIMIT:=0}" VARS[POSTFIX_MAILBOX_SIZE_LIMIT]="${POSTFIX_MAILBOX_SIZE_LIMIT:=0}"
VARS[POSTFIX_MESSAGE_SIZE_LIMIT]="${POSTFIX_MESSAGE_SIZE_LIMIT:=10240000}" # ~10 MB VARS[POSTFIX_MESSAGE_SIZE_LIMIT]="${POSTFIX_MESSAGE_SIZE_LIMIT:=10240000}" # ~10 MB
VARS[POSTFIX_DAGENT]="${POSTFIX_DAGENT:=}"
_log 'trace' 'Setting miscellaneous environment variables' _log 'trace' 'Setting miscellaneous environment variables'
@ -217,3 +197,24 @@ function _environment_variables_saslauthd
VARS[SASLAUTHD_LDAP_MECH]="${SASLAUTHD_LDAP_MECH}" VARS[SASLAUTHD_LDAP_MECH]="${SASLAUTHD_LDAP_MECH}"
fi fi
} }
# This function Writes the contents of the `VARS` map (associative array)
# to locations where they can be sourced from (e.g. `/etc/dms-settings`)
# or where they can be used by Bash directly (e.g. `/root/.bashrc`).
function _environment_variables_export
{
_log 'debug' "Exporting environment variables now (creating '/etc/dms-settings')"
: >/root/.bashrc # make DMS variables available in login shells and their subprocesses
: >/etc/dms-settings # this file can be sourced by other scripts
local VAR
for VAR in "${!VARS[@]}"
do
echo "export ${VAR}='${VARS[${VAR}]}'" >>/root/.bashrc
echo "${VAR}='${VARS[${VAR}]}'" >>/etc/dms-settings
done
sort -o /root/.bashrc /root/.bashrc
sort -o /etc/dms-settings /etc/dms-settings
}