summaryrefslogtreecommitdiff
path: root/plugins/OpenSSL/src/ssl_openssl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/OpenSSL/src/ssl_openssl.cpp')
-rw-r--r--plugins/OpenSSL/src/ssl_openssl.cpp31
1 files changed, 16 insertions, 15 deletions
diff --git a/plugins/OpenSSL/src/ssl_openssl.cpp b/plugins/OpenSSL/src/ssl_openssl.cpp
index 78ed29bd69..4e910d24ea 100644
--- a/plugins/OpenSSL/src/ssl_openssl.cpp
+++ b/plugins/OpenSSL/src/ssl_openssl.cpp
@@ -480,28 +480,29 @@ cleanup:
SslHandle *NetlibSslConnect(SOCKET s, const char* host, int verify)
{
- SslHandle *ssl = (SslHandle*)mir_calloc(sizeof(SslHandle));
- ssl->s = s;
/* negotiate SSL session, verify cert, return NULL if failed */
-
- DWORD dwFlags = 0;
- if (!host || inet_addr(host) != INADDR_NONE)
- dwFlags |= 0x00001000;
-
bool res = SSL_library_load();
- if (!res) {
+ if (!res)
return NULL;
- }
+
+ SslHandle *ssl = (SslHandle*)mir_calloc(sizeof(SslHandle));
+ ssl->s = s;
+ res = ClientConnect(ssl, host);
- if (res) res = ClientConnect(ssl, host);
- if (res && verify) res = VerifyCertificate(ssl, host, dwFlags);
+ if (res && verify) {
+ DWORD dwFlags = 0;
+ if (!host || inet_addr(host) != INADDR_NONE)
+ dwFlags |= 0x00001000;
+ res = VerifyCertificate(ssl, host, dwFlags);
+ }
- if (!res)
- {
+ if(res) {
+ return ssl;
+ }
+ else {
NetlibSslFree(ssl);
- ssl = NULL;
+ return NULL;
}
- return ssl;
}
void NetlibSslShutdown(SslHandle *ssl)