Network System 0.1.1
High-performance modular networking library for scalable client-server applications
Loading...
Searching...
No Matches
kcenon::network::facade::http_facade Class Reference

Simplified facade for creating HTTP clients and servers. More...

#include <http_facade.h>

Collaboration diagram for kcenon::network::facade::http_facade:
Collaboration graph

Classes

struct  client_config
 Configuration for creating an HTTP client. More...
 
struct  server_config
 Configuration for creating an HTTP server. More...
 

Public Member Functions

auto create_client (const client_config &config) const -> Result< std::shared_ptr< interfaces::i_protocol_client > >
 Creates an HTTP client with the specified configuration.
 
auto create_server (const server_config &config) const -> Result< std::shared_ptr< interfaces::i_protocol_server > >
 Creates an HTTP server with the specified configuration.
 

Static Private Member Functions

static auto generate_client_id () -> std::string
 Generates a unique client ID.
 
static auto generate_server_id () -> std::string
 Generates a unique server ID.
 
static auto validate_client_config (const client_config &config) -> VoidResult
 Validates client configuration.
 
static auto validate_server_config (const server_config &config) -> VoidResult
 Validates server configuration.
 

Detailed Description

Simplified facade for creating HTTP clients and servers.

This facade provides a simple, unified API for creating HTTP/1.1 protocol clients and servers, hiding the complexity of underlying implementation from the user.

Design Goals

  • Simplicity: No template parameters or protocol tags
  • Consistency: Same API pattern across all protocol facades
  • Type Safety: Returns unified protocol interfaces (i_protocol_client/i_protocol_server)
  • Zero Cost: No performance overhead compared to direct instantiation

Thread Safety

All methods are thread-safe and can be called concurrently.

Usage Example

using namespace kcenon::network::facade;
// Create HTTP client
http_facade facade;
auto client = facade.create_client({
.client_id = "my-http-client",
.timeout = std::chrono::seconds(10)
});
// Create HTTP server
auto server = facade.create_server({
.port = 8080,
.server_id = "my-http-server"
});
Simplified facade for creating HTTP clients and servers.
Definition http_facade.h:77
auto create_server(const server_config &config) const -> Result< std::shared_ptr< interfaces::i_protocol_server > >
Creates an HTTP server with the specified configuration.
auto create_client(const client_config &config) const -> Result< std::shared_ptr< interfaces::i_protocol_client > >
Creates an HTTP client with the specified configuration.
See also
interfaces::i_protocol_client
interfaces::i_protocol_server

Definition at line 76 of file http_facade.h.

Member Function Documentation

◆ create_client()

auto kcenon::network::facade::http_facade::create_client ( const client_config & config) const -> Result<std::shared_ptr<interfaces::i_protocol_client>>
nodiscard

Creates an HTTP client with the specified configuration.

Parameters
configClient configuration.
Returns
Result containing shared pointer to i_protocol_client, or error.

Behavior

  • Creates an HTTP client adapter wrapping http_client
  • Client ID is auto-generated if not provided
  • Default timeout is 30 seconds if not specified
  • Returns unified i_protocol_client interface for protocol-agnostic usage

Protocol-Specific Notes

  • start() sets the base URL (host:port) for subsequent requests
  • send() performs an HTTP POST request with binary data
  • Received response body is delivered via receive callback

Error Conditions

  • Returns error if timeout is zero or negative

Definition at line 63 of file http_facade.cpp.

65{
66 auto validation = validate_client_config(config);
67 if (validation.is_err())
68 {
70 validation.error().code, validation.error().message, "http_facade");
71 }
72
73 const auto client_id = config.client_id.empty() ? generate_client_id() : config.client_id;
74
75 // Create adapter with timeout from config
76 auto adapter = std::make_shared<internal::adapters::http_client_adapter>(
77 client_id, config.timeout);
78
79 // Configure path and SSL
80 adapter->set_path(config.path);
81 adapter->set_use_ssl(config.use_ssl);
82
83 return ok(std::shared_ptr<interfaces::i_protocol_client>(adapter));
84}
static auto validate_client_config(const client_config &config) -> VoidResult
Validates client configuration.
static auto generate_client_id() -> std::string
Generates a unique client ID.
tracing_config config
Definition exporters.cpp:29
VoidResult ok()

