Bitcoin
Public Types | Public Member Functions | Public Attributes | Static Private Member Functions | Private Attributes | List of all members
TorControlConnection Class Reference

Public Types

typedef std::function< void(TorControlConnection &)> ConnectionCB
 
typedef std::function< void(TorControlConnection &, const TorControlReply &)> ReplyHandlerCB
 

Public Member Functions

 TorControlConnection (struct event_base *base)
 
 ~TorControlConnection ()
 
bool Connect (const std::string &target, const ConnectionCB &connected, const ConnectionCB &disconnected)
 
void Disconnect ()
 
bool Command (const std::string &cmd, const ReplyHandlerCB &reply_handler)
 

Public Attributes

boost::signals2::signal< void(TorControlConnection &, const TorControlReply &)> async_handler
 

Static Private Member Functions

static void readcb (struct bufferevent *bev, void *ctx)
 
static void eventcb (struct bufferevent *bev, short what, void *ctx)
 

Private Attributes

std::function< void(TorControlConnection &)> connected
 
std::function< void(TorControlConnection &)> disconnected
 
struct event_base * base
 
struct bufferevent * b_conn
 
TorControlReply message
 
std::deque< ReplyHandlerCBreply_handlers
 

Detailed Description

Low-level handling for Tor control connection. Speaks the SMTP-like protocol as defined in torspec/control-spec.txt

Member Typedef Documentation

◆ ConnectionCB

◆ ReplyHandlerCB

Constructor & Destructor Documentation

◆ TorControlConnection()

TorControlConnection::TorControlConnection ( struct event_base *  base)
explicit

Create a new TorControlConnection.

◆ ~TorControlConnection()

TorControlConnection::~TorControlConnection ( )

Member Function Documentation

◆ Command()

bool TorControlConnection::Command ( const std::string &  cmd,
const ReplyHandlerCB reply_handler 
)

Send a command, register a handler for the reply. A trailing CRLF is automatically added. Return true on success.

◆ Connect()

bool TorControlConnection::Connect ( const std::string &  target,
const ConnectionCB connected,
const ConnectionCB disconnected 
)

Connect to a Tor control port. target is address of the form host:port. connected is the handler that is called when connection is successfully established. disconnected is a handler that is called when the connection is broken. Return true on success.

◆ Disconnect()

void TorControlConnection::Disconnect ( )

Disconnect from Tor control port.

◆ eventcb()

void TorControlConnection::eventcb ( struct bufferevent *  bev,
short  what,
void *  ctx 
)
staticprivate

◆ readcb()

void TorControlConnection::readcb ( struct bufferevent *  bev,
void *  ctx 
)
staticprivate

Libevent handlers: internal

Member Data Documentation

◆ async_handler

boost::signals2::signal<void(TorControlConnection &,const TorControlReply &)> TorControlConnection::async_handler

Response handlers for async replies

◆ b_conn

struct bufferevent* TorControlConnection::b_conn
private

Connection to control socket

◆ base

struct event_base* TorControlConnection::base
private

Libevent event base

◆ connected

std::function<void(TorControlConnection&)> TorControlConnection::connected
private

Callback when ready for use

◆ disconnected

std::function<void(TorControlConnection&)> TorControlConnection::disconnected
private

Callback when connection lost

◆ message

TorControlReply TorControlConnection::message
private

Message being received

◆ reply_handlers

std::deque<ReplyHandlerCB> TorControlConnection::reply_handlers
private

Response handlers


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