Wire Sysio Wire Sysion 1.0.0
Loading...
Searching...
No Matches
websocketpp::transport::debug::connection< config > Class Template Reference

#include <connection.hpp>

Inheritance diagram for websocketpp::transport::debug::connection< config >:
Collaboration diagram for websocketpp::transport::debug::connection< config >:

Public Types

typedef connection< configtype
 Type of this connection transport component.
 
typedef lib::shared_ptr< typeptr
 Type of a shared pointer to this connection transport component.
 
typedef config::concurrency_type concurrency_type
 transport concurrency policy
 
typedef config::alog_type alog_type
 Type of this transport's access logging policy.
 
typedef config::elog_type elog_type
 Type of this transport's error logging policy.
 
typedef concurrency_type::scoped_lock_type scoped_lock_type
 
typedef concurrency_type::mutex_type mutex_type
 
typedef lib::shared_ptr< timertimer_ptr
 

Public Member Functions

 connection (bool is_server, alog_type &alog, elog_type &elog)
 
ptr get_shared ()
 Get a shared pointer to this component.
 
void set_secure (bool)
 Set whether or not this connection is secure.
 
bool is_secure () const
 Tests whether or not the underlying transport is secure.
 
void set_uri (uri_ptr)
 Set uri hook.
 
void set_remote_endpoint (std::string)
 Set human readable remote endpoint address.
 
std::string get_remote_endpoint () const
 Get human readable remote endpoint address.
 
connection_hdl get_handle () const
 Get the connection handle.
 
timer_ptr set_timer (long, timer_handler handler)
 Call back a function after a period of time.
 
size_t read_all (char const *buf, size_t len)
 Manual input supply (read all)
 
void expire_timer (lib::error_code const &ec)
 
void fullfil_write ()
 

Protected Member Functions

void init (init_handler handler)
 Initialize the connection transport.
 
void async_read_at_least (size_t num_bytes, char *buf, size_t len, read_handler handler)
 Initiate an async_read for at least num_bytes bytes into buf.
 
void async_write (char const *, size_t, write_handler handler)
 Asyncronous Transport Write.
 
void async_write (std::vector< buffer > const &, write_handler handler)
 Asyncronous Transport Write (scatter-gather)
 
void set_handle (connection_hdl)
 Set Connection Handle.
 
lib::error_code dispatch (dispatch_handler handler)
 Call given handler back within the transport's event system (if present)
 
void async_shutdown (shutdown_handler handler)
 Perform cleanup on socket shutdown_handler.
 
size_t read_some_impl (char const *buf, size_t len)
 
void complete_read (lib::error_code const &ec)
 Signal that a requested read is complete.
 

Detailed Description

template<typename config>
class websocketpp::transport::debug::connection< config >

Definition at line 56 of file connection.hpp.

Member Typedef Documentation

◆ alog_type

template<typename config >
config::alog_type websocketpp::transport::debug::connection< config >::alog_type

Definition at line 66 of file connection.hpp.

◆ concurrency_type

template<typename config >
config::concurrency_type websocketpp::transport::debug::connection< config >::concurrency_type

Definition at line 64 of file connection.hpp.

◆ elog_type

template<typename config >
config::elog_type websocketpp::transport::debug::connection< config >::elog_type

Definition at line 68 of file connection.hpp.

◆ mutex_type

template<typename config >
concurrency_type::mutex_type websocketpp::transport::debug::connection< config >::mutex_type

Definition at line 72 of file connection.hpp.

◆ ptr

template<typename config >
lib::shared_ptr<type> websocketpp::transport::debug::connection< config >::ptr

Definition at line 61 of file connection.hpp.

◆ scoped_lock_type

template<typename config >
concurrency_type::scoped_lock_type websocketpp::transport::debug::connection< config >::scoped_lock_type

Definition at line 71 of file connection.hpp.

◆ timer_ptr

