CMakeLists.txt 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. #
  2. # libwebsockets - small server side websockets and web server implementation
  3. #
  4. # Copyright (C) 2010 - 2020 Andy Green <[email protected]>
  5. #
  6. # Permission is hereby granted, free of charge, to any person obtaining a copy
  7. # of this software and associated documentation files (the "Software"), to
  8. # deal in the Software without restriction, including without limitation the
  9. # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  10. # sell copies of the Software, and to permit persons to whom the Software is
  11. # furnished to do so, subject to the following conditions:
  12. #
  13. # The above copyright notice and this permission notice shall be included in
  14. # all copies or substantial portions of the Software.
  15. #
  16. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  19. # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  20. # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  21. # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  22. # IN THE SOFTWARE.
  23. #
  24. #
  25. # This converts everything about the tls support into
  26. #
  27. # - entries on SOURCES (modifications set back in PARENT_SCOPE)
  28. # - entries on LIB_LIST (modifications set back in PARENT_SCOPE)
  29. # - include_directories()
  30. # - Api build-time discovery results set in PARENT_SCOPE
  31. #
  32. # Everything else is handled privately here.
  33. include_directories(.)
  34. # Allow the user to use the old CyaSSL options/library in stead of wolfSSL
  35. if (LWS_WITH_CYASSL AND LWS_WITH_WOLFSSL)
  36. message(FATAL_ERROR "LWS_WITH_CYASSL and LWS_WITH_WOLFSSL are mutually exclusive!")
  37. endif()
  38. if (LWS_WITH_CYASSL)
  39. # Copy CyaSSL options to the wolfSSL options
  40. set(LWS_WITH_WOLFSSL ${LWS_WITH_CYASSL} CACHE BOOL "Use wolfSSL/CyaSSL instead of OpenSSL" FORCE PARENT_SCOPE)
  41. set(LWS_WOLFSSL_LIBRARIES ${LWS_CYASSL_LIBRARIES} CACHE PATH "Path to wolfSSL/CyaSSL libraries" FORCE PARENT_SCOPE)
  42. set(LWS_WOLFSSL_INCLUDE_DIRS ${LWS_CYASSL_INCLUDE_DIRS} CACHE PATH "Path to wolfSSL/CyaSSL header files" FORCE PARENT_SCOPE)
  43. endif()
  44. set(LWS_OPENSSL_LIBRARIES CACHE PATH "Path to the OpenSSL library" )
  45. set(LWS_OPENSSL_INCLUDE_DIRS CACHE PATH "Path to the OpenSSL include directory" )
  46. set(LWS_WOLFSSL_LIBRARIES CACHE PATH "Path to the wolfSSL library" )
  47. set(LWS_WOLFSSL_INCLUDE_DIRS CACHE PATH "Path to the wolfSSL include directory" )
  48. if (LWS_WITH_BORINGSSL)
  49. # boringssl deprecated EVP_PKEY
  50. set (LWS_WITH_GENHASH OFF PARENT_SCOPE)
  51. endif()
  52. if (LWS_WITH_SSL AND NOT LWS_WITH_WOLFSSL AND NOT LWS_WITH_MBEDTLS)
  53. if ("${LWS_OPENSSL_LIBRARIES}" STREQUAL "" OR "${LWS_OPENSSL_INCLUDE_DIRS}" STREQUAL "")
  54. else()
  55. if (NOT LWS_PLAT_FREERTOS)
  56. set(OPENSSL_LIBRARIES ${LWS_OPENSSL_LIBRARIES})
  57. endif()
  58. set(OPENSSL_INCLUDE_DIRS ${LWS_OPENSSL_INCLUDE_DIRS})
  59. set(OPENSSL_FOUND 1)
  60. endif()
  61. endif()
  62. if (LWS_WITH_SSL AND LWS_WITH_WOLFSSL)
  63. if ("${LWS_WOLFSSL_LIBRARIES}" STREQUAL "" OR "${LWS_WOLFSSL_INCLUDE_DIRS}" STREQUAL "")
  64. if (NOT WOLFSSL_FOUND)
  65. if (LWS_WITH_CYASSL)
  66. message(FATAL_ERROR "You must set LWS_CYASSL_LIBRARIES and LWS_CYASSL_INCLUDE_DIRS when LWS_WITH_CYASSL is turned on.")
  67. else()
  68. message(FATAL_ERROR "You must set LWS_WOLFSSL_LIBRARIES and LWS_WOLFSSL_INCLUDE_DIRS when LWS_WITH_WOLFSSL is turned on.")
  69. endif()
  70. endif()
  71. else()
  72. set(WOLFSSL_LIBRARIES ${LWS_WOLFSSL_LIBRARIES})
  73. set(WOLFSSL_INCLUDE_DIRS ${LWS_WOLFSSL_INCLUDE_DIRS})
  74. set(WOLFSSL_FOUND 1)
  75. endif()
  76. set(USE_WOLFSSL 1)
  77. set(USE_WOLFSSL 1 PARENT_SCOPE)
  78. set(LWS_WITH_TLS 1 PARENT_SCOPE)
  79. if (LWS_WITH_CYASSL)
  80. set(USE_OLD_CYASSL 1)
  81. endif()
  82. endif()
  83. if (LWS_SSL_CLIENT_USE_OS_CA_CERTS)
  84. set(LWS_SSL_CLIENT_USE_OS_CA_CERTS 1 PARENT_SCOPE)
  85. endif()
  86. if (LWS_WITH_MBEDTLS)
  87. add_subdirectory(mbedtls)
  88. include_directories(${_CMAKE_INC_LIST})
  89. endif()
  90. # The base dir where the test-apps look for the SSL certs.
  91. set(LWS_OPENSSL_CLIENT_CERTS ../share CACHE PATH "Server SSL certificate directory")
  92. if (WIN32)
  93. set(LWS_OPENSSL_CLIENT_CERTS . CACHE PATH "Client SSL certificate directory" PARENT_SCOPE)
  94. else()
  95. set(LWS_OPENSSL_CLIENT_CERTS /etc/pki/tls/certs/ CACHE PATH "Client SSL certificate directory")
  96. endif()
  97. if (LWS_WITH_SSL)
  98. list(APPEND SOURCES
  99. tls/tls.c)
  100. if (LWS_WITH_NETWORK)
  101. list(APPEND SOURCES
  102. tls/tls-network.c)
  103. endif()
  104. if (LWS_WITH_MBEDTLS)
  105. list(APPEND SOURCES
  106. tls/mbedtls/mbedtls-tls.c
  107. tls/mbedtls/mbedtls-x509.c)
  108. if (LWS_WITH_NETWORK)
  109. list(APPEND SOURCES
  110. tls/mbedtls/mbedtls-ssl.c)
  111. endif()
  112. if (LWS_WITH_GENCRYPTO)
  113. list(APPEND SOURCES
  114. tls/mbedtls/lws-genhash.c
  115. tls/mbedtls/lws-genrsa.c
  116. tls/mbedtls/lws-genaes.c
  117. tls/lws-genec-common.c
  118. tls/mbedtls/lws-genec.c
  119. tls/mbedtls/lws-gencrypto.c)
  120. endif()
  121. else()
  122. list(APPEND SOURCES
  123. tls/openssl/openssl-tls.c
  124. tls/openssl/openssl-x509.c)
  125. if (LWS_WITH_NETWORK)
  126. list(APPEND SOURCES
  127. tls/openssl/openssl-ssl.c)
  128. endif()
  129. if (LWS_WITH_GENCRYPTO)
  130. list(APPEND SOURCES
  131. tls/openssl/lws-genhash.c
  132. tls/openssl/lws-genrsa.c
  133. tls/openssl/lws-genaes.c
  134. tls/lws-genec-common.c
  135. tls/openssl/lws-genec.c
  136. tls/openssl/lws-gencrypto.c)
  137. endif()
  138. endif()
  139. if (NOT LWS_WITHOUT_SERVER)
  140. list(APPEND SOURCES
  141. tls/tls-server.c)
  142. if (LWS_WITH_MBEDTLS)
  143. list(APPEND SOURCES
  144. tls/mbedtls/mbedtls-server.c)
  145. else()
  146. list(APPEND SOURCES
  147. tls/openssl/openssl-server.c)
  148. endif()
  149. endif()
  150. if (NOT LWS_WITHOUT_CLIENT)
  151. list(APPEND SOURCES
  152. tls/tls-client.c)
  153. if (LWS_WITH_MBEDTLS)
  154. list(APPEND SOURCES
  155. tls/mbedtls/mbedtls-client.c)
  156. else()
  157. list(APPEND SOURCES
  158. tls/openssl/openssl-client.c)
  159. endif()
  160. endif()
  161. endif()
  162. set(SOURCES ${SOURCES} PARENT_SCOPE)
  163. #
  164. # OpenSSL
  165. #
  166. if (LWS_WITH_SSL)
  167. message("Compiling with SSL support")
  168. set(chose_ssl 0)
  169. if (LWS_WITH_WOLFSSL)
  170. # Use wolfSSL as OpenSSL replacement.
  171. # TODO: Add a find_package command for this also.
  172. message("wolfSSL include dir: ${WOLFSSL_INCLUDE_DIRS}")
  173. message("wolfSSL libraries: ${WOLFSSL_LIBRARIES}")
  174. # Additional to the root directory we need to include
  175. # the wolfssl/ subdirectory which contains the OpenSSL
  176. # compatibility layer headers.
  177. if (LWS_WITH_CYASSL)
  178. foreach(inc ${WOLFSSL_INCLUDE_DIRS})
  179. set(OPENSSL_INCLUDE_DIRS ${OPENSSL_INCLUDE_DIRS} ${inc} ${inc}/cyassl)
  180. include_directories("${inc}" "${inc}/cyassl")
  181. endforeach()
  182. else()
  183. foreach(inc ${WOLFSSL_INCLUDE_DIRS})
  184. set(OPENSSL_INCLUDE_DIRS ${OPENSSL_INCLUDE_DIRS} ${inc} ${inc}/wolfssl)
  185. include_directories("${inc}" "${inc}/wolfssl")
  186. endforeach()
  187. endif()
  188. set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} ${OPENSSL_INCLUDE_DIRS})
  189. set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} PARENT_SCOPE)
  190. set(OPENSSL_INCLUDE_DIRS ${OPENSSL_INCLUDE_DIRS} PARENT_SCOPE)
  191. set(VARIA wolfSSL_)
  192. list(INSERT LIB_LIST 0 "${WOLFSSL_LIBRARIES}")
  193. message("LIB_LIST ${LIB_LIST}")
  194. set(chose_ssl 1)
  195. endif()
  196. if (LWS_WITH_MBEDTLS AND DEFINED MBEDTLS_INCLUDE_DIRS AND DEFINED MBEDTLS_LIBRARIES)
  197. message("MBEDTLS include dir: ${MBEDTLS_INCLUDE_DIRS}")
  198. message("MBEDTLS libraries: ${MBEDTLS_LIBRARIES}")
  199. foreach(inc ${MBEDTLS_INCLUDE_DIRS})
  200. include_directories("${inc}" "${inc}/mbedtls")
  201. endforeach()
  202. list(INSERT LIB_LIST 0 "${MBEDTLS_LIBRARIES}")
  203. endif()
  204. if (LWS_WITH_MBEDTLS)
  205. set(chose_ssl 1)
  206. endif()
  207. if (NOT chose_ssl)
  208. if (NOT OPENSSL_FOUND AND NOT LWS_WITH_BORINGSSL)
  209. # TODO: Add support for STATIC also.
  210. if (NOT LWS_PLAT_FREERTOS)
  211. find_package(PkgConfig QUIET)
  212. pkg_check_modules(PC_OPENSSL openssl QUIET)
  213. find_package(OpenSSL REQUIRED)
  214. list(APPEND OPENSSL_LIBRARIES ${PC_OPENSSL_LIBRARIES})
  215. set(OPENSSL_LIBRARIES ${OPENSSL_LIBRARIES} PARENT_SCOPE)
  216. endif()
  217. set(OPENSSL_INCLUDE_DIRS "${OPENSSL_INCLUDE_DIR}")
  218. endif()
  219. message("OpenSSL include dir: ${OPENSSL_INCLUDE_DIRS}")
  220. if (NOT LWS_PLAT_FREERTOS)
  221. message("OpenSSL libraries: ${OPENSSL_LIBRARIES}")
  222. endif()
  223. if (OPENSSL_INCLUDE_DIRS)
  224. include_directories("${OPENSSL_INCLUDE_DIRS}")
  225. if (NOT LWS_PLAT_FREERTOS)
  226. list(INSERT LIB_LIST 0 ${OPENSSL_LIBRARIES})
  227. endif()
  228. if (NOT LWS_WITH_MBEDTLS)
  229. # older (0.98) Openssl lacks this
  230. set(CMAKE_REQUIRED_INCLUDES ${CMAKE_REQUIRED_INCLUDES} ${OPENSSL_INCLUDE_DIRS} PARENT_SCOPE)
  231. check_include_file(openssl/ecdh.h LWS_HAVE_OPENSSL_ECDH_H)
  232. if (LWS_SSL_SERVER_WITH_ECDH_CERT AND NOT LWS_HAVE_OPENSSL_ECDH_H)
  233. message(FATAL_ERROR "Missing openssl/ecdh.h, so cannot use LWS_SSL_SERVER_WITH_ECDH_CERT")
  234. endif()
  235. else()
  236. unset(LWS_HAVE_OPENSSL_ECDH_H PARENT_SCOPE)
  237. endif(NOT LWS_WITH_MBEDTLS)
  238. endif()
  239. endif()
  240. endif(LWS_WITH_SSL)
  241. if (DEFINED OPENSSL_INCLUDE_DIRS)
  242. set(CMAKE_REQUIRED_INCLUDES ${OPENSSL_INCLUDE_DIRS})
  243. endif()
  244. if (DEFINED LIB_LIST)
  245. set(CMAKE_REQUIRED_LIBRARIES ${LIB_LIST})
  246. endif()
  247. if (UNIX AND NOT (${CMAKE_SYSTEM_NAME} MATCHES "QNX"))
  248. set(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} dl)
  249. endif()
  250. if ((CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX) AND NOT (${CMAKE_SYSTEM_NAME} MATCHES "QNX"))
  251. set(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} pthread)
  252. endif()
  253. if (NOT VARIA)
  254. set(VARIA "")
  255. endif()
  256. CHECK_FUNCTION_EXISTS(${VARIA}SSL_CTX_set1_param LWS_HAVE_SSL_CTX_set1_param PARENT_SCOPE)
  257. CHECK_FUNCTION_EXISTS(${VARIA}SSL_set_info_callback LWS_HAVE_SSL_SET_INFO_CALLBACK PARENT_SCOPE)
  258. CHECK_FUNCTION_EXISTS(${VARIA}X509_VERIFY_PARAM_set1_host LWS_HAVE_X509_VERIFY_PARAM_set1_host PARENT_SCOPE)
  259. CHECK_FUNCTION_EXISTS(${VARIA}RSA_set0_key LWS_HAVE_RSA_SET0_KEY PARENT_SCOPE)
  260. CHECK_FUNCTION_EXISTS(${VARIA}X509_get_key_usage LWS_HAVE_X509_get_key_usage PARENT_SCOPE)
  261. CHECK_FUNCTION_EXISTS(${VARIA}EVP_PKEY_new_raw_private_key LWS_HAVE_SSL_CTX_EVP_PKEY_new_raw_private_key PARENT_SCOPE)
  262. CHECK_FUNCTION_EXISTS(${VARIA}SSL_CTX_get0_certificate LWS_HAVE_SSL_CTX_get0_certificate PARENT_SCOPE)
  263. CHECK_FUNCTION_EXISTS(${VARIA}SSL_get0_alpn_selected LWS_HAVE_SSL_get0_alpn_selected PARENT_SCOPE)
  264. CHECK_FUNCTION_EXISTS(${VARIA}SSL_set_alpn_protos LWS_HAVE_SSL_set_alpn_protos PARENT_SCOPE)
  265. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_128_cfb8 LWS_HAVE_EVP_aes_128_cfb8 PARENT_SCOPE)
  266. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_128_cfb128 LWS_HAVE_EVP_aes_128_cfb128 PARENT_SCOPE)
  267. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_192_cfb8 LWS_HAVE_EVP_aes_192_cfb8 PARENT_SCOPE)
  268. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_192_cfb128 LWS_HAVE_EVP_aes_192_cfb128 PARENT_SCOPE)
  269. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_256_cfb8 LWS_HAVE_EVP_aes_256_cfb8 PARENT_SCOPE)
  270. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_256_cfb128 LWS_HAVE_EVP_aes_256_cfb128 PARENT_SCOPE)
  271. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_128_xts LWS_HAVE_EVP_aes_128_xts PARENT_SCOPE)
  272. CHECK_FUNCTION_EXISTS(${VARIA}RSA_verify_pss_mgf1 LWS_HAVE_RSA_verify_pss_mgf1 PARENT_SCOPE)
  273. CHECK_FUNCTION_EXISTS(${VARIA}HMAC_CTX_new LWS_HAVE_HMAC_CTX_new PARENT_SCOPE)
  274. CHECK_FUNCTION_EXISTS(${VARIA}SSL_CTX_set_ciphersuites LWS_HAVE_SSL_CTX_set_ciphersuites PARENT_SCOPE)
  275. CHECK_FUNCTION_EXISTS(${VARIA}EVP_PKEY_new_raw_private_key LWS_HAVE_EVP_PKEY_new_raw_private_key PARENT_SCOPE)
  276. if (LWS_WITH_SSL AND NOT LWS_WITH_MBEDTLS)
  277. # we don't want to confuse what's in or out of the wrapper with
  278. # what's in an openssl also installed on the build host
  279. CHECK_C_SOURCE_COMPILES("#include <openssl/ssl.h>\nint main(void) { STACK_OF(X509) *c = NULL; SSL_CTX *ctx = NULL; return (int)SSL_CTX_get_extra_chain_certs_only(ctx, &c); }\n" LWS_HAVE_SSL_EXTRA_CHAIN_CERTS)
  280. CHECK_C_SOURCE_COMPILES("#include <openssl/ssl.h>\nint main(void) { EVP_MD_CTX *md_ctx = NULL; EVP_MD_CTX_free(md_ctx); return 0; }\n" LWS_HAVE_EVP_MD_CTX_free)
  281. set(LWS_HAVE_SSL_EXTRA_CHAIN_CERTS ${LWS_HAVE_SSL_EXTRA_CHAIN_CERTS} PARENT_SCOPE)
  282. set(LWS_HAVE_EVP_MD_CTX_free ${LWS_HAVE_EVP_MD_CTX_free} PARENT_SCOPE)
  283. CHECK_FUNCTION_EXISTS(${VARIA}ECDSA_SIG_set0 LWS_HAVE_ECDSA_SIG_set0 PARENT_SCOPE)
  284. CHECK_FUNCTION_EXISTS(${VARIA}BN_bn2binpad LWS_HAVE_BN_bn2binpad PARENT_SCOPE)
  285. CHECK_FUNCTION_EXISTS(${VARIA}EVP_aes_128_wrap LWS_HAVE_EVP_aes_128_wrap PARENT_SCOPE)
  286. CHECK_FUNCTION_EXISTS(${VARIA}EC_POINT_get_affine_coordinates LWS_HAVE_EC_POINT_get_affine_coordinates PARENT_SCOPE)
  287. CHECK_FUNCTION_EXISTS(${VARIA}SSL_CTX_load_verify_file LWS_HAVE_SSL_CTX_load_verify_file PARENT_SCOPE)
  288. CHECK_FUNCTION_EXISTS(${VARIA}SSL_CTX_load_verify_dir LWS_HAVE_SSL_CTX_load_verify_dir PARENT_SCOPE)
  289. endif()
  290. if (LWS_WITH_MBEDTLS)
  291. set(LWS_HAVE_TLS_CLIENT_METHOD 1 PARENT_SCOPE)
  292. if (NOT LWS_PLAT_FREERTOS)
  293. # not supported in esp-idf openssl wrapper yet, but is in our version
  294. set(LWS_HAVE_X509_VERIFY_PARAM_set1_host 1 PARENT_SCOPE)
  295. endif()
  296. CHECK_FUNCTION_EXISTS(mbedtls_ssl_conf_alpn_protocols LWS_HAVE_mbedtls_ssl_conf_alpn_protocols PARENT_SCOPE)
  297. CHECK_FUNCTION_EXISTS(mbedtls_ssl_get_alpn_protocol LWS_HAVE_mbedtls_ssl_get_alpn_protocol PARENT_SCOPE)
  298. CHECK_FUNCTION_EXISTS(mbedtls_ssl_conf_sni LWS_HAVE_mbedtls_ssl_conf_sni PARENT_SCOPE)
  299. CHECK_FUNCTION_EXISTS(mbedtls_ssl_set_hs_ca_chain LWS_HAVE_mbedtls_ssl_set_hs_ca_chain PARENT_SCOPE)
  300. CHECK_FUNCTION_EXISTS(mbedtls_ssl_set_hs_own_cert LWS_HAVE_mbedtls_ssl_set_hs_own_cert PARENT_SCOPE)
  301. CHECK_FUNCTION_EXISTS(mbedtls_ssl_set_hs_authmode LWS_HAVE_mbedtls_ssl_set_hs_authmode PARENT_SCOPE)
  302. CHECK_FUNCTION_EXISTS(mbedtls_net_init LWS_HAVE_mbedtls_net_init PARENT_SCOPE)
  303. CHECK_FUNCTION_EXISTS(mbedtls_md_setup LWS_HAVE_mbedtls_md_setup PARENT_SCOPE) # not on xenial 2.2
  304. CHECK_FUNCTION_EXISTS(mbedtls_rsa_complete LWS_HAVE_mbedtls_rsa_complete PARENT_SCOPE) # not on xenial 2.2
  305. CHECK_FUNCTION_EXISTS(mbedtls_internal_aes_encrypt LWS_HAVE_mbedtls_internal_aes_encrypt PARENT_SCOPE) # not on xenial 2.2
  306. else()
  307. CHECK_FUNCTION_EXISTS(${VARIA}TLS_client_method LWS_HAVE_TLS_CLIENT_METHOD PARENT_SCOPE)
  308. CHECK_FUNCTION_EXISTS(${VARIA}TLSv1_2_client_method LWS_HAVE_TLSV1_2_CLIENT_METHOD PARENT_SCOPE)
  309. endif()
  310. # Generate self-signed SSL certs for the test-server.
  311. if (LWS_WITH_SSL AND NOT LWS_WITH_WOLFSSL)
  312. message("Searching for OpenSSL executable and dlls")
  313. find_package(OpenSSL)
  314. if (DEFINED OPENSSL_EXECUTABLE)
  315. message("OpenSSL executable: ${OPENSSL_EXECUTABLE}")
  316. if (OPENSSL_EXECUTABLE MATCHES "^$")
  317. set(OPENSSL_EXECUTABLE openssl)
  318. endif()
  319. endif()
  320. if (NOT DEFINED OPENSSL_EXECUTABLE)
  321. set(OPENSSL_EXECUTABLE openssl)
  322. endif()
  323. endif()
  324. set(GENCERTS 0)
  325. if (LWS_WITH_SSL AND OPENSSL_EXECUTABLE AND NOT LWS_WITHOUT_TEST_SERVER AND NOT LWS_WITHOUT_SERVER AND NOT LWS_WITHOUT_TESTAPPS)
  326. set(GENCERTS 1)
  327. endif()
  328. if (LWS_PLAT_FREERTOS AND LWS_WITH_SSL)
  329. set(GENCERTS 1)
  330. endif()
  331. message(" GENCERTS = ${GENCERTS}")
  332. if (GENCERTS)
  333. message("Generating SSL Certificates for the test-server...")
  334. set(TEST_SERVER_SSL_KEY "${PROJECT_BINARY_DIR}/libwebsockets-test-server.key.pem")
  335. set(TEST_SERVER_SSL_CERT "${PROJECT_BINARY_DIR}/libwebsockets-test-server.pem")
  336. if (WIN32)
  337. if (MINGW)
  338. message("cmd = \"${OPENSSL_EXECUTABLE}\" req -new -newkey rsa:2048 -days 10000 -nodes -x509 -subj \"/C=GB/ST=Erewhon/L=All around/O=libwebsockets-test/CN=localhost\" -keyout \"${TEST_SERVER_SSL_KEY}\" -out \"${TEST_SERVER_SSL_CERT}\"")
  339. execute_process(
  340. COMMAND "${OPENSSL_EXECUTABLE}" req -new -newkey rsa:2048 -days 10000 -nodes -x509 -subj "/C=GB/ST=Erewhon/L=All around/O=libwebsockets-test/CN=localhost" -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}"
  341. RESULT_VARIABLE OPENSSL_RETURN_CODE)
  342. else()
  343. file(WRITE "${PROJECT_BINARY_DIR}/openssl_input.txt"
  344. "GB\n"
  345. "Erewhon\n"
  346. "All around\n"
  347. "libwebsockets-test\n"
  348. "localhost\n"
  349. "[email protected]\n\n"
  350. )
  351. # The "type" command is a bit picky with paths.
  352. file(TO_NATIVE_PATH "${PROJECT_BINARY_DIR}/openssl_input.txt" OPENSSL_INPUT_WIN_PATH)
  353. message("OPENSSL_INPUT_WIN_PATH = ${OPENSSL_INPUT_WIN_PATH}")
  354. message("cmd = \"${OPENSSL_EXECUTABLE}\" req -new -newkey rsa:2048 -days 10000 -nodes -x509 -keyout \"${TEST_SERVER_SSL_KEY}\" -out \"${TEST_SERVER_SSL_CERT}\"")
  355. execute_process(
  356. COMMAND cmd /c type "${OPENSSL_INPUT_WIN_PATH}"
  357. COMMAND "${OPENSSL_EXECUTABLE}" req -new -newkey rsa:2048 -days 10000 -nodes -x509 -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}"
  358. RESULT_VARIABLE OPENSSL_RETURN_CODE
  359. OUTPUT_QUIET ERROR_QUIET)
  360. message("\n")
  361. endif()
  362. if (OPENSSL_RETURN_CODE)
  363. message(WARNING "!!! Failed to generate SSL certificate for Test Server using cmd.exe !!!:\nOpenSSL return code = ${OPENSSL_RETURN_CODE}")
  364. else()
  365. message("SUCCSESFULLY generated SSL certificate")
  366. endif()
  367. else()
  368. # Unix.
  369. execute_process(
  370. COMMAND printf "GB\\nErewhon\\nAll around\\nlibwebsockets-test\\n\\nlocalhost\\[email protected]\\n"
  371. COMMAND "${OPENSSL_EXECUTABLE}"
  372. req -new -newkey rsa:2048 -days 10000 -nodes -x509 -keyout "${TEST_SERVER_SSL_KEY}" -out "${TEST_SERVER_SSL_CERT}"
  373. RESULT_VARIABLE OPENSSL_RETURN_CODE
  374. # OUTPUT_QUIET ERROR_QUIET
  375. )
  376. if (OPENSSL_RETURN_CODE)
  377. message(WARNING "!!! Failed to generate SSL certificate for Test Server!!!:\nOpenSSL return code = ${OPENSSL_RETURN_CODE}")
  378. else()
  379. message("SUCCESSFULLY generated SSL certificate")
  380. endif()
  381. endif()
  382. list(APPEND TEST_SERVER_DATA
  383. "${TEST_SERVER_SSL_KEY}"
  384. "${TEST_SERVER_SSL_CERT}")
  385. endif()
  386. #
  387. # Copy OpenSSL dlls to the output directory on Windows.
  388. # (Otherwise we'll get an error when trying to run)
  389. #
  390. if (MSVC AND LWS_WITH_SSL AND NOT LWS_WITH_WOLFSSL)
  391. if(OPENSSL_BIN_FOUND)
  392. message("OpenSSL dlls found:")
  393. message(" Libeay: ${LIBEAY_BIN}")
  394. message(" SSLeay: ${SSLEAY_BIN}")
  395. foreach(TARGET_BIN ${TEST_APP_LIST})
  396. add_custom_command(TARGET ${TARGET_BIN}
  397. POST_BUILD
  398. COMMAND "${CMAKE_COMMAND}" -E copy "${LIBEAY_BIN}" "$<TARGET_FILE_DIR:${TARGET_BIN}>" VERBATIM)
  399. add_custom_command(TARGET ${TARGET_BIN}
  400. POST_BUILD
  401. COMMAND "${CMAKE_COMMAND}" -E copy "${SSLEAY_BIN}" "$<TARGET_FILE_DIR:${TARGET_BIN}>" VERBATIM)
  402. #
  403. # Win32: if we are using libuv, also need to copy it in the output dir
  404. #
  405. if (MSVC AND LWS_WITH_LIBUV)
  406. STRING(REPLACE ".lib" ".dll" LIBUV_BIN ${LIBUV_LIBRARIES})
  407. add_custom_command(TARGET ${TARGET_BIN}
  408. POST_BUILD
  409. COMMAND "${CMAKE_COMMAND}" -E copy "${LIBUV_BIN}" "$<TARGET_FILE_DIR:${TARGET_BIN}>" VERBATIM)
  410. endif()
  411. endforeach()
  412. endif()
  413. endif()
  414. if (LWS_WITH_TLS AND (LWS_WITH_JOSE OR LWS_WITH_GENCRYPTO))
  415. list(APPEND SOURCES
  416. tls/lws-gencrypto-common.c)
  417. endif()
  418. #
  419. # Keep explicit parent scope exports at end
  420. #
  421. exports_to_parent_scope()
  422. set(LWS_HAVE_MBEDTLS_NET_SOCKETS ${LWS_HAVE_MBEDTLS_NET_SOCKETS} PARENT_SCOPE)
  423. set(TEST_SERVER_SSL_KEY "${TEST_SERVER_SSL_KEY}" PARENT_SCOPE)
  424. set(TEST_SERVER_SSL_CERT "${TEST_SERVER_SSL_CERT}" PARENT_SCOPE)
  425. set(TEST_SERVER_DATA ${TEST_SERVER_DATA} PARENT_SCOPE)