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