template<typename config >
lib::shared_ptr<timer> websocketpp::transport::debug::connection< config >::timer_ptr

Definition at line 74 of file connection.hpp.

◆ type

Definition at line 59 of file connection.hpp.

Constructor & Destructor Documentation

◆ connection()

template<typename config >
websocketpp::transport::debug::connection< config >::connection ( bool is_server,
alog_type & alog,
elog_type & elog )
inlineexplicit

Definition at line 76 of file connection.hpp.

77 : m_reading(false), m_is_server(is_server), m_alog(alog), m_elog(elog)
78 {
79 m_alog.write(log::alevel::devel,"debug con transport constructor");
80 }
#define elog(FORMAT,...)
Definition logger.hpp:130
static level const devel
Development messages (warning: very chatty)
Definition levels.hpp:141

Member Function Documentation

◆ async_read_at_least()

template<typename config >
void websocketpp::transport::debug::connection< config >::async_read_at_least ( size_t num_bytes,
char * buf,
size_t len,
read_handler handler )
inlineprotected

Initiates an async_read request for at least num_bytes bytes. The input will be read into buf. A maximum of len bytes will be input. When the operation is complete, handler will be called with the status and number of bytes read.

This method may or may not call handler from within the initial call. The application should be prepared to accept either.

The application should never call this method a second time before it has been called back for the first read. If this is done, the second read will be called back immediately with a double_read error.

If num_bytes or len are zero handler will be called back immediately indicating success.

Parameters
num_bytesDon't call handler until at least this many bytes have been read.
bufThe buffer to read bytes into
lenThe size of buf. At maximum, this many bytes will be read.
handlerThe callback to invoke when the operation is complete or ends in an error

Definition at line 246 of file connection.hpp.

248 {
249 std::stringstream s;
250 s << "debug_con async_read_at_least: " << num_bytes;
251 m_alog.write(log::alevel::devel,s.str());
252
253 if (num_bytes > len) {
254 handler(make_error_code(error::invalid_num_bytes),size_t(0));
255 return;
256 }
257
258 if (m_reading == true) {
259 handler(make_error_code(error::double_read),size_t(0));
260 return;
261 }
262
263 if (num_bytes == 0 || len == 0) {
264 handler(lib::error_code(),size_t(0));
265 return;
266 }
267
268 m_buf = buf;
269 m_len = len;
270 m_bytes_needed = num_bytes;
271 m_read_handler = handler;
272 m_cursor = 0;
273 m_reading = true;
274 }
char * s
size_t len
uint8_t buf[2048]

◆ async_shutdown()

template<typename config >
void websocketpp::transport::debug::connection< config >::async_shutdown ( shutdown_handler handler)
inlineprotected
Parameters
hThe shutdown_handler to call back when complete

Definition at line 335 of file connection.hpp.

335 {
336 handler(lib::error_code());
337 }

◆ async_write() [1/2]

template<typename config >
void websocketpp::transport::debug::connection< config >::async_write ( char const * ,
size_t ,
write_handler handler )
inlineprotected

Write len bytes in buf to the output stream. Call handler to report success or failure. handler may or may not be called during async_write, but it must be safe for this to happen.

Will return 0 on success.

Parameters
bufbuffer to read bytes from
lennumber of bytes to write
handlerCallback to invoke with operation status.

Definition at line 288 of file connection.hpp.

288 {
289 m_alog.write(log::alevel::devel,"debug_con async_write");
290 m_write_handler = handler;
291 }

◆ async_write() [2/2]

template<typename config >
void websocketpp::transport::debug::connection< config >::async_write ( std::vector< buffer > const & ,
write_handler handler )
inlineprotected

Write a sequence of buffers to the output stream. Call handler to report success or failure. handler may or may not be called during async_write, but it must be safe for this to happen.

Will return 0 on success.

Parameters
bufsvector of buffers to write
handlerCallback to invoke with operation status.

