From 8643e1992f6c62983345f89d793742b3449a69ea Mon Sep 17 00:00:00 2001 From: Niels Weber Date: Fri, 20 Apr 2012 14:31:34 +0200 Subject: Improved detection of libcrypto and libssl. The previous solution didn't work on systems where the libraries aren't in the same location. Now we search for both libcrypto and libssl and load them if their versions match, even if they are in different directories. Task-number: QTBUG-25398 Change-Id: I37164638890586947d07670d8a59fc53a84f9c42 Reviewed-by: Joerg Bornemann Reviewed-by: Shane Kearns Reviewed-by: Richard J. Moore --- src/network/ssl/qsslsocket_openssl_symbols.cpp | 63 +++++++++++++++++++++----- 1 file changed, 51 insertions(+), 12 deletions(-) (limited to 'src/network') diff --git a/src/network/ssl/qsslsocket_openssl_symbols.cpp b/src/network/ssl/qsslsocket_openssl_symbols.cpp index 1180b8f4f0..2e99bdbca4 100644 --- a/src/network/ssl/qsslsocket_openssl_symbols.cpp +++ b/src/network/ssl/qsslsocket_openssl_symbols.cpp @@ -368,7 +368,7 @@ static int dlIterateCallback(struct dl_phdr_info *info, size_t size, void *data) } #endif -static QStringList findAllLibSsl() +static QStringList libraryPathList() { QStringList paths; # ifdef Q_OS_DARWIN @@ -379,6 +379,9 @@ static QStringList findAllLibSsl() .split(QLatin1Char(':'), QString::SkipEmptyParts); # endif paths << QLatin1String("/lib") << QLatin1String("/usr/lib") << QLatin1String("/usr/local/lib"); + paths << QLatin1String("/lib64") << QLatin1String("/usr/lib64") << QLatin1String("/usr/local/lib64"); + paths << QLatin1String("/lib32") << QLatin1String("/usr/lib32") << QLatin1String("/usr/local/lib32"); + #ifdef Q_OS_LINUX // discover paths of already loaded libraries QSet loadedPaths; @@ -386,9 +389,17 @@ static QStringList findAllLibSsl() paths.append(loadedPaths.toList()); #endif + return paths; +} + + +static QStringList findAllLibSsl() +{ + QStringList paths = libraryPathList(); QStringList foundSsls; + foreach (const QString &path, paths) { - QDir dir = QDir(path); + QDir dir(path); QStringList entryList = dir.entryList(QStringList() << QLatin1String("libssl.*"), QDir::Files); qSort(entryList.begin(), entryList.end(), libGreaterThan); @@ -398,6 +409,23 @@ static QStringList findAllLibSsl() return foundSsls; } + +static QStringList findAllLibCrypto() +{ + QStringList paths = libraryPathList(); + + QStringList foundCryptos; + foreach (const QString &path, paths) { + QDir dir(path); + QStringList entryList = dir.entryList(QStringList() << QLatin1String("libcrypto.*"), QDir::Files); + + qSort(entryList.begin(), entryList.end(), libGreaterThan); + foreach (const QString &entry, entryList) + foundCryptos << path + QLatin1Char('/') + entry; + } + + return foundCryptos; +} # endif #ifdef Q_OS_WIN @@ -490,18 +518,29 @@ static QPair loadOpenSsl() // third attempt: loop on the most common library paths and find libssl QStringList sslList = findAllLibSsl(); - foreach (const QString &ssl, sslList) { - QString crypto = ssl; - crypto.replace(QLatin1String("ssl"), QLatin1String("crypto")); - libssl->setFileNameAndVersion(ssl, -1); + QStringList cryptoList = findAllLibCrypto(); + + foreach (const QString &crypto, cryptoList) { libcrypto->setFileNameAndVersion(crypto, -1); - if (libcrypto->load() && libssl->load()) { - // libssl.so.0 and libcrypto.so.0 found - return pair; - } else { - libssl->unload(); - libcrypto->unload(); + if (libcrypto->load()) { + QFileInfo fi(crypto); + QString version = fi.completeSuffix(); + + foreach (const QString &ssl, sslList) { + if (!ssl.endsWith(version)) + continue; + + libssl->setFileNameAndVersion(ssl, -1); + + if (libssl->load()) { + // libssl.so.x and libcrypto.so.x found + return pair; + } else { + libssl->unload(); + } + } } + libcrypto->unload(); } // failed to load anything -- cgit v1.2.3