mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-04-23 17:36:37 +02:00
send BOB message reply
This commit is contained in:
parent
cb293b93d2
commit
30a1f9d447
2 changed files with 76 additions and 3 deletions
61
BOB.cpp
61
BOB.cpp
|
@ -16,6 +16,12 @@ namespace client
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::Terminate ()
|
||||||
|
{
|
||||||
|
m_Socket.close ();
|
||||||
|
m_IsOpen = false;
|
||||||
|
}
|
||||||
|
|
||||||
void BOBCommandSession::Receive ()
|
void BOBCommandSession::Receive ()
|
||||||
{
|
{
|
||||||
m_Socket.async_read_some (boost::asio::buffer(m_ReceiveBuffer + m_ReceiveBufferOffset, BOB_COMMAND_BUFFER_SIZE - m_ReceiveBufferOffset),
|
m_Socket.async_read_some (boost::asio::buffer(m_ReceiveBuffer + m_ReceiveBufferOffset, BOB_COMMAND_BUFFER_SIZE - m_ReceiveBufferOffset),
|
||||||
|
@ -26,7 +32,10 @@ namespace client
|
||||||
void BOBCommandSession::HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
void BOBCommandSession::HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
||||||
{
|
{
|
||||||
if (ecode)
|
if (ecode)
|
||||||
|
{
|
||||||
LogPrint ("BOB command channel read error: ", ecode.message ());
|
LogPrint ("BOB command channel read error: ", ecode.message ());
|
||||||
|
Terminate ();
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
size_t size = m_ReceiveBufferOffset + bytes_transferred;
|
size_t size = m_ReceiveBufferOffset + bytes_transferred;
|
||||||
|
@ -55,18 +64,67 @@ namespace client
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
LogPrint (eLogError, "Malformed input of the BOB command channel");
|
LogPrint (eLogError, "Malformed input of the BOB command channel");
|
||||||
return;
|
Terminate ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::Send (size_t len)
|
||||||
|
{
|
||||||
|
boost::asio::async_write (m_Socket, boost::asio::buffer (m_SendBuffer, len),
|
||||||
|
boost::asio::transfer_all (),
|
||||||
|
std::bind(&BOBCommandSession::HandleSent, shared_from_this (),
|
||||||
|
std::placeholders::_1, std::placeholders::_2));
|
||||||
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::HandleSent (const boost::system::error_code& ecode, std::size_t bytes_transferred)
|
||||||
|
{
|
||||||
|
if (ecode)
|
||||||
|
{
|
||||||
|
LogPrint ("BOB command channel send error: ", ecode.message ());
|
||||||
|
Terminate ();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
if (m_IsOpen)
|
if (m_IsOpen)
|
||||||
Receive ();
|
Receive ();
|
||||||
|
else
|
||||||
|
Terminate ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::SendReplyOK (const char * msg)
|
||||||
|
{
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
size_t len = sprintf_s (m_SendBuffer, BOB_COMMAND_BUFFER_SIZE, BOB_REPLY_OK, msg);
|
||||||
|
#else
|
||||||
|
size_t len = snprintf (m_SendBuffer, BOB_COMMAND_BUFFER_SIZE, BOB_REPLY_OK, msg);
|
||||||
|
#endif
|
||||||
|
Send (len);
|
||||||
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::SendReplyError (const char * msg)
|
||||||
|
{
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
size_t len = sprintf_s (m_SendBuffer, BOB_COMMAND_BUFFER_SIZE, BOB_REPLY_ERROR, msg);
|
||||||
|
#else
|
||||||
|
size_t len = snprintf (m_SendBuffer, BOB_COMMAND_BUFFER_SIZE, BOB_REPLY_ERROR, msg);
|
||||||
|
#endif
|
||||||
|
Send (len);
|
||||||
|
}
|
||||||
|
|
||||||
void BOBCommandSession::ZapCommandHandler (const char * operand, size_t len)
|
void BOBCommandSession::ZapCommandHandler (const char * operand, size_t len)
|
||||||
{
|
{
|
||||||
LogPrint (eLogDebug, "BOB: zap");
|
LogPrint (eLogDebug, "BOB: zap");
|
||||||
|
Terminate ();
|
||||||
|
}
|
||||||
|
|
||||||
|
void BOBCommandSession::QuitCommandHandler (const char * operand, size_t len)
|
||||||
|
{
|
||||||
|
LogPrint (eLogDebug, "BOB: quit");
|
||||||
m_IsOpen = false;
|
m_IsOpen = false;
|
||||||
|
SendReplyOK ("Bye!");
|
||||||
}
|
}
|
||||||
|
|
||||||
BOBCommandChannel::BOBCommandChannel (int port):
|
BOBCommandChannel::BOBCommandChannel (int port):
|
||||||
|
@ -74,6 +132,7 @@ namespace client
|
||||||
m_Acceptor (m_Service, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), port))
|
m_Acceptor (m_Service, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), port))
|
||||||
{
|
{
|
||||||
m_CommandHandlers[BOB_COMMAND_ZAP] = &BOBCommandSession::ZapCommandHandler;
|
m_CommandHandlers[BOB_COMMAND_ZAP] = &BOBCommandSession::ZapCommandHandler;
|
||||||
|
m_CommandHandlers[BOB_COMMAND_QUIT] = &BOBCommandSession::QuitCommandHandler;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOBCommandChannel::~BOBCommandChannel ()
|
BOBCommandChannel::~BOBCommandChannel ()
|
||||||
|
|
18
BOB.h
18
BOB.h
|
@ -15,6 +15,10 @@ namespace client
|
||||||
{
|
{
|
||||||
const size_t BOB_COMMAND_BUFFER_SIZE = 1024;
|
const size_t BOB_COMMAND_BUFFER_SIZE = 1024;
|
||||||
const char BOB_COMMAND_ZAP[] = "zap";
|
const char BOB_COMMAND_ZAP[] = "zap";
|
||||||
|
const char BOB_COMMAND_QUIT[] = "quit";
|
||||||
|
|
||||||
|
const char BOB_REPLY_OK[] = "OK %s\n";
|
||||||
|
const char BOB_REPLY_ERROR[] = "ERROR %s\n";
|
||||||
|
|
||||||
class BOBCommandChannel;
|
class BOBCommandChannel;
|
||||||
class BOBCommandSession: public std::enable_shared_from_this<BOBCommandSession>
|
class BOBCommandSession: public std::enable_shared_from_this<BOBCommandSession>
|
||||||
|
@ -23,19 +27,29 @@ namespace client
|
||||||
|
|
||||||
BOBCommandSession (BOBCommandChannel& owner);
|
BOBCommandSession (BOBCommandChannel& owner);
|
||||||
~BOBCommandSession ();
|
~BOBCommandSession ();
|
||||||
|
void Terminate ();
|
||||||
|
|
||||||
boost::asio::ip::tcp::socket& GetSocket () { return m_Socket; };
|
boost::asio::ip::tcp::socket& GetSocket () { return m_Socket; };
|
||||||
void Receive ();
|
void Receive ();
|
||||||
void HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
|
||||||
|
|
||||||
// command handlers
|
// command handlers
|
||||||
void ZapCommandHandler (const char * operand, size_t len);
|
void ZapCommandHandler (const char * operand, size_t len);
|
||||||
|
void QuitCommandHandler (const char * operand, size_t len);
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
void HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
|
|
||||||
|
void Send (size_t len);
|
||||||
|
void HandleSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
|
void SendReplyOK (const char * msg);
|
||||||
|
void SendReplyError (const char * msg);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
BOBCommandChannel& m_Owner;
|
BOBCommandChannel& m_Owner;
|
||||||
boost::asio::ip::tcp::socket m_Socket;
|
boost::asio::ip::tcp::socket m_Socket;
|
||||||
char m_ReceiveBuffer[BOB_COMMAND_BUFFER_SIZE + 1];
|
char m_ReceiveBuffer[BOB_COMMAND_BUFFER_SIZE + 1], m_SendBuffer[BOB_COMMAND_BUFFER_SIZE + 1];
|
||||||
size_t m_ReceiveBufferOffset;
|
size_t m_ReceiveBufferOffset;
|
||||||
bool m_IsOpen;
|
bool m_IsOpen;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Reference in a new issue