aboutsummaryrefslogtreecommitdiffstats
path: root/src/libutil/ssl_util.h
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-13 12:04:29 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-06-13 17:31:29 +0100
commitfa66761cd5d0e22b7a3fa84e299b22c8e368897c (patch)
treeabc181703ff0e540e54f4e1e0114a0d108e417aa /src/libutil/ssl_util.h
parent7c9830991c58a6b23014a0bdc8748fb4ab7588da (diff)
downloadrspamd-fa66761cd5d0e22b7a3fa84e299b22c8e368897c.tar.gz
rspamd-fa66761cd5d0e22b7a3fa84e299b22c8e368897c.zip
[Feature] Add preliminary version of ssl toolbox
Diffstat (limited to 'src/libutil/ssl_util.h')
-rw-r--r--src/libutil/ssl_util.h56
1 files changed, 56 insertions, 0 deletions
diff --git a/src/libutil/ssl_util.h b/src/libutil/ssl_util.h
new file mode 100644
index 000000000..1fcd65a35
--- /dev/null
+++ b/src/libutil/ssl_util.h
@@ -0,0 +1,56 @@
+/*-
+ * Copyright 2016 Vsevolod Stakhov
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+#ifndef SRC_LIBUTIL_SSL_UTIL_H_
+#define SRC_LIBUTIL_SSL_UTIL_H_
+
+#include "config.h"
+#include "libutil/addr.h"
+
+struct rspamd_ssl_connection;
+
+typedef void (*rspamd_ssl_handler_t)(gint fd, short what, gpointer d);
+typedef void (*rspamd_ssl_error_handler_t)(gpointer d, GError *err);
+
+/**
+ * Creates a new ssl connection data structure
+ * @param ssl_ctx initialized SSL_CTX structure
+ * @return opaque connection data
+ */
+struct rspamd_ssl_connection * rspamd_ssl_connection_new (gpointer ssl_ctx);
+
+/**
+ * Connects SSL session using the specified (connected) FD
+ * @param conn connection
+ * @param fd fd to use
+ * @param hostname hostname for SNI
+ * @param ev event to use
+ * @param tv timeout for connection
+ * @param handler connected session handler
+ * @param handler_data opaque data
+ * @return TRUE if a session has been connected
+ */
+gboolean rspamd_ssl_connect_fd (struct rspamd_ssl_connection *conn, gint fd,
+ const gchar *hostname, struct event *ev, struct timeval *tv,
+ rspamd_ssl_handler_t handler, rspamd_ssl_error_handler_t err_handler,
+ gpointer handler_data);
+
+/**
+ * Removes connection data
+ * @param conn
+ */
+void rspamd_ssl_connection_free (struct rspamd_ssl_connection *conn);
+
+#endif /* SRC_LIBUTIL_SSL_UTIL_H_ */