11#ifndef NETWORK_USE_EXPERIMENTAL
12#define NETWORK_USE_EXPERIMENTAL
28 std::string_view session_id,
29 std::shared_ptr<session::quic_session> session)
30 : session_id_(session_id)
31 , session_(std::move(session))
48 if (!is_connected_.load(std::memory_order_acquire))
52 "Session is not connected",
53 "quic_session_wrapper::send"
61 "Session not initialized",
62 "quic_session_wrapper::send"
67 return session_->send(std::move(data));
72 is_connected_.store(
false, std::memory_order_release);
75 (void)session_->close(0);
84 : server_id_(server_id)
85 , server_(std::make_shared<core::messaging_quic_server>(server_id))
104 cert_path_ = std::string(path);
109 key_path_ = std::string(path);
114 alpn_protocols_ = protocols;
119 ca_cert_path_ = std::string(path);
124 require_client_cert_ = require;
129 max_idle_timeout_ms_ = timeout_ms;
134 max_connections_ = max;
143 return is_running_.load(std::memory_order_acquire);
150 server_->wait_for_stop();
164 "Server not initialized",
165 "quic_server_adapter::start"
171 config.cert_file = cert_path_;
172 config.key_file = key_path_;
173 config.ca_cert_file = ca_cert_path_;
174 config.require_client_cert = require_client_cert_;
175 config.alpn_protocols = alpn_protocols_;
176 config.max_idle_timeout_ms = max_idle_timeout_ms_;
177 config.max_connections = max_connections_;
179 auto result = server_->start_server(port,
config);
182 is_running_.store(
true, std::memory_order_release);
193 "Server not initialized",
194 "quic_server_adapter::stop"
198 auto result = server_->stop_server();
199 is_running_.store(
false, std::memory_order_release);
203 std::lock_guard<std::mutex> lock(sessions_mutex_);
218 std::lock_guard<std::mutex> lock(callbacks_mutex_);
219 connection_callback_ = std::move(callback);
224 std::lock_guard<std::mutex> lock(callbacks_mutex_);
225 disconnection_callback_ = std::move(callback);
230 std::lock_guard<std::mutex> lock(callbacks_mutex_);
231 receive_callback_ = std::move(callback);
236 std::lock_guard<std::mutex> lock(callbacks_mutex_);
237 error_callback_ = std::move(callback);
253 [
this](std::shared_ptr<session::quic_session> quic_sess) {
259 auto wrapper = get_or_create_wrapper(quic_sess);
263 std::lock_guard<std::mutex> lock(callbacks_mutex_);
264 callback_copy = connection_callback_;
269 callback_copy(wrapper);
272 server_->set_connection_callback(conn_cb);
275 server_->set_disconnection_callback(
276 [
this](std::string_view session_id) {
279 std::lock_guard<std::mutex> lock(callbacks_mutex_);
280 callback_copy = disconnection_callback_;
285 callback_copy(session_id);
288 remove_wrapper(std::string(session_id));
292 server_->set_receive_callback(
293 [
this](std::string_view session_id,
const std::vector<uint8_t>& data) {
296 std::lock_guard<std::mutex> lock(callbacks_mutex_);
297 callback_copy = receive_callback_;
302 callback_copy(session_id, data);
307 server_->set_error_callback(
308 [
this](std::string_view session_id, std::error_code ec) {
311 std::lock_guard<std::mutex> lock(callbacks_mutex_);
312 callback_copy = error_callback_;
317 callback_copy(session_id, ec);
323 -> std::shared_ptr<quic_session_wrapper>
325 const std::string session_id = session->session_id();
327 std::lock_guard<std::mutex> lock(sessions_mutex_);
329 auto it = sessions_.find(session_id);
330 if (it != sessions_.end())
335 auto wrapper = std::make_shared<quic_session_wrapper>(session_id, session);
336 sessions_[session_id] = wrapper;
342 std::lock_guard<std::mutex> lock(sessions_mutex_);
343 sessions_.erase(session_id);
std::function< void(std::shared_ptr< session::quic_session >)> connection_callback_t
Callback type for new connections.
std::function< void(std::string_view)> disconnection_callback_t
Callback type for disconnections (session_id)
std::function< void(std::string_view, const std::vector< uint8_t > &)> receive_callback_t
Callback type for received data (session_id, data)
std::function< void(std::string_view, std::error_code)> error_callback_t
Callback type for errors (session_id, error)
std::function< void(std::shared_ptr< i_session >)> connection_callback_t
Callback type for new connections.
auto start(uint16_t port) -> VoidResult override
Starts the server and begins listening for connections.
std::unordered_map< std::string, std::shared_ptr< quic_session_wrapper > > sessions_
auto set_error_callback(error_callback_t callback) -> void override
Sets the callback for errors.
std::mutex sessions_mutex_
~quic_server_adapter() override
Destructor ensures proper cleanup.
auto set_ca_cert_path(std::string_view path) -> void
Sets CA certificate path for client verification.
auto set_key_path(std::string_view path) -> void
Sets the server private key path.
std::shared_ptr< core::messaging_quic_server > server_
auto is_running() const -> bool override
Checks if the component is currently running.
auto wait_for_stop() -> void override
Blocks until the component has stopped.
auto remove_wrapper(const std::string &session_id) -> void
Removes a session wrapper.
auto set_disconnection_callback(disconnection_callback_t callback) -> void override
Sets the callback for disconnections.
auto set_require_client_cert(bool require) -> void
Sets whether to require client certificate (mutual TLS)
auto stop() -> VoidResult override
Stops the server and closes all connections.
auto setup_internal_callbacks() -> void
Sets up internal callbacks to bridge QUIC callbacks to i_protocol_server callbacks.
auto set_connection_callback(connection_callback_t callback) -> void override
Sets the callback for new connections.
auto set_alpn_protocols(const std::vector< std::string > &protocols) -> void
Sets the ALPN protocols for negotiation.
auto get_or_create_wrapper(std::shared_ptr< session::quic_session > session) -> std::shared_ptr< quic_session_wrapper >
Creates or retrieves a session wrapper for a QUIC session.
quic_server_adapter(std::string_view server_id)
Constructs an adapter with a unique server ID.
auto set_max_idle_timeout(uint64_t timeout_ms) -> void
Sets max idle timeout in milliseconds.
auto set_receive_callback(receive_callback_t callback) -> void override
Sets the callback for received data.
auto set_cert_path(std::string_view path) -> void
Sets the server certificate path.
std::atomic< bool > is_running_
auto connection_count() const -> size_t override
Gets the number of active client connections.
auto set_max_connections(size_t max) -> void
Sets maximum number of concurrent connections.
auto is_connected() const -> bool override
Checks if the session is currently connected.
auto close() -> void override
Closes the session.
quic_session_wrapper(std::string_view session_id, std::shared_ptr< session::quic_session > session)
Constructs a session wrapper.
std::atomic< bool > is_connected_
auto send(std::vector< uint8_t > &&data) -> VoidResult override
Sends data to the client.
std::shared_ptr< session::quic_session > session_
auto id() const -> std::string_view override
Gets the unique identifier for this session.
constexpr int invalid_argument
constexpr int internal_error
VoidResult error_void(int code, const std::string &message, const std::string &source="network_system", const std::string &details="")
QUIC-specific session with stream multiplexing.
Network-specific error and result type definitions.
Configuration options for QUIC server.