Network System 0.1.1
High-performance modular networking library for scalable client-server applications
Loading...
Searching...
No Matches
tcp_server_adapter.h
Go to the documentation of this file.
1// BSD 3-Clause License
2// Copyright (c) 2024, 🍀☀🌕🌥 🌊
3// See the LICENSE file in the project root for full license information.
4
5#pragma once
6
8
9#include <memory>
10#include <mutex>
11#include <string>
12#include <unordered_map>
13
14namespace kcenon::network::core {
15 class messaging_server;
16}
17
20}
21
23
55public:
60 explicit tcp_server_adapter(std::string_view server_id);
61
65 ~tcp_server_adapter() override;
66
67 // Non-copyable, non-movable
72
73 // =========================================================================
74 // i_network_component interface implementation
75 // =========================================================================
76
77 [[nodiscard]] auto is_running() const -> bool override;
78 auto wait_for_stop() -> void override;
79
80 // =========================================================================
81 // i_protocol_server interface implementation
82 // =========================================================================
83
84 [[nodiscard]] auto start(uint16_t port) -> VoidResult override;
85 [[nodiscard]] auto stop() -> VoidResult override;
86 [[nodiscard]] auto connection_count() const -> size_t override;
87
88 auto set_connection_callback(connection_callback_t callback) -> void override;
89 auto set_disconnection_callback(disconnection_callback_t callback) -> void override;
90 auto set_receive_callback(receive_callback_t callback) -> void override;
91 auto set_error_callback(error_callback_t callback) -> void override;
92
93private:
97 auto setup_internal_callbacks() -> void;
98
104 auto track_session(std::shared_ptr<session::messaging_session> session)
105 -> std::shared_ptr<interfaces::i_session>;
106
107 std::string server_id_;
108 std::shared_ptr<core::messaging_server> server_;
109
115
116 // Session tracking for lookup by ID
117 mutable std::mutex sessions_mutex_;
118 std::unordered_map<std::string, std::shared_ptr<session::messaging_session>> sessions_;
119};
120
121} // namespace kcenon::network::internal::adapters
Unified interface for all protocol server implementations.
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.
Adapter that wraps messaging_server to implement i_protocol_server.
auto set_error_callback(error_callback_t callback) -> void override
Sets the callback for errors.
tcp_server_adapter & operator=(tcp_server_adapter &&)=delete
std::unordered_map< std::string, std::shared_ptr< session::messaging_session > > sessions_
~tcp_server_adapter() override
Destructor ensures proper cleanup.
auto set_disconnection_callback(disconnection_callback_t callback) -> void override
Sets the callback for disconnections.
auto set_connection_callback(connection_callback_t callback) -> void override
Sets the callback for new connections.
auto setup_internal_callbacks() -> void
Sets up internal callbacks to bridge legacy callbacks to i_protocol_server callbacks.
auto track_session(std::shared_ptr< session::messaging_session > session) -> std::shared_ptr< interfaces::i_session >
Tracks a session and returns it as i_session.
auto is_running() const -> bool override
Checks if the component is currently running.
tcp_server_adapter & operator=(const tcp_server_adapter &)=delete
auto stop() -> VoidResult override
Stops the server and closes all connections.
auto connection_count() const -> size_t override
Gets the number of active client connections.
tcp_server_adapter(const tcp_server_adapter &)=delete
std::shared_ptr< core::messaging_server > server_
auto start(uint16_t port) -> VoidResult override
Starts the server and begins listening for connections.
auto set_receive_callback(receive_callback_t callback) -> void override
Sets the callback for received data.
tcp_server_adapter(std::string_view server_id)
Constructs an adapter with a unique server ID.
auto wait_for_stop() -> void override
Blocks until the component has stopped.
Protocol-specific server interface extending i_server.
kcenon::network::session::messaging_session messaging_session
kcenon::network::core::messaging_server messaging_server
std::mutex mutex