Definition at line 304 of file connection.hpp.

304 {
305 m_alog.write(log::alevel::devel,"debug_con async_write buffer list");
306 m_write_handler = handler;
307 }

◆ complete_read()

template<typename config >
void websocketpp::transport::debug::connection< config >::complete_read ( lib::error_code const & ec)
inlineprotected

Sets the reading flag to false and returns the handler that should be called back with the result of the read. The cursor position that is sent is whatever the value of m_cursor is.

It MUST NOT be called when m_reading is false. it MUST be called while holding the read lock

It is important to use this method rather than directly setting/calling m_read_handler back because this function makes sure to delete the locally stored handler which contains shared pointers that will otherwise cause circular reference based memory leaks.

Parameters
ecThe error code to forward to the read handler

Definition at line 376 of file connection.hpp.

376 {
377 m_reading = false;
378
379 read_handler handler = m_read_handler;
380 m_read_handler = read_handler();
381
382 handler(ec,m_cursor);
383 }
lib::function< void(lib::error_code const &, size_t)> read_handler
The type and signature of the callback passed to the read method.
Here is the caller graph for this function:

◆ dispatch()

template<typename config >
lib::error_code websocketpp::transport::debug::connection< config >::dispatch ( dispatch_handler handler)
inlineprotected

Invoke a callback within the transport's event system if it has one. If it doesn't, the handler will be invoked immediately before this function returns.

Parameters
handlerThe callback to invoke
Returns
Whether or not the transport was able to register the handler for callback.

Definition at line 326 of file connection.hpp.

326 {
327 handler();
328 return lib::error_code();
329 }

◆ expire_timer()

template<typename config >
void websocketpp::transport::debug::connection< config >::expire_timer ( lib::error_code const & ec)
inline

Definition at line 203 of file connection.hpp.

203 {
204 m_timer_handler(ec);
205 }

◆ fullfil_write()

template<typename config >
void websocketpp::transport::debug::connection< config >::fullfil_write ( )
inline

Definition at line 207 of file connection.hpp.

207 {
208 m_write_handler(lib::error_code());
209 }

◆ get_handle()

template<typename config >
connection_hdl websocketpp::transport::debug::connection< config >::get_handle ( ) const
inline
Returns
The handle for this connection.

Definition at line 154 of file connection.hpp.

154 {
155 return connection_hdl();
156 }
lib::weak_ptr< void > connection_hdl
A handle to uniquely identify a connection.

◆ get_remote_endpoint()

template<typename config >
std::string websocketpp::transport::debug::connection< config >::get_remote_endpoint ( ) const
inline

TODO: docs

This value is used in access and error logs and is available to the end application for including in user facing interfaces and messages.

Returns
A string identifying the address of the remote endpoint

Definition at line 146 of file connection.hpp.

146 {
147 return "unknown (debug transport)";
148 }

◆ get_shared()

template<typename config >
ptr websocketpp::transport::debug::connection< config >::get_shared ( )
inline

Definition at line 83 of file connection.hpp.

83 {
84 return type::shared_from_this();
85 }

◆ init()

template<typename config >
void websocketpp::transport::debug::connection< config >::init ( init_handler handler)
inlineprotected

Initialize the connection's transport component.

Parameters
handlerThe init_handler to call when initialization is done

Definition at line 217 of file connection.hpp.

217 {
218 m_alog.write(log::alevel::devel,"debug connection init");
219 handler(lib::error_code());
220 }

◆ is_secure()

template<typename config >
bool websocketpp::transport::debug::connection< config >::is_secure ( ) const
inline

TODO: docs

Returns
Whether or not the underlying transport is secure

Definition at line 103 of file connection.hpp.

103 {
104 return false;
105 }

◆ read_all()

template<typename config >
size_t websocketpp::transport::debug::connection< config >::read_all ( char const * buf,
size_t len )
inline

