39 :
public std::enable_shared_from_this< ws_t >
127 final_flag, opcode, asio_ns::buffer_size( payload.
buf() ) };
132 bufs.emplace_back( std::move( payload ) );
142 const bool is_close_frame =
143 opcode_t::connection_close_frame == opcode;
161 throw exception_t{
"ws doesn't support sendfile" };
166 throw exception_t{
"websocket is not available" };
213 typename WS_Message_Handler >
223 WS_Message_Handler ws_message_handler )
228 if( !upgrade_response_header_fields.
has_field( http_field::sec_websocket_accept ) )
233 "{} field is mandatory for upgrade response" ),
237 if( !upgrade_response_header_fields.
has_field( http_field::upgrade ) )
239 upgrade_response_header_fields.
set_field( http_field::upgrade,
"websocket" );
246 throw exception_t{
"no connection for upgrade: already moved" };
248 auto & con =
dynamic_cast< connection_t &
>( *conn_ptr );
252 auto upgrade_internals = con.move_upgrade_internals();
254 std::make_shared< ws_connection_t >(
256 std::move( upgrade_internals.m_settings ),
257 std::move( upgrade_internals.m_socket ),
258 std::move( upgrade_internals.m_lifetime_monitor ),
259 std::move( ws_message_handler ) );
264 upgrade_response_header.swap_fields( upgrade_response_header_fields );
267 const auto content_length_flag =
270 upgrade_response_bufs.emplace_back(
272 upgrade_response_header,
273 content_length_flag ) );
276 ws_connection->write_data(
281 std::make_shared< ws_t >( std::move( ws_connection ), req.
remote_endpoint() );
294 typename WS_Message_Handler >
299 std::string sec_websocket_accept_field_value,
300 WS_Message_Handler ws_message_handler )
303 upgrade_response_header_fields.
set_field(
304 http_field::sec_websocket_accept,
305 std::move( sec_websocket_accept_field_value ) );
308 upgrade< Traits, WS_Message_Handler >(
311 std::move( upgrade_response_header_fields ),
312 std::move( ws_message_handler ) );
317 typename WS_Message_Handler >
322 std::string sec_websocket_accept_field_value,
323 std::string sec_websocket_protocol_field_value,
324 WS_Message_Handler ws_message_handler )
327 upgrade_response_header_fields.
set_field(
328 http_field::sec_websocket_accept,
329 std::move( sec_websocket_accept_field_value ) );
331 upgrade_response_header_fields.
set_field(
332 http_field::sec_websocket_protocol,
333 std::move( sec_websocket_protocol_field_value ) );
336 upgrade< Traits, WS_Message_Handler >(
339 std::move( upgrade_response_header_fields ),
340 std::move( ws_message_handler ) );
345 typename WS_Message_Handler >
350 WS_Message_Handler ws_message_handler )
352 const char * websocket_accept_field_suffix =
"258EAFA5-E914-47DA-95CA-C5AB0DC85B11";
355 websocket_accept_field_suffix;
363 upgrade_response_header_fields.
set_field(
364 http_field::sec_websocket_accept,
365 std::move( sec_websocket_accept_field_value ) );
368 upgrade< Traits, WS_Message_Handler >(
371 std::move( upgrade_response_header_fields ),
372 std::move( ws_message_handler ) );
Exception class for all exceptions thrown by RESTinio.
const http_request_header_t & header() const noexcept
Get request header.
const endpoint_t & remote_endpoint() const noexcept
Get the remote endpoint of the underlying connection.
Context for handling http connections.
Websocket message class with more detailed protocol information.
Context for handling websocket connections.
final_frame_flag_t final_flag() const noexcept
Get final flag.
opcode_t opcode() const noexcept
void send_message(message_t msg, write_status_cb_t wscb=write_status_cb_t{})
ws_t(impl::ws_connection_handle_t ws_connection_handle, endpoint_t remote_endpoint)
ws_t & operator=(const ws_t &)=delete
ws_t(const ws_t &)=delete
impl::ws_connection_handle_t m_ws_connection_handle
connection_id_t connection_id() const
Get connection id.
void shutdown()
Shutdown websocket: wait for all outgoing data to be sent, and close connection.
void kill()
Kill websocket: close underlying tcp socket. Do not tolerate unsent outgoing data.
friend void activate(ws_t &ws)
Activate websocket: start receiving messages.
const endpoint_t & remote_endpoint() const noexcept
Get the remote endpoint of the underlying connection.
const endpoint_t m_remote_endpoint
Remote endpoint for this ws-connection.
void send_message(final_frame_flag_t final_flag, opcode_t opcode, writable_item_t payload, write_status_cb_t wscb=write_status_cb_t{})
Send_websocket message.
Class for storing the buffers used for streaming body (request/response).
asio_ns::const_buffer buf() const
Create a buf reference object used by ASIO.
writable_item_type_t write_type() const noexcept
Get a type of a stored buffer object.
Group of writable items transported to the context of underlying connection as one solid piece.
void after_write_notificator(write_status_cb_t notificator) noexcept
Set after write notificator.
#define RESTINIO_FMT_FORMAT_STRING(s)
connection_handle_t & access_req_connection(generic_request_t< Extra_Data > &) noexcept
std::string create_header_string(const http_response_header_t &h, content_length_field_presence_t content_length_field_presence=content_length_field_presence_t::add_content_length, std::size_t buffer_size=0)
Creates a string for http response header.
std::string encode(string_view_t str)
std::string to_string(const digest_t &what)
digest_t make_digest(const std::uint8_t *what, std::size_t length)
raw_data_t write_message_details(const message_details_t &message)
Serialize websocket message details into bytes buffer.
std::shared_ptr< ws_connection_base_t > ws_connection_handle_t
Alias for WebSocket connection handle.
activation_t
Flags for websocket activation policies.
@ immediate
Activate immediately after upgrade operation.
@ delayed
User will initiate activation later.
final_frame_flag_t
WS frame (message) "final"/"not final" flag.
std::shared_ptr< ws_t > ws_handle_t
Alias for ws_t handle.
std::vector< writable_item_t > writable_items_container_t
@ trivial_write_operation
Item is a buffer and must be written trivially.
const char * field_to_string(http_field_t f) noexcept
Helper sunction to get method string name.
http_status_line_t status_switching_protocols()
std::function< void(const asio_ns::error_code &ec) > write_status_cb_t
An alias for a callback to be invoked after the write operation of a particular group of "buffers".
asio_ns::ip::tcp::endpoint endpoint_t
An alias for endpoint type from Asio.
std::uint64_t connection_id_t
Type for ID of connection.