Add tls_verify_hosts and tls_try_verify_hosts to smtp transport
[exim.git] / src / src / transports / smtp.h
1 /*************************************************
2 * Exim - an Internet mail transport agent *
3 *************************************************/
4
5 /* Copyright (c) University of Cambridge 1995 - 2013 */
6 /* See the file NOTICE for conditions of use and distribution. */
7
8 /* Private structure for the private options and other private data. */
9
10 typedef struct {
11 uschar *hosts;
12 uschar *fallback_hosts;
13 host_item *hostlist;
14 host_item *fallback_hostlist;
15 uschar *authenticated_sender;
16 uschar *helo_data;
17 uschar *interface;
18 uschar *port;
19 uschar *protocol;
20 uschar *dscp;
21 uschar *serialize_hosts;
22 uschar *hosts_try_auth;
23 uschar *hosts_require_auth;
24 #ifdef EXPERIMENTAL_PRDR
25 uschar *hosts_try_prdr;
26 #endif
27 #ifdef EXPERIMENTAL_OCSP
28 uschar *hosts_require_ocsp;
29 #endif
30 uschar *hosts_require_tls;
31 uschar *hosts_avoid_tls;
32 uschar *hosts_verify_avoid_tls;
33 uschar *hosts_avoid_pipelining;
34 uschar *hosts_avoid_esmtp;
35 uschar *hosts_nopass_tls;
36 int command_timeout;
37 int connect_timeout;
38 int data_timeout;
39 int final_timeout;
40 int size_addition;
41 int hosts_max_try;
42 int hosts_max_try_hardlimit;
43 BOOL address_retry_include_sender;
44 BOOL allow_localhost;
45 BOOL authenticated_sender_force;
46 BOOL gethostbyname;
47 BOOL dns_qualify_single;
48 BOOL dns_search_parents;
49 BOOL delay_after_cutoff;
50 BOOL hosts_override;
51 BOOL hosts_randomize;
52 BOOL keepalive;
53 BOOL lmtp_ignore_quota;
54 BOOL retry_include_ip_address;
55 #ifdef SUPPORT_TLS
56 uschar *tls_certificate;
57 uschar *tls_crl;
58 uschar *tls_privatekey;
59 uschar *tls_require_ciphers;
60 uschar *gnutls_require_kx;
61 uschar *gnutls_require_mac;
62 uschar *gnutls_require_proto;
63 uschar *tls_sni;
64 uschar *tls_verify_certificates;
65 int tls_dh_min_bits;
66 BOOL tls_tempfail_tryclear;
67 uschar *tls_verify_hosts;
68 uschar *tls_try_verify_hosts;
69 #endif
70 #ifndef DISABLE_DKIM
71 uschar *dkim_domain;
72 uschar *dkim_private_key;
73 uschar *dkim_selector;
74 uschar *dkim_canon;
75 uschar *dkim_sign_headers;
76 uschar *dkim_strict;
77 #endif
78 #ifdef EXPERIMENTAL_TPDA
79 uschar *tpda_host_defer_action;
80 #endif
81 } smtp_transport_options_block;
82
83 /* Data for reading the private options. */
84
85 extern optionlist smtp_transport_options[];
86 extern int smtp_transport_options_count;
87
88 /* Block containing default values. */
89
90 extern smtp_transport_options_block smtp_transport_option_defaults;
91
92 /* The main, init, and closedown entry points for the transport */
93
94 extern BOOL smtp_transport_entry(transport_instance *, address_item *);
95 extern void smtp_transport_init(transport_instance *);
96 extern void smtp_transport_closedown(transport_instance *);
97
98
99
100 extern int smtp_auth(uschar *, unsigned, address_item *, host_item *,
101 smtp_transport_options_block *, BOOL,
102 smtp_inblock *, smtp_outblock *);
103 extern BOOL smtp_mail_auth_str(uschar *, unsigned,
104 address_item *, smtp_transport_options_block *);
105
106 /* End of transports/smtp.h */