summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLemonBoy <thatlemon@gmail.com>2017-01-23 16:53:30 +0100
committerLemonBoy <thatlemon@gmail.com>2017-02-03 13:29:19 +0100
commit73e8a065bd24092a03c0938eb6c93fec3ee0f4d9 (patch)
tree2c3ceda86835e58bbe8486cbcd573aec9394a0ff /src
parent228f487a69cc032b368a0ae0daea6796b7d10d6e (diff)
downloadirssi-73e8a065bd24092a03c0938eb6c93fec3ee0f4d9.zip
Support OpenSSL 1.1.0.
- X509_get_notBefore becomes X509_get0_notBefore - X509_get_notAfter becomes X509_get0_notAfter - ASN1_STRING_data becomes ASN1_STRING_get0_data (and drops the const) - The whole library is now initialized by OPENSSL_init_ssl Closes #597
Diffstat (limited to 'src')
-rw-r--r--src/core/network-openssl.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/core/network-openssl.c b/src/core/network-openssl.c
index 1eb85341..f193a61e 100644
--- a/src/core/network-openssl.c
+++ b/src/core/network-openssl.c
@@ -32,6 +32,17 @@
#include <openssl/ssl.h>
#include <openssl/err.h>
+/* OpenSSL 1.1.0 introduced some backward-incompatible changes to the api */
+#if (OPENSSL_VERSION_NUMBER >= 0x10100000L) && !defined(LIBRESSL_VERSION_NUMBER)
+/* The two functions below could be already defined if OPENSSL_API_COMPAT is
+ * below the 1.1.0 version so let's do a clean start */
+#undef X509_get_notBefore
+#undef X509_get_notAfter
+#define X509_get_notBefore(x) X509_get0_notBefore(x)
+#define X509_get_notAfter(x) X509_get0_notAfter(x)
+#define ASN1_STRING_data(x) ASN1_STRING_get0_data(x)
+#endif
+
/* ssl i/o channel object */
typedef struct
{
@@ -352,13 +363,19 @@ static GIOFuncs irssi_ssl_channel_funcs = {
static gboolean irssi_ssl_init(void)
{
+#if (OPENSSL_VERSION_NUMBER >= 0x10100000L) && !defined(LIBRESSL_VERSION_NUMBER)
+ if (!OPENSSL_init_ssl(OPENSSL_INIT_SSL_DEFAULT, NULL)) {
+ g_error("Could not initialize OpenSSL");
+ return FALSE;
+ }
+#else
SSL_library_init();
SSL_load_error_strings();
OpenSSL_add_all_algorithms();
+#endif
ssl_inited = TRUE;
return TRUE;
-
}
static int get_pem_password_callback(char *buffer, int max_length, int rwflag, void *pass)