2022-10-17 08:40:09 +00:00
|
|
|
#!/bin/bash
|
2022-06-04 23:59:54 +00:00
|
|
|
|
|
|
|
# This helper supports the changedetector service. Used by:
|
|
|
|
# - check-for-changes.sh
|
|
|
|
# - test/test_helper/common.bash:wait_for_changes_to_be_detected_in_container()
|
|
|
|
# - test/test_helper.bats
|
2022-06-09 07:48:07 +00:00
|
|
|
# - start-mailserver.sh --> setup-stack.sh:_setup (to initialize the CHKSUM_FILE state)
|
2022-06-04 23:59:54 +00:00
|
|
|
|
|
|
|
# Global checksum file used to track when monitored files have changed in content:
|
|
|
|
# shellcheck disable=SC2034
|
|
|
|
CHKSUM_FILE=/tmp/docker-mailserver-config-chksum
|
|
|
|
|
|
|
|
# Once container startup scripts complete, take a snapshot of
|
|
|
|
# the config state via storing a list of files content hashes.
|
2023-05-25 23:01:41 +00:00
|
|
|
function _prepare_for_change_detection() {
|
2022-06-04 23:59:54 +00:00
|
|
|
_log 'debug' 'Setting up configuration checksum file'
|
|
|
|
|
2022-06-09 07:48:07 +00:00
|
|
|
_log 'trace' "Creating '${CHKSUM_FILE}'"
|
|
|
|
_monitored_files_checksums >"${CHKSUM_FILE}"
|
2022-06-04 23:59:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Returns a list of changed files, each line is a value pair of:
|
|
|
|
# <SHA-512 content hash> <changed file path>
|
2023-05-25 23:01:41 +00:00
|
|
|
function _monitored_files_checksums() {
|
2022-06-04 23:59:54 +00:00
|
|
|
# If a wildcard path pattern (or an empty ENV) would yield an invalid path
|
|
|
|
# or no results, `shopt -s nullglob` prevents it from being added.
|
|
|
|
shopt -s nullglob
|
|
|
|
declare -a STAGING_FILES CHANGED_FILES
|
|
|
|
|
2022-06-09 07:48:07 +00:00
|
|
|
# Supported user provided configs:
|
|
|
|
local DMS_DIR=/tmp/docker-mailserver
|
2023-05-24 07:06:59 +00:00
|
|
|
if [[ -d ${DMS_DIR} ]]; then
|
2022-06-09 07:48:07 +00:00
|
|
|
STAGING_FILES+=(
|
|
|
|
"${DMS_DIR}/postfix-accounts.cf"
|
|
|
|
"${DMS_DIR}/postfix-virtual.cf"
|
|
|
|
"${DMS_DIR}/postfix-regexp.cf"
|
|
|
|
"${DMS_DIR}/postfix-aliases.cf"
|
|
|
|
"${DMS_DIR}/postfix-relaymap.cf"
|
|
|
|
"${DMS_DIR}/postfix-sasl-password.cf"
|
|
|
|
"${DMS_DIR}/dovecot-quotas.cf"
|
|
|
|
"${DMS_DIR}/dovecot-masters.cf"
|
|
|
|
)
|
|
|
|
fi
|
2022-06-04 23:59:54 +00:00
|
|
|
|
2022-06-09 07:48:07 +00:00
|
|
|
# SSL certs:
|
2023-05-24 07:06:59 +00:00
|
|
|
if [[ ${SSL_TYPE:-} == 'manual' ]]; then
|
2022-06-04 23:59:54 +00:00
|
|
|
# When using "manual" as the SSL type,
|
|
|
|
# the following variables may contain the certificate files
|
|
|
|
STAGING_FILES+=(
|
|
|
|
"${SSL_CERT_PATH:-}"
|
|
|
|
"${SSL_KEY_PATH:-}"
|
|
|
|
"${SSL_ALT_CERT_PATH:-}"
|
|
|
|
"${SSL_ALT_KEY_PATH:-}"
|
|
|
|
)
|
2023-05-24 07:06:59 +00:00
|
|
|
elif [[ ${SSL_TYPE:-} == 'letsencrypt' ]]; then
|
2022-06-04 23:59:54 +00:00
|
|
|
# React to any cert changes within the following LetsEncrypt locations:
|
|
|
|
STAGING_FILES+=(
|
|
|
|
/etc/letsencrypt/acme.json
|
|
|
|
/etc/letsencrypt/live/"${SSL_DOMAIN}"/*.pem
|
|
|
|
/etc/letsencrypt/live/"${HOSTNAME}"/*.pem
|
|
|
|
/etc/letsencrypt/live/"${DOMAINNAME}"/*.pem
|
|
|
|
)
|
|
|
|
fi
|
|
|
|
|
2022-06-09 07:48:07 +00:00
|
|
|
# If the file actually exists, add to CHANGED_FILES
|
|
|
|
# and generate a content hash entry:
|
2023-05-26 12:00:40 +00:00
|
|
|
for FILE in "${STAGING_FILES[@]}"; do
|
2022-06-04 23:59:54 +00:00
|
|
|
[[ -f "${FILE}" ]] && CHANGED_FILES+=("${FILE}")
|
|
|
|
done
|
2022-09-19 08:45:40 +00:00
|
|
|
|
2023-05-24 07:06:59 +00:00
|
|
|
if [[ -n ${CHANGED_FILES:-} ]]; then
|
2022-09-19 08:45:40 +00:00
|
|
|
sha512sum -- "${CHANGED_FILES[@]}"
|
|
|
|
fi
|
2022-06-04 23:59:54 +00:00
|
|
|
}
|