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

#include <connection.hpp>

Inheritance diagram for websocketpp::transport::iostream::connection< config >:
Collaboration diagram for websocketpp::transport::iostream::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 register_ostream (std::ostream *o)
 Register a std::ostream with the transport for writing output.
 
void set_uri (uri_ptr)
 Set uri hook.
 
size_t read_some (char const *buf, size_t len)
 Manual input supply (read some)
 
size_t read_all (char const *buf, size_t len)
 Manual input supply (read all)
 
size_t readsome (char const *buf, size_t len)
 Manual input supply (DEPRECATED)
 
void eof ()
 Signal EOF.
 
void fatal_error ()
 Signal transport error.
 
void set_secure (bool value)
 Set whether or not this connection is secure.
 
bool is_secure () const
 Tests whether or not the underlying transport is secure.
 
void set_remote_endpoint (std::string value)
 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)
 Call back a function after a period of time.
 
void set_write_handler (write_handler h)
 Sets the write handler.
 
void set_vector_write_handler (vector_write_handler h)
 Sets the vectored write handler.
 
void set_shutdown_handler (shutdown_handler h)
 Sets the shutdown handler.
 

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 *buf, size_t len, transport::write_handler handler)
 Asyncronous Transport Write.
 
void async_write (std::vector< buffer > const &bufs, transport::write_handler handler)
 Asyncronous Transport Write (scatter-gather)
 
