diff options
author | dinoex <dinoex@FreeBSD.org> | 2018-10-20 23:41:31 +0800 |
---|---|---|
committer | dinoex <dinoex@FreeBSD.org> | 2018-10-20 23:41:31 +0800 |
commit | 9a352dfaefb32bc01accf72d6a916b46aa653227 (patch) | |
tree | 529b316150a8770bb3d9db1b5030555e61372d81 | |
parent | b3e9a206f6fbab70b0012274869aacd6f9f4e62e (diff) | |
download | freebsd-ports-gnome-9a352dfaefb32bc01accf72d6a916b46aa653227.tar.gz freebsd-ports-gnome-9a352dfaefb32bc01accf72d6a916b46aa653227.tar.zst freebsd-ports-gnome-9a352dfaefb32bc01accf72d6a916b46aa653227.zip |
- fix OpenSSL 1.1.x build
-rw-r--r-- | net-im/licq/Makefile | 2 | ||||
-rw-r--r-- | net-im/licq/files/patch-licq.cpp | 52 |
2 files changed, 53 insertions, 1 deletions
diff --git a/net-im/licq/Makefile b/net-im/licq/Makefile index 0e051a98dfd2..1b90123f3057 100644 --- a/net-im/licq/Makefile +++ b/net-im/licq/Makefile @@ -4,7 +4,7 @@ PORTNAME= base PORTVERSION= ${LICQ_VER} -PORTREVISION= 11 +PORTREVISION= 12 CATEGORIES= net-im PKGNAMESUFFIX= ${SOCKS_SUFFIX}${PKGNAMESUFFIX2} diff --git a/net-im/licq/files/patch-licq.cpp b/net-im/licq/files/patch-licq.cpp new file mode 100644 index 000000000000..932db2f9e765 --- /dev/null +++ b/net-im/licq/files/patch-licq.cpp @@ -0,0 +1,52 @@ +--- src/licq.cpp.orig 2014-06-01 19:16:42 UTC ++++ src/licq.cpp +@@ -89,6 +89,19 @@ using std::string; + extern SSL_CTX *gSSL_CTX; + extern SSL_CTX *gSSL_CTX_NONICQ; + ++# if !defined(OPENSSL_VERSION_NUMBER) || OPENSSL_VERSION_NUMBER < 0x10100001L || \ ++ (defined(LIBRESSL_VERSION_NUMBER) && LIBRESSL_VERSION_NUMBER < 0x20700000L) ++static int ++DH_set0_pqg(DH *dh, BIGNUM *p, BIGNUM *q, BIGNUM *g) ++{ ++ dh->p=p; ++ if (q != NULL) ++ dh->q=q; ++ dh->g=g; ++ return 1; /* success */ ++} ++# endif /* !defined() || OPENSSL_VERSION_NUMBER < 0x00907000L */ ++ + // AUTOGENERATED by dhparam + static DH *get_dh512() + { +@@ -104,12 +117,14 @@ static DH *get_dh512() + 0x02, + }; + DH *dh; ++ BIGNUM *dhp_bn, *dhg_bn; ++ + + if ((dh=DH_new()) == NULL) return(NULL); +- dh->p=BN_bin2bn(dh512_p,sizeof(dh512_p),NULL); +- dh->g=BN_bin2bn(dh512_g,sizeof(dh512_g),NULL); +- if ((dh->p == NULL) || (dh->g == NULL)) +- { DH_free(dh); return(NULL); } ++ dhp_bn = BN_bin2bn(dh512_p, sizeof(dh512_p), NULL); ++ dhg_bn = BN_bin2bn(dh512_g, sizeof(dh512_g), NULL); ++ if ((dhp_bn == NULL) || (dhg_bn == NULL) || !DH_set0_pqg(dh, dhp_bn, NULL, dhg_bn)) ++ { DH_free(dh); BN_free(dhp_bn); BN_free(dhg_bn); return(NULL); } + return(dh); + } + +@@ -610,8 +625,8 @@ bool CLicq::Init(int argc, char **argv) + #ifdef USE_OPENSSL + // Initialize SSL + SSL_library_init(); +- gSSL_CTX = SSL_CTX_new(TLSv1_method()); +- gSSL_CTX_NONICQ = SSL_CTX_new(TLSv1_method()); ++ gSSL_CTX = SSL_CTX_new(SSLv23_method()); ++ gSSL_CTX_NONICQ = SSL_CTX_new(SSLv23_method()); + #if OPENSSL_VERSION_NUMBER >= 0x00905000L + SSL_CTX_set_cipher_list(gSSL_CTX, "ADH:@STRENGTH"); + #else |