Add tls_verify_hosts and tls_try_verify_hosts to smtp transport. Bug 1371
[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 */