Move certificate name checking to mainline, default enabled
[exim.git] / src / src / functions.h
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
9 /* Prototypes for functions that appear in various modules. Gathered together
10 to avoid having a lot of tiddly little headers with only a couple of lines in
11 them. However, some functions that are used (or not used) by utility programs
12 are in in fact in separate headers. */
13
14
15 #ifdef EXIM_PERL
16 extern uschar *call_perl_cat(uschar *, int *, int *, uschar **, uschar *,
17 uschar **);
18 extern void cleanup_perl(void);
19 extern uschar *init_perl(uschar *);
20 #endif
21
22
23 #ifdef SUPPORT_TLS
24 extern const char *
25 std_dh_prime_default(void);
26 extern const char *
27 std_dh_prime_named(const uschar *);
28
29 extern uschar * tls_cert_crl_uri(void *, uschar * mod);
30 extern uschar * tls_cert_ext_by_oid(void *, uschar *, int);
31 extern uschar * tls_cert_issuer(void *, uschar * mod);
32 extern uschar * tls_cert_not_before(void *, uschar * mod);
33 extern uschar * tls_cert_not_after(void *, uschar * mod);
34 extern uschar * tls_cert_ocsp_uri(void *, uschar * mod);
35 extern uschar * tls_cert_serial_number(void *, uschar * mod);
36 extern uschar * tls_cert_signature(void *, uschar * mod);
37 extern uschar * tls_cert_signature_algorithm(void *, uschar * mod);
38 extern uschar * tls_cert_subject(void *, uschar * mod);
39 extern uschar * tls_cert_subject_altname(void *, uschar * mod);
40 extern uschar * tls_cert_version(void *, uschar * mod);
41
42 extern uschar * tls_cert_fprt_md5(void *);
43 extern uschar * tls_cert_fprt_sha1(void *);
44 extern uschar * tls_cert_fprt_sha256(void *);
45
46 extern int tls_client_start(int, host_item *, address_item *,
47 transport_instance *
48 #ifdef EXPERIMENTAL_DANE
49 , dns_answer *
50 #endif
51 );
52 extern void tls_close(BOOL, BOOL);
53 extern int tls_export_cert(uschar *, size_t, void *);
54 extern int tls_feof(void);
55 extern int tls_ferror(void);
56 extern void tls_free_cert(void *);
57 extern int tls_getc(void);
58 extern int tls_import_cert(const uschar *, void **);
59 extern int tls_read(BOOL, uschar *, size_t);
60 extern int tls_server_start(const uschar *);
61 extern BOOL tls_smtp_buffered(void);
62 extern int tls_ungetc(int);
63 extern int tls_write(BOOL, const uschar *, size_t);
64 extern uschar *tls_validate_require_cipher(void);
65 extern void tls_version_report(FILE *);
66 # ifndef USE_GNUTLS
67 extern BOOL tls_openssl_options_parse(uschar *, long *);
68 # endif
69 extern uschar * tls_field_from_dn(uschar *, uschar *);
70 extern BOOL tls_is_name_for_cert(uschar *, void *);
71
72 # ifdef EXPERIMENTAL_DANE
73 extern int tlsa_lookup(const host_item *, dns_answer *, BOOL, BOOL *);
74 # endif
75
76 #endif /*SUPPORT_TLS*/
77
78
79 /* Everything else... */
80
81 extern acl_block *acl_read(uschar *(*)(void), uschar **);
82 extern int acl_check(int, uschar *, uschar *, uschar **, uschar **);
83 extern int acl_eval(int, uschar *, uschar **, uschar **);
84
85 extern tree_node *acl_var_create(uschar *);
86 extern void acl_var_write(uschar *, uschar *, void *);
87 extern uschar *auth_b64encode(uschar *, int);
88 extern int auth_b64decode(uschar *, uschar **);
89 extern int auth_call_pam(uschar *, uschar **);
90 extern int auth_call_pwcheck(uschar *, uschar **);
91 extern int auth_call_radius(uschar *, uschar **);
92 extern int auth_call_saslauthd(uschar *, uschar *, uschar *, uschar *,
93 uschar **);
94 extern int auth_check_serv_cond(auth_instance *);
95 extern int auth_check_some_cond(auth_instance *, uschar *, uschar *, int);
96
97 extern int auth_get_data(uschar **, uschar *, int);
98 extern int auth_get_no64_data(uschar **, uschar *);
99 extern uschar *auth_xtextencode(uschar *, int);
100 extern int auth_xtextdecode(uschar *, uschar **);
101
102 extern void cancel_cutthrough_connection(const char *);
103 extern int check_host(void *, uschar *, uschar **, uschar **);
104 extern uschar **child_exec_exim(int, BOOL, int *, BOOL, int, ...);
105 extern pid_t child_open_uid(uschar **, uschar **, int, uid_t *, gid_t *,
106 int *, int *, uschar *, BOOL);
107 extern uschar *cutthrough_finaldot(void);
108 extern BOOL cutthrough_flush_send(void);
109 extern BOOL cutthrough_headers_send(void);
110 extern BOOL cutthrough_predata(void);
111 extern BOOL cutthrough_puts(uschar *, int);
112 extern BOOL cutthrough_put_nl(void);
113
114 extern void daemon_go(void);
115
116 #ifdef EXPERIMENTAL_DCC
117 extern int dcc_process(uschar **);
118 #endif
119
120 extern void debug_logging_activate(uschar *, uschar *);
121 extern void debug_print_argv(uschar **);
122 extern void debug_print_ids(uschar *);
123 extern void debug_print_string(uschar *);
124 extern void debug_print_tree(tree_node *);
125 extern void debug_vprintf(const char *, va_list);
126 extern void decode_bits(unsigned int *, unsigned int *,
127 int, int, uschar *, bit_table *, int, uschar *, int);
128 extern address_item *deliver_make_addr(uschar *, BOOL);
129 extern void delivery_log(int, address_item *, int, uschar *);
130 extern int deliver_message(uschar *, BOOL, BOOL);
131 extern void deliver_msglog(const char *, ...) PRINTF_FUNCTION(1,2);
132 extern void deliver_set_expansions(address_item *);
133 extern int deliver_split_address(address_item *);
134 extern void deliver_succeeded(address_item *);
135 #ifdef WITH_OLD_DEMIME
136 extern int demime(uschar **);
137 #endif
138 extern BOOL directory_make(const uschar *, const uschar *, int, BOOL);
139 #ifndef DISABLE_DKIM
140 extern BOOL dkim_transport_write_message(address_item *, int, int,
141 int, uschar *, uschar *, uschar *, uschar *, rewrite_rule *,
142 int, uschar *, uschar *, uschar *, uschar *, uschar *, uschar *);
143 #endif
144 extern dns_address *dns_address_from_rr(dns_answer *, dns_record *);
145 extern void dns_build_reverse(uschar *, uschar *);
146 extern void dns_init(BOOL, BOOL, BOOL);
147 extern int dns_basic_lookup(dns_answer *, const uschar *, int);
148 extern BOOL dns_is_secure(const dns_answer *);
149 extern int dns_lookup(dns_answer *, const uschar *, int, uschar **);
150 extern int dns_special_lookup(dns_answer *, const uschar *, int, uschar **);
151 extern dns_record *dns_next_rr(dns_answer *, dns_scan *, int);
152 extern uschar *dns_text_type(int);
153 extern void dscp_list_to_stream(FILE *);
154 extern BOOL dscp_lookup(const uschar *, int, int *, int *, int *);
155
156 extern void enq_end(uschar *);
157 extern BOOL enq_start(uschar *);
158 #ifdef EXPERIMENTAL_EVENT
159 extern uschar *event_raise(uschar *, uschar *, uschar *);
160 #endif
161 extern void exim_exit(int);
162 extern void exim_nullstd(void);
163 extern void exim_setugid(uid_t, gid_t, BOOL, uschar *);
164 extern int exim_tvcmp(struct timeval *, struct timeval *);
165 extern void exim_wait_tick(struct timeval *, int);
166 extern int exp_bool(address_item *addr,
167 uschar *mtype, uschar *mname, unsigned dgb_opt, uschar *oname, BOOL bvalue,
168 uschar *svalue, BOOL *rvalue);
169 extern BOOL expand_check_condition(uschar *, uschar *, uschar *);
170 extern uschar *expand_string(uschar *);
171 extern uschar *expand_string_copy(uschar *);
172 extern int_eximarith_t expand_string_integer(uschar *, BOOL);
173 extern void modify_variable(uschar *, void *);
174
175 extern int filter_interpret(uschar *, int, address_item **, uschar **);
176 extern BOOL filter_personal(string_item *, BOOL);
177 extern BOOL filter_runtest(int, uschar *, BOOL, BOOL);
178 extern BOOL filter_system_interpret(address_item **, uschar **);
179
180 extern uschar * fn_hdrs_added(void);
181
182 extern void header_add(int, const char *, ...);
183 extern int header_checkname(header_line *, BOOL);
184 extern BOOL header_match(uschar *, BOOL, BOOL, string_item *, int, ...);
185 extern int host_address_extract_port(uschar *);
186 extern uschar *host_and_ident(BOOL);
187 extern int host_aton(uschar *, int *);
188 extern void host_build_hostlist(host_item **, uschar *, BOOL);
189 extern ip_address_item *host_build_ifacelist(uschar *, uschar *);
190 extern void host_build_log_info(void);
191 extern void host_build_sender_fullhost(void);
192 extern BOOL host_find_byname(host_item *, uschar *, int, uschar **, BOOL);
193 extern int host_find_bydns(host_item *, uschar *, int, uschar *, uschar *,
194 uschar *, uschar *, uschar *, uschar **, BOOL *);
195 extern ip_address_item *host_find_interfaces(void);
196 extern BOOL host_is_in_net(uschar *, uschar *, int);
197 extern BOOL host_is_tls_on_connect_port(int);
198 extern int host_item_get_port(host_item *);
199 extern void host_mask(int, int *, int);
200 extern int host_name_lookup(void);
201 extern int host_nmtoa(int, int *, int, uschar *, int);
202 extern uschar *host_ntoa(int, const void *, uschar *, int *);
203 extern int host_scan_for_local_hosts(host_item *, host_item **, BOOL *);
204
205 extern void invert_address(uschar *, uschar *);
206 extern int ip_bind(int, int, uschar *, int);
207 extern int ip_connect(int, int, uschar *, int, int);
208 extern int ip_connectedsocket(int, const uschar *, int, int,
209 int, host_item *, uschar **);
210 extern int ip_get_address_family(int);
211 extern void ip_keepalive(int, uschar *, BOOL);
212 extern int ip_recv(int, uschar *, int, int);
213 extern int ip_socket(int, int);
214
215 extern uschar *local_part_quote(uschar *);
216 extern int log_create(uschar *);
217 extern int log_create_as_exim(uschar *);
218 extern void log_close_all(void);
219
220 #ifdef WITH_CONTENT_SCAN
221 extern int malware(uschar **);
222 extern int malware_in_file(uschar *);
223 #endif
224 extern int match_address_list(uschar *, BOOL, BOOL, uschar **,
225 unsigned int *, int, int, uschar **);
226 extern int match_check_list(uschar **, int, tree_node **, unsigned int **,
227 int(*)(void *, uschar *, uschar **, uschar **), void *, int,
228 const uschar *, uschar **);
229 extern int match_isinlist(const uschar *, uschar **, int, tree_node **,
230 unsigned int *, int, BOOL, uschar **);
231 extern int match_check_string(uschar *, uschar *, int, BOOL, BOOL, BOOL,
232 uschar **);
233 extern void md5_end(md5 *, const uschar *, int, uschar *);
234 extern void md5_mid(md5 *, const uschar *);
235 extern void md5_start(md5 *);
236 extern void millisleep(int);
237 #ifdef WITH_CONTENT_SCAN
238 struct mime_boundary_context;
239 extern int mime_acl_check(uschar *acl, FILE *f,
240 struct mime_boundary_context *, uschar **, uschar **);
241 extern int mime_decode(uschar **);
242 extern int mime_regex(uschar **);
243 #endif
244 extern uschar *moan_check_errorcopy(uschar *);
245 extern BOOL moan_skipped_syntax_errors(uschar *, error_block *, uschar *,
246 BOOL, uschar *);
247 extern void moan_smtp_batch(uschar *, const char *, ...) PRINTF_FUNCTION(2,3);
248 extern void moan_tell_someone(uschar *, address_item *,
249 const uschar *, const char *, ...) PRINTF_FUNCTION(4,5);
250 extern BOOL moan_to_sender(int, error_block *, header_line *, FILE *, BOOL);
251 extern void moan_write_from(FILE *);
252 extern FILE *modefopen(const uschar *, const char *, mode_t);
253
254 extern void open_cutthrough_connection( address_item * addr );
255
256 extern uschar *parse_extract_address(uschar *, uschar **, int *, int *, int *,
257 BOOL);
258 extern int parse_forward_list(uschar *, int, address_item **, uschar **,
259 uschar *, uschar *, error_block **);
260 extern uschar *parse_find_address_end(uschar *, BOOL);
261 extern uschar *parse_find_at(uschar *);
262 extern uschar *parse_fix_phrase(uschar *, int, uschar *, int);
263 extern uschar *parse_message_id(uschar *, uschar **, uschar **);
264 extern uschar *parse_quote_2047(uschar *, int, uschar *, uschar *, int, BOOL);
265 extern uschar *parse_date_time(uschar *str, time_t *t);
266 extern int vaguely_random_number(int);
267 #ifdef SUPPORT_TLS
268 extern int vaguely_random_number_fallback(int);
269 #endif
270
271 extern BOOL queue_action(uschar *, int, uschar **, int, int);
272 extern void queue_check_only(void);
273 extern void queue_list(int, uschar **, int);
274 extern void queue_count(void);
275 extern void queue_run(uschar *, uschar *, BOOL);
276
277 extern int random_number(int);
278 #ifdef WITH_CONTENT_SCAN
279 extern int recv_line(int, uschar *, int);
280 #endif
281 extern int rda_interpret(redirect_block *, int, uschar *, uschar *,
282 uschar *, uschar *, uschar *, ugid_block *, address_item **,
283 uschar **, error_block **, int *, uschar *);
284 extern int rda_is_filter(const uschar *);
285 extern BOOL readconf_depends(driver_instance *, uschar *);
286 extern void readconf_driver_init(uschar *, driver_instance **,
287 driver_info *, int, void *, int, optionlist *, int);
288 extern uschar *readconf_find_option(void *);
289 extern void readconf_main(void);
290 extern void readconf_print(uschar *, uschar *, BOOL);
291 extern uschar *readconf_printtime(int);
292 extern uschar *readconf_readname(uschar *, int, uschar *);
293 extern int readconf_readtime(uschar *, int, BOOL);
294 extern void readconf_rest();
295 extern uschar *readconf_retry_error(uschar *, uschar *, int *, int *);
296 extern void read_message_body(BOOL);
297 extern void receive_bomb_out(uschar *, uschar *);
298 extern BOOL receive_check_fs(int);
299 extern BOOL receive_check_set_sender(uschar *);
300 extern BOOL receive_msg(BOOL);
301 extern int receive_statvfs(BOOL, int *);
302 extern void receive_swallow_smtp(void);
303 #ifdef WITH_CONTENT_SCAN
304 extern int regex(uschar **);
305 #endif
306 extern BOOL regex_match_and_setup(const pcre *, const uschar *, int, int);
307 extern const pcre *regex_must_compile(uschar *, BOOL, BOOL);
308 extern void retry_add_item(address_item *, uschar *, int);
309 extern BOOL retry_check_address(uschar *, host_item *, uschar *, BOOL,
310 uschar **, uschar **);
311 extern retry_config *retry_find_config(uschar *, uschar *, int, int);
312 extern BOOL retry_ultimate_address_timeout(uschar *, uschar *,
313 dbdata_retry *, time_t);
314 extern void retry_update(address_item **, address_item **, address_item **);
315 extern uschar *rewrite_address(uschar *, BOOL, BOOL, rewrite_rule *, int);
316 extern uschar *rewrite_address_qualify(uschar *, BOOL);
317 extern header_line *rewrite_header(header_line *, uschar *, uschar *,
318 rewrite_rule *, int, BOOL);
319 extern uschar *rewrite_one(uschar *, int, BOOL *, BOOL, uschar *,
320 rewrite_rule *);
321 extern void rewrite_test(uschar *);
322 extern uschar *rfc2047_decode2(uschar *, BOOL, uschar *, int, int *, int *,
323 uschar **);
324 extern int route_address(address_item *, address_item **, address_item **,
325 address_item **, address_item **, int);
326 extern int route_check_prefix(uschar *, uschar *);
327 extern int route_check_suffix(uschar *, uschar *);
328 extern BOOL route_findgroup(uschar *, gid_t *);
329 extern BOOL route_finduser(uschar *, struct passwd **, uid_t *);
330 extern BOOL route_find_expanded_group(uschar *, uschar *, uschar *, gid_t *,
331 uschar **);
332 extern BOOL route_find_expanded_user(uschar *, uschar *, uschar *,
333 struct passwd **, uid_t *, uschar **);
334 extern void route_init(void);
335 extern void route_tidyup(void);
336
337 extern uschar *search_find(void *, uschar *, uschar *, int, uschar *, int,
338 int, int *);
339 extern int search_findtype(uschar *, int);
340 extern int search_findtype_partial(uschar *, int *, uschar **, int *,
341 int *);
342 extern void *search_open(uschar *, int, int, uid_t *, gid_t *);
343 extern void search_tidyup(void);
344 extern void set_process_info(const char *, ...) PRINTF_FUNCTION(1,2);
345 extern void sha1_end(sha1 *, const uschar *, int, uschar *);
346 extern void sha1_mid(sha1 *, const uschar *);
347 extern void sha1_start(sha1 *);
348 extern int sieve_interpret(uschar *, int, uschar *, uschar *, uschar *,
349 uschar *, address_item **, uschar **);
350 extern void sigalrm_handler(int);
351 extern BOOL smtp_buffered(void);
352 extern void smtp_closedown(uschar *);
353 extern int smtp_connect(host_item *, int, int, uschar *, int, BOOL, const uschar *
354 #ifdef EXPERIMENTAL_EVENT
355 , uschar *
356 #endif
357 );
358 extern int smtp_feof(void);
359 extern int smtp_ferror(void);
360 extern uschar *smtp_get_connection_info(void);
361 extern BOOL smtp_get_interface(uschar *, int, address_item *, BOOL *,
362 uschar **, uschar *);
363 extern BOOL smtp_get_port(uschar *, address_item *, int *, uschar *);
364 extern int smtp_getc(void);
365 extern int smtp_handle_acl_fail(int, int, uschar *, uschar *);
366 extern void smtp_log_no_mail(void);
367 extern void smtp_message_code(uschar **, int *, uschar **, uschar **);
368 extern BOOL smtp_read_response(smtp_inblock *, uschar *, int, int, int);
369 extern void smtp_respond(uschar *, int, BOOL, uschar *);
370 extern void smtp_notquit_exit(uschar *, uschar *, uschar *, ...);
371 extern void smtp_send_prohibition_message(int, uschar *);
372 extern int smtp_setup_msg(void);
373 extern BOOL smtp_start_session(void);
374 extern int smtp_ungetc(int);
375 extern BOOL smtp_verify_helo(void);
376 extern int smtp_write_command(smtp_outblock *, BOOL, const char *, ...) PRINTF_FUNCTION(3,4);
377 #ifdef WITH_CONTENT_SCAN
378 extern int spam(uschar **);
379 extern FILE *spool_mbox(unsigned long *, uschar *);
380 #endif
381 extern BOOL spool_move_message(uschar *, uschar *, uschar *, uschar *);
382 extern BOOL spool_open_datafile(uschar *);
383 extern int spool_open_temp(uschar *);
384 extern int spool_read_header(uschar *, BOOL, BOOL);
385 extern int spool_write_header(uschar *, int, uschar **);
386 extern int stdin_getc(void);
387 extern int stdin_feof(void);
388 extern int stdin_ferror(void);
389 extern int stdin_ungetc(int);
390 extern uschar *string_append(uschar *, int *, int *, int, ...);
391 extern uschar *string_append_listele(uschar *, uschar, const uschar *);
392 extern uschar *string_base62(unsigned long int);
393 extern uschar *string_cat(uschar *, int *, int *, const uschar *, int);
394 extern uschar *string_copy_dnsdomain(uschar *);
395 extern uschar *string_copy_malloc(uschar *);
396 extern uschar *string_copylc(const uschar *);
397 extern uschar *string_copynlc(uschar *, int);
398 extern uschar *string_dequote(uschar **);
399 extern BOOL string_format(uschar *, int, const char *, ...) ALMOST_PRINTF(3,4);
400 extern uschar *string_format_size(int, uschar *);
401 extern int string_interpret_escape(uschar **);
402 extern int string_is_ip_address(const uschar *, int *);
403 extern uschar *string_log_address(address_item *, BOOL, BOOL);
404 extern uschar *string_nextinlist(uschar **, int *, uschar *, int);
405 extern uschar *string_open_failed(int, const char *, ...) PRINTF_FUNCTION(2,3);
406 extern uschar *string_printing2(uschar *, BOOL);
407 extern uschar *string_split_message(uschar *);
408 extern uschar *string_unprinting(uschar *);
409 extern BOOL string_vformat(uschar *, int, const char *, va_list);
410 extern int strcmpic(const uschar *, const uschar *);
411 extern int strncmpic(const uschar *, const uschar *, int);
412 extern uschar *strstric(uschar *, uschar *, BOOL);
413
414 extern uschar *tod_stamp(int);
415
416 extern void tls_modify_variables(tls_support *);
417 extern BOOL transport_check_waiting(uschar *, uschar *, int, uschar *,
418 BOOL *);
419 extern void transport_init(void);
420 extern BOOL transport_pass_socket(uschar *, uschar *, uschar *, uschar *,
421 int);
422 extern uschar *transport_rcpt_address(address_item *, BOOL);
423 extern BOOL transport_set_up_command(uschar ***, uschar *, BOOL, int,
424 address_item *, uschar *, uschar **);
425 extern void transport_update_waiting(host_item *, uschar *);
426 extern BOOL transport_write_block(int, uschar *, int);
427 extern BOOL transport_write_string(int, const char *, ...);
428 extern BOOL transport_headers_send(address_item *, int, uschar *, uschar *,
429 BOOL (*)(int, uschar *, int, BOOL), BOOL, rewrite_rule *, int);
430 extern BOOL transport_write_message(address_item *, int, int, int, uschar *,
431 uschar *, uschar *, uschar *, rewrite_rule *, int);
432 extern void tree_add_duplicate(uschar *, address_item *);
433 extern void tree_add_nonrecipient(uschar *);
434 extern void tree_add_unusable(host_item *);
435 extern int tree_insertnode(tree_node **, tree_node *);
436 extern tree_node *tree_search(tree_node *, uschar *);
437 extern void tree_write(tree_node *, FILE *);
438 extern void tree_walk(tree_node *, void (*)(uschar*, uschar*, void*), void *);
439
440 #ifdef WITH_CONTENT_SCAN
441 extern void unspool_mbox(void);
442 #endif
443
444 extern int verify_address(address_item *, FILE *, int, int, int, int,
445 uschar *, uschar *, BOOL *);
446 extern int verify_check_dnsbl(uschar **);
447 extern int verify_check_header_address(uschar **, uschar **, int, int, int,
448 uschar *, uschar *, int, int *);
449 extern int verify_check_headers(uschar **);
450 extern int verify_check_header_names_ascii(uschar **);
451 extern int verify_check_host(uschar **);
452 extern int verify_check_notblind(void);
453 extern int verify_check_given_host(uschar **, host_item *);
454 extern int verify_check_this_host(uschar **, unsigned int *, uschar*,
455 uschar *, uschar **);
456 extern address_item *verify_checked_sender(uschar *);
457 extern void verify_get_ident(int);
458 extern BOOL verify_sender(int *, uschar **);
459 extern BOOL verify_sender_preliminary(int *, uschar **);
460 extern void version_init(void);
461
462 extern ssize_t write_to_fd_buf(int, const uschar *, size_t);
463
464 /* vi: aw
465 */
466 /* End of functions.h */