mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-02-02 02:44:15 +00:00
send actual status back
This commit is contained in:
parent
ea7f4447b2
commit
340c73cbdf
49
BOB.cpp
49
BOB.cpp
@ -202,7 +202,7 @@ namespace client
|
|||||||
}
|
}
|
||||||
|
|
||||||
BOBCommandSession::BOBCommandSession (BOBCommandChannel& owner):
|
BOBCommandSession::BOBCommandSession (BOBCommandChannel& owner):
|
||||||
m_Owner (owner), m_Socket (m_Owner.GetService ()), m_Timer (m_Owner.GetService ()),
|
m_Owner (owner), m_Socket (m_Owner.GetService ()),
|
||||||
m_ReceiveBufferOffset (0), m_IsOpen (true), m_IsQuiet (false),
|
m_ReceiveBufferOffset (0), m_IsOpen (true), m_IsQuiet (false),
|
||||||
m_InPort (0), m_OutPort (0), m_CurrentDestination (nullptr)
|
m_InPort (0), m_OutPort (0), m_CurrentDestination (nullptr)
|
||||||
{
|
{
|
||||||
@ -364,30 +364,8 @@ namespace client
|
|||||||
if (m_OutPort && !m_Address.empty ())
|
if (m_OutPort && !m_Address.empty ())
|
||||||
m_CurrentDestination->CreateOutboundTunnel (m_Address, m_OutPort, m_IsQuiet);
|
m_CurrentDestination->CreateOutboundTunnel (m_Address, m_OutPort, m_IsQuiet);
|
||||||
m_CurrentDestination->Start ();
|
m_CurrentDestination->Start ();
|
||||||
if (m_CurrentDestination->GetLocalDestination ()->IsReady ())
|
SendReplyOK ("tunnel starting");
|
||||||
SendReplyOK ("tunnel starting");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Timer.expires_from_now (boost::posix_time::seconds(BOB_SESSION_READINESS_CHECK_INTERVAL));
|
|
||||||
m_Timer.async_wait (std::bind (&BOBCommandSession::HandleSessionReadinessCheckTimer,
|
|
||||||
shared_from_this (), std::placeholders::_1));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void BOBCommandSession::HandleSessionReadinessCheckTimer (const boost::system::error_code& ecode)
|
|
||||||
{
|
|
||||||
if (ecode != boost::asio::error::operation_aborted)
|
|
||||||
{
|
|
||||||
if (m_CurrentDestination->GetLocalDestination ()->IsReady ())
|
|
||||||
SendReplyOK ("tunnel starting");
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Timer.expires_from_now (boost::posix_time::seconds(BOB_SESSION_READINESS_CHECK_INTERVAL));
|
|
||||||
m_Timer.async_wait (std::bind (&BOBCommandSession::HandleSessionReadinessCheckTimer,
|
|
||||||
shared_from_this (), std::placeholders::_1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void BOBCommandSession::StopCommandHandler (const char * operand, size_t len)
|
void BOBCommandSession::StopCommandHandler (const char * operand, size_t len)
|
||||||
{
|
{
|
||||||
@ -549,8 +527,27 @@ namespace client
|
|||||||
void BOBCommandSession::StatusCommandHandler (const char * operand, size_t len)
|
void BOBCommandSession::StatusCommandHandler (const char * operand, size_t len)
|
||||||
{
|
{
|
||||||
LogPrint (eLogDebug, "BOB: status ", operand);
|
LogPrint (eLogDebug, "BOB: status ", operand);
|
||||||
if (m_Owner.FindDestination (operand))
|
if (operand == m_Nickname)
|
||||||
SendReplyOK ("");
|
{
|
||||||
|
std::stringstream s;
|
||||||
|
s << "DATA"; s << " NICKNAME:"; s << operand;
|
||||||
|
if (m_CurrentDestination->GetLocalDestination ()->IsReady ())
|
||||||
|
s << " STARTING:false RUNNING:true STOPPING:false";
|
||||||
|
else
|
||||||
|
s << " STARTING:true RUNNING:false STOPPING:false";
|
||||||
|
s << " KEYS: true"; s << " QUIET:"; s << (m_IsQuiet ? "true":"false");
|
||||||
|
if (m_InPort)
|
||||||
|
{
|
||||||
|
s << " INPORT:" << m_InPort;
|
||||||
|
s << " INHOST:" << (m_Address.length () > 0 ? m_Address : "127.0.0.1");
|
||||||
|
}
|
||||||
|
if (m_OutPort)
|
||||||
|
{
|
||||||
|
s << " OUTPORT:" << m_OutPort;
|
||||||
|
s << " OUTHOST:" << (m_Address.length () > 0 ? m_Address : "127.0.0.1");
|
||||||
|
}
|
||||||
|
SendReplyOK (s.str().c_str());
|
||||||
|
}
|
||||||
else
|
else
|
||||||
SendReplyError ("no nickname has been set");
|
SendReplyError ("no nickname has been set");
|
||||||
}
|
}
|
||||||
|
4
BOB.h
4
BOB.h
@ -43,8 +43,6 @@ namespace client
|
|||||||
const char BOB_REPLY_ERROR[] = "ERROR %s\n";
|
const char BOB_REPLY_ERROR[] = "ERROR %s\n";
|
||||||
const char BOB_DATA[] = "NICKNAME %s\n";
|
const char BOB_DATA[] = "NICKNAME %s\n";
|
||||||
|
|
||||||
const int BOB_SESSION_READINESS_CHECK_INTERVAL = 5; // in seconds
|
|
||||||
|
|
||||||
class BOBI2PTunnel: public I2PService
|
class BOBI2PTunnel: public I2PService
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -177,7 +175,6 @@ namespace client
|
|||||||
|
|
||||||
void Receive ();
|
void Receive ();
|
||||||
void HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleReceived (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
void HandleSessionReadinessCheckTimer (const boost::system::error_code& ecode);
|
|
||||||
|
|
||||||
void Send (size_t len);
|
void Send (size_t len);
|
||||||
void HandleSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
void HandleSent (const boost::system::error_code& ecode, std::size_t bytes_transferred);
|
||||||
@ -189,7 +186,6 @@ namespace client
|
|||||||
|
|
||||||
BOBCommandChannel& m_Owner;
|
BOBCommandChannel& m_Owner;
|
||||||
boost::asio::ip::tcp::socket m_Socket;
|
boost::asio::ip::tcp::socket m_Socket;
|
||||||
boost::asio::deadline_timer m_Timer;
|
|
||||||
char m_ReceiveBuffer[BOB_COMMAND_BUFFER_SIZE + 1], m_SendBuffer[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, m_IsQuiet;
|
bool m_IsOpen, m_IsQuiet;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user