Similar to read_some, but continues to read until all bytes in the supplied buffer have been read or the connection runs out of read requests.

This method still may not read all of the bytes in the input buffer. if it doesn't it indicates that the connection was most likely closed or is in an error state where it is no longer accepting new input.

Since
0.3.0
Parameters
bufChar buffer to read into the websocket
lenLength of buf
Returns
The number of characters from buf actually read.

Definition at line 190 of file connection.hpp.

190 {
191 size_t total_read = 0;
192 size_t temp_read = 0;
193
194 do {
195 temp_read = this->read_some_impl(buf+total_read,len-total_read);
196 total_read += temp_read;
197 } while (temp_read != 0 && total_read < len);
198
199 return total_read;
200 }
size_t read_some_impl(char const *buf, size_t len)
Here is the call graph for this function:

◆ read_some_impl()

template<typename config >
size_t websocketpp::transport::debug::connection< config >::read_some_impl ( char const * buf,
size_t len )
inlineprotected

Definition at line 339 of file connection.hpp.

339 {
340 m_alog.write(log::alevel::devel,"debug_con read_some");
341
342 if (!m_reading) {
343 m_elog.write(log::elevel::devel,"write while not reading");
344 return 0;
345 }
346
347 size_t bytes_to_copy = (std::min)(len,m_len-m_cursor);
348
349 std::copy(buf,buf+bytes_to_copy,m_buf+m_cursor);
350
351 m_cursor += bytes_to_copy;
352
353 if (m_cursor >= m_bytes_needed) {
354 complete_read(lib::error_code());
355 }
356
357 return bytes_to_copy;
358 }
void complete_read(lib::error_code const &ec)
Signal that a requested read is complete.
static level const devel
Low level debugging information (warning: very chatty)
Definition levels.hpp:63
Here is the call graph for this function:
Here is the caller graph for this function:

◆ set_handle()

template<typename config >
void websocketpp::transport::debug::connection< config >::set_handle ( connection_hdl )
inlineprotected
Parameters
hdlThe new handle

Definition at line 313 of file connection.hpp.

313{}

◆ set_remote_endpoint()

template<typename config >
void websocketpp::transport::debug::connection< config >::set_remote_endpoint ( std::string )
inline

Sets the remote endpoint address returned by get_remote_endpoint. This value should be a human readable string that describes the remote endpoint. Typically an IP address or hostname, perhaps with a port. But may be something else depending on the nature of the underlying transport.

If none is set a default is returned.

Since
0.3.0-alpha4
Parameters
valueThe remote endpoint address to set.

Definition at line 135 of file connection.hpp.

135{}

◆ set_secure()

template<typename config >
void websocketpp::transport::debug::connection< config >::set_secure ( bool )
inline

Todo: docs

Since
0.3.0-alpha4
Parameters
valueWhether or not this connection is secure.

Definition at line 95 of file connection.hpp.

95{}

◆ set_timer()

template<typename config >
timer_ptr websocketpp::transport::debug::connection< config >::set_timer ( long ,
timer_handler handler )
inline

Timers are not implemented in this transport. The timer pointer will always be empty. The handler will never be called.

Parameters
durationLength of time to wait in milliseconds
callbackThe function to call back when the timer has expired
Returns
A handle that can be used to cancel the timer if it is no longer needed.

Definition at line 168 of file connection.hpp.

168 {
169 m_alog.write(log::alevel::devel,"debug connection set timer");
170 m_timer_handler = handler;
171 return timer_ptr();
172 }

◆ set_uri()

template<typename config >
void websocketpp::transport::debug::connection< config >::set_uri ( uri_ptr )
inline

Called by the endpoint as a connection is being established to provide the uri being connected to to the transport layer.

Implementation is optional and can be ignored if the transport has no need for this information.

Since
0.6.0
Parameters
uThe uri to set

Definition at line 119 of file connection.hpp.

119{}

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