Extractor for named RDN element types from a certificate DN field.
[users/heiko/exim.git] / test / confs / 2102
1 # Exim test configuration 2102
2
3 exim_path = EXIM_PATH
4 host_lookup_order = bydns
5 primary_hostname = myhost.test.ex
6 rfc1413_query_timeout = 0s
7 spool_directory = DIR/spool
8 log_file_path = DIR/spool/log/%slog
9 gecos_pattern = ""
10 gecos_name = CALLER_NAME
11
12 # ----- Main settings -----
13
14 acl_smtp_rcpt = check_recipient
15
16 log_selector = +tls_peerdn
17
18 queue_only
19 queue_run_in_order
20
21 tls_advertise_hosts = 127.0.0.1 : HOSTIPV4
22
23 tls_certificate = DIR/aux-fixed/exim-ca/example.com/server1.example.com/server1.example.com.pem
24 tls_privatekey = DIR/aux-fixed/exim-ca/example.com/server1.example.com/server1.example.com.unlocked.key
25
26 tls_verify_hosts = HOSTIPV4
27 tls_verify_certificates = DIR/aux-fixed/exim-ca/example.com/server2.example.com/ca_chain.pem
28
29
30 # ------ ACL ------
31
32 begin acl
33
34 check_recipient:
35   accept  hosts = :
36   deny    hosts = HOSTIPV4
37          !encrypted = AES256-SHA : \
38                       AES256-GCM-SHA384 : \
39                       IDEA-CBC-MD5 : \
40                       DES-CBC3-SHA : \
41                       DHE-RSA-AES256-SHA : \
42                       DHE-RSA-AES256-GCM-SHA384 : \
43                       DHE_RSA_AES_256_CBC_SHA1 : \
44                       DHE_RSA_3DES_EDE_CBC_SHA
45   warn    logwrite =  ${if def:tls_in_ourcert \
46                 {Our cert SN: <${certextract{subject}{$tls_in_ourcert}}>} \
47                 {We did not present a cert}}
48   accept  condition = ${if !def:tls_in_peercert}
49           logwrite =  Peer did not present a cert
50   accept  logwrite =  Peer cert:
51           logwrite =  ver ${certextract {version}{$tls_in_peercert}}
52           logwrite =  SR  <${certextract {serial_number}{$tls_in_peercert}}>
53           logwrite =  SN  <${certextract {subject}      {$tls_in_peercert}}>
54           logwrite =  IN  <${certextract {issuer}       {$tls_in_peercert}}>
55           logwrite =  IN/O <${certextract {issuer,O}    {$tls_in_peercert}}>
56           logwrite =  NB  <${certextract {notbefore}    {$tls_in_peercert}}>
57           logwrite =  NA  <${certextract {notafter}     {$tls_in_peercert}}>
58           logwrite =  SA  <${certextract {sig_algorithm}{$tls_in_peercert}}>
59           logwrite =  SG  <${certextract {signature}    {$tls_in_peercert}}>
60           logwrite =       ${certextract {subj_altname} {$tls_in_peercert} {SAN <$value>}{(no SAN)}}
61           logwrite =       ${certextract {ocsp_uri}     {$tls_in_peercert} {OCU <$value>}{(no OCU)}}
62           logwrite =       ${certextract {crl_uri}      {$tls_in_peercert} {CRU <$value>}{(no CRU)}}
63           logwrite =  md5    fingerprint ${md5:$tls_in_peercert}
64           logwrite =  sha1   fingerprint ${sha1:$tls_in_peercert}
65           logwrite =  sha256 fingerprint ${sha256:$tls_in_peercert}
66
67
68 # ----- Routers -----
69
70 begin routers
71
72 abc:
73   driver = accept
74   retry_use_local_part
75   transport = local_delivery
76   headers_add = tls-certificate-verified: $tls_certificate_verified
77
78
79 # ----- Transports -----
80
81 begin transports
82
83 local_delivery:
84   driver = appendfile
85   file = DIR/test-mail/$local_part
86   headers_add = TLS: cipher=$tls_cipher peerdn=$tls_peerdn
87   user = CALLER
88
89 # End