2023-06-04 21:38:10 +03:00
|
|
|
#!/bin/sh
|
|
|
|
set -x # print commands
|
|
|
|
set -e # exit on failed command
|
|
|
|
|
|
|
|
apk add unbound curl
|
|
|
|
|
|
|
|
(rm -r /tmp/mox 2>/dev/null || exit 0) # clean slate
|
|
|
|
mkdir /tmp/mox
|
|
|
|
cd /tmp/mox
|
|
|
|
mox quickstart moxtest1@mox1.example "$MOX_UID" > output.txt
|
|
|
|
|
2023-07-01 15:24:28 +03:00
|
|
|
sed -i -e '/- 172.28.1.10/d' -e 's/- 0.0.0.0/- 172.28.1.10/' -e '/- ::/d' -e 's/letsencrypt:/pebble:/g' -e 's/: letsencrypt/: pebble/g' -e 's,DirectoryURL: https://acme-v02.api.letsencrypt.org/directory,DirectoryURL: https://acmepebble.example:14000/dir,' -e 's/SMTP:$/SMTP:\n\t\t\tFirstTimeSenderDelay: 1s/' config/mox.conf
|
2023-06-04 21:38:10 +03:00
|
|
|
cat <<EOF >>config/mox.conf
|
|
|
|
|
|
|
|
TLS:
|
|
|
|
CA:
|
|
|
|
CertFiles:
|
|
|
|
# So certificates from moxmail2 are trusted, and pebble's certificate is trusted.
|
2023-07-24 00:32:02 +03:00
|
|
|
- /integration/tls/ca.pem
|
2023-06-04 21:38:10 +03:00
|
|
|
EOF
|
|
|
|
|
2023-07-24 00:32:02 +03:00
|
|
|
(
|
|
|
|
cat /integration/example.zone;
|
|
|
|
sed -n '/^;/,/IN CAA/p' output.txt |
|
|
|
|
# allow sending from postfix for mox1.example.
|
|
|
|
sed 's/mox1.example. *IN TXT "v=spf1 mx ~all"/mox1.example. IN TXT "v=spf1 mx ip4:172.28.1.70 ~all"/'
|
|
|
|
) >/integration/example-integration.zone
|
2023-06-04 21:38:10 +03:00
|
|
|
unbound-control -s 172.28.1.30 reload # reload unbound with zone file changes
|
|
|
|
|
2023-07-24 00:32:02 +03:00
|
|
|
CURL_CA_BUNDLE=/integration/tls/ca.pem curl -o /integration/tmp-pebble-ca.pem https://acmepebble.example:15000/roots/0
|
2023-06-04 21:38:10 +03:00
|
|
|
|
|
|
|
mox serve &
|
|
|
|
while true; do
|
|
|
|
if test -e data/ctl; then
|
|
|
|
echo -n accountpass1234 | mox setaccountpassword moxtest1@mox1.example
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
sleep 0.1
|
|
|
|
done
|
|
|
|
wait
|