X-Git-Url: https://git.exim.org/exim.git/blobdiff_plain/75c121f07a85b4029458f11b113a4655114af126..c0c781e2cabb7746a49edc88043db91f9e869c0b:/src/src/structs.h diff --git a/src/src/structs.h b/src/src/structs.h index 48f475a89..1e63d752b 100644 --- a/src/src/structs.h +++ b/src/src/structs.h @@ -66,8 +66,10 @@ typedef enum { CHUNKING_NOT_OFFERED = -1, CHUNKING_LAST} chunking_state_t; typedef enum { TFO_NOT_USED = 0, - TFO_ATTEMPTED, - TFO_USED } tfo_state_t; + TFO_ATTEMPTED_NODATA, + TFO_ATTEMPTED_DATA, + TFO_USED_NODATA, + TFO_USED_DATA } tfo_state_t; /* Structure for holding information about a host for use mainly by routers, but also used when checking lists of hosts and when transporting. Looking up @@ -442,6 +444,7 @@ typedef struct ip_address_item { int port; BOOL v6_include_v4; /* Used in the daemon */ uschar address[46]; + uschar * log; /* portion of "listening on" log line */ } ip_address_item; /* Structure for chaining together arbitrary strings. */ @@ -618,7 +621,11 @@ typedef struct address_item { BOOL af_bad_reply:1; /* filter could not generate autoreply */ BOOL af_tcp_fastopen_conn:1; /* delivery connection used TCP Fast Open */ BOOL af_tcp_fastopen:1; /* delivery usefully used TCP Fast Open */ + BOOL af_tcp_fastopen_data:1; /* delivery sent SMTP commands on TCP Fast Open */ BOOL af_pipelining:1; /* delivery used (traditional) pipelining */ +#ifdef EXPERIMENTAL_PIPE_CONNECT + BOOL af_early_pipe:1; /* delivery used connect-time pipelining */ +#endif #ifndef DISABLE_PRDR BOOL af_prdr_used:1; /* delivery used SMTP PRDR */ #endif @@ -787,6 +794,15 @@ typedef struct sha1 { unsigned int length; } sha1; +/* Information for making an smtp connection */ +typedef struct { + transport_instance * tblock; + void * ob; /* smtp_transport_options_block * */ + host_item * host; + int host_af; + uschar * interface; +} smtp_connect_args; + /* A client-initiated connection. If TLS, the second element is non-NULL */ typedef struct { int sock; @@ -817,6 +833,8 @@ typedef struct smtp_outblock { BOOL authenticating; /* TRUE when authenticating */ uschar *ptr; /* current position in the buffer */ uschar *buffer; /* the buffer itself */ + + smtp_connect_args * conn_args; /* to make connection, if not yet made */ } smtp_outblock; /* Structure to hold information about the source of redirection information */