mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
Enable SSL certificate verification
This commit is contained in:
parent
8ec40f9293
commit
38560ba666
6 changed files with 47 additions and 15 deletions
3
.gitmodules
vendored
3
.gitmodules
vendored
|
@ -44,3 +44,6 @@
|
|||
[submodule "lib/twitch-eventsub-ws"]
|
||||
path = lib/twitch-eventsub-ws
|
||||
url = https://github.com/Chatterino/twitch-eventsub-ws
|
||||
[submodule "lib/certify"]
|
||||
path = lib/certify
|
||||
url = https://github.com/Chatterino/certify
|
||||
|
|
|
@ -194,6 +194,7 @@ if (BUILD_BENCHMARKS)
|
|||
endif ()
|
||||
|
||||
find_package(PajladaSerialize REQUIRED)
|
||||
find_package(BoostCertify REQUIRED)
|
||||
find_package(PajladaSignals REQUIRED)
|
||||
find_package(LRUCache REQUIRED)
|
||||
find_package(MagicEnum REQUIRED)
|
||||
|
|
14
cmake/FindBoostCertify.cmake
Normal file
14
cmake/FindBoostCertify.cmake
Normal file
|
@ -0,0 +1,14 @@
|
|||
include(FindPackageHandleStandardArgs)
|
||||
|
||||
find_path(BoostCertify_INCLUDE_DIR boost/certify/https_verification.hpp HINTS ${CMAKE_SOURCE_DIR}/lib/certify/include)
|
||||
|
||||
find_package_handle_standard_args(BoostCertify DEFAULT_MSG BoostCertify_INCLUDE_DIR)
|
||||
|
||||
if (BoostCertify_FOUND)
|
||||
add_library(BoostCertify INTERFACE IMPORTED)
|
||||
set_target_properties(BoostCertify PROPERTIES
|
||||
INTERFACE_INCLUDE_DIRECTORIES "${BoostCertify_INCLUDE_DIR}"
|
||||
)
|
||||
endif ()
|
||||
|
||||
mark_as_advanced(BoostCertify_INCLUDE_DIR)
|
1
lib/certify
Submodule
1
lib/certify
Submodule
|
@ -0,0 +1 @@
|
|||
Subproject commit a448a3915ddac716ce76e4b8cbf0e7f4153ed1e2
|
|
@ -775,6 +775,7 @@ target_link_libraries(${LIBRARY_PROJECT}
|
|||
LRUCache
|
||||
MagicEnum
|
||||
twitch-eventsub-ws
|
||||
BoostCertify
|
||||
)
|
||||
|
||||
if (CHATTERINO_PLUGINS)
|
||||
|
|
|
@ -16,6 +16,8 @@
|
|||
|
||||
#include <boost/asio/io_context.hpp>
|
||||
#include <boost/asio/ssl.hpp>
|
||||
#include <boost/asio/ssl/verify_mode.hpp>
|
||||
#include <boost/certify/https_verification.hpp>
|
||||
#include <boost/json.hpp>
|
||||
#include <twitch-eventsub-ws/listener.hpp>
|
||||
#include <twitch-eventsub-ws/session.hpp>
|
||||
|
@ -27,6 +29,20 @@ using namespace std::literals::chrono_literals;
|
|||
|
||||
namespace {
|
||||
|
||||
/// Enable LOCAL_EVENTSUB when you want to debug eventsub with a local instance of the Twitch CLI
|
||||
/// twitch event websocket start-server --ssl --port 3012
|
||||
constexpr bool LOCAL_EVENTSUB = false;
|
||||
|
||||
std::tuple<std::string, std::string, std::string> getEventSubHost()
|
||||
{
|
||||
if constexpr (LOCAL_EVENTSUB)
|
||||
{
|
||||
return {"localhost", "3012", "/ws"};
|
||||
}
|
||||
|
||||
return {"eventsub.wss.twitch.tv", "443", "/ws"};
|
||||
}
|
||||
|
||||
// NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)
|
||||
const auto &LOG = chatterinoTwitchEventSub;
|
||||
|
||||
|
@ -250,20 +266,7 @@ void EventSub::start()
|
|||
.toUtf8()
|
||||
.toStdString();
|
||||
|
||||
// for use with twitch CLI: twitch event websocket start-server --ssl --port 3012
|
||||
// std::string host{"localhost"};
|
||||
// std::string port{"3012"};
|
||||
// std::string path{"/ws"};
|
||||
|
||||
// for use with websocat: websocat -s 8080 --pkcs12-der certificate.p12
|
||||
// std::string host{"localhost"};
|
||||
// std::string port{"8080"};
|
||||
// std::string path;
|
||||
|
||||
// for use with real Twitch eventsub
|
||||
std::string host{"eventsub.wss.twitch.tv"};
|
||||
std::string port{"443"};
|
||||
std::string path{"/ws"};
|
||||
auto [host, port, path] = getEventSubHost();
|
||||
|
||||
this->mainThread = std::make_unique<std::thread>([=] {
|
||||
try
|
||||
|
@ -273,7 +276,16 @@ void EventSub::start()
|
|||
boost::asio::ssl::context sslContext{
|
||||
boost::asio::ssl::context::tlsv12_client};
|
||||
|
||||
// TODO: Load certificates into SSL context
|
||||
if constexpr (!LOCAL_EVENTSUB)
|
||||
{
|
||||
sslContext.set_verify_mode(
|
||||
boost::asio::ssl::verify_peer |
|
||||
boost::asio::ssl::verify_fail_if_no_peer_cert);
|
||||
sslContext.set_default_verify_paths();
|
||||
|
||||
boost::certify::enable_native_https_server_verification(
|
||||
sslContext);
|
||||
}
|
||||
|
||||
std::make_shared<eventsub::Session>(ctx, sslContext,
|
||||
std::make_unique<MyListener>())
|
||||
|
|
Loading…
Reference in a new issue