mirror of
https://github.com/alexkulya/pandaria_5.4.8.git
synced 2025-12-28 13:37:14 +00:00
Added Support Openssl 3.0.x
This commit is contained in:
parent
9339e072af
commit
df3ff87f65
10 changed files with 935 additions and 210 deletions
|
|
@ -1,75 +1,337 @@
|
||||||
# - Try to find the OpenSSL encryption library
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
||||||
# Once done this will define
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
||||||
#
|
|
||||||
# OPENSSL_ROOT_DIR - Set this variable to the root installation of OpenSSL
|
|
||||||
#
|
|
||||||
# Read-Only variables:
|
|
||||||
# OPENSSL_FOUND - system has the OpenSSL library
|
|
||||||
# OPENSSL_INCLUDE_DIR - the OpenSSL include directory
|
|
||||||
# OPENSSL_LIBRARIES - The libraries needed to use OpenSSL
|
|
||||||
|
|
||||||
#=============================================================================
|
#[=======================================================================[.rst:
|
||||||
# Copyright 2006-2009 Kitware, Inc.
|
FindOpenSSL
|
||||||
# Copyright 2006 Alexander Neundorf <neundorf@kde.org>
|
-----------
|
||||||
# Copyright 2009-2010 Mathieu Malaterre <mathieu.malaterre@gmail.com>
|
|
||||||
#
|
|
||||||
# Distributed under the OSI-approved BSD License (the "License");
|
|
||||||
# see accompanying file Copyright.txt for details.
|
|
||||||
#
|
|
||||||
# This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
||||||
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
||||||
# See the License for more information.
|
|
||||||
#=============================================================================
|
|
||||||
# (To distributed this file outside of CMake, substitute the full
|
|
||||||
# License text for the above reference.)
|
|
||||||
|
|
||||||
|
Find the OpenSSL encryption library.
|
||||||
|
|
||||||
|
This module finds an installed OpenSSL library and determines its version.
|
||||||
|
|
||||||
|
.. versionadded:: 3.19
|
||||||
|
When a version is requested, it can be specified as a simple value or as a
|
||||||
|
range. For a detailed description of version range usage and capabilities,
|
||||||
|
refer to the :command:`find_package` command.
|
||||||
|
|
||||||
|
.. versionadded:: 3.18
|
||||||
|
Support for OpenSSL 3.0.
|
||||||
|
|
||||||
|
Optional COMPONENTS
|
||||||
|
^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
.. versionadded:: 3.12
|
||||||
|
|
||||||
|
This module supports two optional COMPONENTS: ``Crypto`` and ``SSL``. Both
|
||||||
|
components have associated imported targets, as described below.
|
||||||
|
|
||||||
|
Imported Targets
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
.. versionadded:: 3.4
|
||||||
|
|
||||||
|
This module defines the following :prop_tgt:`IMPORTED` targets:
|
||||||
|
|
||||||
|
``OpenSSL::SSL``
|
||||||
|
The OpenSSL ``ssl`` library, if found.
|
||||||
|
``OpenSSL::Crypto``
|
||||||
|
The OpenSSL ``crypto`` library, if found.
|
||||||
|
``OpenSSL::applink``
|
||||||
|
.. versionadded:: 3.18
|
||||||
|
|
||||||
|
The OpenSSL ``applink`` components that might be need to be compiled into
|
||||||
|
projects under MSVC. This target is available only if found OpenSSL version
|
||||||
|
is not less than 0.9.8. By linking this target the above OpenSSL targets can
|
||||||
|
be linked even if the project has different MSVC runtime configurations with
|
||||||
|
the above OpenSSL targets. This target has no effect on platforms other than
|
||||||
|
MSVC.
|
||||||
|
|
||||||
|
NOTE: Due to how ``INTERFACE_SOURCES`` are consumed by the consuming target,
|
||||||
|
unless you certainly know what you are doing, it is always preferred to link
|
||||||
|
``OpenSSL::applink`` target as ``PRIVATE`` and to make sure that this target is
|
||||||
|
linked at most once for the whole dependency graph of any library or
|
||||||
|
executable:
|
||||||
|
|
||||||
|
.. code-block:: cmake
|
||||||
|
|
||||||
|
target_link_libraries(myTarget PRIVATE OpenSSL::applink)
|
||||||
|
|
||||||
|
Otherwise you would probably encounter unexpected random problems when building
|
||||||
|
and linking, as both the ISO C and the ISO C++ standard claims almost nothing
|
||||||
|
about what a link process should be.
|
||||||
|
|
||||||
|
Result Variables
|
||||||
|
^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
This module will set the following variables in your project:
|
||||||
|
|
||||||
|
``OPENSSL_FOUND``
|
||||||
|
System has the OpenSSL library. If no components are requested it only
|
||||||
|
requires the crypto library.
|
||||||
|
``OPENSSL_INCLUDE_DIR``
|
||||||
|
The OpenSSL include directory.
|
||||||
|
``OPENSSL_CRYPTO_LIBRARY``
|
||||||
|
The OpenSSL crypto library.
|
||||||
|
``OPENSSL_CRYPTO_LIBRARIES``
|
||||||
|
The OpenSSL crypto library and its dependencies.
|
||||||
|
``OPENSSL_SSL_LIBRARY``
|
||||||
|
The OpenSSL SSL library.
|
||||||
|
``OPENSSL_SSL_LIBRARIES``
|
||||||
|
The OpenSSL SSL library and its dependencies.
|
||||||
|
``OPENSSL_LIBRARIES``
|
||||||
|
All OpenSSL libraries and their dependencies.
|
||||||
|
``OPENSSL_VERSION``
|
||||||
|
This is set to ``$major.$minor.$revision$patch`` (e.g. ``0.9.8s``).
|
||||||
|
``OPENSSL_APPLINK_SOURCE``
|
||||||
|
The sources in the target ``OpenSSL::applink`` that is mentioned above. This
|
||||||
|
variable shall always be undefined if found openssl version is less than
|
||||||
|
0.9.8 or if platform is not MSVC.
|
||||||
|
|
||||||
|
Hints
|
||||||
|
^^^^^
|
||||||
|
|
||||||
|
The following variables may be set to control search behavior:
|
||||||
|
|
||||||
|
``OPENSSL_ROOT_DIR``
|
||||||
|
Set to the root directory of an OpenSSL installation.
|
||||||
|
|
||||||
|
``OPENSSL_USE_STATIC_LIBS``
|
||||||
|
.. versionadded:: 3.4
|
||||||
|
|
||||||
|
Set to ``TRUE`` to look for static libraries.
|
||||||
|
|
||||||
|
``OPENSSL_MSVC_STATIC_RT``
|
||||||
|
.. versionadded:: 3.5
|
||||||
|
|
||||||
|
Set to ``TRUE`` to choose the MT version of the lib.
|
||||||
|
|
||||||
|
``ENV{PKG_CONFIG_PATH}``
|
||||||
|
On UNIX-like systems, ``pkg-config`` is used to locate the system OpenSSL.
|
||||||
|
Set the ``PKG_CONFIG_PATH`` environment variable to look in alternate
|
||||||
|
locations. Useful on multi-lib systems.
|
||||||
|
#]=======================================================================]
|
||||||
|
|
||||||
|
macro(_OpenSSL_test_and_find_dependencies ssl_library crypto_library)
|
||||||
|
unset(_OpenSSL_extra_static_deps)
|
||||||
|
|
||||||
|
if(UNIX AND
|
||||||
|
(("${ssl_library}" MATCHES "\\${CMAKE_STATIC_LIBRARY_SUFFIX}$") OR
|
||||||
|
("${crypto_library}" MATCHES "\\${CMAKE_STATIC_LIBRARY_SUFFIX}$")))
|
||||||
|
set(_OpenSSL_has_dependencies TRUE)
|
||||||
|
unset(_OpenSSL_has_dependency_zlib)
|
||||||
|
|
||||||
|
if(OPENSSL_USE_STATIC_LIBS)
|
||||||
|
set(_OpenSSL_libs "${_OPENSSL_STATIC_LIBRARIES}")
|
||||||
|
set(_OpenSSL_ldflags_other "${_OPENSSL_STATIC_LDFLAGS_OTHER}")
|
||||||
|
else()
|
||||||
|
set(_OpenSSL_libs "${_OPENSSL_LIBRARIES}")
|
||||||
|
set(_OpenSSL_ldflags_other "${_OPENSSL_LDFLAGS_OTHER}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_libs)
|
||||||
|
unset(_OpenSSL_has_dependency_dl)
|
||||||
|
|
||||||
|
foreach(_OPENSSL_DEP_LIB IN LISTS _OpenSSL_libs)
|
||||||
|
if(_OPENSSL_DEP_LIB STREQUAL "ssl" OR _OPENSSL_DEP_LIB STREQUAL "crypto")
|
||||||
|
# ignoring: these are the targets
|
||||||
|
elseif(_OPENSSL_DEP_LIB STREQUAL CMAKE_DL_LIBS)
|
||||||
|
set(_OpenSSL_has_dependency_dl TRUE)
|
||||||
|
elseif(_OPENSSL_DEP_LIB STREQUAL "z")
|
||||||
|
find_package(ZLIB)
|
||||||
|
set(_OpenSSL_has_dependency_zlib TRUE)
|
||||||
|
else()
|
||||||
|
list(APPEND _OpenSSL_extra_static_deps "${_OPENSSL_DEP_LIB}")
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
unset(_OPENSSL_DEP_LIB)
|
||||||
|
elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
||||||
|
set(_OpenSSL_has_dependency_dl TRUE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_ldflags_other)
|
||||||
|
unset(_OpenSSL_has_dependency_threads)
|
||||||
|
|
||||||
|
foreach(_OPENSSL_DEP_LDFLAG IN LISTS _OpenSSL_ldflags_other)
|
||||||
|
if(_OPENSSL_DEP_LDFLAG STREQUAL "-pthread")
|
||||||
|
set(_OpenSSL_has_dependency_threads TRUE)
|
||||||
|
find_package(Threads)
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
unset(_OPENSSL_DEP_LDFLAG)
|
||||||
|
elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux")
|
||||||
|
set(_OpenSSL_has_dependency_threads TRUE)
|
||||||
|
find_package(Threads)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
unset(_OpenSSL_libs)
|
||||||
|
unset(_OpenSSL_ldflags_other)
|
||||||
|
else()
|
||||||
|
set(_OpenSSL_has_dependencies FALSE)
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
function(_OpenSSL_add_dependencies libraries_var)
|
||||||
|
if(_OpenSSL_has_dependency_zlib)
|
||||||
|
list(APPEND ${libraries_var} ${ZLIB_LIBRARY})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_has_dependency_threads)
|
||||||
|
list(APPEND ${libraries_var} ${CMAKE_THREAD_LIBS_INIT})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_has_dependency_dl)
|
||||||
|
list(APPEND ${libraries_var} ${CMAKE_DL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
list(APPEND ${libraries_var} ${_OpenSSL_extra_static_deps})
|
||||||
|
set(${libraries_var} ${${libraries_var}} PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(_OpenSSL_target_add_dependencies target)
|
||||||
|
if(_OpenSSL_has_dependencies)
|
||||||
|
if(_OpenSSL_has_dependency_zlib)
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES ZLIB::ZLIB)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_has_dependency_threads)
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES Threads::Threads)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_has_dependency_dl)
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES ${CMAKE_DL_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(_OpenSSL_extra_static_deps)
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES ${_OpenSSL_extra_static_deps})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(WIN32 AND OPENSSL_USE_STATIC_LIBS)
|
||||||
|
if(WINCE)
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES ws2)
|
||||||
|
else()
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES ws2_32)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set_property(TARGET ${target} APPEND PROPERTY INTERFACE_LINK_LIBRARIES crypt32)
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
if(UNIX)
|
||||||
|
find_package(PkgConfig QUIET)
|
||||||
|
pkg_check_modules(_OPENSSL QUIET openssl)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Support preference of static libs by adjusting CMAKE_FIND_LIBRARY_SUFFIXES
|
||||||
|
if(OPENSSL_USE_STATIC_LIBS)
|
||||||
|
set(_openssl_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
|
||||||
|
if(MSVC)
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .lib .a ${CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
else()
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES .a)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_SYSTEM_NAME STREQUAL "QNX" AND
|
||||||
|
CMAKE_SYSTEM_VERSION VERSION_GREATER_EQUAL "7.0" AND CMAKE_SYSTEM_VERSION VERSION_LESS "7.1" AND
|
||||||
|
OpenSSL_FIND_VERSION VERSION_GREATER_EQUAL "1.1" AND OpenSSL_FIND_VERSION VERSION_LESS "1.2")
|
||||||
|
# QNX 7.0.x provides openssl 1.0.2 and 1.1.1 in parallel:
|
||||||
|
# * openssl 1.0.2: libcrypto.so.2 and libssl.so.2, headers under usr/include/openssl
|
||||||
|
# * openssl 1.1.1: libcrypto1_1.so.2.1 and libssl1_1.so.2.1, header under usr/include/openssl1_1
|
||||||
|
# See http://www.qnx.com/developers/articles/rel_6726_0.html
|
||||||
|
set(_OPENSSL_FIND_PATH_SUFFIX "openssl1_1")
|
||||||
|
set(_OPENSSL_NAME_POSTFIX "1_1")
|
||||||
|
else()
|
||||||
|
set(_OPENSSL_FIND_PATH_SUFFIX "include")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(OPENSSL_ROOT_DIR OR NOT "$ENV{OPENSSL_ROOT_DIR}" STREQUAL "")
|
||||||
|
set(_OPENSSL_ROOT_HINTS HINTS ${OPENSSL_ROOT_DIR} ENV OPENSSL_ROOT_DIR)
|
||||||
|
set(_OPENSSL_ROOT_PATHS NO_DEFAULT_PATH)
|
||||||
|
elseif(MSVC)
|
||||||
# http://www.slproweb.com/products/Win32OpenSSL.html
|
# http://www.slproweb.com/products/Win32OpenSSL.html
|
||||||
|
set(_OPENSSL_MSI_INSTALL_GUIDS "")
|
||||||
|
|
||||||
SET(_OPENSSL_ROOT_HINTS
|
if("${CMAKE_SIZEOF_VOID_P}" STREQUAL "8")
|
||||||
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (32-bit)_is1;Inno Setup: App Path]"
|
if(TRINITY_SYSTEM_PROCESSOR STREQUAL "arm64")
|
||||||
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (64-bit)_is1;Inno Setup: App Path]"
|
set(_arch "Win64-ARM")
|
||||||
"$ENV{OPENSSL_ROOT_DIR}"
|
set(_OPENSSL_MSI_INSTALL_GUIDS "99C28AFA-6419-40B1-B88D-32B810BB4234")
|
||||||
"${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}"
|
else()
|
||||||
)
|
set(_arch "Win64")
|
||||||
|
set(_OPENSSL_MSI_INSTALL_GUIDS "117551DB-A110-4BBD-BB05-CFE0BCB3ED31" "50A9FBE2-0F8C-4D5D-97A4-A63A71C4EA1E")
|
||||||
|
endif()
|
||||||
|
|
||||||
IF(PLATFORM EQUAL 64)
|
file(TO_CMAKE_PATH "$ENV{PROGRAMFILES}" _programfiles)
|
||||||
SET(_OPENSSL_ROOT_PATHS
|
set(_OPENSSL_ROOT_HINTS HINTS "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (64-bit)_is1;Inno Setup: App Path]")
|
||||||
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (64-bit)_is1;InstallLocation]"
|
else()
|
||||||
"C:/OpenSSL-Win64/"
|
set(_arch "Win32")
|
||||||
"C:/OpenSSL/"
|
set(_progfiles_x86 "ProgramFiles(x86)")
|
||||||
"C:/Program Files/OpenSSL-Win64/"
|
|
||||||
)
|
|
||||||
ELSE()
|
|
||||||
SET(_OPENSSL_ROOT_PATHS
|
|
||||||
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (32-bit)_is1;InstallLocation]"
|
|
||||||
"[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (32-bit)_is1;InstallLocation]"
|
|
||||||
"C:/OpenSSL/"
|
|
||||||
"C:/Program Files/OpenSSL/"
|
|
||||||
)
|
|
||||||
ENDIF()
|
|
||||||
|
|
||||||
FIND_PATH(OPENSSL_ROOT_DIR
|
if(NOT "$ENV{${_progfiles_x86}}" STREQUAL "")
|
||||||
NAMES
|
# under windows 64 bit machine
|
||||||
include/openssl/ssl.h
|
file(TO_CMAKE_PATH "$ENV{${_progfiles_x86}}" _programfiles)
|
||||||
HINTS
|
else()
|
||||||
${_OPENSSL_ROOT_HINTS}
|
# under windows 32 bit machine
|
||||||
|
file(TO_CMAKE_PATH "$ENV{ProgramFiles}" _programfiles)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(_OPENSSL_ROOT_HINTS HINTS "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (32-bit)_is1;Inno Setup: App Path]")
|
||||||
|
set(_OPENSSL_MSI_INSTALL_GUIDS "A1EEC576-43B9-4E75-9E02-03DA542D2A38" "31D2408A-9CAE-4988-9EC3-F40FDE7D6AE5")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# If OpenSSL was installed using .msi package instead of .exe, Inno Setup registry values are not written to Uninstall\OpenSSL
|
||||||
|
# but because it is only a shim around Inno Setup it does write the location of uninstaller which we can use to determine path
|
||||||
|
foreach(_OPENSSL_MSI_INSTALL_GUID IN LISTS _OPENSSL_MSI_INSTALL_GUIDS)
|
||||||
|
get_filename_component(_OPENSSL_MSI_INSTALL_PATH "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Inno Setup MSIs\\${_OPENSSL_MSI_INSTALL_GUID};]" DIRECTORY)
|
||||||
|
|
||||||
|
if(NOT _OPENSSL_MSI_INSTALL_PATH STREQUAL "/")
|
||||||
|
list(INSERT _OPENSSL_ROOT_HINTS 2 ${_OPENSSL_MSI_INSTALL_PATH})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
unset(_OPENSSL_MSI_INSTALL_GUIDS)
|
||||||
|
|
||||||
|
set(_OPENSSL_ROOT_PATHS
|
||||||
PATHS
|
PATHS
|
||||||
|
"${_programfiles}/OpenSSL"
|
||||||
|
"${_programfiles}/OpenSSL-${_arch}"
|
||||||
|
"C:/OpenSSL/"
|
||||||
|
"C:/OpenSSL-${_arch}/"
|
||||||
|
)
|
||||||
|
unset(_programfiles)
|
||||||
|
unset(_arch)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(HOMEBREW_PREFIX)
|
||||||
|
list(APPEND _OPENSSL_ROOT_HINTS
|
||||||
|
"${HOMEBREW_PREFIX}/opt/openssl@3")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(_OPENSSL_ROOT_HINTS_AND_PATHS
|
||||||
|
${_OPENSSL_ROOT_HINTS}
|
||||||
${_OPENSSL_ROOT_PATHS}
|
${_OPENSSL_ROOT_PATHS}
|
||||||
)
|
)
|
||||||
MARK_AS_ADVANCED(OPENSSL_ROOT_DIR)
|
|
||||||
|
|
||||||
# Re-use the previous path:
|
find_path(OPENSSL_INCLUDE_DIR
|
||||||
FIND_PATH(OPENSSL_INCLUDE_DIR openssl/ssl.h
|
NAMES
|
||||||
${OPENSSL_ROOT_DIR}/include
|
openssl/ssl.h
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
HINTS
|
||||||
|
${_OPENSSL_INCLUDEDIR}
|
||||||
|
${_OPENSSL_INCLUDE_DIRS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
${_OPENSSL_FIND_PATH_SUFFIX}
|
||||||
)
|
)
|
||||||
|
|
||||||
IF(WIN32 AND NOT CYGWIN)
|
if(WIN32 AND NOT CYGWIN)
|
||||||
# MINGW should go here too
|
if(MSVC)
|
||||||
IF(MSVC)
|
|
||||||
# /MD and /MDd are the standard values - if someone wants to use
|
# /MD and /MDd are the standard values - if someone wants to use
|
||||||
# others, the libnames have to change here too
|
# others, the libnames have to change here too
|
||||||
# use also ssl and ssleay32 in debug as fallback for openssl < 0.9.8b
|
# use also ssl and ssleay32 in debug as fallback for openssl < 0.9.8b
|
||||||
# TODO: handle /MT and static lib
|
# enable OPENSSL_MSVC_STATIC_RT to get the libs build /MT (Multithreaded no-DLL)
|
||||||
# In Visual C++ naming convention each of these four kinds of Windows libraries has it's standard suffix:
|
# In Visual C++ naming convention each of these four kinds of Windows libraries has it's standard suffix:
|
||||||
# * MD for dynamic-release
|
# * MD for dynamic-release
|
||||||
# * MDd for dynamic-debug
|
# * MDd for dynamic-debug
|
||||||
|
|
@ -80,116 +342,526 @@ IF(WIN32 AND NOT CYGWIN)
|
||||||
# We are using the libraries located in the VC subdir instead of the parent directory even though :
|
# We are using the libraries located in the VC subdir instead of the parent directory even though :
|
||||||
# libeay32MD.lib is identical to ../libeay32.lib, and
|
# libeay32MD.lib is identical to ../libeay32.lib, and
|
||||||
# ssleay32MD.lib is identical to ../ssleay32.lib
|
# ssleay32MD.lib is identical to ../ssleay32.lib
|
||||||
|
# enable OPENSSL_USE_STATIC_LIBS to use the static libs located in lib/VC/static
|
||||||
|
if(OPENSSL_MSVC_STATIC_RT)
|
||||||
|
set(_OPENSSL_MSVC_RT_MODE "MT")
|
||||||
|
else()
|
||||||
|
set(_OPENSSL_MSVC_RT_MODE "MD")
|
||||||
|
endif()
|
||||||
|
|
||||||
# In 1.1 version of OpenSSL we have other names of libs: libcrypto32MTd.lib and libssl32MTd.lib
|
# Since OpenSSL 1.1, lib names are like libcrypto32MTd.lib and libssl32MTd.lib
|
||||||
if("${CMAKE_SIZEOF_VOID_P}" STREQUAL "8")
|
if("${CMAKE_SIZEOF_VOID_P}" STREQUAL "8")
|
||||||
set(_OPENSSL_MSVC_ARCH_SUFFIX "64")
|
set(_OPENSSL_MSVC_ARCH_SUFFIX "64")
|
||||||
|
|
||||||
|
if(FC_SYSTEM_PROCESSOR STREQUAL "arm64")
|
||||||
|
set(_OPENSSL_MSVC_ARCH_DIRECTORY "arm64")
|
||||||
|
else()
|
||||||
|
set(_OPENSSL_MSVC_ARCH_DIRECTORY "x64")
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
set(_OPENSSL_MSVC_ARCH_SUFFIX "32")
|
set(_OPENSSL_MSVC_ARCH_SUFFIX "32")
|
||||||
|
set(_OPENSSL_MSVC_ARCH_DIRECTORY "x86")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
FIND_LIBRARY(LIB_EAY_DEBUG
|
if(OPENSSL_USE_STATIC_LIBS)
|
||||||
NAMES
|
set(_OPENSSL_STATIC_SUFFIX
|
||||||
libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}MDd libcrypto libeay32MDd libeay32
|
"_static"
|
||||||
PATHS
|
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
|
||||||
${OPENSSL_ROOT_DIR}/debug/lib
|
|
||||||
)
|
)
|
||||||
|
set(_OPENSSL_PATH_SUFFIXES
|
||||||
FIND_LIBRARY(LIB_EAY_RELEASE
|
"lib/VC/static"
|
||||||
NAMES
|
"VC/static"
|
||||||
libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}MD libcrypto libeay32MD libeay32
|
"lib"
|
||||||
PATHS
|
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
|
||||||
${OPENSSL_ROOT_DIR}/lib
|
|
||||||
)
|
|
||||||
|
|
||||||
FIND_LIBRARY(SSL_EAY_DEBUG
|
|
||||||
NAMES
|
|
||||||
libssl${_OPENSSL_MSVC_ARCH_SUFFIX}MDd libssl ssleay32MDd ssleay32 ssl
|
|
||||||
PATHS
|
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
|
||||||
${OPENSSL_ROOT_DIR}/debug/lib
|
|
||||||
)
|
|
||||||
|
|
||||||
FIND_LIBRARY(SSL_EAY_RELEASE
|
|
||||||
NAMES
|
|
||||||
libssl${_OPENSSL_MSVC_ARCH_SUFFIX}MD libssl ssleay32MD ssleay32 ssl
|
|
||||||
PATHS
|
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
|
||||||
${OPENSSL_ROOT_DIR}/lib
|
|
||||||
)
|
|
||||||
|
|
||||||
if( CMAKE_CONFIGURATION_TYPES OR CMAKE_BUILD_TYPE )
|
|
||||||
set( OPENSSL_LIBRARIES
|
|
||||||
optimized ${SSL_EAY_RELEASE} ${LIB_EAY_RELEASE}
|
|
||||||
debug ${SSL_EAY_DEBUG} ${LIB_EAY_DEBUG}
|
|
||||||
)
|
)
|
||||||
else()
|
else()
|
||||||
set( OPENSSL_LIBRARIES
|
set(_OPENSSL_STATIC_SUFFIX
|
||||||
${SSL_EAY_RELEASE}
|
""
|
||||||
${LIB_EAY_RELEASE}
|
)
|
||||||
|
set(_OPENSSL_PATH_SUFFIXES
|
||||||
|
"lib/VC"
|
||||||
|
"VC"
|
||||||
|
"lib"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
MARK_AS_ADVANCED(SSL_EAY_DEBUG SSL_EAY_RELEASE LIB_EAY_DEBUG LIB_EAY_RELEASE)
|
find_library(LIB_EAY_DEBUG
|
||||||
ELSEIF(MINGW)
|
|
||||||
|
|
||||||
# same player, for MingW
|
|
||||||
FIND_LIBRARY(LIB_EAY
|
|
||||||
NAMES
|
NAMES
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
"lib/VC/${_OPENSSL_MSVC_ARCH_DIRECTORY}/${_OPENSSL_MSVC_RT_MODE}d"
|
||||||
|
)
|
||||||
|
|
||||||
|
if(NOT LIB_EAY_DEBUG)
|
||||||
|
find_library(LIB_EAY_DEBUG
|
||||||
|
NAMES
|
||||||
|
|
||||||
|
# When OpenSSL is built with default options, the static library name is suffixed with "_static".
|
||||||
|
# Looking the "libcrypto_static.lib" with a higher priority than "libcrypto.lib" which is the
|
||||||
|
# import library of "libcrypto.dll".
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
libeay32${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libeay32${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
crypto${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
|
||||||
|
# When OpenSSL is built with the "-static" option, only the static build is produced,
|
||||||
|
# and it is not suffixed with "_static".
|
||||||
|
libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libcrypto${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libcryptod
|
||||||
|
libeay32${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libeay32d
|
||||||
|
cryptod
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
${_OPENSSL_PATH_SUFFIXES}
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
find_library(LIB_EAY_RELEASE
|
||||||
|
NAMES
|
||||||
|
|
||||||
|
# When OpenSSL is built with default options, the static library name is suffixed with "_static".
|
||||||
|
# Looking the "libcrypto_static.lib" with a higher priority than "libcrypto.lib" which is the
|
||||||
|
# import library of "libcrypto.dll".
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libcrypto${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
libeay32${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libeay32${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
crypto${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
|
||||||
|
# When OpenSSL is built with the "-static" option, only the static build is produced,
|
||||||
|
# and it is not suffixed with "_static".
|
||||||
|
libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libcrypto${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libcrypto
|
||||||
|
libeay32${_OPENSSL_MSVC_RT_MODE}
|
||||||
libeay32
|
libeay32
|
||||||
PATHS
|
crypto
|
||||||
${OPENSSL_ROOT_DIR}/lib/MinGW
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
${_OPENSSL_PATH_SUFFIXES}
|
||||||
|
"lib/VC/${_OPENSSL_MSVC_ARCH_DIRECTORY}/${_OPENSSL_MSVC_RT_MODE}"
|
||||||
)
|
)
|
||||||
|
|
||||||
FIND_LIBRARY(SSL_EAY NAMES
|
find_library(SSL_EAY_DEBUG
|
||||||
NAMES
|
NAMES
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
"lib/VC/${_OPENSSL_MSVC_ARCH_DIRECTORY}/${_OPENSSL_MSVC_RT_MODE}d"
|
||||||
|
)
|
||||||
|
|
||||||
|
if(NOT SSL_EAY_DEBUG)
|
||||||
|
find_library(SSL_EAY_DEBUG
|
||||||
|
NAMES
|
||||||
|
|
||||||
|
# When OpenSSL is built with default options, the static library name is suffixed with "_static".
|
||||||
|
# Looking the "libssl_static.lib" with a higher priority than "libssl.lib" which is the
|
||||||
|
# import library of "libssl.dll".
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
ssleay32${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
ssleay32${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
ssl${_OPENSSL_STATIC_SUFFIX}d
|
||||||
|
|
||||||
|
# When OpenSSL is built with the "-static" option, only the static build is produced,
|
||||||
|
# and it is not suffixed with "_static".
|
||||||
|
libssl${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libssl${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
libssld
|
||||||
|
ssleay32${_OPENSSL_MSVC_RT_MODE}d
|
||||||
|
ssleay32d
|
||||||
|
ssld
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
${_OPENSSL_PATH_SUFFIXES}
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
find_library(SSL_EAY_RELEASE
|
||||||
|
NAMES
|
||||||
|
|
||||||
|
# When OpenSSL is built with default options, the static library name is suffixed with "_static".
|
||||||
|
# Looking the "libssl_static.lib" with a higher priority than "libssl.lib" which is the
|
||||||
|
# import library of "libssl.dll".
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libssl${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
ssleay32${_OPENSSL_STATIC_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
ssleay32${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
ssl${_OPENSSL_STATIC_SUFFIX}
|
||||||
|
|
||||||
|
# When OpenSSL is built with the "-static" option, only the static build is produced,
|
||||||
|
# and it is not suffixed with "_static".
|
||||||
|
libssl${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libssl${_OPENSSL_MSVC_RT_MODE}
|
||||||
|
libssl
|
||||||
|
ssleay32${_OPENSSL_MSVC_RT_MODE}
|
||||||
ssleay32
|
ssleay32
|
||||||
PATHS
|
ssl
|
||||||
${OPENSSL_ROOT_DIR}/lib/MinGW
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
${_OPENSSL_PATH_SUFFIXES}
|
||||||
|
"lib/VC/${_OPENSSL_MSVC_ARCH_DIRECTORY}/${_OPENSSL_MSVC_RT_MODE}"
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(SSL_EAY LIB_EAY)
|
set(LIB_EAY_LIBRARY_DEBUG "${LIB_EAY_DEBUG}")
|
||||||
|
set(LIB_EAY_LIBRARY_RELEASE "${LIB_EAY_RELEASE}")
|
||||||
|
set(SSL_EAY_LIBRARY_DEBUG "${SSL_EAY_DEBUG}")
|
||||||
|
set(SSL_EAY_LIBRARY_RELEASE "${SSL_EAY_RELEASE}")
|
||||||
|
|
||||||
set( OPENSSL_LIBRARIES
|
include(SelectLibraryConfigurations)
|
||||||
${SSL_EAY}
|
select_library_configurations(LIB_EAY)
|
||||||
${LIB_EAY}
|
select_library_configurations(SSL_EAY)
|
||||||
|
|
||||||
|
mark_as_advanced(LIB_EAY_LIBRARY_DEBUG LIB_EAY_LIBRARY_RELEASE
|
||||||
|
SSL_EAY_LIBRARY_DEBUG SSL_EAY_LIBRARY_RELEASE)
|
||||||
|
set(OPENSSL_SSL_LIBRARY ${SSL_EAY_LIBRARY})
|
||||||
|
set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY_LIBRARY})
|
||||||
|
elseif(MINGW)
|
||||||
|
# same player, for MinGW
|
||||||
|
set(LIB_EAY_NAMES crypto libeay32)
|
||||||
|
set(SSL_EAY_NAMES ssl ssleay32)
|
||||||
|
find_library(LIB_EAY
|
||||||
|
NAMES
|
||||||
|
${LIB_EAY_NAMES}
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
"lib/MinGW"
|
||||||
|
"lib"
|
||||||
|
"lib64"
|
||||||
)
|
)
|
||||||
ELSE(MSVC)
|
|
||||||
|
find_library(SSL_EAY
|
||||||
|
NAMES
|
||||||
|
${SSL_EAY_NAMES}
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
"lib/MinGW"
|
||||||
|
"lib"
|
||||||
|
"lib64"
|
||||||
|
)
|
||||||
|
|
||||||
|
mark_as_advanced(SSL_EAY LIB_EAY)
|
||||||
|
set(OPENSSL_SSL_LIBRARY ${SSL_EAY})
|
||||||
|
set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY})
|
||||||
|
unset(LIB_EAY_NAMES)
|
||||||
|
unset(SSL_EAY_NAMES)
|
||||||
|
else()
|
||||||
# Not sure what to pick for -say- intel, let's use the toplevel ones and hope someone report issues:
|
# Not sure what to pick for -say- intel, let's use the toplevel ones and hope someone report issues:
|
||||||
FIND_LIBRARY(LIB_EAY
|
find_library(LIB_EAY
|
||||||
NAMES
|
NAMES
|
||||||
|
libcrypto
|
||||||
libeay32
|
libeay32
|
||||||
PATHS
|
NAMES_PER_DIR
|
||||||
${OPENSSL_ROOT_DIR}/lib
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
HINTS
|
||||||
|
${_OPENSSL_LIBDIR}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
lib
|
||||||
)
|
)
|
||||||
|
|
||||||
FIND_LIBRARY(SSL_EAY
|
find_library(SSL_EAY
|
||||||
NAMES
|
NAMES
|
||||||
|
libssl
|
||||||
ssleay32
|
ssleay32
|
||||||
PATHS
|
NAMES_PER_DIR
|
||||||
${OPENSSL_ROOT_DIR}/lib
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
${OPENSSL_ROOT_DIR}/lib/VC
|
HINTS
|
||||||
|
${_OPENSSL_LIBDIR}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
lib
|
||||||
)
|
)
|
||||||
MARK_AS_ADVANCED(SSL_EAY LIB_EAY)
|
|
||||||
|
|
||||||
SET( OPENSSL_LIBRARIES ${SSL_EAY} ${LIB_EAY} )
|
mark_as_advanced(SSL_EAY LIB_EAY)
|
||||||
ENDIF(MSVC)
|
set(OPENSSL_SSL_LIBRARY ${SSL_EAY})
|
||||||
ELSE(WIN32 AND NOT CYGWIN)
|
set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY})
|
||||||
FIND_LIBRARY(OPENSSL_SSL_LIBRARIES NAMES ssl ssleay32 ssleay32MD)
|
endif()
|
||||||
FIND_LIBRARY(OPENSSL_CRYPTO_LIBRARIES NAMES crypto)
|
else()
|
||||||
MARK_AS_ADVANCED(OPENSSL_CRYPTO_LIBRARIES OPENSSL_SSL_LIBRARIES)
|
find_library(OPENSSL_SSL_LIBRARY
|
||||||
|
NAMES
|
||||||
|
ssl${_OPENSSL_NAME_POSTFIX}
|
||||||
|
ssleay32
|
||||||
|
ssleay32MD
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
HINTS
|
||||||
|
${_OPENSSL_LIBDIR}
|
||||||
|
${_OPENSSL_LIBRARY_DIRS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
lib lib64
|
||||||
|
)
|
||||||
|
|
||||||
SET(OPENSSL_LIBRARIES ${OPENSSL_SSL_LIBRARIES} ${OPENSSL_CRYPTO_LIBRARIES})
|
find_library(OPENSSL_CRYPTO_LIBRARY
|
||||||
|
NAMES
|
||||||
|
crypto${_OPENSSL_NAME_POSTFIX}
|
||||||
|
NAMES_PER_DIR
|
||||||
|
${_OPENSSL_ROOT_HINTS_AND_PATHS}
|
||||||
|
HINTS
|
||||||
|
${_OPENSSL_LIBDIR}
|
||||||
|
${_OPENSSL_LIBRARY_DIRS}
|
||||||
|
PATH_SUFFIXES
|
||||||
|
lib lib64
|
||||||
|
)
|
||||||
|
|
||||||
ENDIF(WIN32 AND NOT CYGWIN)
|
mark_as_advanced(OPENSSL_CRYPTO_LIBRARY OPENSSL_SSL_LIBRARY)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(OPENSSL_SSL_LIBRARIES ${OPENSSL_SSL_LIBRARY})
|
||||||
|
set(OPENSSL_CRYPTO_LIBRARIES ${OPENSSL_CRYPTO_LIBRARY})
|
||||||
|
set(OPENSSL_LIBRARIES ${OPENSSL_SSL_LIBRARIES} ${OPENSSL_CRYPTO_LIBRARIES})
|
||||||
|
_OpenSSL_test_and_find_dependencies("${OPENSSL_SSL_LIBRARY}" "${OPENSSL_CRYPTO_LIBRARY}")
|
||||||
|
|
||||||
|
if(_OpenSSL_has_dependencies)
|
||||||
|
_OpenSSL_add_dependencies(OPENSSL_SSL_LIBRARIES)
|
||||||
|
_OpenSSL_add_dependencies(OPENSSL_CRYPTO_LIBRARIES)
|
||||||
|
_OpenSSL_add_dependencies(OPENSSL_LIBRARIES)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
function(from_hex HEX DEC)
|
||||||
|
string(TOUPPER "${HEX}" HEX)
|
||||||
|
set(_res 0)
|
||||||
|
string(LENGTH "${HEX}" _strlen)
|
||||||
|
|
||||||
|
while(_strlen GREATER 0)
|
||||||
|
math(EXPR _res "${_res} * 16")
|
||||||
|
string(SUBSTRING "${HEX}" 0 1 NIBBLE)
|
||||||
|
string(SUBSTRING "${HEX}" 1 -1 HEX)
|
||||||
|
|
||||||
|
if(NIBBLE STREQUAL "A")
|
||||||
|
math(EXPR _res "${_res} + 10")
|
||||||
|
elseif(NIBBLE STREQUAL "B")
|
||||||
|
math(EXPR _res "${_res} + 11")
|
||||||
|
elseif(NIBBLE STREQUAL "C")
|
||||||
|
math(EXPR _res "${_res} + 12")
|
||||||
|
elseif(NIBBLE STREQUAL "D")
|
||||||
|
math(EXPR _res "${_res} + 13")
|
||||||
|
elseif(NIBBLE STREQUAL "E")
|
||||||
|
math(EXPR _res "${_res} + 14")
|
||||||
|
elseif(NIBBLE STREQUAL "F")
|
||||||
|
math(EXPR _res "${_res} + 15")
|
||||||
|
else()
|
||||||
|
math(EXPR _res "${_res} + ${NIBBLE}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
string(LENGTH "${HEX}" _strlen)
|
||||||
|
endwhile()
|
||||||
|
|
||||||
|
set(${DEC} ${_res} PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
if(OPENSSL_INCLUDE_DIR AND EXISTS "${OPENSSL_INCLUDE_DIR}/openssl/opensslv.h")
|
||||||
|
file(STRINGS "${OPENSSL_INCLUDE_DIR}/openssl/opensslv.h" openssl_version_str
|
||||||
|
REGEX "^#[\t ]*define[\t ]+OPENSSL_VERSION_NUMBER[\t ]+0x([0-9a-fA-F])+.*")
|
||||||
|
|
||||||
|
if(openssl_version_str)
|
||||||
|
# The version number is encoded as 0xMNNFFPPS: major minor fix patch status
|
||||||
|
# The status gives if this is a developer or prerelease and is ignored here.
|
||||||
|
# Major, minor, and fix directly translate into the version numbers shown in
|
||||||
|
# the string. The patch field translates to the single character suffix that
|
||||||
|
# indicates the bug fix state, which 00 -> nothing, 01 -> a, 02 -> b and so
|
||||||
|
# on.
|
||||||
|
message(STATUS "Found OpenSSL version: ${openssl_version_str}")
|
||||||
|
string(REGEX REPLACE "^.*OPENSSL_VERSION_NUMBER[\t ]+0x([0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F]).*$"
|
||||||
|
"\\1;\\2;\\3;\\4;\\5" OPENSSL_VERSION_LIST "${openssl_version_str}")
|
||||||
|
list(GET OPENSSL_VERSION_LIST 0 OPENSSL_VERSION_MAJOR)
|
||||||
|
list(GET OPENSSL_VERSION_LIST 1 OPENSSL_VERSION_MINOR)
|
||||||
|
from_hex("${OPENSSL_VERSION_MINOR}" OPENSSL_VERSION_MINOR)
|
||||||
|
list(GET OPENSSL_VERSION_LIST 2 OPENSSL_VERSION_FIX)
|
||||||
|
from_hex("${OPENSSL_VERSION_FIX}" OPENSSL_VERSION_FIX)
|
||||||
|
list(GET OPENSSL_VERSION_LIST 3 OPENSSL_VERSION_PATCH)
|
||||||
|
|
||||||
|
if(NOT OPENSSL_VERSION_PATCH STREQUAL "00")
|
||||||
|
from_hex("${OPENSSL_VERSION_PATCH}" _tmp)
|
||||||
|
|
||||||
|
# 96 is the ASCII code of 'a' minus 1
|
||||||
|
math(EXPR OPENSSL_VERSION_PATCH_ASCII "${_tmp} + 96")
|
||||||
|
unset(_tmp)
|
||||||
|
|
||||||
|
# Once anyone knows how OpenSSL would call the patch versions beyond 'z'
|
||||||
|
# this should be updated to handle that, too. This has not happened yet
|
||||||
|
# so it is simply ignored here for now.
|
||||||
|
string(ASCII "${OPENSSL_VERSION_PATCH_ASCII}" OPENSSL_VERSION_PATCH_STRING)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(OPENSSL_VERSION "${OPENSSL_VERSION_MAJOR}.${OPENSSL_VERSION_MINOR}.${OPENSSL_VERSION_FIX}${OPENSSL_VERSION_PATCH_STRING}")
|
||||||
|
else()
|
||||||
|
# Since OpenSSL 3.0.0, the new version format is MAJOR.MINOR.PATCH and
|
||||||
|
# a new OPENSSL_VERSION_STR macro contains exactly that
|
||||||
|
file(STRINGS "${OPENSSL_INCLUDE_DIR}/openssl/opensslv.h" OPENSSL_VERSION_STR
|
||||||
|
REGEX "^#[\t ]*define[\t ]+OPENSSL_VERSION_STR[\t ]+\"([0-9])+\\.([0-9])+\\.([0-9])+\".*")
|
||||||
|
string(REGEX REPLACE "^.*OPENSSL_VERSION_STR[\t ]+\"([0-9]+\\.[0-9]+\\.[0-9]+)\".*$"
|
||||||
|
"\\1" OPENSSL_VERSION_STR "${OPENSSL_VERSION_STR}")
|
||||||
|
|
||||||
|
set(OPENSSL_VERSION "${OPENSSL_VERSION_STR}")
|
||||||
|
|
||||||
|
unset(OPENSSL_VERSION_STR)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
foreach(_comp IN LISTS OpenSSL_FIND_COMPONENTS)
|
||||||
|
if(_comp STREQUAL "Crypto")
|
||||||
|
if(EXISTS "${OPENSSL_INCLUDE_DIR}" AND
|
||||||
|
(EXISTS "${OPENSSL_CRYPTO_LIBRARY}" OR
|
||||||
|
EXISTS "${LIB_EAY_LIBRARY_DEBUG}" OR
|
||||||
|
EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
|
||||||
|
)
|
||||||
|
set(OpenSSL_${_comp}_FOUND TRUE)
|
||||||
|
else()
|
||||||
|
set(OpenSSL_${_comp}_FOUND FALSE)
|
||||||
|
endif()
|
||||||
|
elseif(_comp STREQUAL "SSL")
|
||||||
|
if(EXISTS "${OPENSSL_INCLUDE_DIR}" AND
|
||||||
|
(EXISTS "${OPENSSL_SSL_LIBRARY}" OR
|
||||||
|
EXISTS "${SSL_EAY_LIBRARY_DEBUG}" OR
|
||||||
|
EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
|
||||||
|
)
|
||||||
|
set(OpenSSL_${_comp}_FOUND TRUE)
|
||||||
|
else()
|
||||||
|
set(OpenSSL_${_comp}_FOUND FALSE)
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
message(WARNING "${_comp} is not a valid OpenSSL component")
|
||||||
|
set(OpenSSL_${_comp}_FOUND FALSE)
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
unset(_comp)
|
||||||
|
|
||||||
include(FindPackageHandleStandardArgs)
|
include(FindPackageHandleStandardArgs)
|
||||||
find_package_handle_standard_args(OpenSSL DEFAULT_MSG
|
find_package_handle_standard_args(OpenSSL
|
||||||
OPENSSL_LIBRARIES
|
REQUIRED_VARS
|
||||||
|
OPENSSL_CRYPTO_LIBRARY
|
||||||
OPENSSL_INCLUDE_DIR
|
OPENSSL_INCLUDE_DIR
|
||||||
|
VERSION_VAR
|
||||||
|
OPENSSL_VERSION
|
||||||
|
HANDLE_COMPONENTS
|
||||||
|
FAIL_MESSAGE
|
||||||
|
"Could NOT find OpenSSL, try to set the path to OpenSSL root folder in the system variable OPENSSL_ROOT_DIR"
|
||||||
)
|
)
|
||||||
|
|
||||||
MARK_AS_ADVANCED(OPENSSL_INCLUDE_DIR OPENSSL_LIBRARIES)
|
mark_as_advanced(OPENSSL_INCLUDE_DIR)
|
||||||
|
|
||||||
|
if(OPENSSL_FOUND)
|
||||||
|
if(NOT TARGET OpenSSL::Crypto AND
|
||||||
|
(EXISTS "${OPENSSL_CRYPTO_LIBRARY}" OR
|
||||||
|
EXISTS "${LIB_EAY_LIBRARY_DEBUG}" OR
|
||||||
|
EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
|
||||||
|
)
|
||||||
|
add_library(OpenSSL::Crypto UNKNOWN IMPORTED)
|
||||||
|
set_target_properties(OpenSSL::Crypto PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${OPENSSL_INCLUDE_DIR}")
|
||||||
|
|
||||||
|
if(EXISTS "${OPENSSL_CRYPTO_LIBRARY}")
|
||||||
|
set_target_properties(OpenSSL::Crypto PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES "C"
|
||||||
|
IMPORTED_LOCATION "${OPENSSL_CRYPTO_LIBRARY}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
|
||||||
|
set_property(TARGET OpenSSL::Crypto APPEND PROPERTY
|
||||||
|
IMPORTED_CONFIGURATIONS RELEASE)
|
||||||
|
set_target_properties(OpenSSL::Crypto PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES_RELEASE "C"
|
||||||
|
IMPORTED_LOCATION_RELEASE "${LIB_EAY_LIBRARY_RELEASE}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(EXISTS "${LIB_EAY_LIBRARY_DEBUG}")
|
||||||
|
set_property(TARGET OpenSSL::Crypto APPEND PROPERTY
|
||||||
|
IMPORTED_CONFIGURATIONS DEBUG)
|
||||||
|
set_target_properties(OpenSSL::Crypto PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES_DEBUG "C"
|
||||||
|
IMPORTED_LOCATION_DEBUG "${LIB_EAY_LIBRARY_DEBUG}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
_OpenSSL_target_add_dependencies(OpenSSL::Crypto)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT TARGET OpenSSL::SSL AND
|
||||||
|
(EXISTS "${OPENSSL_SSL_LIBRARY}" OR
|
||||||
|
EXISTS "${SSL_EAY_LIBRARY_DEBUG}" OR
|
||||||
|
EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
|
||||||
|
)
|
||||||
|
add_library(OpenSSL::SSL UNKNOWN IMPORTED)
|
||||||
|
set_target_properties(OpenSSL::SSL PROPERTIES
|
||||||
|
INTERFACE_INCLUDE_DIRECTORIES "${OPENSSL_INCLUDE_DIR}")
|
||||||
|
|
||||||
|
if(EXISTS "${OPENSSL_SSL_LIBRARY}")
|
||||||
|
set_target_properties(OpenSSL::SSL PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES "C"
|
||||||
|
IMPORTED_LOCATION "${OPENSSL_SSL_LIBRARY}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
|
||||||
|
set_property(TARGET OpenSSL::SSL APPEND PROPERTY
|
||||||
|
IMPORTED_CONFIGURATIONS RELEASE)
|
||||||
|
set_target_properties(OpenSSL::SSL PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES_RELEASE "C"
|
||||||
|
IMPORTED_LOCATION_RELEASE "${SSL_EAY_LIBRARY_RELEASE}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(EXISTS "${SSL_EAY_LIBRARY_DEBUG}")
|
||||||
|
set_property(TARGET OpenSSL::SSL APPEND PROPERTY
|
||||||
|
IMPORTED_CONFIGURATIONS DEBUG)
|
||||||
|
set_target_properties(OpenSSL::SSL PROPERTIES
|
||||||
|
IMPORTED_LINK_INTERFACE_LANGUAGES_DEBUG "C"
|
||||||
|
IMPORTED_LOCATION_DEBUG "${SSL_EAY_LIBRARY_DEBUG}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(TARGET OpenSSL::Crypto)
|
||||||
|
set_target_properties(OpenSSL::SSL PROPERTIES
|
||||||
|
INTERFACE_LINK_LIBRARIES OpenSSL::Crypto)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
_OpenSSL_target_add_dependencies(OpenSSL::SSL)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if("${OPENSSL_VERSION_MAJOR}.${OPENSSL_VERSION_MINOR}.${OPENSSL_VERSION_FIX}" VERSION_GREATER_EQUAL "0.9.8")
|
||||||
|
if(MSVC)
|
||||||
|
if(EXISTS "${OPENSSL_INCLUDE_DIR}")
|
||||||
|
set(_OPENSSL_applink_paths PATHS ${OPENSSL_INCLUDE_DIR})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
find_file(OPENSSL_APPLINK_SOURCE
|
||||||
|
NAMES
|
||||||
|
openssl/applink.c
|
||||||
|
${_OPENSSL_applink_paths}
|
||||||
|
NO_DEFAULT_PATH)
|
||||||
|
|
||||||
|
if(OPENSSL_APPLINK_SOURCE)
|
||||||
|
set(_OPENSSL_applink_interface_srcs ${OPENSSL_APPLINK_SOURCE})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT TARGET OpenSSL::applink)
|
||||||
|
add_library(OpenSSL::applink INTERFACE IMPORTED)
|
||||||
|
set_property(TARGET OpenSSL::applink APPEND
|
||||||
|
PROPERTY INTERFACE_SOURCES
|
||||||
|
${_OPENSSL_applink_interface_srcs})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Restore the original find library ordering
|
||||||
|
if(OPENSSL_USE_STATIC_LIBS)
|
||||||
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ${_openssl_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
unset(_OPENSSL_FIND_PATH_SUFFIX)
|
||||||
|
unset(_OPENSSL_NAME_POSTFIX)
|
||||||
|
unset(_OpenSSL_extra_static_deps)
|
||||||
|
unset(_OpenSSL_has_dependency_dl)
|
||||||
|
unset(_OpenSSL_has_dependency_threads)
|
||||||
|
unset(_OpenSSL_has_dependency_zlib)
|
||||||
|
|
@ -29,8 +29,9 @@
|
||||||
#include <ace/Sig_Handler.h>
|
#include <ace/Sig_Handler.h>
|
||||||
#include <openssl/opensslv.h>
|
#include <openssl/opensslv.h>
|
||||||
#include <openssl/crypto.h>
|
#include <openssl/crypto.h>
|
||||||
|
#include "OpenSSLCrypto.h"
|
||||||
#include "Common.h"
|
#include "Common.h"
|
||||||
|
#include <boost/dll/runtime_symbol_info.hpp>
|
||||||
#include "Database/DatabaseEnv.h"
|
#include "Database/DatabaseEnv.h"
|
||||||
#include "Configuration/Config.h"
|
#include "Configuration/Config.h"
|
||||||
#include "Log.h"
|
#include "Log.h"
|
||||||
|
|
@ -40,6 +41,9 @@
|
||||||
#include "RealmList.h"
|
#include "RealmList.h"
|
||||||
#include "RealmAcceptor.h"
|
#include "RealmAcceptor.h"
|
||||||
#include "AppenderDB.h"
|
#include "AppenderDB.h"
|
||||||
|
#if defined(OPENSSL_VERSION_MAJOR) && (OPENSSL_VERSION_MAJOR >= 3)
|
||||||
|
#include <openssl/provider.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
#include <sched.h>
|
#include <sched.h>
|
||||||
|
|
@ -150,7 +154,7 @@ extern int main(int argc, char** argv)
|
||||||
|
|
||||||
TC_LOG_INFO("server.authserver", "Using configuration file %s.", configFile);
|
TC_LOG_INFO("server.authserver", "Using configuration file %s.", configFile);
|
||||||
|
|
||||||
TC_LOG_WARN("server.authserver", "%s (Library: %s)", OPENSSL_VERSION_TEXT, SSLeay_version(SSLEAY_VERSION));
|
TC_LOG_WARN("server.authserver", "%s (Library: %s)", OPENSSL_VERSION_TEXT, OpenSSL_version(OPENSSL_VERSION));
|
||||||
|
|
||||||
#if defined (ACE_HAS_EVENT_POLL) || defined (ACE_HAS_DEV_POLL)
|
#if defined (ACE_HAS_EVENT_POLL) || defined (ACE_HAS_DEV_POLL)
|
||||||
ACE_Reactor::instance(new ACE_Reactor(new ACE_Dev_Poll_Reactor(ACE::max_handles(), 1), 1), true);
|
ACE_Reactor::instance(new ACE_Reactor(new ACE_Dev_Poll_Reactor(ACE::max_handles(), 1), 1), true);
|
||||||
|
|
|
||||||
|
|
@ -17,35 +17,51 @@
|
||||||
|
|
||||||
#include "ARC4.h"
|
#include "ARC4.h"
|
||||||
#include <openssl/sha.h>
|
#include <openssl/sha.h>
|
||||||
|
#include "Errors.h"
|
||||||
|
|
||||||
ARC4::ARC4(uint8 len)
|
ARC4::ARC4(uint8 len) : _ctx(EVP_CIPHER_CTX_new())
|
||||||
{
|
{
|
||||||
EVP_CIPHER_CTX_init(m_ctx);
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
EVP_EncryptInit_ex(m_ctx, EVP_rc4(), NULL, NULL, NULL);
|
_cipher = EVP_CIPHER_fetch(nullptr, "RC4", nullptr);
|
||||||
EVP_CIPHER_CTX_set_key_length(m_ctx, len);
|
#else
|
||||||
|
EVP_CIPHER const* _cipher = EVP_rc4();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
EVP_CIPHER_CTX_init(_ctx);
|
||||||
|
EVP_EncryptInit_ex(_ctx, EVP_rc4(), nullptr, nullptr, nullptr);
|
||||||
|
EVP_CIPHER_CTX_set_key_length(_ctx, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
ARC4::ARC4(uint8 const* seed, size_t len)
|
ARC4::ARC4(uint8 const* seed, size_t len) : _ctx(EVP_CIPHER_CTX_new())
|
||||||
{
|
{
|
||||||
EVP_CIPHER_CTX_init(m_ctx);
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
EVP_EncryptInit_ex(m_ctx, EVP_rc4(), NULL, NULL, NULL);
|
_cipher = EVP_CIPHER_fetch(nullptr, "RC4", nullptr);
|
||||||
EVP_CIPHER_CTX_set_key_length(m_ctx, len);
|
#else
|
||||||
EVP_EncryptInit_ex(m_ctx, NULL, NULL, seed, NULL);
|
EVP_CIPHER const* _cipher = EVP_rc4();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
EVP_CIPHER_CTX_init(_ctx);
|
||||||
|
EVP_EncryptInit_ex(_ctx, EVP_rc4(), nullptr, nullptr, nullptr);
|
||||||
|
EVP_CIPHER_CTX_set_key_length(_ctx, len);
|
||||||
|
EVP_EncryptInit_ex(_ctx, nullptr, nullptr, seed, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
ARC4::~ARC4()
|
ARC4::~ARC4()
|
||||||
{
|
{
|
||||||
EVP_CIPHER_CTX_cleanup(m_ctx);
|
EVP_CIPHER_CTX_free(_ctx);
|
||||||
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
|
EVP_CIPHER_free(_cipher);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void ARC4::Init(uint8 const* seed)
|
void ARC4::Init(uint8 const* seed)
|
||||||
{
|
{
|
||||||
EVP_EncryptInit_ex(m_ctx, NULL, NULL, seed, NULL);
|
EVP_EncryptInit_ex(_ctx, nullptr, nullptr, seed, nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ARC4::UpdateData(int len, uint8 *data)
|
void ARC4::UpdateData(int len, uint8 *data)
|
||||||
{
|
{
|
||||||
int outlen = 0;
|
int outlen = 0;
|
||||||
EVP_EncryptUpdate(m_ctx, data, &outlen, data, len);
|
EVP_EncryptUpdate(_ctx, data, &outlen, data, len);
|
||||||
EVP_EncryptFinal_ex(m_ctx, data, &outlen);
|
EVP_EncryptFinal_ex(_ctx, data, &outlen);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -20,6 +20,7 @@
|
||||||
|
|
||||||
#include "Define.h"
|
#include "Define.h"
|
||||||
#include <openssl/evp.h>
|
#include <openssl/evp.h>
|
||||||
|
#include <array>
|
||||||
|
|
||||||
class ARC4
|
class ARC4
|
||||||
{
|
{
|
||||||
|
|
@ -30,7 +31,10 @@ class ARC4
|
||||||
void Init(uint8 const* seed);
|
void Init(uint8 const* seed);
|
||||||
void UpdateData(int len, uint8 *data);
|
void UpdateData(int len, uint8 *data);
|
||||||
private:
|
private:
|
||||||
EVP_CIPHER_CTX * m_ctx = EVP_CIPHER_CTX_new();
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
|
EVP_CIPHER* _cipher;
|
||||||
|
#endif
|
||||||
|
EVP_CIPHER_CTX* _ctx;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -20,40 +20,29 @@
|
||||||
#include <ace/Thread_Mutex.h>
|
#include <ace/Thread_Mutex.h>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <ace/Thread.h>
|
#include <ace/Thread.h>
|
||||||
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
|
#include <openssl/provider.h>
|
||||||
|
OSSL_PROVIDER* LegacyProvider;
|
||||||
|
OSSL_PROVIDER* DefaultProvider;
|
||||||
|
#endif
|
||||||
|
|
||||||
std::vector<ACE_Thread_Mutex*> cryptoLocks;
|
|
||||||
|
|
||||||
static void lockingCallback(int mode, int type, const char* /*file*/, int /*line*/)
|
void OpenSSLCrypto::threadsSetup([[maybe_unused]] boost::filesystem::path const& providerModulePath)
|
||||||
{
|
{
|
||||||
if (mode & CRYPTO_LOCK)
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
cryptoLocks[type]->acquire();
|
#if PLATFORM == PLATFORM_WINDOWS
|
||||||
else
|
OSSL_PROVIDER_set_default_search_path(nullptr, providerModulePath.string().c_str());
|
||||||
cryptoLocks[type]->release();
|
#endif
|
||||||
}
|
LegacyProvider = OSSL_PROVIDER_load(nullptr, "legacy");
|
||||||
|
DefaultProvider = OSSL_PROVIDER_load(nullptr, "default");
|
||||||
static void threadIdCallback(CRYPTO_THREADID * id)
|
#endif
|
||||||
{
|
|
||||||
CRYPTO_THREADID_set_numeric(id, ACE_Thread::self());
|
|
||||||
}
|
|
||||||
|
|
||||||
void OpenSSLCrypto::threadsSetup()
|
|
||||||
{
|
|
||||||
cryptoLocks.resize(CRYPTO_num_locks());
|
|
||||||
for(int i = 0 ; i < CRYPTO_num_locks(); ++i)
|
|
||||||
{
|
|
||||||
cryptoLocks[i] = new ACE_Thread_Mutex();
|
|
||||||
}
|
|
||||||
CRYPTO_THREADID_set_callback(threadIdCallback);
|
|
||||||
CRYPTO_set_locking_callback(lockingCallback);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void OpenSSLCrypto::threadsCleanup()
|
void OpenSSLCrypto::threadsCleanup()
|
||||||
{
|
{
|
||||||
CRYPTO_set_locking_callback(NULL);
|
#if OPENSSL_VERSION_NUMBER >= 0x30000000L
|
||||||
CRYPTO_THREADID_set_callback(NULL);
|
OSSL_PROVIDER_unload(LegacyProvider);
|
||||||
for(int i = 0 ; i < CRYPTO_num_locks(); ++i)
|
OSSL_PROVIDER_unload(DefaultProvider);
|
||||||
{
|
OSSL_PROVIDER_set_default_search_path(nullptr, nullptr);
|
||||||
delete cryptoLocks[i];
|
#endif
|
||||||
}
|
|
||||||
cryptoLocks.resize(0);
|
|
||||||
}
|
}
|
||||||
|
|
@ -15,9 +15,9 @@
|
||||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef OPENSSL_CRYPTO_H
|
#ifndef PD_OPENSSL_CRYPTO_H
|
||||||
#define OPENSSL_CRYPTO_H
|
#define PD_OPENSSL_CRYPTO_H
|
||||||
|
#include <boost/filesystem/path.hpp>
|
||||||
/**
|
/**
|
||||||
* A group of functions which setup openssl crypto module to work properly in multithreaded enviroment
|
* A group of functions which setup openssl crypto module to work properly in multithreaded enviroment
|
||||||
* If not setup properly - it will crash
|
* If not setup properly - it will crash
|
||||||
|
|
@ -25,7 +25,7 @@
|
||||||
namespace OpenSSLCrypto
|
namespace OpenSSLCrypto
|
||||||
{
|
{
|
||||||
/// Needs to be called before threads using openssl are spawned
|
/// Needs to be called before threads using openssl are spawned
|
||||||
void threadsSetup();
|
void threadsSetup(boost::filesystem::path const& providerModulePath);
|
||||||
/// Needs to be called after threads using openssl are despawned
|
/// Needs to be called after threads using openssl are despawned
|
||||||
void threadsCleanup();
|
void threadsCleanup();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -21,18 +21,41 @@
|
||||||
|
|
||||||
SHA1Hash::SHA1Hash()
|
SHA1Hash::SHA1Hash()
|
||||||
{
|
{
|
||||||
SHA1_Init(&mC);
|
m_ctx = EVP_MD_CTX_new();
|
||||||
memset(mDigest, 0, SHA_DIGEST_LENGTH * sizeof(uint8));
|
EVP_DigestInit_ex(m_ctx, EVP_sha1(), nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
SHA1Hash::SHA1Hash(const SHA1Hash& other) : SHA1Hash() // copy
|
||||||
|
{
|
||||||
|
EVP_MD_CTX_copy_ex(m_ctx, other.m_ctx);
|
||||||
|
std::memcpy(m_digest, other.m_digest, SHA_DIGEST_LENGTH);
|
||||||
|
}
|
||||||
|
|
||||||
|
SHA1Hash::SHA1Hash(SHA1Hash&& other) : SHA1Hash() // move
|
||||||
|
{
|
||||||
|
Swap(other);
|
||||||
|
}
|
||||||
|
|
||||||
|
SHA1Hash& SHA1Hash::operator=(SHA1Hash other) // assign
|
||||||
|
{
|
||||||
|
Swap(other);
|
||||||
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
SHA1Hash::~SHA1Hash()
|
SHA1Hash::~SHA1Hash()
|
||||||
{
|
{
|
||||||
SHA1_Init(&mC);
|
EVP_MD_CTX_free(m_ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SHA1Hash::Swap(SHA1Hash& other) throw()
|
||||||
|
{
|
||||||
|
std::swap(m_ctx, other.m_ctx);
|
||||||
|
std::swap(m_digest, other.m_digest);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SHA1Hash::UpdateData(const uint8 *dta, int len)
|
void SHA1Hash::UpdateData(const uint8 *dta, int len)
|
||||||
{
|
{
|
||||||
SHA1_Update(&mC, dta, len);
|
EVP_DigestUpdate(m_ctx, dta, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SHA1Hash::UpdateData(const std::string &str)
|
void SHA1Hash::UpdateData(const std::string &str)
|
||||||
|
|
@ -57,11 +80,12 @@ void SHA1Hash::UpdateBigNumbers(BigNumber* bn0, ...)
|
||||||
|
|
||||||
void SHA1Hash::Initialize()
|
void SHA1Hash::Initialize()
|
||||||
{
|
{
|
||||||
SHA1_Init(&mC);
|
EVP_DigestInit(m_ctx, EVP_sha1());
|
||||||
}
|
}
|
||||||
|
|
||||||
void SHA1Hash::Finalize(void)
|
void SHA1Hash::Finalize(void)
|
||||||
{
|
{
|
||||||
SHA1_Final(mDigest, &mC);
|
uint32 length = SHA_DIGEST_LENGTH;
|
||||||
|
EVP_DigestFinal_ex(m_ctx, m_digest, &length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -21,6 +21,7 @@
|
||||||
#include "Define.h"
|
#include "Define.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <openssl/sha.h>
|
#include <openssl/sha.h>
|
||||||
|
#include <openssl/evp.h>
|
||||||
|
|
||||||
class BigNumber;
|
class BigNumber;
|
||||||
|
|
||||||
|
|
@ -28,8 +29,13 @@ class SHA1Hash
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
SHA1Hash();
|
SHA1Hash();
|
||||||
|
SHA1Hash(SHA1Hash const& other); // copy
|
||||||
|
SHA1Hash(SHA1Hash&& other); // move
|
||||||
|
SHA1Hash& operator=(SHA1Hash other); // assign
|
||||||
~SHA1Hash();
|
~SHA1Hash();
|
||||||
|
|
||||||
|
void Swap(SHA1Hash& other) throw();
|
||||||
|
friend void Swap(SHA1Hash& left, SHA1Hash& right) { left.Swap(right); }
|
||||||
void UpdateBigNumbers(BigNumber* bn0, ...);
|
void UpdateBigNumbers(BigNumber* bn0, ...);
|
||||||
|
|
||||||
void UpdateData(const uint8 *dta, int len);
|
void UpdateData(const uint8 *dta, int len);
|
||||||
|
|
@ -38,12 +44,12 @@ class SHA1Hash
|
||||||
void Initialize();
|
void Initialize();
|
||||||
void Finalize();
|
void Finalize();
|
||||||
|
|
||||||
uint8 *GetDigest(void) { return mDigest; };
|
uint8* GetDigest(void) { return m_digest; }
|
||||||
int GetLength(void) const { return SHA_DIGEST_LENGTH; };
|
int GetLength() const { return SHA_DIGEST_LENGTH; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SHA_CTX mC;
|
EVP_MD_CTX* m_ctx;
|
||||||
uint8 mDigest[SHA_DIGEST_LENGTH];
|
uint8 m_digest[SHA_DIGEST_LENGTH];
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -21,12 +21,18 @@
|
||||||
|
|
||||||
#include <openssl/opensslv.h>
|
#include <openssl/opensslv.h>
|
||||||
#include <openssl/crypto.h>
|
#include <openssl/crypto.h>
|
||||||
|
#if defined(OPENSSL_VERSION_MAJOR) && (OPENSSL_VERSION_MAJOR >= 3)
|
||||||
|
#include <openssl/provider.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <boost/dll/runtime_symbol_info.hpp>
|
||||||
#include <ace/Version.h>
|
#include <ace/Version.h>
|
||||||
|
|
||||||
#include "Common.h"
|
#include "Common.h"
|
||||||
#include "Database/DatabaseEnv.h"
|
#include "Database/DatabaseEnv.h"
|
||||||
#include "Configuration/Config.h"
|
#include "Configuration/Config.h"
|
||||||
|
|
||||||
|
|
||||||
#include "Log.h"
|
#include "Log.h"
|
||||||
#include "Master.h"
|
#include "Master.h"
|
||||||
#include "World.h"
|
#include "World.h"
|
||||||
|
|
@ -139,7 +145,7 @@ extern int main(int argc, char** argv)
|
||||||
|
|
||||||
TC_LOG_INFO("server.worldserver", "Using configuration file %s.", cfg_file);
|
TC_LOG_INFO("server.worldserver", "Using configuration file %s.", cfg_file);
|
||||||
|
|
||||||
TC_LOG_INFO("server.worldserver", "Using SSL version: %s (library: %s)", OPENSSL_VERSION_TEXT, SSLeay_version(SSLEAY_VERSION));
|
TC_LOG_INFO("server.worldserver", "Using SSL version: %s (library: %s)", OPENSSL_VERSION_TEXT, OpenSSL_version(OPENSSL_VERSION));
|
||||||
TC_LOG_INFO("server.worldserver", "Using ACE version: %s", ACE_VERSION);
|
TC_LOG_INFO("server.worldserver", "Using ACE version: %s", ACE_VERSION);
|
||||||
|
|
||||||
///- and run the 'Master'
|
///- and run the 'Master'
|
||||||
|
|
@ -151,9 +157,6 @@ extern int main(int argc, char** argv)
|
||||||
// 1 - shutdown at error
|
// 1 - shutdown at error
|
||||||
// 2 - restart command used, this code can be used by restarter for restart Trinityd
|
// 2 - restart command used, this code can be used by restarter for restart Trinityd
|
||||||
|
|
||||||
|
|
||||||
std::this_thread::sleep_for(std::chrono::seconds(20));
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -32,6 +32,13 @@
|
||||||
#include "Database/DatabaseEnv.h"
|
#include "Database/DatabaseEnv.h"
|
||||||
#include "Database/DatabaseWorkerPool.h"
|
#include "Database/DatabaseWorkerPool.h"
|
||||||
|
|
||||||
|
#include <openssl/crypto.h>
|
||||||
|
#include <openssl/opensslv.h>
|
||||||
|
#if defined(OPENSSL_VERSION_MAJOR) && (OPENSSL_VERSION_MAJOR >= 3)
|
||||||
|
#include <openssl/provider.h>
|
||||||
|
#endif
|
||||||
|
#include <boost/dll/runtime_symbol_info.hpp>
|
||||||
|
|
||||||
#include "CliRunnable.h"
|
#include "CliRunnable.h"
|
||||||
#include "Log.h"
|
#include "Log.h"
|
||||||
#include "Master.h"
|
#include "Master.h"
|
||||||
|
|
@ -161,7 +168,7 @@ void RunAuthserverIfNeed()
|
||||||
/// Main function
|
/// Main function
|
||||||
int Master::Run()
|
int Master::Run()
|
||||||
{
|
{
|
||||||
OpenSSLCrypto::threadsSetup();
|
OpenSSLCrypto::threadsSetup(boost::dll::program_location().remove_filename());
|
||||||
BigNumber seed1;
|
BigNumber seed1;
|
||||||
seed1.SetRand(16 * 8);
|
seed1.SetRand(16 * 8);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue