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

Include postfix, dovecot, opendkim in preloaded vm

This commit is contained in:
downtownallday 2022-06-26 22:13:16 -04:00
parent f05fa8ba01
commit 6255ecb2f3
3 changed files with 30 additions and 26 deletions

View File

@ -51,10 +51,13 @@ export NC_ADMIN_PASSWORD="${NC_ADMIN_PASSWORD:-Test_1234}"
export MIAB_UPSTREAM_GIT="${MIAB_UPSTREAM_GIT:-https://github.com/mail-in-a-box/mailinabox.git}"
export UPSTREAM_TAG="${UPSTREAM_TAG:-}"
# For setup scripts that install miabldap releases
# For setup scripts that install miabldap releases (eg. upgrade tests)
export MIABLDAP_GIT="${MIABLDAP_GIT:-https://github.com/downtownallday/mailinabox-ldap.git}"
export MIABLDAP_RELEASE_TAG="${MIABLDAP_RELEASE_TAG:-v55}"
export MIABLDAP_RELEASE_TAG="${MIABLDAP_RELEASE_TAG:-v60}"
# When running tests that require php, use this version of php. This
# should be the same as what's in setup/functions.sh.
export PHP_VER=8.0
# Tag of last version supported on Ubuntu Bionic 18.04
FINAL_RELEASE_TAG_BIONIC64=master #v57a

View File

@ -1,13 +1,10 @@
#!/bin/bash
# load defaults for MIABLDAP_RELEASE_TAG and MIABLDAP_GIT
# load defaults for MIABLDAP_GIT and FINAL_RELEASE_TAG_BIONIC64 (make available to Vagrantfile)
pushd "../../.." >/dev/null
source tests/system-setup/setup-defaults.sh || exit 1
popd >/dev/null
# TODO: replace MIABLDAP_RELEASE_TAG with the actual tag for the last supported version of miabldap for bionic64
UBUNTU_BIONIC64_RELEASE_TAG=$MIABLDAP_RELEASE_TAG
vagrant destroy -f
rm -f prepcode.txt
@ -28,7 +25,7 @@ boxes=(
# preload packages from source of the following git tags. empty string
# means use the current source tree
tags=(
"$UBUNTU_BIONIC64_RELEASE_TAG"
"$FINAL_RELEASE_TAG_BIONIC64"
""
)
try_reboot=(

View File

@ -10,10 +10,9 @@
# Nextcloud and Roundcube are downloaded with wget by the setup
# scripts, so they are not included
#
# postfix, postgrey and slapd because they require terminal input
# slapd - we want to test installation with setup/ldap.sh
#
if [ ! -d "setup" ]; then
echo "Run from the miab root directory"
exit 1
@ -36,6 +35,9 @@ fi
# prevent apt from running needrestart(1)
export NEEDRESTART_SUSPEND=true
# prevent interaction during package install
export DEBIAN_FRONTEND=noninteractive
# what major version of ubuntu are we installing on?
OS_MAJOR=$(. /etc/os-release; echo $VERSION_ID | awk -F. '{print $1}')
@ -66,31 +68,17 @@ install_packages() {
;;
esac
# don't install postfix - causes problems with setup scripts
# and requires user input. exclude postgrey because it will
# install postfix as a dependency
pkgs="$(sed 's/postgrey//g' <<< "$pkgs")"
pkgs="$(sed 's/postfix-[^ $]*//g' <<<"$pkgs")"
pkgs="$(sed 's/postfix//g' <<<"$pkgs")"
# don't install slapd - it requires user input
# don't install slapd
pkgs="$(sed 's/slapd//g' <<< "$pkgs")"
# manually set PHP_VER if necessary
if grep "PHP_VER" <<<"$pkgs" >/dev/null; then
pkgs="$(sed "s/\${*PHP_VER}*/$PHP_VER/g" <<< "$pkgs")"
fi
if [ $OS_MAJOR -ge 22 ]; then
# don't install opendmarc on ubuntu 22 and higher - it requires
# interactive user input
pkgs="$(sed 's/opendmarc//g' <<< "$pkgs")"
fi
if [ ! -z "$pkgs" ]; then
H2 "install: $pkgs"
if ! $dry_run; then
#apt-get install -y -qq $pkgs
exec_no_output apt-get install -y $pkgs
fi
fi
@ -109,12 +97,26 @@ install_ppas() {
done
}
add_swap() {
H1 "Add a swap file to the system"
if ! $dry_run; then
dd if=/dev/zero of=/swapfile bs=1024 count=$[1024*1024] status=none
chmod 600 /swapfile
mkswap /swapfile
swapon /swapfile
echo "/swapfile none swap sw 0 0" >> /etc/fstab
fi
}
# install PPAs from sources
install_ppas
# add swap file
add_swap
# obtain PHP_VER variable from sources
PHP_VER=$(grep "^PHP_VER=" setup/functions.sh | awk -F= '{ print $2 }')
PHP_VER=$(source setup/functions.sh; echo $PHP_VER)
if ! $dry_run; then
@ -138,11 +140,13 @@ if ! $dry_run; then
H2 "openssh-server"
exec_no_output apt-get install -y openssh-server
# ssh-rsa no longer a default algorithm, but still used by vagrant
echo "PubkeyAcceptedAlgorithms +ssh-rsa" > /etc/ssh/sshd_config.d/miabldap.conf
# echo "PubkeyAcceptedAlgorithms +ssh-rsa" > /etc/ssh/sshd_config.d/miabldap.conf
H2 "emacs"
exec_no_output apt-get install -y emacs-nox
H2 "nptdate"
exec_no_output apt-get install -y ntpdate
H2 "net-tools"
exec_no_output apt-get install -y net-tools
# these are added by system-setup scripts and needed for test runner
H2 "python3-dnspython jq"