summaryrefslogtreecommitdiff
path: root/usr.sbin/smtpd/ssl.h
diff options
context:
space:
mode:
authorGilles Chehade <gilles@cvs.openbsd.org>2013-01-26 09:37:25 +0000
committerGilles Chehade <gilles@cvs.openbsd.org>2013-01-26 09:37:25 +0000
commit52e93b0e61fd0a116dbb373054e2cd0ea3bfcf39 (patch)
tree41934d0fc43bfebf55ba5a199e0d699adf24aff1 /usr.sbin/smtpd/ssl.h
parent3b78bd2481525635417ca0fc75396ef754c09171 (diff)
Sync with our smtpd repo:
* first bricks of ldap and sqlite support (not finished but both working) * new table API to replace map API, all lookups are done through tables * improved handling of temporary errors throughout the daemon * improved scheduler and mta logic: connection reuse, optimizes batches * improved queue: more tolerant to admin errors, new layout, less disk-IO * improved memory usage under high load * SSL certs/keys isolated to lookup process to avoid facing network * VIRTUAL support improved, fully virtual setups possible now * runtime tracing of processes through smtpctl trace * ssl_privsep.c sync-ed with relayd * ssl.c no longer contains smtpd specific interfaces * smtpd-specific ssl bits moved to ssl_smtpd.c * update mail address in copyright FLUSH YOUR QUEUE. FLUSH YOUR QUEUE. FLUSH YOUR QUEUE. FLUSH YOUR QUEUE. smtpd.conf(5) simplified, it will require adaptations ok eric@
Diffstat (limited to 'usr.sbin/smtpd/ssl.h')
-rw-r--r--usr.sbin/smtpd/ssl.h57
1 files changed, 57 insertions, 0 deletions
diff --git a/usr.sbin/smtpd/ssl.h b/usr.sbin/smtpd/ssl.h
new file mode 100644
index 00000000000..640dc63f491
--- /dev/null
+++ b/usr.sbin/smtpd/ssl.h
@@ -0,0 +1,57 @@
+/* $OpenBSD: ssl.h,v 1.1 2013/01/26 09:37:24 gilles Exp $ */
+/*
+ * Copyright (c) 2013 Gilles Chehade <gilles@poolp.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#define SSL_CIPHERS "HIGH"
+#define SSL_SESSION_TIMEOUT 300
+
+struct ssl {
+ char ssl_name[PATH_MAX];
+ char *ssl_ca;
+ off_t ssl_ca_len;
+ char *ssl_cert;
+ off_t ssl_cert_len;
+ char *ssl_key;
+ off_t ssl_key_len;
+ char *ssl_dhparams;
+ off_t ssl_dhparams_len;
+ uint8_t flags;
+};
+
+/* ssl.c */
+void ssl_init(void);
+int ssl_setup(SSL_CTX **, struct ssl *);
+SSL_CTX *ssl_ctx_create(void);
+int ssl_load_certfile(struct ssl **, const char *, const char *, uint8_t);
+void *ssl_mta_init(char *, off_t, char *, off_t);
+void *ssl_smtp_init(void *, char *, off_t, char *, off_t);
+int ssl_cmp(struct ssl *, struct ssl *);
+DH *get_dh1024(void);
+DH *get_dh_from_memory(char *, size_t);
+void ssl_set_ephemeral_key_exchange(SSL_CTX *, DH *);
+extern int ssl_ctx_load_verify_memory(SSL_CTX *, char *, off_t);
+char *ssl_load_file(const char *, off_t *, mode_t);
+char *ssl_load_key(const char *, off_t *, char *);
+
+const char *ssl_to_text(const SSL *);
+void ssl_error(const char *);
+
+
+/* ssl_privsep.c */
+int ssl_ctx_use_private_key(SSL_CTX *, char *, off_t);
+int ssl_ctx_use_certificate_chain(SSL_CTX *, char *, off_t);
+int ssl_ctx_load_verify_memory(SSL_CTX *, char *, off_t);
+int ssl_by_mem_ctrl(X509_LOOKUP *, int, const char *, long, char **);