SECURITY: Avoid integer overflow on too many recipients
[exim.git] / test / confs / 5720
1 # Exim test configuration 5720 (dup of 5710)
2 # $tls_out_peercert - OpenSSL
3
4 SERVER=
5
6 .include DIR/aux-var/tls_conf_prefix
7
8 primary_hostname = myhost.test.ex
9 timezone = UTC
10
11 # ----- Main settings -----
12
13 acl_smtp_rcpt = accept
14
15 log_selector =  +tls_peerdn
16
17 queue_only
18 queue_run_in_order
19
20 tls_advertise_hosts = *
21
22 tls_certificate = DIR/aux-fixed/exim-ca/example.com/server1.example.com/server1.example.com.pem
23 tls_privatekey = DIR/aux-fixed/exim-ca/example.com/server1.example.com/server1.example.com.unlocked.key
24
25 tls_verify_hosts = *
26 tls_verify_certificates = DIR/aux-fixed/exim-ca/example.com/server2.example.com/ca_chain.pem
27
28 event_action = ${acl {server_cert_log}}
29
30 #
31
32 begin acl
33
34 server_cert_log:
35   accept condition = ${if eq {tls:cert}{$event_name}}
36          logwrite =  [$sender_host_address] \
37                         depth=$event_data \
38                         ${certextract{subject}{$tls_in_peercert}}
39   accept
40
41 ev_tls:
42   accept logwrite =  $event_name depth=$event_data \
43                         <${certextract {subject} {$tls_out_peercert}}>
44 #        message = nooooo
45
46 ev_msg:
47   warn   logwrite =  $acl_arg1 $local_part
48   warn   logwrite =  ${if !def:tls_out_ourcert \
49                 {NO CLIENT CERT presented} \
50                 {Our cert SN: ${certextract{subject}{$tls_out_ourcert}}}}
51   accept condition = ${if !def:tls_out_peercert}
52          logwrite =  No Peer cert
53   accept logwrite = Peer cert:
54          logwrite =  ver <${certextract {version}       {$tls_out_peercert}}>
55          logwrite =  SN  <${certextract {subject}       {$tls_out_peercert}}>
56          logwrite =  SN; <${certextract {subject,>;}    {$tls_out_peercert}}>
57          logwrite =  SNO <${certextract {subject,O}     {$tls_out_peercert}}>
58          logwrite =  IN  <${certextract {issuer}        {$tls_out_peercert}}>
59          logwrite =  NB  <${certextract {notbefore}     {$tls_out_peercert}}>
60          logwrite =  NA  <${certextract {notafter}      {$tls_out_peercert}}>
61          logwrite =  SA  <${certextract {sig_algorithm} {$tls_out_peercert}}>
62          logwrite =  SG  <${certextract {signature}     {$tls_out_peercert}}>
63          logwrite = ${certextract {subj_altname,>;}{$tls_out_peercert}{SAN <$value>}{(no SAN)}}
64          logwrite =       ${certextract {ocsp_uri}      {$tls_out_peercert} {OCU <$value>}{(no OCU)}}
65          logwrite =       ${certextract {crl_uri}       {$tls_out_peercert} {CRU <$value>}{(no CRU)}}
66
67 logger:
68   accept condition = ${if eq {msg} {${listextract{1}{$event_name}}}}
69          acl =       ev_msg $event_name $acl_arg2
70   accept condition = ${if eq {tls} {${listextract{1}{$event_name}}}}
71          message =   ${acl {ev_tls}}
72   accept condition = ${if eq {smtp:ehlo}{$event_name}}
73          logwrite =  $tls_out_cipher smtp:ehlo $event_data
74          logwrite =  cipher_ $tls_out_cipher_std
75          logwrite =  ver:    $tls_out_ver
76   accept
77
78 # ----- Routers -----
79
80 begin routers
81
82 client:
83   driver = accept
84   condition = ${if eq {SERVER}{server}{no}{yes}}
85   retry_use_local_part
86   transport = send_to_server
87
88
89 # ----- Transports -----
90
91 begin transports
92
93 send_to_server:
94   driver = smtp
95   allow_localhost
96   hosts = 127.0.0.1
97   port = PORT_D
98   hosts_try_fastopen =  :
99
100   tls_certificate = DIR/aux-fixed/exim-ca/example.com/server2.example.com/server2.example.com.pem
101   tls_privatekey = DIR/aux-fixed/exim-ca/example.com/server2.example.com/server2.example.com.unlocked.key
102
103   tls_verify_certificates = DIR/aux-fixed/exim-ca/\
104        ${if eq {$local_part}{good}\
105 {example.com/server1.example.com/ca_chain.pem}\
106 {example.net/server1.example.net/ca_chain.pem}}
107   tls_verify_cert_hostnames =
108   tls_try_verify_hosts =
109
110   event_action =   ${acl {logger} {$event_name} {$domain} }
111
112 # ----- Retry -----
113
114
115 begin retry
116
117 * * F,5d,10s
118
119
120 # End