References config, kcenon::network::error, and kcenon::network::ok().

Referenced by main().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ create_server()

auto kcenon::network::facade::http_facade::create_server ( const server_config & config) const -> Result<std::shared_ptr<interfaces::i_protocol_server>>
nodiscard

Creates an HTTP server with the specified configuration.

Parameters
configServer configuration.
Returns
Result containing shared pointer to i_protocol_server, or error.

Behavior

  • Creates an HTTP server adapter wrapping http_server
  • Server ID is auto-generated if not provided
  • Server must be started manually using start() method
  • Returns unified i_protocol_server interface for protocol-agnostic usage

Protocol-Specific Notes

  • Receive callback delivers HTTP request body as binary data
  • Session send() queues response data for the current request

Error Conditions

  • Returns error if port is 0 or > 65535

Definition at line 86 of file http_facade.cpp.

88{
89 auto validation = validate_server_config(config);
90 if (validation.is_err())
91 {
93 validation.error().code, validation.error().message, "http_facade");
94 }
95
96 const auto server_id = config.server_id.empty() ? generate_server_id() : config.server_id;
97
98 // Create adapter
99 return ok(std::shared_ptr<interfaces::i_protocol_server>(
100 std::make_shared<internal::adapters::http_server_adapter>(server_id)));
101}
static auto validate_server_config(const server_config &config) -> VoidResult
Validates server configuration.
static auto generate_server_id() -> std::string
Generates a unique server ID.

References config, kcenon::network::error, and kcenon::network::ok().

Referenced by main().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ generate_client_id()

auto kcenon::network::facade::http_facade::generate_client_id ( ) -> std::string
staticnodiscardprivate

Generates a unique client ID.

Definition at line 27 of file http_facade.cpp.

28{
29 const auto id = g_client_id_counter.fetch_add(1, std::memory_order_relaxed);
30 std::ostringstream oss;
31 oss << "http_client_" << std::setfill('0') << std::setw(8) << id;
32 return oss.str();
33}

◆ generate_server_id()

auto kcenon::network::facade::http_facade::generate_server_id ( ) -> std::string
staticnodiscardprivate

Generates a unique server ID.

Definition at line 35 of file http_facade.cpp.

36{
37 const auto id = g_server_id_counter.fetch_add(1, std::memory_order_relaxed);
38 std::ostringstream oss;
39 oss << "http_server_" << std::setfill('0') << std::setw(8) << id;
40 return oss.str();
41}

◆ validate_client_config()

auto kcenon::network::facade::http_facade::validate_client_config ( const client_config & config) -> VoidResult
staticprivate

Validates client configuration.

Definition at line 43 of file http_facade.cpp.

44{
45 if (config.timeout.count() <= 0)
46 {
47 return error_void(-1, "http_facade: timeout must be positive", "http_facade");
48 }
49
50 return ok();
51}
VoidResult error_void(int code, const std::string &message, const std::string &source="network_system", const std::string &details="")

References config, kcenon::network::error_void(), and kcenon::network::ok().

Here is the call graph for this function:

◆ validate_server_config()

auto kcenon::network::facade::http_facade::validate_server_config ( const server_config & config) -> VoidResult
staticprivate

Validates server configuration.

Definition at line 53 of file http_facade.cpp.

54{
55 if (config.port == 0 || config.port > 65535)
56 {
57 return error_void(-1, "http_facade: port must be between 1 and 65535", "http_facade");
58 }
59
60 return ok();
61}

References config, kcenon::network::error_void(), and kcenon::network::ok().

Here is the call graph for this function:

The documentation for this class was generated from the following files: