1
0
mirror of https://github.com/mail-in-a-box/mailinabox.git synced 2025-04-05 00:27:25 +00:00

Improve formatting of setup output

This commit is contained in:
downtownallday 2022-03-06 10:53:00 -05:00
parent b7c7187fa5
commit a6c819eea0
3 changed files with 62 additions and 13 deletions

View File

@ -161,7 +161,9 @@ fi
# #
if [ -d "${LOCAL_MODS_DIR:-local}" ]; then if [ -d "${LOCAL_MODS_DIR:-local}" ]; then
for mod in $(ls "${LOCAL_MODS_DIR:-local}" | grep -v '~$'); do for mod in $(ls "${LOCAL_MODS_DIR:-local}" | grep -v '~$'); do
${LOCAL_MODS_DIR:-local}/$mod if [ -x ${LOCAL_MODS_DIR:-local}/$mod ]; then
${LOCAL_MODS_DIR:-local}/$mod |& sed -e "s/^/mod(${mod%%.*}): /"
fi
done done
fi fi

View File

@ -49,11 +49,18 @@ dump_file_if_exists() {
} }
update_system_time() { update_system_time() {
if [ ! -x /usr/sbin/ntpdate ]; then if systemctl is-active --quiet ntp; then
wait_for_apt # ntpd is running and running ntpdate will fail with "the NTP
apt-get install -y -qq ntpdate || return 1 # socket is in use"
echo "ntpd is already running, not updating time"
return 0
fi fi
ntpdate -s ntp.ubuntu.com && echo "System time updated" if [ ! -x /usr/sbin/ntpdate ]; then
echo "Installing ntpdate"
wait_for_apt
exec_no_output apt-get install -y ntpdate || return 1
fi
ntpdate ntp.ubuntu.com
} }
set_system_hostname() { set_system_hostname() {
@ -110,3 +117,26 @@ install_docker() {
|| return 5 || return 5
} }
exec_no_output() {
# This function hides the output of a command unless the command
# fails
local of=$(mktemp)
"$@" &> "$of"
local code=$?
if [ $code -ne 0 ]; then
echo "" 1>&2
echo "FAILED: $@" 1>&2
echo "-----------------------------------------" 1>&2
echo "Return code: $code" 1>&2
echo "Output:" 1>&2
cat "$of" 1>&2
echo "-----------------------------------------" 1>&2
fi
# Remove temporary file.
rm -f "$of"
[ $code -ne 0 ] && return 1
return 0
}

View File

@ -2,7 +2,7 @@
# #
# requires: # requires:
# #
# test scripts: [ lib/misc.sh, lib/system.sh ] # test scripts: [ lib/misc.sh, lib/system.sh, lib/color-output.sh ]
# #
@ -81,7 +81,7 @@ init_test_system() {
# update package lists before installing anything # update package lists before installing anything
H2 "apt-get update" H2 "apt-get update"
wait_for_apt wait_for_apt
apt-get update -qq || die "apt-get update failed!" exec_no_output apt-get update -qq || die "apt-get update failed!"
# upgrade packages - if we don't do this and something like bind # upgrade packages - if we don't do this and something like bind
# is upgraded through automatic upgrades (because maybe MiaB was # is upgraded through automatic upgrades (because maybe MiaB was
@ -90,15 +90,24 @@ init_test_system() {
if is_false "$TRAVIS" && [ "$SKIP_SYSTEM_UPDATE" != "1" ]; then if is_false "$TRAVIS" && [ "$SKIP_SYSTEM_UPDATE" != "1" ]; then
H2 "apt-get upgrade" H2 "apt-get upgrade"
wait_for_apt wait_for_apt
apt-get upgrade -qq || die "apt-get upgrade failed!" cp /var/log/apt/history.log /tmp/history.log \
|| die "Unable to copy /var/log/apt/history.log to /tmp"
exec_no_output apt-get upgrade -y --with-new-pkgs \
|| die "apt-get upgrade failed!"
diff /tmp/history.log /var/log/apt/history.log \
| sed 's/^> //' \
| awk '/^(Upgrade|Install): / { print $0 }'
rm -f /tmp/history.log
fi fi
# install avahi if the system dns domain is .local - note that # install avahi if the system dns domain is .local - note that
# /bin/dnsdomainname returns empty string at this point # /bin/dnsdomainname returns empty string at this point
case "$PRIMARY_HOSTNAME" in case "$PRIMARY_HOSTNAME" in
*.local ) *.local )
H2 "Install avahi"
wait_for_apt wait_for_apt
apt-get install -y -qq avahi-daemon || die "could not install avahi" exec_no_output apt-get install -y avahi-daemon \
|| die "could not install avahi"
;; ;;
esac esac
} }
@ -131,8 +140,10 @@ init_miab_testing() {
# python3-dnspython: is used by the python scripts in 'tests' and is # python3-dnspython: is used by the python scripts in 'tests' and is
# not installed by setup # not installed by setup
# also install 'jq' for json processing # also install 'jq' for json processing
echo "Install python3-dnspython, jq"
wait_for_apt wait_for_apt
apt-get install -y -qq python3-dnspython jq exec_no_output apt-get install -y python3-dnspython jq \
|| die "Unable to install setup prerequisites !!"
# copy in pre-built MiaB-LDAP ssl files # copy in pre-built MiaB-LDAP ssl files
# 1. avoid the lengthy generation of DH params # 1. avoid the lengthy generation of DH params
@ -249,12 +260,15 @@ miab_ldap_install() {
# but only when in interactive mode. make sure it's also installed # but only when in interactive mode. make sure it's also installed
# in non-interactive mode # in non-interactive mode
if [ ! -z "${NONINTERACTIVE:-}" ]; then if [ ! -z "${NONINTERACTIVE:-}" ]; then
H2 "Install email_validator python3 module" echo "Install email_validator python3 module"
wait_for_apt wait_for_apt
apt-get install -y -qq python3-pip || die "Unable to install pip3!" exec_no_output apt-get install -y -qq python3-pip \
pip3 install -q "email_validator>=1.0.0" || die "Unable to install email_validator python3 module!" || die "Unable to install pip !"
exec_no_output pip3 install -q "email_validator>=1.0.0" \
|| die "Unable to install email_validator !"
fi fi
H2 "Run mailinabox-ldap setup"
# if EHDD_KEYFILE is set, use encryption-at-rest support # if EHDD_KEYFILE is set, use encryption-at-rest support
if [ ! -z "$EHDD_KEYFILE" ]; then if [ ! -z "$EHDD_KEYFILE" ]; then
ehdd/start-encrypted.sh ehdd/start-encrypted.sh
@ -270,6 +284,7 @@ miab_ldap_install() {
die "MiaB-LDAP setup failed!" die "MiaB-LDAP setup failed!"
fi fi
H2 "Post-setup actions"
workaround_dovecot_sieve_bug workaround_dovecot_sieve_bug
# set actual STORAGE_ROOT, STORAGE_USER, PRIVATE_IP, etc # set actual STORAGE_ROOT, STORAGE_USER, PRIVATE_IP, etc
@ -279,6 +294,8 @@ miab_ldap_install() {
if systemctl is-active --quiet avahi-daemon; then if systemctl is-active --quiet avahi-daemon; then
systemctl restart avahi-daemon systemctl restart avahi-daemon
fi fi
H2 "miab-ldap install success"
} }