From 3b1f7f73e2b473ecaca4916b6c6b4f54f7526e53 Mon Sep 17 00:00:00 2001 From: SChernykh <15806605+SChernykh@users.noreply.github.com> Date: Tue, 6 Aug 2024 14:35:46 +0200 Subject: [PATCH] Allow TLS support without GRPC --- CMakeLists.txt | 9 ++++++++- cmake/ssl/CMakeLists.txt | 31 +++++++++++++++++++++++++++++++ src/stratum_server.cpp | 4 ++-- 3 files changed, 41 insertions(+), 3 deletions(-) create mode 100644 cmake/ssl/CMakeLists.txt diff --git a/CMakeLists.txt b/CMakeLists.txt index 410fec96..cd0ca386 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -38,6 +38,9 @@ if (WITH_GRPC) include(cmake/grpc.cmake) add_subdirectory(external/src/Tari) +elseif (WITH_TLS) + add_subdirectory(cmake/ssl) + include_directories(external/src/grpc/third_party/boringssl-with-bazel/src/include) endif() if (WITH_RANDOMX) @@ -167,7 +170,7 @@ if (WITH_GRPC) set(SOURCES ${SOURCES} src/merge_mining_client_tari.cpp) endif() -if (WITH_GRPC AND WITH_TLS) +if (WITH_TLS) add_definitions(-DWITH_TLS) set(HEADERS ${HEADERS} src/tls.h) @@ -412,6 +415,8 @@ if (STATIC_BINARY OR STATIC_LIBS) if (WITH_GRPC) set(STATIC_LIBS ${STATIC_LIBS} Tari_gRPC grpc grpc++ libprotobuf) + elseif(WITH_TLS) + set(LIBS ${LIBS} ssl crypto) endif() target_link_libraries(${CMAKE_PROJECT_NAME} @@ -423,6 +428,8 @@ if (STATIC_BINARY OR STATIC_LIBS) else() if (WITH_GRPC) set(LIBS ${LIBS} Tari_gRPC grpc grpc++ libprotobuf) + elseif(WITH_TLS) + set(LIBS ${LIBS} ssl crypto) endif() target_link_libraries(${CMAKE_PROJECT_NAME} debug ${ZMQ_LIBRARY_DEBUG} debug ${UV_LIBRARY_DEBUG} debug ${CURL_LIBRARY_DEBUG} optimized ${ZMQ_LIBRARY} optimized ${UV_LIBRARY} optimized ${CURL_LIBRARY} ${LIBS}) diff --git a/cmake/ssl/CMakeLists.txt b/cmake/ssl/CMakeLists.txt new file mode 100644 index 00000000..40992a89 --- /dev/null +++ b/cmake/ssl/CMakeLists.txt @@ -0,0 +1,31 @@ +cmake_minimum_required(VERSION 3.12) + +project(P2Pool_SSL LANGUAGES C CXX) + +if (CMAKE_CXX_COMPILER_ID MATCHES MSVC) + set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /W0 /Zi /Od /Ob0 /MP /MTd") + set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /W0 /Zi /Od /Ob0 /MP /MTd") + set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /W0 /O1 /Ob2 /Oi /Os /Oy /MP /MT") + set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /W0 /O1 /Ob2 /Oi /Os /Oy /MP /MT") + set(CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /W0 /Ob1 /Ot /Zi /MP /MT") + set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /W0 /Ob1 /Ot /Zi /MP /MT") +else() + set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Os -w") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Os -w") +endif() + +if(CMAKE_GENERATOR MATCHES "Visual Studio") + if(CMAKE_VERSION VERSION_LESS 3.13) + message(WARNING "Disabling SSL assembly support because CMake version ${CMAKE_VERSION} is too old (less than 3.13)") + set(OPENSSL_NO_ASM ON) + else() + include(CheckLanguage) + check_language(ASM_NASM) + if(NOT CMAKE_ASM_NASM_COMPILER) + message(WARNING "Disabling SSL assembly support because NASM could not be found") + set(OPENSSL_NO_ASM ON) + endif() + endif() +endif() + +add_subdirectory(../../external/src/grpc/third_party/boringssl-with-bazel BoringSSL) diff --git a/src/stratum_server.cpp b/src/stratum_server.cpp index 5518b3cd..5e515e59 100644 --- a/src/stratum_server.cpp +++ b/src/stratum_server.cpp @@ -541,7 +541,7 @@ void StratumServer::show_workers() size_t n = 0; LOGINFO(0, log::pad_right("IP:port", addr_len + 8) - << "TLS " + << "TLS " << log::pad_right("uptime", 20) << log::pad_right("difficulty", 20) << log::pad_right("hashrate", 15) @@ -566,7 +566,7 @@ void StratumServer::show_workers() #endif LOGINFO(0, log::pad_right(static_cast(c->m_addrString), addr_len + 8) - << (is_tls ? "no " : "yes ") + << (is_tls ? "no " : "yes ") << log::pad_right(log::Duration(cur_time - c->m_connectedTime), 20) << log::pad_right(diff, 20) << log::pad_right(log::Hashrate(c->m_autoDiff.lo / AUTO_DIFF_TARGET_TIME, m_autoDiff && (c->m_autoDiff != 0)), 15)