1
0
mirror of https://blitiri.com.ar/repos/chasquid synced 2025-12-17 14:37:02 +00:00
Files
go-chasquid-smtp/test/t-02-exim/run.sh
Alberto Bertogli e2fdcb3705 Add checks to prevent unauthorized relaying and impersonation
This patch adds checks that verify:

 - The envelope from must match the authenticated user. This prevents
   impersonation at the envelope level (while still allowing bounces, of
   course).
 - If the destination is remote, then the user must have completed
   authentication. This prevents unauthorized relaying.

The patch ends up adjusting quite a few tests, as they were not written
considering these restrictions so they have to be changed accordingly.
2016-10-10 00:50:56 +01:00

59 lines
1.6 KiB
Bash
Executable File

#!/bin/bash
#
# This test checks that we can send and receive mail to/from exim4.
#
# Setup:
# - chasquid listening on :1025.
# - exim listening on :2025.
# - hosts "srv-chasquid" and "srv-exim" pointing back to localhost.
# - exim configured to accept all email and forward it to
# someone@srv-chasquid.
#
# Test:
# msmtp --> chasquid --> exim --> chasquid --> local delivery
#
# msmtp will auth as user@srv-chasquid to chasquid, and send an email with
# recipient someone@srv-exim.
#
# chasquid will deliver the mail to exim.
#
# exim will deliver the mail back to chasquid (after changing the
# destination to someone@chasquid).
#
# chasquid will receive the email from exim, and deliver it locally.
set -e
. $(dirname ${0})/../util/lib.sh
init
# Create a temporary directory for exim4 to use, and generate the exim4
# config based on the template.
mkdir -p .exim4
EXIMDIR="$PWD/.exim4" envsubst < config/exim4.in > .exim4/config
generate_certs_for srv-chasquid
# Launch chasquid at port 1025 (in config).
# Use outgoing port 2025 which is where exim will be at.
# Bypass MX lookup, so it can find srv-exim (via our host alias).
mkdir -p .logs
chasquid -v=2 --log_dir=.logs --config_dir=config \
--testing__outgoing_smtp_port=2025 \
--testing__bypass_mx_lookup &
wait_until_ready 1025
# Launch exim at port 2025
.exim4/exim4 -bd -d -C "$PWD/.exim4/config" > .exim4/log 2>&1 &
wait_until_ready 2025
# msmtp will use chasquid to send an email to someone@srv-exim.
run_msmtp someone@srv-exim < content
wait_for_file .mail/someone@srv-chasquid
mail_diff content .mail/someone@srv-chasquid
success