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