Added tls_dh_max_bits & check tls_require_ciphers early.
[users/jgh/exim.git] / src / src / globals.c
1 /*************************************************
2 *     Exim - an Internet mail transport agent    *
3 *************************************************/
4
5 /* Copyright (c) University of Cambridge 1995 - 2012 */
6 /* See the file NOTICE for conditions of use and distribution. */
7
8 /* All the global variables are defined together in this one module, so
9 that they are easy to find. */
10
11 #include "exim.h"
12
13
14 /* Generic options for auths, all of which live inside auth_instance
15 data blocks and hence have the opt_public flag set. */
16
17 optionlist optionlist_auths[] = {
18   { "client_condition", opt_stringptr | opt_public,
19                  (void *)(offsetof(auth_instance, client_condition)) },
20   { "driver",        opt_stringptr | opt_public,
21                  (void *)(offsetof(auth_instance, driver_name)) },
22   { "public_name",   opt_stringptr | opt_public,
23                  (void *)(offsetof(auth_instance, public_name)) },
24   { "server_advertise_condition", opt_stringptr | opt_public,
25                  (void *)(offsetof(auth_instance, advertise_condition))},
26   { "server_condition", opt_stringptr | opt_public,
27                  (void *)(offsetof(auth_instance, server_condition)) },
28   { "server_debug_print", opt_stringptr | opt_public,
29                  (void *)(offsetof(auth_instance, server_debug_string)) },
30   { "server_mail_auth_condition", opt_stringptr | opt_public,
31                  (void *)(offsetof(auth_instance, mail_auth_condition)) },
32   { "server_set_id", opt_stringptr | opt_public,
33                  (void *)(offsetof(auth_instance, set_id)) }
34 };
35
36 int     optionlist_auths_size = sizeof(optionlist_auths)/sizeof(optionlist);
37
38 /* An empty host aliases list. */
39
40 uschar *no_aliases             = NULL;
41
42
43 /* For comments on these variables, see globals.h. I'm too idle to
44 duplicate them here... */
45
46 #ifdef EXIM_PERL
47 uschar *opt_perl_startup       = NULL;
48 BOOL    opt_perl_at_start      = FALSE;
49 BOOL    opt_perl_started       = FALSE;
50 #endif
51
52 #ifdef EXPAND_DLFUNC
53 tree_node *dlobj_anchor        = NULL;
54 #endif
55
56 #ifdef LOOKUP_IBASE
57 uschar *ibase_servers          = NULL;
58 #endif
59
60 #ifdef LOOKUP_LDAP
61 uschar *eldap_ca_cert_dir      = NULL;
62 uschar *eldap_ca_cert_file     = NULL;
63 uschar *eldap_cert_file        = NULL;
64 uschar *eldap_cert_key         = NULL;
65 uschar *eldap_cipher_suite     = NULL;
66 uschar *eldap_default_servers  = NULL;
67 uschar *eldap_require_cert     = NULL;
68 int     eldap_version          = -1;
69 BOOL    eldap_start_tls        = FALSE;
70 #endif
71
72 #ifdef LOOKUP_MYSQL
73 uschar *mysql_servers          = NULL;
74 #endif
75
76 #ifdef LOOKUP_ORACLE
77 uschar *oracle_servers         = NULL;
78 #endif
79
80 #ifdef LOOKUP_PGSQL
81 uschar *pgsql_servers          = NULL;
82 #endif
83
84 #ifdef LOOKUP_SQLITE
85 int     sqlite_lock_timeout    = 5;
86 #endif
87
88 #ifdef SUPPORT_MOVE_FROZEN_MESSAGES
89 BOOL    move_frozen_messages   = FALSE;
90 #endif
91
92 /* These variables are outside the #ifdef because it keeps the code less
93 cluttered in several places (e.g. during logging) if we can always refer to
94 them. Also, the tls_ variables are now always visible. */
95
96 BOOL    tls_active             = -1;
97 int     tls_bits               = 0;
98 BOOL    tls_certificate_verified = FALSE;
99 uschar *tls_cipher             = NULL;
100 BOOL    tls_on_connect         = FALSE;
101 uschar *tls_on_connect_ports   = NULL;
102 uschar *tls_peerdn             = NULL;
103
104 #ifdef SUPPORT_TLS
105 BOOL    gnutls_compat_mode     = FALSE;
106 uschar *gnutls_require_mac     = NULL;
107 uschar *gnutls_require_kx      = NULL;
108 uschar *gnutls_require_proto   = NULL;
109 uschar *openssl_options        = NULL;
110 const pcre *regex_STARTTLS     = NULL;
111 uschar *tls_advertise_hosts    = NULL;    /* This is deliberate */
112 uschar *tls_certificate        = NULL;
113 uschar *tls_crl                = NULL;
114 /* This default matches NSS DH_MAX_P_BITS value at current time (2012), because
115 that's the interop problem which has been observed: GnuTLS suggesting a higher
116 bit-count as "NORMAL" (2432) and Thunderbird dropping connection. */
117 int     tls_dh_max_bits        = 2236;
118 uschar *tls_dhparam            = NULL;
119 #if defined(EXPERIMENTAL_OCSP) && !defined(USE_GNUTLS)
120 uschar *tls_ocsp_file          = NULL;
121 #endif
122 BOOL    tls_offered            = FALSE;
123 uschar *tls_privatekey         = NULL;
124 BOOL    tls_remember_esmtp     = FALSE;
125 uschar *tls_require_ciphers    = NULL;
126 uschar *tls_sni                = NULL;
127 uschar *tls_try_verify_hosts   = NULL;
128 uschar *tls_verify_certificates= NULL;
129 uschar *tls_verify_hosts       = NULL;
130 #endif
131
132
133 /* Input-reading functions for messages, so we can use special ones for
134 incoming TCP/IP. The defaults use stdin. We never need these for any
135 stand-alone tests. */
136
137 #ifndef STAND_ALONE
138 int (*receive_getc)(void)      = stdin_getc;
139 int (*receive_ungetc)(int)     = stdin_ungetc;
140 int (*receive_feof)(void)      = stdin_feof;
141 int (*receive_ferror)(void)    = stdin_ferror;
142 BOOL (*receive_smtp_buffered)(void) = NULL;   /* Only used for SMTP */
143 #endif
144
145
146 /* List of per-address expansion variables for clearing and saving/restoring
147 when verifying one address while routing/verifying another. We have to have
148 the size explicit, because it is referenced from more than one module. */
149
150 uschar **address_expansions[ADDRESS_EXPANSIONS_COUNT] = {
151   &deliver_address_data,
152   &deliver_domain,
153   &deliver_domain_data,
154   &deliver_domain_orig,
155   &deliver_domain_parent,
156   &deliver_localpart,
157   &deliver_localpart_data,
158   &deliver_localpart_orig,
159   &deliver_localpart_parent,
160   &deliver_localpart_prefix,
161   &deliver_localpart_suffix,
162   (uschar **)(&deliver_recipients),
163   &deliver_host,
164   &deliver_home,
165   &address_file,
166   &address_pipe,
167   &self_hostname,
168   NULL };
169
170 int address_expansions_count = sizeof(address_expansions)/sizeof(uschar **);
171
172 /* General global variables */
173
174 header_line *acl_added_headers = NULL;
175 tree_node *acl_anchor          = NULL;
176
177 uschar *acl_not_smtp           = NULL;
178 #ifdef WITH_CONTENT_SCAN
179 uschar *acl_not_smtp_mime      = NULL;
180 #endif
181 uschar *acl_not_smtp_start     = NULL;
182
183 uschar *acl_smtp_auth          = NULL;
184 uschar *acl_smtp_connect       = NULL;
185 uschar *acl_smtp_data          = NULL;
186 #ifndef DISABLE_DKIM
187 uschar *acl_smtp_dkim          = NULL;
188 #endif
189 uschar *acl_smtp_etrn          = NULL;
190 uschar *acl_smtp_expn          = NULL;
191 uschar *acl_smtp_helo          = NULL;
192 uschar *acl_smtp_mail          = NULL;
193 uschar *acl_smtp_mailauth      = NULL;
194 #ifdef WITH_CONTENT_SCAN
195 uschar *acl_smtp_mime          = NULL;
196 #endif
197 uschar *acl_smtp_notquit       = NULL;
198 uschar *acl_smtp_predata       = NULL;
199 uschar *acl_smtp_quit          = NULL;
200 uschar *acl_smtp_rcpt          = NULL;
201 uschar *acl_smtp_starttls      = NULL;
202 uschar *acl_smtp_vrfy          = NULL;
203
204 BOOL    acl_temp_details       = FALSE;
205 tree_node *acl_var_c           = NULL;
206 tree_node *acl_var_m           = NULL;
207 uschar *acl_verify_message     = NULL;
208 string_item *acl_warn_logged   = NULL;
209
210 /* Names of SMTP places for use in ACL error messages, and corresponding SMTP
211 error codes - keep in step with definitions of ACL_WHERE_xxxx in macros.h. */
212
213 uschar *acl_wherenames[]       = { US"RCPT",
214                                    US"MAIL",
215                                    US"PREDATA",
216                                    US"MIME",
217                                    US"DKIM",
218                                    US"DATA",
219                                    US"non-SMTP",
220                                    US"AUTH",
221                                    US"connection",
222                                    US"ETRN",
223                                    US"EXPN",
224                                    US"EHLO or HELO",
225                                    US"MAILAUTH",
226                                    US"non-SMTP-start",
227                                    US"NOTQUIT",
228                                    US"QUIT",
229                                    US"STARTTLS",
230                                    US"VRFY"
231                                  };
232
233 uschar *acl_wherecodes[]       = { US"550",     /* RCPT */
234                                    US"550",     /* MAIL */
235                                    US"550",     /* PREDATA */
236                                    US"550",     /* MIME */
237                                    US"550",     /* DKIM */
238                                    US"550",     /* DATA */
239                                    US"0",       /* not SMTP; not relevant */
240                                    US"503",     /* AUTH */
241                                    US"550",     /* connect */
242                                    US"458",     /* ETRN */
243                                    US"550",     /* EXPN */
244                                    US"550",     /* HELO/EHLO */
245                                    US"0",       /* MAILAUTH; not relevant */
246                                    US"0",       /* not SMTP; not relevant */
247                                    US"0",       /* NOTQUIT; not relevant */
248                                    US"0",       /* QUIT; not relevant */
249                                    US"550",     /* STARTTLS */
250                                    US"252"      /* VRFY */
251                                  };
252
253 BOOL    active_local_from_check = FALSE;
254 BOOL    active_local_sender_retain = FALSE;
255 BOOL    accept_8bitmime        = TRUE; /* deliberately not RFC compliant */
256 address_item  *addr_duplicate  = NULL;
257
258 address_item address_defaults = {
259   NULL,                 /* next */
260   NULL,                 /* parent */
261   NULL,                 /* first */
262   NULL,                 /* dupof */
263   NULL,                 /* start_router */
264   NULL,                 /* router */
265   NULL,                 /* transport */
266   NULL,                 /* host_list */
267   NULL,                 /* host_used */
268   NULL,                 /* fallback_hosts */
269   NULL,                 /* reply */
270   NULL,                 /* retries */
271   NULL,                 /* address */
272   NULL,                 /* unique */
273   NULL,                 /* cc_local_part */
274   NULL,                 /* lc_local_part */
275   NULL,                 /* local_part */
276   NULL,                 /* prefix */
277   NULL,                 /* suffix */
278   NULL,                 /* domain */
279   NULL,                 /* address_retry_key */
280   NULL,                 /* domain_retry_key */
281   NULL,                 /* current_dir */
282   NULL,                 /* home_dir */
283   NULL,                 /* message */
284   NULL,                 /* user_message */
285   NULL,                 /* onetime_parent */
286   NULL,                 /* pipe_expandn */
287   NULL,                 /* return_filename */
288   NULL,                 /* self_hostname */
289   NULL,                 /* shadow_message */
290   #ifdef SUPPORT_TLS
291   NULL,                 /* cipher */
292   NULL,                 /* peerdn */
293   #endif
294   (uid_t)(-1),          /* uid */
295   (gid_t)(-1),          /* gid */
296   0,                    /* flags */
297   { 0 },                /* domain_cache - any larger array should be zeroed */
298   { 0 },                /* localpart_cache - ditto */
299   -1,                   /* mode */
300   0,                    /* more_errno */
301   ERRNO_UNKNOWNERROR,   /* basic_errno */
302   0,                    /* child_count */
303   -1,                   /* return_file */
304   SPECIAL_NONE,         /* special_action */
305   DEFER,                /* transport_return */
306   {                     /* fields that are propagated to children */
307     NULL,               /* address_data */
308     NULL,               /* domain_data */
309     NULL,               /* localpart_data */
310     NULL,               /* errors_address */
311     NULL,               /* extra_headers */
312     NULL,               /* remove_headers */
313 #ifdef EXPERIMENTAL_SRS
314     NULL,               /* srs_sender */
315 #endif
316   }
317 };
318
319 uschar *address_file           = NULL;
320 uschar *address_pipe           = NULL;
321 BOOL    address_test_mode      = FALSE;
322 tree_node *addresslist_anchor  = NULL;
323 int     addresslist_count      = 0;
324 gid_t  *admin_groups           = NULL;
325 BOOL    admin_user             = FALSE;
326 BOOL    allow_auth_unadvertised= FALSE;
327 BOOL    allow_domain_literals  = FALSE;
328 BOOL    allow_mx_to_ip         = FALSE;
329 BOOL    allow_unqualified_recipient = TRUE;    /* For local messages */
330 BOOL    allow_unqualified_sender = TRUE;       /* Reset for SMTP */
331 BOOL    allow_utf8_domains     = FALSE;
332 uschar *authenticated_id       = NULL;
333 uschar *authenticated_sender   = NULL;
334 BOOL    authentication_failed  = FALSE;
335 auth_instance  *auths          = NULL;
336 uschar *auth_advertise_hosts   = US"*";
337 auth_instance auth_defaults    = {
338     NULL,                      /* chain pointer */
339     NULL,                      /* name */
340     NULL,                      /* info */
341     NULL,                      /* private options block pointer */
342     NULL,                      /* driver_name */
343     NULL,                      /* advertise_condition */
344     NULL,                      /* client_condition */
345     NULL,                      /* public_name */
346     NULL,                      /* set_id */
347     NULL,                      /* server_mail_auth_condition */
348     NULL,                      /* server_debug_string */
349     NULL,                      /* server_condition */
350     FALSE,                     /* client */
351     FALSE,                     /* server */
352     FALSE                      /* advertised */
353 };
354
355 uschar *auth_defer_msg         = US"reason not recorded";
356 uschar *auth_defer_user_msg    = US"";
357 uschar *auth_vars[AUTH_VARS];
358 int     auto_thaw              = 0;
359 #ifdef WITH_CONTENT_SCAN
360 BOOL    av_failed              = FALSE;
361 uschar *av_scanner             = US"sophie:/var/run/sophie";  /* AV scanner */
362 #endif
363
364 BOOL    background_daemon      = TRUE;
365
366 #if BASE_62 == 62
367 uschar *base62_chars=
368     US"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
369 #else
370 uschar *base62_chars= US"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
371 #endif
372
373 uschar *bi_command             = NULL;
374 uschar *big_buffer             = NULL;
375 int     big_buffer_size        = BIG_BUFFER_SIZE;
376 #ifdef EXPERIMENTAL_BRIGHTMAIL
377 uschar *bmi_alt_location       = NULL;
378 uschar *bmi_base64_tracker_verdict = NULL;
379 uschar *bmi_base64_verdict     = NULL;
380 uschar *bmi_config_file        = US"/opt/brightmail/etc/brightmail.cfg";
381 int     bmi_deliver            = 1;
382 int     bmi_run                = 0;
383 uschar *bmi_verdicts           = NULL;
384 #endif
385 int     body_linecount         = 0;
386 int     body_zerocount         = 0;
387 uschar *bounce_message_file    = NULL;
388 uschar *bounce_message_text    = NULL;
389 uschar *bounce_recipient       = NULL;
390 BOOL    bounce_return_body     = TRUE;
391 BOOL    bounce_return_message  = TRUE;
392 int     bounce_return_size_limit = 100*1024;
393 uschar *bounce_sender_authentication = NULL;
394 int     bsmtp_transaction_linecount = 0;
395
396 int     callout_cache_domain_positive_expire = 7*24*60*60;
397 int     callout_cache_domain_negative_expire = 3*60*60;
398 int     callout_cache_positive_expire = 24*60*60;
399 int     callout_cache_negative_expire = 2*60*60;
400 uschar *callout_random_local_part = US"$primary_hostname-$tod_epoch-testing";
401 uschar *check_dns_names_pattern= US"(?i)^(?>(?(1)\\.|())[^\\W](?>[a-z0-9/_-]*[^\\W])?)+(\\.?)$";
402 int     check_log_inodes       = 0;
403 int     check_log_space        = 0;
404 BOOL    check_rfc2047_length   = TRUE;
405 int     check_spool_inodes     = 0;
406 int     check_spool_space      = 0;
407 int     clmacro_count          = 0;
408 uschar *clmacros[MAX_CLMACROS];
409 BOOL    config_changed         = FALSE;
410 FILE   *config_file            = NULL;
411 uschar *config_filename        = NULL;
412 int     config_lineno          = 0;
413 #ifdef CONFIGURE_GROUP
414 gid_t   config_gid             = CONFIGURE_GROUP;
415 #endif
416 uschar *config_main_filelist   = US CONFIGURE_FILE
417                          "\0<-----------Space to patch configure_filename->";
418 uschar *config_main_filename   = NULL;
419
420 #ifdef CONFIGURE_OWNER
421 uid_t   config_uid             = CONFIGURE_OWNER;
422 #endif
423
424 int     connection_max_messages= -1;
425 uschar *continue_hostname      = NULL;
426 uschar *continue_host_address  = NULL;
427 BOOL    continue_more          = FALSE;
428 int     continue_sequence      = 1;
429 uschar *continue_transport     = NULL;
430
431 uschar *csa_status             = NULL;
432
433 BOOL    daemon_listen          = FALSE;
434 uschar *daemon_smtp_port       = US"smtp";
435 int     daemon_startup_retries = 9;
436 int     daemon_startup_sleep   = 30;
437
438 #ifdef EXPERIMENTAL_DCC
439 BOOL    dcc_direct_add_header  = FALSE;
440 uschar *dcc_header             = NULL;
441 uschar *dcc_result             = NULL;
442 uschar *dccifd_address         = US"/usr/local/dcc/var/dccifd";
443 uschar *dccifd_options         = US"header";
444 #endif
445
446 BOOL    debug_daemon           = FALSE;
447 int     debug_fd               = -1;
448 FILE   *debug_file             = NULL;
449 bit_table debug_options[]      = {
450   { US"acl",            D_acl },
451   { US"all",            D_all },
452   { US"auth",           D_auth },
453   { US"deliver",        D_deliver },
454   { US"dns",            D_dns },
455   { US"dnsbl",          D_dnsbl },
456   { US"exec",           D_exec },
457   { US"expand",         D_expand },
458   { US"filter",         D_filter },
459   { US"hints_lookup",   D_hints_lookup },
460   { US"host_lookup",    D_host_lookup },
461   { US"ident",          D_ident },
462   { US"interface",      D_interface },
463   { US"lists",          D_lists },
464   { US"load",           D_load },
465   { US"local_scan",     D_local_scan },
466   { US"lookup",         D_lookup },
467   { US"memory",         D_memory },
468   { US"pid",            D_pid },
469   { US"process_info",   D_process_info },
470   { US"queue_run",      D_queue_run },
471   { US"receive",        D_receive },
472   { US"resolver",       D_resolver },
473   { US"retry",          D_retry },
474   { US"rewrite",        D_rewrite },
475   { US"route",          D_route },
476   { US"timestamp",      D_timestamp },
477   { US"tls",            D_tls },
478   { US"transport",      D_transport },
479   { US"uid",            D_uid },
480   { US"verify",         D_verify }
481 };
482 int     debug_options_count    = sizeof(debug_options)/sizeof(bit_table);
483 unsigned int debug_selector    = 0;
484 int     delay_warning[DELAY_WARNING_SIZE] = { DELAY_WARNING_SIZE, 1, 24*60*60 };
485 uschar *delay_warning_condition=
486   US"${if or {"
487             "{ !eq{$h_list-id:$h_list-post:$h_list-subscribe:}{} }"
488             "{ match{$h_precedence:}{(?i)bulk|list|junk} }"
489             "{ match{$h_auto-submitted:}{(?i)auto-generated|auto-replied} }"
490             "} {no}{yes}}";
491 BOOL    delivery_date_remove   = TRUE;
492 uschar *deliver_address_data   = NULL;
493 int     deliver_datafile       = -1;
494 uschar *deliver_domain         = NULL;
495 uschar *deliver_domain_data    = NULL;
496 uschar *deliver_domain_orig    = NULL;
497 uschar *deliver_domain_parent  = NULL;
498 BOOL    deliver_drop_privilege = FALSE;
499 BOOL    deliver_firsttime      = FALSE;
500 BOOL    deliver_force          = FALSE;
501 BOOL    deliver_freeze         = FALSE;
502 int     deliver_frozen_at      = 0;
503 uschar *deliver_home           = NULL;
504 uschar *deliver_host           = NULL;
505 uschar *deliver_host_address   = NULL;
506 uschar *deliver_in_buffer      = NULL;
507 ino_t   deliver_inode          = 0;
508 uschar *deliver_localpart      = NULL;
509 uschar *deliver_localpart_data = NULL;
510 uschar *deliver_localpart_orig = NULL;
511 uschar *deliver_localpart_parent = NULL;
512 uschar *deliver_localpart_prefix = NULL;
513 uschar *deliver_localpart_suffix = NULL;
514 BOOL    deliver_force_thaw     = FALSE;
515 BOOL    deliver_manual_thaw    = FALSE;
516 uschar *deliver_out_buffer     = NULL;
517 int     deliver_queue_load_max = -1;
518 address_item  *deliver_recipients = NULL;
519 uschar *deliver_selectstring   = NULL;
520 BOOL    deliver_selectstring_regex = FALSE;
521 uschar *deliver_selectstring_sender = NULL;
522 BOOL    deliver_selectstring_sender_regex = FALSE;
523 #ifdef WITH_OLD_DEMIME
524 int     demime_errorlevel      = 0;
525 int     demime_ok              = 0;
526 uschar *demime_reason          = NULL;
527 #endif
528 BOOL    disable_callout_flush  = FALSE;
529 BOOL    disable_delay_flush    = FALSE;
530 #ifdef ENABLE_DISABLE_FSYNC
531 BOOL    disable_fsync          = FALSE;
532 #endif
533 BOOL    disable_ipv6           = FALSE;
534 BOOL    disable_logging        = FALSE;
535
536 #ifndef DISABLE_DKIM
537 uschar *dkim_cur_signer          = NULL;
538 uschar *dkim_signers             = NULL;
539 uschar *dkim_signing_domain      = NULL;
540 uschar *dkim_signing_selector    = NULL;
541 uschar *dkim_verify_signers      = US"$dkim_signers";
542 BOOL    dkim_collect_input       = FALSE;
543 BOOL    dkim_disable_verify      = FALSE;
544 #endif
545
546 uschar *dns_again_means_nonexist = NULL;
547 int     dns_csa_search_limit   = 5;
548 BOOL    dns_csa_use_reverse    = TRUE;
549 uschar *dns_ipv4_lookup        = NULL;
550 int     dns_retrans            = 0;
551 int     dns_retry              = 0;
552 int     dns_use_edns0          = -1; /* <0 = not coerced */
553 uschar *dnslist_domain         = NULL;
554 uschar *dnslist_matched        = NULL;
555 uschar *dnslist_text           = NULL;
556 uschar *dnslist_value          = NULL;
557 tree_node *domainlist_anchor   = NULL;
558 int     domainlist_count       = 0;
559 BOOL    dont_deliver           = FALSE;
560 BOOL    dot_ends               = TRUE;
561 BOOL    drop_cr                = FALSE;         /* No longer used */
562 uschar *dsn_from               = US DEFAULT_DSN_FROM;
563
564 BOOL    enable_dollar_recipients = FALSE;
565 BOOL    envelope_to_remove     = TRUE;
566 int     errno_quota            = ERRNO_QUOTA;
567 uschar *errors_copy            = NULL;
568 int     error_handling         = ERRORS_SENDER;
569 uschar *errors_reply_to        = NULL;
570 int     errors_sender_rc       = EXIT_FAILURE;
571
572 gid_t   exim_gid               = EXIM_GID;
573 BOOL    exim_gid_set           = TRUE;          /* This gid is always set */
574 uschar *exim_path              = US BIN_DIRECTORY "/exim"
575                         "\0<---------------Space to patch exim_path->";
576 uid_t   exim_uid               = EXIM_UID;
577 BOOL    exim_uid_set           = TRUE;          /* This uid is always set */
578 int     expand_forbid          = 0;
579 int     expand_nlength[EXPAND_MAXN+1];
580 int     expand_nmax            = -1;
581 uschar *expand_nstring[EXPAND_MAXN+1];
582 BOOL    expand_string_forcedfail = FALSE;
583 uschar *expand_string_message;
584 BOOL    extract_addresses_remove_arguments = TRUE;
585 uschar *extra_local_interfaces = NULL;
586
587 int     fake_response          = OK;
588 uschar *fake_response_text     = US"Your message has been rejected but is "
589                                    "being kept for evaluation.\nIf it was a "
590                                    "legitimate message, it may still be "
591                                    "delivered to the target recipient(s).";
592 int     filter_n[FILTER_VARIABLE_COUNT];
593 BOOL    filter_running         = FALSE;
594 int     filter_sn[FILTER_VARIABLE_COUNT];
595 int     filter_test            = FTEST_NONE;
596 uschar *filter_test_sfile      = NULL;
597 uschar *filter_test_ufile      = NULL;
598 uschar *filter_thisaddress     = NULL;
599 int     finduser_retries       = 0;
600 #ifdef WITH_OLD_DEMIME
601 uschar *found_extension        = NULL;
602 #endif
603 uid_t   fixed_never_users[]    = { FIXED_NEVER_USERS };
604 uschar *freeze_tell            = NULL;
605 uschar *freeze_tell_config     = NULL;
606 uschar *fudged_queue_times     = US"";
607
608 uschar *gecos_name             = NULL;
609 uschar *gecos_pattern          = NULL;
610 rewrite_rule  *global_rewrite_rules = NULL;
611
612 uschar *headers_charset        = US HEADERS_CHARSET;
613 int     header_insert_maxlen   = 64 * 1024;
614 header_line  *header_last      = NULL;
615 header_line  *header_list      = NULL;
616 int     header_maxsize         = HEADER_MAXSIZE;
617 int     header_line_maxsize    = 0;
618
619 header_name header_names[] = {
620   { US"bcc",            3, TRUE,  htype_bcc },
621   { US"cc",             2, TRUE,  htype_cc },
622   { US"date",           4, TRUE,  htype_date },
623   { US"delivery-date", 13, FALSE, htype_delivery_date },
624   { US"envelope-to",   11, FALSE, htype_envelope_to },
625   { US"from",           4, TRUE,  htype_from },
626   { US"message-id",    10, TRUE,  htype_id },
627   { US"received",       8, FALSE, htype_received },
628   { US"reply-to",       8, FALSE, htype_reply_to },
629   { US"return-path",   11, FALSE, htype_return_path },
630   { US"sender",         6, TRUE,  htype_sender },
631   { US"subject",        7, FALSE, htype_subject },
632   { US"to",             2, TRUE,  htype_to }
633 };
634
635 int header_names_size          = sizeof(header_names)/sizeof(header_name);
636
637 BOOL    header_rewritten       = FALSE;
638 uschar *helo_accept_junk_hosts = NULL;
639 uschar *helo_allow_chars       = US"";
640 uschar *helo_lookup_domains    = US"@ : @[]";
641 uschar *helo_try_verify_hosts  = NULL;
642 BOOL    helo_verified          = FALSE;
643 BOOL    helo_verify_failed     = FALSE;
644 uschar *helo_verify_hosts      = NULL;
645 const uschar *hex_digits       = CUS"0123456789abcdef";
646 uschar *hold_domains           = NULL;
647 BOOL    host_checking          = FALSE;
648 BOOL    host_checking_callout  = FALSE;
649 uschar *host_data              = NULL;
650 BOOL    host_find_failed_syntax= FALSE;
651 uschar *host_lookup            = NULL;
652 BOOL    host_lookup_deferred   = FALSE;
653 BOOL    host_lookup_failed     = FALSE;
654 uschar *host_lookup_order      = US"bydns:byaddr";
655 uschar *host_lookup_msg        = US"";
656 int     host_number            = 0;
657 uschar *host_number_string     = NULL;
658 uschar *host_reject_connection = NULL;
659 tree_node *hostlist_anchor     = NULL;
660 int     hostlist_count         = 0;
661 uschar *hosts_treat_as_local   = NULL;
662 uschar *hosts_connection_nolog = NULL;
663
664 int     ignore_bounce_errors_after = 10*7*24*60*60;  /* 10 weeks */
665 BOOL    ignore_fromline_local  = FALSE;
666 uschar *ignore_fromline_hosts  = NULL;
667 BOOL    inetd_wait_mode        = FALSE;
668 int     inetd_wait_timeout     = -1;
669 uschar *interface_address      = NULL;
670 int     interface_port         = -1;
671 BOOL    is_inetd               = FALSE;
672 uschar *iterate_item           = NULL;
673
674 int     journal_fd             = -1;
675
676 int     keep_malformed         = 4*24*60*60;    /* 4 days */
677
678 uschar *eldap_dn               = NULL;
679 int     load_average           = -2;
680 BOOL    local_error_message    = FALSE;
681 BOOL    local_from_check       = TRUE;
682 uschar *local_from_prefix      = NULL;
683 uschar *local_from_suffix      = NULL;
684
685 #if HAVE_IPV6
686 uschar *local_interfaces       = US"<; ::0 ; 0.0.0.0";
687 #else
688 uschar *local_interfaces       = US"0.0.0.0";
689 #endif
690
691 uschar *local_scan_data        = NULL;
692 int     local_scan_timeout     = 5*60;
693 BOOL    local_sender_retain    = FALSE;
694 gid_t   local_user_gid         = (gid_t)(-1);
695 uid_t   local_user_uid         = (uid_t)(-1);
696
697 tree_node *localpartlist_anchor= NULL;
698 int     localpartlist_count    = 0;
699 uschar *log_buffer             = NULL;
700 unsigned int log_extra_selector = LX_default;
701 uschar *log_file_path          = US LOG_FILE_PATH
702                            "\0<--------------Space to patch log_file_path->";
703
704 /* Those log options with L_xxx identifiers have values less than 0x800000 and
705 are the ones that get put into log_write_selector. They can be used in calls to
706 log_write() to test for the bit. The options with LX_xxx identifiers have
707 values greater than 0x80000000 and are put into log_extra_selector (without the
708 top bit). They are never used in calls to log_write(), but are tested
709 independently. This separation became necessary when the number of log
710 selectors was getting close to filling a 32-bit word. */
711
712 /* Note that this list must be in alphabetical order. */
713
714 bit_table log_options[]        = {
715   { US"acl_warn_skipped",             LX_acl_warn_skipped },
716   { US"address_rewrite",              L_address_rewrite },
717   { US"all",                          L_all },
718   { US"all_parents",                  L_all_parents },
719   { US"arguments",                    LX_arguments },
720   { US"connection_reject",            L_connection_reject },
721   { US"delay_delivery",               L_delay_delivery },
722   { US"deliver_time",                 LX_deliver_time },
723   { US"delivery_size",                LX_delivery_size },
724   { US"dnslist_defer",                L_dnslist_defer },
725   { US"etrn",                         L_etrn },
726   { US"host_lookup_failed",           L_host_lookup_failed },
727   { US"ident_timeout",                LX_ident_timeout },
728   { US"incoming_interface",           LX_incoming_interface },
729   { US"incoming_port",                LX_incoming_port },
730   { US"lost_incoming_connection",     L_lost_incoming_connection },
731   { US"outgoing_port",                LX_outgoing_port },
732   { US"pid",                          LX_pid },
733   { US"queue_run",                    L_queue_run },
734   { US"queue_time",                   LX_queue_time },
735   { US"queue_time_overall",           LX_queue_time_overall },
736   { US"received_recipients",          LX_received_recipients },
737   { US"received_sender",              LX_received_sender },
738   { US"rejected_header",              LX_rejected_header },
739   { US"rejected_headers",             LX_rejected_header },
740   { US"retry_defer",                  L_retry_defer },
741   { US"return_path_on_delivery",      LX_return_path_on_delivery },
742   { US"sender_on_delivery",           LX_sender_on_delivery },
743   { US"sender_verify_fail",           LX_sender_verify_fail },
744   { US"size_reject",                  L_size_reject },
745   { US"skip_delivery",                L_skip_delivery },
746   { US"smtp_confirmation",            LX_smtp_confirmation },
747   { US"smtp_connection",              L_smtp_connection },
748   { US"smtp_incomplete_transaction",  L_smtp_incomplete_transaction },
749   { US"smtp_no_mail",                 LX_smtp_no_mail },
750   { US"smtp_protocol_error",          L_smtp_protocol_error },
751   { US"smtp_syntax_error",            L_smtp_syntax_error },
752   { US"subject",                      LX_subject },
753   { US"tls_certificate_verified",     LX_tls_certificate_verified },
754   { US"tls_cipher",                   LX_tls_cipher },
755   { US"tls_peerdn",                   LX_tls_peerdn },
756   { US"tls_sni",                      LX_tls_sni },
757   { US"unknown_in_list",              LX_unknown_in_list }
758 };
759
760 int     log_options_count      = sizeof(log_options)/sizeof(bit_table);
761 int     log_reject_target      = 0;
762 uschar *log_selector_string    = NULL;
763 FILE   *log_stderr             = NULL;
764 BOOL    log_testing_mode       = FALSE;
765 BOOL    log_timezone           = FALSE;
766 unsigned int log_write_selector= L_default;
767 uschar *login_sender_address   = NULL;
768 int     lookup_open_max        = 25;
769 uschar *lookup_value           = NULL;
770
771 macro_item  *macros            = NULL;
772 uschar *mailstore_basename     = NULL;
773 #ifdef WITH_CONTENT_SCAN
774 uschar *malware_name           = NULL;  /* Virus Name */
775 #endif
776 int     max_received_linelength= 0;
777 int     max_username_length    = 0;
778 int     message_age            = 0;
779 uschar *message_body           = NULL;
780 uschar *message_body_end       = NULL;
781 BOOL    message_body_newlines  = FALSE;
782 int     message_body_size      = 0;
783 int     message_body_visible   = 500;
784 int     message_ended          = END_NOTSTARTED;
785 uschar *message_headers        = NULL;
786 uschar *message_id;
787 uschar *message_id_domain      = NULL;
788 uschar *message_id_text        = NULL;
789 struct timeval message_id_tv   = { 0, 0 };
790 uschar  message_id_option[MESSAGE_ID_LENGTH + 3];
791 uschar *message_id_external;
792 int     message_linecount      = 0;
793 BOOL    message_logs           = TRUE;
794 int     message_size           = 0;
795 uschar *message_size_limit     = US"50M";
796 uschar  message_subdir[2]      = { 0, 0 };
797 uschar *message_reference      = NULL;
798
799 /* MIME ACL expandables */
800 #ifdef WITH_CONTENT_SCAN
801 int     mime_anomaly_level     = 0;
802 const uschar *mime_anomaly_text      = NULL;
803 uschar *mime_boundary          = NULL;
804 uschar *mime_charset           = NULL;
805 uschar *mime_content_description = NULL;
806 uschar *mime_content_disposition = NULL;
807 uschar *mime_content_id        = NULL;
808 unsigned int mime_content_size = 0;
809 uschar *mime_content_transfer_encoding = NULL;
810 uschar *mime_content_type      = NULL;
811 uschar *mime_decoded_filename  = NULL;
812 uschar *mime_filename          = NULL;
813 int     mime_is_multipart      = 0;
814 int     mime_is_coverletter    = 0;
815 int     mime_is_rfc822         = 0;
816 int     mime_part_count        = -1;
817 #endif
818
819 BOOL    mua_wrapper            = FALSE;
820
821 uid_t  *never_users            = NULL;
822 #ifdef WITH_CONTENT_SCAN
823 BOOL    no_mbox_unspool        = FALSE;
824 #endif
825 BOOL    no_multiline_responses = FALSE;
826
827 uid_t   original_euid;
828 gid_t   originator_gid;
829 uschar *originator_login       = NULL;
830 uschar *originator_name        = NULL;
831 uid_t   originator_uid;
832 uschar *override_local_interfaces = NULL;
833 uschar *override_pid_file_path = NULL;
834
835 BOOL    parse_allow_group      = FALSE;
836 BOOL    parse_found_group      = FALSE;
837 uschar *percent_hack_domains   = NULL;
838 uschar *pid_file_path          = US PID_FILE_PATH
839                            "\0<--------------Space to patch pid_file_path->";
840 BOOL    pipelining_enable      = TRUE;
841 uschar *pipelining_advertise_hosts = US"*";
842 BOOL    preserve_message_logs  = FALSE;
843 uschar *primary_hostname       = NULL;
844 BOOL    print_topbitchars      = FALSE;
845 uschar  process_info[PROCESS_INFO_SIZE];
846 int     process_info_len       = 0;
847 uschar *process_log_path       = NULL;
848 BOOL    prod_requires_admin    = TRUE;
849 uschar *prvscheck_address      = NULL;
850 uschar *prvscheck_keynum       = NULL;
851 uschar *prvscheck_result       = NULL;
852
853
854 uschar *qualify_domain_recipient = NULL;
855 uschar *qualify_domain_sender  = NULL;
856 BOOL    queue_2stage           = FALSE;
857 uschar *queue_domains          = NULL;
858 int     queue_interval         = -1;
859 BOOL    queue_list_requires_admin = TRUE;
860 BOOL    queue_only             = FALSE;
861 uschar *queue_only_file        = NULL;
862 int     queue_only_load        = -1;
863 BOOL    queue_only_load_latch  = TRUE;
864 BOOL    queue_only_override    = TRUE;
865 BOOL    queue_only_policy      = FALSE;
866 BOOL    queue_run_first_delivery = FALSE;
867 BOOL    queue_run_force        = FALSE;
868 BOOL    queue_run_in_order     = FALSE;
869 BOOL    queue_run_local        = FALSE;
870 int     queue_run_max          = 5;
871 pid_t   queue_run_pid          = (pid_t)0;
872 int     queue_run_pipe         = -1;
873 BOOL    queue_running          = FALSE;
874 BOOL    queue_smtp             = FALSE;
875 uschar *queue_smtp_domains     = NULL;
876
877 unsigned int random_seed       = 0;
878 tree_node *ratelimiters_cmd    = NULL;
879 tree_node *ratelimiters_conn   = NULL;
880 tree_node *ratelimiters_mail   = NULL;
881 uschar *raw_active_hostname    = NULL;
882 uschar *raw_sender             = NULL;
883 uschar **raw_recipients        = NULL;
884 int     raw_recipients_count   = 0;
885
886 int     rcpt_count             = 0;
887 int     rcpt_fail_count        = 0;
888 int     rcpt_defer_count       = 0;
889 gid_t   real_gid;
890 uid_t   real_uid;
891 BOOL    really_exim            = TRUE;
892 BOOL    receive_call_bombout   = FALSE;
893 int     receive_linecount      = 0;
894 int     receive_messagecount   = 0;
895 int     receive_timeout        = 0;
896 int     received_count         = 0;
897 uschar *received_for           = NULL;
898
899 /*  This is the default text for Received headers generated by Exim. The
900 date  will be automatically added on the end. */
901
902 uschar *received_header_text   = US
903      "Received: "
904      "${if def:sender_rcvhost {from $sender_rcvhost\n\t}"
905      "{${if def:sender_ident {from ${quote_local_part:$sender_ident} }}"
906      "${if def:sender_helo_name {(helo=$sender_helo_name)\n\t}}}}"
907      "by $primary_hostname "
908      "${if def:received_protocol {with $received_protocol}} "
909      #ifdef SUPPORT_TLS
910      "${if def:tls_cipher {($tls_cipher)\n\t}}"
911      #endif
912      "(Exim $version_number)\n\t"
913      "${if def:sender_address {(envelope-from <$sender_address>)\n\t}}"
914      "id $message_exim_id"
915      "${if def:received_for {\n\tfor $received_for}}"
916      "\0<---------------Space to patch received_header_text->";
917
918 int     received_headers_max   = 30;
919 uschar *received_protocol      = NULL;
920 int     received_time          = 0;
921 uschar *recipient_data         = NULL;
922 uschar *recipient_unqualified_hosts = NULL;
923 uschar *recipient_verify_failure = NULL;
924 int     recipients_count       = 0;
925 BOOL    recipients_discarded   = FALSE;
926 recipient_item  *recipients_list = NULL;
927 int     recipients_list_max    = 0;
928 int     recipients_max         = 0;
929 BOOL    recipients_max_reject  = FALSE;
930 const pcre *regex_AUTH         = NULL;
931 const pcre *regex_check_dns_names = NULL;
932 const pcre *regex_From         = NULL;
933 const pcre *regex_IGNOREQUOTA  = NULL;
934 const pcre *regex_PIPELINING   = NULL;
935 const pcre *regex_SIZE         = NULL;
936 const pcre *regex_smtp_code    = NULL;
937 const pcre *regex_ismsgid      = NULL;
938 #ifdef WHITELIST_D_MACROS
939 const pcre *regex_whitelisted_macro = NULL;
940 #endif
941 #ifdef WITH_CONTENT_SCAN
942 uschar *regex_match_string     = NULL;
943 #endif
944 int     remote_delivery_count  = 0;
945 int     remote_max_parallel    = 2;
946 uschar *remote_sort_domains    = NULL;
947 int     retry_data_expire      = 7*24*60*60;
948 int     retry_interval_max     = 24*60*60;
949 int     retry_maximum_timeout  = 0;        /* set from retry config */
950 retry_config  *retries         = NULL;
951 uschar *return_path            = NULL;
952 BOOL    return_path_remove     = TRUE;
953 int     rewrite_existflags     = 0;
954 uschar *rfc1413_hosts          = US"*";
955 int     rfc1413_query_timeout  = 5;
956 /* BOOL    rfc821_domains         = FALSE;  <<< on the way out */
957 uid_t   root_gid               = ROOT_GID;
958 uid_t   root_uid               = ROOT_UID;
959
960 router_instance  *routers  = NULL;
961 router_instance  router_defaults = {
962     NULL,                      /* chain pointer */
963     NULL,                      /* name */
964     NULL,                      /* info */
965     NULL,                      /* private options block pointer */
966     NULL,                      /* driver name */
967
968     NULL,                      /* address_data */
969 #ifdef EXPERIMENTAL_BRIGHTMAIL
970     NULL,                      /* bmi_rule */
971 #endif
972     NULL,                      /* cannot_route_message */
973     NULL,                      /* condition */
974     NULL,                      /* current_directory */
975     NULL,                      /* debug_string */
976     NULL,                      /* domains */
977     NULL,                      /* errors_to */
978     NULL,                      /* expand_gid */
979     NULL,                      /* expand_uid */
980     NULL,                      /* expand_more */
981     NULL,                      /* expand_unseen */
982     NULL,                      /* extra_headers */
983     NULL,                      /* fallback_hosts */
984     NULL,                      /* home_directory */
985     NULL,                      /* ignore_target_hosts */
986     NULL,                      /* local_parts */
987     NULL,                      /* pass_router_name */
988     NULL,                      /* prefix */
989     NULL,                      /* redirect_router_name */
990     NULL,                      /* remove_headers */
991     NULL,                      /* require_files */
992     NULL,                      /* router_home_directory */
993     US"freeze",                /* self */
994     NULL,                      /* senders */
995     NULL,                      /* suffix */
996     NULL,                      /* translate_ip_address */
997     NULL,                      /* transport_name */
998
999     TRUE,                      /* address_test */
1000 #ifdef EXPERIMENTAL_BRIGHTMAIL
1001     FALSE,                     /* bmi_deliver_alternate */
1002     FALSE,                     /* bmi_deliver_default */
1003     FALSE,                     /* bmi_dont_deliver */
1004 #endif
1005     TRUE,                      /* expn */
1006     FALSE,                     /* caseful_local_part */
1007     FALSE,                     /* check_local_user */
1008     FALSE,                     /* disable_logging */
1009     FALSE,                     /* fail_verify_recipient */
1010     FALSE,                     /* fail_verify_sender */
1011     FALSE,                     /* gid_set */
1012     FALSE,                     /* initgroups */
1013     TRUE_UNSET,                /* log_as_local */
1014     TRUE,                      /* more */
1015     FALSE,                     /* pass_on_timeout */
1016     FALSE,                     /* prefix_optional */
1017     TRUE,                      /* repeat_use */
1018     TRUE_UNSET,                /* retry_use_local_part - fudge "unset" */
1019     FALSE,                     /* same_domain_copy_routing */
1020     FALSE,                     /* self_rewrite */
1021     FALSE,                     /* suffix_optional */
1022     FALSE,                     /* verify_only */
1023     TRUE,                      /* verify_recipient */
1024     TRUE,                      /* verify_sender */
1025     FALSE,                     /* uid_set */
1026     FALSE,                     /* unseen */
1027
1028     self_freeze,               /* self_code */
1029     (uid_t)(-1),               /* uid */
1030     (gid_t)(-1),               /* gid */
1031
1032     NULL,                      /* fallback_hostlist */
1033     NULL,                      /* transport instance */
1034     NULL,                      /* pass_router */
1035     NULL                       /* redirect_router */
1036 };
1037
1038 ip_address_item *running_interfaces = NULL;
1039 BOOL    running_in_test_harness = FALSE;
1040
1041 /* This is a weird one. The following string gets patched in the binary by the
1042 script that sets up a copy of Exim for running in the test harness. It seems
1043 that compilers are now clever, and share constant strings if they can.
1044 Elsewhere in Exim the string "<" is used. The compiler optimization seems to
1045 make use of the end of this string in order to save space. So the patching then
1046 wrecks this. We defeat this optimization by adding some additional characters
1047 onto the end of the string. */
1048
1049 uschar *running_status         = US">>>running<<<" "\0EXTRA";
1050
1051 int     runrc                  = 0;
1052
1053 uschar *search_error_message   = NULL;
1054 BOOL    search_find_defer      = FALSE;
1055 uschar *self_hostname          = NULL;
1056 uschar *sender_address         = NULL;
1057 unsigned int sender_address_cache[(MAX_NAMED_LIST * 2)/32];
1058 uschar *sender_address_data    = NULL;
1059 BOOL    sender_address_forced  = FALSE;
1060 uschar *sender_address_unrewritten = NULL;
1061 uschar *sender_data            = NULL;
1062 unsigned int sender_domain_cache[(MAX_NAMED_LIST * 2)/32];
1063 uschar *sender_fullhost        = NULL;
1064 uschar *sender_helo_name       = NULL;
1065 uschar **sender_host_aliases   = &no_aliases;
1066 uschar *sender_host_address    = NULL;
1067 uschar *sender_host_authenticated = NULL;
1068 unsigned int sender_host_cache[(MAX_NAMED_LIST * 2)/32];
1069 uschar *sender_host_name       = NULL;
1070 int     sender_host_port       = 0;
1071 BOOL    sender_host_notsocket  = FALSE;
1072 BOOL    sender_host_unknown    = FALSE;
1073 uschar *sender_ident           = NULL;
1074 BOOL    sender_local           = FALSE;
1075 BOOL    sender_name_forced     = FALSE;
1076 uschar *sender_rate            = NULL;
1077 uschar *sender_rate_limit      = NULL;
1078 uschar *sender_rate_period     = NULL;
1079 uschar *sender_rcvhost         = NULL;
1080 BOOL    sender_set_untrusted   = FALSE;
1081 uschar *sender_unqualified_hosts = NULL;
1082 uschar *sender_verify_failure = NULL;
1083 address_item *sender_verified_list  = NULL;
1084 address_item *sender_verified_failed = NULL;
1085 int     sender_verified_rc     = -1;
1086 BOOL    sender_verified_responded = FALSE;
1087 uschar *sending_ip_address     = NULL;
1088 int     sending_port           = -1;
1089 SIGNAL_BOOL sigalrm_seen       = FALSE;
1090 uschar **sighup_argv           = NULL;
1091 int     smtp_accept_count      = 0;
1092 BOOL    smtp_accept_keepalive  = TRUE;
1093 int     smtp_accept_max        = 20;
1094 int     smtp_accept_max_nonmail= 10;
1095 uschar *smtp_accept_max_nonmail_hosts = US"*";
1096 int     smtp_accept_max_per_connection = 1000;
1097 uschar *smtp_accept_max_per_host = NULL;
1098 int     smtp_accept_queue      = 0;
1099 int     smtp_accept_queue_per_connection = 10;
1100 int     smtp_accept_reserve    = 0;
1101 uschar *smtp_active_hostname   = NULL;
1102 BOOL    smtp_authenticated     = FALSE;
1103 uschar *smtp_banner            = US"$smtp_active_hostname ESMTP "
1104                              "Exim $version_number $tod_full"
1105                              "\0<---------------Space to patch smtp_banner->";
1106 BOOL    smtp_batched_input     = FALSE;
1107 BOOL    smtp_check_spool_space = TRUE;
1108 int     smtp_ch_index          = 0;
1109 uschar *smtp_cmd_argument      = NULL;
1110 uschar *smtp_cmd_buffer        = NULL;
1111 time_t  smtp_connection_start  = 0;
1112 uschar  smtp_connection_had[SMTP_HBUFF_SIZE];
1113 int     smtp_connect_backlog   = 20;
1114 double  smtp_delay_mail        = 0.0;
1115 double  smtp_delay_rcpt        = 0.0;
1116 BOOL    smtp_enforce_sync      = TRUE;
1117 FILE   *smtp_in                = NULL;
1118 BOOL    smtp_input             = FALSE;
1119 int     smtp_load_reserve      = -1;
1120 int     smtp_mailcmd_count     = 0;
1121 FILE   *smtp_out               = NULL;
1122 uschar *smtp_etrn_command      = NULL;
1123 BOOL    smtp_etrn_serialize    = TRUE;
1124 int     smtp_max_synprot_errors= 3;
1125 int     smtp_max_unknown_commands = 3;
1126 uschar *smtp_notquit_reason    = NULL;
1127 uschar *smtp_ratelimit_hosts   = NULL;
1128 uschar *smtp_ratelimit_mail    = NULL;
1129 uschar *smtp_ratelimit_rcpt    = NULL;
1130 uschar *smtp_read_error        = US"";
1131 int     smtp_receive_timeout   = 5*60;
1132 uschar *smtp_reserve_hosts     = NULL;
1133 BOOL    smtp_return_error_details = FALSE;
1134 int     smtp_rlm_base          = 0;
1135 double  smtp_rlm_factor        = 0.0;
1136 int     smtp_rlm_limit         = 0;
1137 int     smtp_rlm_threshold     = INT_MAX;
1138 int     smtp_rlr_base          = 0;
1139 double  smtp_rlr_factor        = 0.0;
1140 int     smtp_rlr_limit         = 0;
1141 int     smtp_rlr_threshold     = INT_MAX;
1142 BOOL    smtp_use_pipelining    = FALSE;
1143 BOOL    smtp_use_size          = FALSE;
1144
1145 #ifdef WITH_CONTENT_SCAN
1146 uschar *spamd_address          = US"127.0.0.1 783";
1147 uschar *spam_bar               = NULL;
1148 uschar *spam_report            = NULL;
1149 uschar *spam_score             = NULL;
1150 uschar *spam_score_int         = NULL;
1151 #endif
1152 #ifdef EXPERIMENTAL_SPF
1153 uschar *spf_guess              = US"v=spf1 a/24 mx/24 ptr ?all";
1154 uschar *spf_header_comment     = NULL;
1155 uschar *spf_received           = NULL;
1156 uschar *spf_result             = NULL;
1157 uschar *spf_smtp_comment       = NULL;
1158 #endif
1159
1160 BOOL    split_spool_directory  = FALSE;
1161 uschar *spool_directory        = US SPOOL_DIRECTORY
1162                            "\0<--------------Space to patch spool_directory->";
1163 #ifdef EXPERIMENTAL_SRS
1164 uschar *srs_config             = NULL;
1165 uschar *srs_db_address         = NULL;
1166 uschar *srs_db_key             = NULL;
1167 int     srs_hashlength         = 6;
1168 int     srs_hashmin            = -1;
1169 int     srs_maxage             = 31;
1170 uschar *srs_orig_recipient     = NULL;
1171 uschar *srs_orig_sender        = NULL;
1172 uschar *srs_recipient          = NULL;
1173 uschar *srs_secrets            = NULL;
1174 uschar *srs_status             = NULL;
1175 BOOL    srs_usehash            = TRUE;
1176 BOOL    srs_usetimestamp       = TRUE;
1177 #endif
1178 BOOL    strict_acl_vars        = FALSE;
1179 int     string_datestamp_offset= -1;
1180 int     string_datestamp_length= 0;
1181 int     string_datestamp_type  = -1;
1182 BOOL    strip_excess_angle_brackets = FALSE;
1183 BOOL    strip_trailing_dot     = FALSE;
1184 uschar *submission_domain      = NULL;
1185 BOOL    submission_mode        = FALSE;
1186 uschar *submission_name        = NULL;
1187 BOOL    suppress_local_fixups  = FALSE;
1188 BOOL    synchronous_delivery   = FALSE;
1189 BOOL    syslog_duplication     = TRUE;
1190 int     syslog_facility        = LOG_MAIL;
1191 uschar *syslog_processname     = US"exim";
1192 BOOL    syslog_timestamp       = TRUE;
1193 uschar *system_filter          = NULL;
1194
1195 uschar *system_filter_directory_transport = NULL;
1196 uschar *system_filter_file_transport = NULL;
1197 uschar *system_filter_pipe_transport = NULL;
1198 uschar *system_filter_reply_transport = NULL;
1199
1200 gid_t   system_filter_gid      = 0;
1201 BOOL    system_filter_gid_set  = FALSE;
1202 uid_t   system_filter_uid      = (uid_t)-1;
1203 BOOL    system_filter_uid_set  = FALSE;
1204 BOOL    system_filtering       = FALSE;
1205
1206 BOOL    tcp_nodelay            = TRUE;
1207 #ifdef USE_TCP_WRAPPERS
1208 uschar *tcp_wrappers_daemon_name = US TCP_WRAPPERS_DAEMON_NAME;
1209 #endif
1210 int     test_harness_load_avg  = 0;
1211 int     thismessage_size_limit = 0;
1212 int     timeout_frozen_after   = 0;
1213 BOOL    timestamps_utc         = FALSE;
1214
1215 transport_instance  *transports = NULL;
1216
1217 transport_instance  transport_defaults = {
1218     NULL,                     /* chain pointer */
1219     NULL,                     /* name */
1220     NULL,                     /* info */
1221     NULL,                     /* private options block pointer */
1222     NULL,                     /* driver name */
1223     NULL,                     /* setup entry point */
1224     1,                        /* batch_max */
1225     NULL,                     /* batch_id */
1226     NULL,                     /* home_dir */
1227     NULL,                     /* current_dir */
1228     TRUE,                     /* multi-domain */
1229     FALSE,                    /* overrides_hosts */
1230     100,                      /* max_addresses */
1231     500,                      /* connection_max_messages */
1232     FALSE,                    /* deliver_as_creator */
1233     FALSE,                    /* disable_logging */
1234     FALSE,                    /* initgroups */
1235     FALSE,                    /* uid_set */
1236     FALSE,                    /* gid_set */
1237     (uid_t)(-1),              /* uid */
1238     (gid_t)(-1),              /* gid */
1239     NULL,                     /* expand_uid */
1240     NULL,                     /* expand_gid */
1241     NULL,                     /* warn_message */
1242     NULL,                     /* shadow */
1243     NULL,                     /* shadow_condition */
1244     NULL,                     /* filter_command */
1245     NULL,                     /* add_headers */
1246     NULL,                     /* remove_headers */
1247     NULL,                     /* return_path */
1248     NULL,                     /* debug_string */
1249     NULL,                     /* message_size_limit */
1250     NULL,                     /* headers_rewrite */
1251     NULL,                     /* rewrite_rules */
1252     0,                        /* rewrite_existflags */
1253     300,                      /* filter_timeout */
1254     FALSE,                    /* body_only */
1255     FALSE,                    /* delivery_date_add */
1256     FALSE,                    /* envelope_to_add */
1257     FALSE,                    /* headers_only */
1258     FALSE,                    /* rcpt_include_affixes */
1259     FALSE,                    /* return_path_add */
1260     FALSE,                    /* return_output */
1261     FALSE,                    /* return_fail_output */
1262     FALSE,                    /* log_output */
1263     FALSE,                    /* log_fail_output */
1264     FALSE,                    /* log_defer_output */
1265     TRUE_UNSET                /* retry_use_local_part: BOOL, but set neither
1266                                  1 nor 0 so can detect unset */
1267 };
1268
1269 int     transport_count;
1270 int     transport_newlines;
1271 uschar **transport_filter_argv  = NULL;
1272 int     transport_filter_timeout;
1273 BOOL    transport_filter_timed_out = FALSE;
1274 int     transport_write_timeout= 0;
1275
1276 tree_node  *tree_dns_fails     = NULL;
1277 tree_node  *tree_duplicates    = NULL;
1278 tree_node  *tree_nonrecipients = NULL;
1279 tree_node  *tree_unusable      = NULL;
1280
1281 BOOL    trusted_caller         = FALSE;
1282 BOOL    trusted_config         = TRUE;
1283 gid_t  *trusted_groups         = NULL;
1284 uid_t  *trusted_users          = NULL;
1285 uschar *timezone_string        = US TIMEZONE_DEFAULT;
1286
1287 uschar *unknown_login          = NULL;
1288 uschar *unknown_username       = NULL;
1289 uschar *untrusted_set_sender   = NULL;
1290
1291 /*  A regex for matching a "From_" line in an incoming message, in the form
1292
1293     From ph10 Fri Jan  5 12:35 GMT 1996
1294
1295 which  the "mail" commands send to the MTA (undocumented, of course), or in
1296 the  form
1297
1298     From ph10 Fri, 7 Jan 97 14:00:00 GMT
1299
1300 which  is apparently used by some UUCPs, despite it not being in RFC 976.
1301 Because  of variations in time formats, just match up to the minutes. That
1302 should  be sufficient. Examples have been seen of time fields like 12:1:03,
1303 so  just require one digit for hours and minutes. The weekday is also absent
1304 in  some forms. */
1305
1306 uschar *uucp_from_pattern      = US
1307    "^From\\s+(\\S+)\\s+(?:[a-zA-Z]{3},?\\s+)?"    /* Common start */
1308    "(?:"                                          /* Non-extracting bracket */
1309    "[a-zA-Z]{3}\\s+\\d?\\d|"                      /* First form */
1310    "\\d?\\d\\s+[a-zA-Z]{3}\\s+\\d\\d(?:\\d\\d)?"  /* Second form */
1311    ")"                                            /* End alternation */
1312    "\\s+\\d\\d?:\\d\\d?";                         /* Start of time */
1313
1314 uschar *uucp_from_sender       = US"$1";
1315
1316 uschar *warn_message_file      = NULL;
1317 uschar *warnmsg_delay          = NULL;
1318 uschar *warnmsg_recipients     = NULL;
1319 BOOL    write_rejectlog        = TRUE;
1320
1321 uschar *version_copyright      = US"Copyright (c) University of Cambridge, 1995 - 2007";
1322 uschar *version_date           = US"?";
1323 uschar *version_cnumber        = US"????";
1324 uschar *version_string         = US"?";
1325
1326 int     warning_count          = 0;
1327
1328 /*  End of globals.c */