# Exim test configuration 5840
# DANE

SERVER=

exim_path = EXIM_PATH
host_lookup_order = bydns
primary_hostname = myhost.test.ex
spool_directory = DIR/spool
log_file_path = DIR/spool/log/SERVER%slog
gecos_pattern = ""
gecos_name = CALLER_NAME

# ----- Main settings -----

.ifndef OPT
acl_smtp_rcpt = accept
.else
acl_smtp_rcpt = accept verify = recipient/callout
.endif

log_selector =  +received_recipients +tls_peerdn +tls_certificate_verified

queue_run_in_order

tls_advertise_hosts = *

# Set certificate only if server
CDIR1 = DIR/aux-fixed
CDIR2 = DIR/aux-fixed/exim-ca/example.com/server1.example.com

tls_certificate = ${if eq {SERVER}{server} \
	{${if or {{eq {DETAILS}{ta}} {eq {DETAILS}{ca}}} \
		{CDIR2/fullchain.pem}\
		{CDIR1/cert1}}}\
	fail}

tls_privatekey = ${if eq {SERVER}{server} \
	{${if or {{eq {DETAILS}{ta}} {eq {DETAILS}{ca}}} \
		{CDIR2/server1.example.com.unlocked.key}\
		{CDIR1/cert1}}}\
	fail}

# ----- Routers -----

begin routers

client:
  driver = dnslookup
  condition = ${if eq {SERVER}{}}
  dnssec_request_domains = *
  self = send
  transport = send_to_server

server:
  driver = redirect
  data = :blackhole:


# ----- Transports -----

begin transports

send_to_server:
  driver = smtp
  allow_localhost
  port = PORT_D

  hosts_try_dane =     *
  hosts_require_dane = !thishost.test.ex
  tls_verify_cert_hostnames = ${if eq {OPT}{no_certname} {}{*}}
  tls_try_verify_hosts = thishost.test.ex
  tls_verify_certificates = CDIR2/ca_chain.pem



# ----- Retry -----


begin retry

* * F,5d,10s


# End