Compare commits
No commits in common. "c8b328e707f2fbefaf639a73874f0f63c54106e6" and "8d10a1a3b9a9f11fd0339bb442fedf2009b9d1a2" have entirely different histories.
c8b328e707
...
8d10a1a3b9
@ -70,7 +70,6 @@ badParam() {
|
|||||||
cleanup() {
|
cleanup() {
|
||||||
# cleanup 503 if copied
|
# cleanup 503 if copied
|
||||||
if [ "$err503Copied" -eq 1 ]; then
|
if [ "$err503Copied" -eq 1 ]; then
|
||||||
# shellcheck disable=SC2129
|
|
||||||
if ! rm -f "$webroot/$err503File" 2>>"$logFile"; then
|
if ! rm -f "$webroot/$err503File" 2>>"$logFile"; then
|
||||||
printf "%s[%s] -- [WARNING] Could not remove 503 error page." \
|
printf "%s[%s] -- [WARNING] Could not remove 503 error page." \
|
||||||
"$warn" "$(stamp)" >>"$logFile"
|
"$warn" "$(stamp)" >>"$logFile"
|
||||||
@ -99,34 +98,34 @@ cleanup() {
|
|||||||
printf "%s[%s] -- [INFO] POSTFIX container is running --%s\n" \
|
printf "%s[%s] -- [INFO] POSTFIX container is running --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
else
|
else
|
||||||
exitError 102 'Could not start POSTFIX container.' 'final'
|
exitError 102 'Could not start POSTFIX container.'
|
||||||
fi
|
fi
|
||||||
doDocker start dovecot
|
doDocker start dovecot
|
||||||
if [ "$dockerResultState" = "true" ]; then
|
if [ "$dockerResultState" = "true" ]; then
|
||||||
printf "%s[%s] -- [INFO] DOVECOT container is running --%s\n" \
|
printf "%s[%s] -- [INFO] DOVECOT container is running --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
else
|
else
|
||||||
exitError 102 'Could not start DOVECOT container.' 'final'
|
exitError 102 'Could not start DOVECOT container.'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
doDocker() {
|
doDocker() {
|
||||||
containerName="$(docker ps -a --format '{{ .Names }}' --filter "name=${COMPOSE_PROJECT_NAME}_${2}-mailcow_1" --filter "name=${COMPOSE_PROJECT_NAME}-${2}-mailcow-1")"
|
containerName="$(docker ps -a --format '{{ .Names }}' --filter name=${COMPOSE_PROJECT_NAME}_${2}-mailcow_1)"
|
||||||
|
|
||||||
# determine action to take
|
# determine action to take
|
||||||
if [ "$1" = "stop" ]; then
|
if [ "$1" = "stop" ]; then
|
||||||
printf "%s[%s] -- [INFO] Stopping %s-mailcow container --%s\n" \
|
printf "%s[%s] -- [INFO] Stopping %s-mailcow container --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$2" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$2" "$norm" >>"$logFile"
|
||||||
${dockerCmd} -f "$mcDockerCompose" stop --timeout "$dockerStopTimeout" "$2-mailcow" 2>>"$logFile"
|
docker-compose -f "$mcDockerCompose" stop --timeout "$dockerStopTimeout" "$2-mailcow" 2>>"$logFile"
|
||||||
# set result vars
|
# set result vars
|
||||||
dockerResultState="$(docker inspect -f '{{ .State.Running }}' "$containerName")"
|
dockerResultState="$(docker inspect -f '{{ .State.Running }}' $containerName)"
|
||||||
dockerResultExit="$(docker inspect -f '{{ .State.ExitCode }}' "$containerName")"
|
dockerResultExit="$(docker inspect -f '{{ .State.ExitCode }}' $containerName)"
|
||||||
elif [ "$1" = "start" ]; then
|
elif [ "$1" = "start" ]; then
|
||||||
printf "%s[%s] -- [INFO] Starting %s-mailcow container --%s\n" \
|
printf "%s[%s] -- [INFO] Starting %s-mailcow container --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$2" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$2" "$norm" >>"$logFile"
|
||||||
${dockerCmd} -f "$mcDockerCompose" start "$2-mailcow" 2>>"$logFile"
|
docker-compose -f "$mcDockerCompose" start "$2-mailcow" 2>>"$logFile"
|
||||||
# set result vars
|
# set result vars
|
||||||
dockerResultState="$(docker inspect -f '{{ .State.Running }}' "$containerName")"
|
dockerResultState="$(docker inspect -f '{{ .State.Running }}' $containerName)"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -134,7 +133,7 @@ doDocker() {
|
|||||||
exitError() {
|
exitError() {
|
||||||
printf "%s[%s] -- [ERROR] %s: %s --%s\n" \
|
printf "%s[%s] -- [ERROR] %s: %s --%s\n" \
|
||||||
"$err" "$(stamp)" "$1" "$2" "$norm" >>"$logFile"
|
"$err" "$(stamp)" "$1" "$2" "$norm" >>"$logFile"
|
||||||
if [ ! "$3" = "final" ]; then cleanup; fi
|
cleanup
|
||||||
# note script completion with error
|
# note script completion with error
|
||||||
printf "%s[%s] --- %s execution completed with error ---%s\n" \
|
printf "%s[%s] --- %s execution completed with error ---%s\n" \
|
||||||
"$err" "$(stamp)" "$scriptName" "$norm" >>"$logFile"
|
"$err" "$(stamp)" "$scriptName" "$norm" >>"$logFile"
|
||||||
@ -145,8 +144,7 @@ exitError() {
|
|||||||
scriptHelp() {
|
scriptHelp() {
|
||||||
newline
|
newline
|
||||||
printf "%sUsage: %s [parameters]%s\n\n" "$bold" "$scriptName" "$norm"
|
printf "%sUsage: %s [parameters]%s\n\n" "$bold" "$scriptName" "$norm"
|
||||||
textblock "There are NO mandatory parameters. If a parameter is not supplied, its default value will be used. In
|
textblock "There are NO mandatory parameters. If a parameter is not supplied, its default value will be used. In the case of a switch parameter, it will remain DEactivated if NOT specified."
|
||||||
the case of a switch parameter, it will remain *deactivated* if NOT specified."
|
|
||||||
newline
|
newline
|
||||||
textblock "Parameters are listed then followed by a description of their effect on the following line. Finally, if a default value exists, it will be listed on the next line in (parentheses)."
|
textblock "Parameters are listed then followed by a description of their effect on the following line. Finally, if a default value exists, it will be listed on the next line in (parentheses)."
|
||||||
newline
|
newline
|
||||||
@ -196,7 +194,7 @@ scriptHelp() {
|
|||||||
textblock "${magenta}--- mailcow related ---${norm}"
|
textblock "${magenta}--- mailcow related ---${norm}"
|
||||||
newline
|
newline
|
||||||
switchTextblock "-d | --docker-compose"
|
switchTextblock "-d | --docker-compose"
|
||||||
textblock "Path to the mailcow 'docker-compose.yml' file."
|
textblock "Path to mailcow's 'docker-compose.yml' file."
|
||||||
defaultsTextblock "(/opt/mailcow-dockerized/docker-compose.yml)"
|
defaultsTextblock "(/opt/mailcow-dockerized/docker-compose.yml)"
|
||||||
newline
|
newline
|
||||||
switchTextblock "-m | --mailcow-config"
|
switchTextblock "-m | --mailcow-config"
|
||||||
@ -265,7 +263,6 @@ configDetails="$scriptPath/${scriptName%.*}.details"
|
|||||||
err503Copied=0
|
err503Copied=0
|
||||||
sqlDumpDirCreated=0
|
sqlDumpDirCreated=0
|
||||||
exclusions=0
|
exclusions=0
|
||||||
dockerCmd="docker compose"
|
|
||||||
borgPath="/usr/bin/borg"
|
borgPath="/usr/bin/borg"
|
||||||
# borg output verbosity -- normal
|
# borg output verbosity -- normal
|
||||||
borgCreateParams='--stats'
|
borgCreateParams='--stats'
|
||||||
@ -433,14 +430,6 @@ if [ "$(id -u)" -ne 0 ]; then
|
|||||||
printf "\n%sERROR: script MUST be run as ROOT%s\n\n" "$err" "$norm"
|
printf "\n%sERROR: script MUST be run as ROOT%s\n\n" "$err" "$norm"
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
# verify compose installed and set proper commands based on version
|
|
||||||
if ! (docker compose version >/dev/null 2>&1); then
|
|
||||||
if ! (docker-compose --version >/dev/null 2>&1); then
|
|
||||||
printf "\n%sERROR: Docker Compose not installed or not functioning%s\n\n" "$err" "$norm"
|
|
||||||
exit 3
|
|
||||||
fi
|
|
||||||
dockerCmd="docker-compose"
|
|
||||||
fi
|
|
||||||
# does the details file exist?
|
# does the details file exist?
|
||||||
if [ ! -f "$configDetails" ]; then
|
if [ ! -f "$configDetails" ]; then
|
||||||
badParam dne "(--details default)" "$configDetails"
|
badParam dne "(--details default)" "$configDetails"
|
||||||
@ -448,7 +437,7 @@ fi
|
|||||||
# is borg installed?
|
# is borg installed?
|
||||||
if ! find "$borgPath" -type f -executable >/dev/null 2>&1; then
|
if ! find "$borgPath" -type f -executable >/dev/null 2>&1; then
|
||||||
printf "\n%sERROR: BORG cannot be found in the specified or default location on this system!%s\n\n" "$err" "$norm"
|
printf "\n%sERROR: BORG cannot be found in the specified or default location on this system!%s\n\n" "$err" "$norm"
|
||||||
exit 4
|
exit 3
|
||||||
fi
|
fi
|
||||||
# if 503 functionality is enabled, do 503 related files exist?
|
# if 503 functionality is enabled, do 503 related files exist?
|
||||||
if [ "$use503" -eq 1 ]; then
|
if [ "$use503" -eq 1 ]; then
|
||||||
@ -700,9 +689,9 @@ fi
|
|||||||
### dump SQL
|
### dump SQL
|
||||||
printf "%s[%s] -- [INFO] Dumping mailcow SQL database --%s\n" \
|
printf "%s[%s] -- [INFO] Dumping mailcow SQL database --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
${dockerCmd} exec -T mysql-mailcow mysqldump --default-character-set=utf8mb4 \
|
docker-compose exec -T mysql-mailcow mysqldump --default-character-set=utf8mb4 \
|
||||||
-u${DBUSER} -p${DBPASS} ${DBNAME} >"$sqlDumpDir/$sqlDumpFile" 2>>"$logFile"
|
-u${DBUSER} -p${DBPASS} ${DBNAME} >"$sqlDumpDir/$sqlDumpFile" 2>>"$logFile"
|
||||||
dumpResult=$(${dockerCmd} exec -T mysql-mailcow echo "$?")
|
dumpResult=$(docker-compose exec -T mysql-mailcow echo "$?")
|
||||||
if [ "$dumpResult" -eq 0 ]; then
|
if [ "$dumpResult" -eq 0 ]; then
|
||||||
printf "%s[%s] -- [INFO] SQL database dumped successfully --%s\n" \
|
printf "%s[%s] -- [INFO] SQL database dumped successfully --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
@ -718,8 +707,8 @@ fi
|
|||||||
# dump redis
|
# dump redis
|
||||||
printf "%s[%s] -- [INFO] Dumping mailcow redis database --%s\n" \
|
printf "%s[%s] -- [INFO] Dumping mailcow redis database --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
${dockerCmd} exec -T redis-mailcow redis-cli save >>"$logFile" 2>&1
|
docker-compose exec -T redis-mailcow redis-cli save >>"$logFile" 2>&1
|
||||||
rdumpResult=$(${dockerCmd} exec -T redis-mailcow echo "$?")
|
rdumpResult=$(docker-compose exec -T redis-mailcow echo "$?")
|
||||||
if [ "$rdumpResult" -eq 0 ]; then
|
if [ "$rdumpResult" -eq 0 ]; then
|
||||||
printf "%s[%s] -- [INFO] mailcow redis dumped successfully --%s\n" \
|
printf "%s[%s] -- [INFO] mailcow redis dumped successfully --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
@ -783,11 +772,10 @@ else
|
|||||||
warnCount=$((warnCount + 1))
|
warnCount=$((warnCount + 1))
|
||||||
fi
|
fi
|
||||||
|
|
||||||
### execute borg prune if parameters are provided, otherwise skip with a warning
|
### execute borg prune if paramters are provided, otherwise skip with a warning
|
||||||
if [ -n "${borgPruneSettings}" ]; then
|
if [ -n "${borgPruneSettings}" ]; then
|
||||||
printf "%s[%s] -- [INFO] Executing borg prune operation --%s\n" \
|
printf "%s[%s] -- [INFO] Executing borg prune operation --%s\n" \
|
||||||
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
"$cyan" "$(stamp)" "$norm" >>"$logFile"
|
||||||
# shellcheck disable=SC2086
|
|
||||||
"${borgPath}" prune --show-rc -v ${borgPruneParams} ${borgPruneSettings} \
|
"${borgPath}" prune --show-rc -v ${borgPruneParams} ${borgPruneSettings} \
|
||||||
2>>"$logFile"
|
2>>"$logFile"
|
||||||
borgPruneResult="$?"
|
borgPruneResult="$?"
|
||||||
@ -846,8 +834,7 @@ exit 0
|
|||||||
### error codes
|
### error codes
|
||||||
# 1: parameter error
|
# 1: parameter error
|
||||||
# 2: not run as root
|
# 2: not run as root
|
||||||
# 3: docker compose not installed or not functioning
|
# 3: borg not installed
|
||||||
# 4: borg not installed
|
|
||||||
# 99: TERM signal trapped
|
# 99: TERM signal trapped
|
||||||
# 100: could not change to mailcow-dockerized directory
|
# 100: could not change to mailcow-dockerized directory
|
||||||
# 101: could not stop container(s)
|
# 101: could not stop container(s)
|
||||||
|
Loading…
Reference in New Issue
Block a user