void set_handle (connection_hdl 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 (transport::shutdown_handler handler)
 Perform cleanup on socket shutdown_handler.
 

Friends

std::istream & operator>> (std::istream &in, type &t)
 Overloaded stream input operator.
 

Detailed Description

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

Definition at line 60 of file connection.hpp.

Member Typedef Documentation

◆ alog_type

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

Definition at line 70 of file connection.hpp.

◆ concurrency_type

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

Definition at line 68 of file connection.hpp.

◆ elog_type

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

Definition at line 72 of file connection.hpp.

◆ mutex_type

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

Definition at line 76 of file connection.hpp.

◆ ptr

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

Definition at line 65 of file connection.hpp.

◆ scoped_lock_type

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

Definition at line 75 of file connection.hpp.

◆ timer_ptr

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

Definition at line 78 of file connection.hpp.

◆ type

Definition at line 63 of file connection.hpp.

Constructor & Destructor Documentation

◆ connection()

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

Definition at line 80 of file connection.hpp.

81 : m_output_stream(NULL)
82 , m_reading(false)
83 , m_is_server(is_server)
84 , m_is_secure(false)
85 , m_alog(alog)
86 , m_elog(elog)
87 , m_remote_endpoint("iostream transport")
88 {
89 m_alog.write(log::alevel::devel,"iostream con transport constructor");
90 }
#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::iostream::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 439 of file connection.hpp.

441 {
442 std::stringstream s;
443 s << "iostream_con async_read_at_least: " << num_bytes;
444 m_alog.write(log::alevel::devel,s.str());
445
446 if (num_bytes > len) {
447 handler(make_error_code(error::invalid_num_bytes),size_t(0));
448 return;
449 }
450
451 if (m_reading == true) {
452 handler(make_error_code(error::double_read),size_t(0));
453 return;
454 }
455
456 if (num_bytes == 0 || len == 0) {
457 handler(lib::error_code(),size_t(0));
458 return;
459 }
460
461 m_buf = buf;
462 m_len = len;
463 m_bytes_needed = num_bytes;
464 m_read_handler = handler;
465 m_cursor = 0;
466 m_reading = true;
467 }
@ invalid_num_bytes
async_read_at_least call requested more bytes than buffer can store
Definition base.hpp:71
@ double_read
async_read called while another async_read was in progress
Definition base.hpp:74
char * s
size_t len
uint8_t buf[2048]
Here is the caller graph for this function:

◆ async_shutdown()

template<typename config >
void websocketpp::transport::iostream::connection< config >::async_shutdown ( transport::shutdown_handler handler)
inlineprotected

If a shutdown handler is set, call it and pass through its return error code. Otherwise assume there is nothing to do and pass through a success code.

Parameters
handlerThe shutdown_handler to call back when complete

Definition at line 593 of file connection.hpp.

593 {
594 lib::error_code ec;
595
596 if (m_shutdown_handler) {
597 ec = m_shutdown_handler(m_connection_hdl);
598 }
599
600 handler(ec);
601 }
Here is the caller graph for this function:

◆ async_write() [1/2]

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

Write len bytes in buf to the output method. 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. Other possible errors (not exhaustive) output_stream_required: No output stream was registered to write to bad_stream: a ostream pass through error

This method will attempt to write to the registered ostream first. If an ostream is not registered it will use the write handler. If neither are registered then an error is passed up to the connection.

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

Definition at line 487 of file connection.hpp.

489 {
490 m_alog.write(log::alevel::devel,"iostream_con async_write");
491 // TODO: lock transport state?
492
493 lib::error_code ec;
494
495 if (m_output_stream) {
496 m_output_stream->write(buf,len);
497
498 if (m_output_stream->bad()) {
499 ec = make_error_code(error::bad_stream);
500 }
501 } else if (m_write_handler) {
502 ec = m_write_handler(m_connection_hdl, buf, len);
503 } else {
504 ec = make_error_code(error::output_stream_required);
505 }
506
507 handler(ec);
508 }
Here is the caller graph for this function:

◆ async_write() [2/2]

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

Write a sequence of buffers to the output method. 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. Other possible errors (not exhaustive) output_stream_required: No output stream was registered to write to bad_stream: a ostream pass through error

This method will attempt to write to the registered ostream first. If an ostream is not registered it will use the write handler. If neither are registered then an error is passed up to the connection.

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

Definition at line 527 of file connection.hpp.

529 {
530 m_alog.write(log::alevel::devel,"iostream_con async_write buffer list");
531 // TODO: lock transport state?
532
533 lib::error_code ec;
534
535 if (m_output_stream) {
536 std::vector<buffer>::const_iterator it;
537 for (it = bufs.begin(); it != bufs.end(); it++) {
538 m_output_stream->write((*it).buf,(*it).len);
539
540 if (m_output_stream->bad()) {
541 ec = make_error_code(error::bad_stream);
542 break;
543 }
544 }
545 } else if (m_vector_write_handler) {
546 ec = m_vector_write_handler(m_connection_hdl, bufs);
547 } else if (m_write_handler) {
548 std::vector<buffer>::const_iterator it;
549 for (it = bufs.begin(); it != bufs.end(); it++) {
550 ec = m_write_handler(m_connection_hdl, (*it).buf, (*it).len);
551 if (ec) {break;}
552 }
553
554 } else {
555 ec = make_error_code(error::output_stream_required);
556 }
557
558 handler(ec);
559 }

◆ dispatch()

template<typename config >
lib::error_code websocketpp::transport::iostream::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 580 of file connection.hpp.

580 {
581 handler();
582 return lib::error_code();
583 }

◆ eof()

template<typename config >
void websocketpp::transport::iostream::connection< config >::eof ( )
inline

Signals to the transport that data stream being read has reached EOF and that no more bytes may be read or written to/from the transport.

Since
0.3.0-alpha4

Definition at line 219 of file connection.hpp.

219 {
220 // this serializes calls to external read.
221 scoped_lock_type lock(m_read_mutex);
222
223 if (m_reading) {
224 complete_read(make_error_code(transport::error::eof));
225 }
226 }
concurrency_type::scoped_lock_type scoped_lock_type
void lock()
Here is the call graph for this function:

◆ fatal_error()

template<typename config >
void websocketpp::transport::iostream::connection< config >::fatal_error ( )
inline

Signals to the transport that a fatal data stream error has occurred and that no more bytes may be read or written to/from the transport.

Since
0.3.0-alpha4

Definition at line 235 of file connection.hpp.

235 {
236 // this serializes calls to external read.
237 scoped_lock_type lock(m_read_mutex);
238
239 if (m_reading) {
240 complete_read(make_error_code(transport::error::pass_through));
241 }
242 }
@ pass_through
underlying transport pass through
Here is the call graph for this function:

◆ get_handle()

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

Definition at line 313 of file connection.hpp.

313 {
314 return m_connection_hdl;
315 }

◆ get_remote_endpoint()

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

The iostream transport has no information about the ultimate remote endpoint. It will return the string "iostream transport". The set_remote_endpoint method may be used by external network code to set a more accurate value.

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 305 of file connection.hpp.

305 {
306 return m_remote_endpoint;
307 }

◆ get_shared()

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

Definition at line 93 of file connection.hpp.

93 {
94 return type::shared_from_this();
95 }
Here is the caller graph for this function:

◆ init()

template<typename config >
void websocketpp::transport::iostream::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 410 of file connection.hpp.

410 {
411 m_alog.write(log::alevel::devel,"iostream connection init");
412 handler(lib::error_code());
413 }

◆ is_secure()

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

iostream transport will return false always because it has no information about the ultimate remote endpoint. This may or may not be accurate depending on the real source of bytes being input. The set_secure method may be used to flag connections that are secured by an external API

Returns
Whether or not the underlying transport is secure

Definition at line 271 of file connection.hpp.

271 {
272 return m_is_secure;
273 }

◆ read_all()

template<typename config >
size_t websocketpp::transport::iostream::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 188 of file connection.hpp.

188 {
189 // this serializes calls to external read.
190 scoped_lock_type lock(m_read_mutex);
191
192 size_t total_read = 0;
193 size_t temp_read = 0;
194
195 do {
196 temp_read = this->read_some_impl(buf+total_read,len-total_read);
197 total_read += temp_read;
198 } while (temp_read != 0 && total_read < len);
199
200 return total_read;
201 }
Here is the call graph for this function:

◆ read_some()

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

Copies bytes from buf into WebSocket++'s input buffers. Bytes will be copied from the supplied buffer to fulfill any pending library reads. It will return the number of bytes successfully processed. If there are no pending reads read_some will return immediately. Not all of the bytes may be able to be read in one call.

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

Definition at line 165 of file connection.hpp.

165 {
166 // this serializes calls to external read.
167 scoped_lock_type lock(m_read_mutex);
168
169 return this->read_some_impl(buf,len);
170 }
Here is the call graph for this function:
Here is the caller graph for this function:

◆ readsome()

template<typename config >
size_t websocketpp::transport::iostream::connection< config >::readsome ( char const * buf,
size_t len )
inline
Deprecated
DEPRECATED in favor of read_some()
See also
read_some()

Definition at line 208 of file connection.hpp.

208 {
209 return this->read_some(buf,len);
210 }
size_t read_some(char const *buf, size_t len)
Manual input supply (read some)
Here is the call graph for this function:

◆ register_ostream()

template<typename config >
void websocketpp::transport::iostream::connection< config >::register_ostream ( std::ostream * o)
inline

Register a std::ostream with the transport. All future writes will be done to this output stream.

Parameters
oA pointer to the ostream to use for output.

Definition at line 104 of file connection.hpp.

104 {
105 // TODO: lock transport state?
106 scoped_lock_type lock(m_read_mutex);
107 m_output_stream = o;
108 }
Here is the call graph for this function:

◆ set_handle()

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

Definition at line 565 of file connection.hpp.

565 {
566 m_connection_hdl = hdl;
567 }

◆ set_remote_endpoint()

template<typename config >
void websocketpp::transport::iostream::connection< config >::set_remote_endpoint ( std::string value)
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 the default is "iostream transport".

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

Definition at line 289 of file connection.hpp.

289 {
290 m_remote_endpoint = value;
291 }
#define value
Definition pkcs11.h:157

◆ set_secure()

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

The iostream transport does not provide any security features. As such it defaults to returning false when is_secure is called. However, the iostream transport may be used to wrap an external socket API that may provide secure transport. This method allows that external API to flag whether or not this connection is secure so that users of the WebSocket++ API will get more accurate information.

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

Definition at line 257 of file connection.hpp.

257 {
258 m_is_secure = value;
259 }

◆ set_shutdown_handler()

template<typename config >
void websocketpp::transport::iostream::connection< config >::set_shutdown_handler ( shutdown_handler h)
inline

The shutdown handler is called when the iostream transport receives a notification from the core library that it is finished with all read and write operations and that the underlying transport can be cleaned up.

If you are using iostream transport with another socket library, this is a good time to close/shutdown the socket for this connection.

The signature of the handler is lib::error_code (connection_hdl). The code returned will be reported and logged by the core library.

Since
0.5.0
Parameters
hThe handler to call on connection shutdown.

Definition at line 400 of file connection.hpp.

400 {
401 m_shutdown_handler = h;
402 }

◆ set_timer()

template<typename config >
timer_ptr websocketpp::transport::iostream::connection< config >::set_timer ( long ,
timer_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 327 of file connection.hpp.

327 {
328 return timer_ptr();
329 }

◆ set_uri()

template<typename config >
void websocketpp::transport::iostream::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.

This transport policy doesn't use the uri so it is ignored.

Since
0.6.0
Parameters
uThe uri to set

Definition at line 121 of file connection.hpp.

121{}

◆ set_vector_write_handler()

template<typename config >
void websocketpp::transport::iostream::connection< config >::set_vector_write_handler ( vector_write_handler h)
inline

The vectored write handler is called when the iostream transport receives multiple chunks of data that need to be written to the appropriate output location. This handler can be used in conjunction with the write_handler in place of registering an ostream for output.

The sequence of buffers represents bytes that should be written consecutively and it is suggested to group the buffers into as few next layer packets as possible. Vector write is used to allow implementations that support it to coalesce writes into a single TCP packet or TLS segment for improved efficiency.

This is an optional handler. If it is not defined then multiple calls will be made to the standard write handler.

The signature of the handler is lib::error_code (connection_hdl, std::vector<websocketpp::transport::buffer> const & bufs). The code returned will be reported and logged by the core library. The websocketpp::transport::buffer type is a struct with two data members. buf (char const *) and len (size_t).

Since
0.6.0
Parameters
hThe handler to call when vectored data is to be written.

Definition at line 380 of file connection.hpp.

380 {
381 m_vector_write_handler = h;
382 }

◆ set_write_handler()

template<typename config >
void websocketpp::transport::iostream::connection< config >::set_write_handler ( write_handler h)
inline

The write handler is called when the iostream transport receives data that needs to be written to the appropriate output location. This handler can be used in place of registering an ostream for output.

The signature of the handler is lib::error_code (connection_hdl, char const *, size_t) The code returned will be reported and logged by the core library.

See also, set_vector_write_handler, for an optional write handler that allows more efficient handling of multiple writes at once.

See also
set_vector_write_handler
Since
0.5.0
Parameters
hThe handler to call when data is to be written.

Definition at line 350 of file connection.hpp.

350 {
351 m_write_handler = h;
352 }

Friends And Related Symbol Documentation

◆ operator>>

template<typename config >
std::istream & operator>> ( std::istream & in,
type & t )
friend

Attempts to read input from the given stream into the transport. Bytes will be extracted from the input stream to fulfill any pending reads. Input in this manner will only read until the current read buffer has been filled. Then it will signal the library to process the input. If the library's input handler adds a new async_read, additional bytes will be read, otherwise the input operation will end.

When this function returns one of the following conditions is true:

  • There is no outstanding read operation
  • There are no more bytes available in the input stream

You can use tellg() on the input stream to determine if all of the input bytes were read or not.

If there is no pending read operation when the input method is called, it will return immediately and tellg() will not have changed.

Definition at line 142 of file connection.hpp.

142 {
143 // this serializes calls to external read.
144 scoped_lock_type lock(t.m_read_mutex);
145
146 t.read(in);
147
148 return in;
149 }

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