mirror of
https://github.com/PurpleI2P/i2pd
synced 2024-11-10 00:00:29 +03:00
handle HTTP response
This commit is contained in:
parent
d2edbfd6fa
commit
a8778e358d
@ -498,7 +498,7 @@ namespace proxy {
|
|||||||
if (Kill())
|
if (Kill())
|
||||||
return;
|
return;
|
||||||
LogPrint (eLogDebug, "HTTPProxy: Created new I2PTunnel stream, sSID=", stream->GetSendStreamID(), ", rSID=", stream->GetRecvStreamID());
|
LogPrint (eLogDebug, "HTTPProxy: Created new I2PTunnel stream, sSID=", stream->GetSendStreamID(), ", rSID=", stream->GetRecvStreamID());
|
||||||
auto connection = std::make_shared<i2p::client::I2PTunnelConnection>(GetOwner(), m_sock, stream);
|
auto connection = std::make_shared<i2p::client::I2PClientTunnelConnectionHTTP>(GetOwner(), m_sock, stream);
|
||||||
GetOwner()->AddHandler (connection);
|
GetOwner()->AddHandler (connection);
|
||||||
connection->I2PConnect (reinterpret_cast<const uint8_t*>(m_send_buf.data()), m_send_buf.length());
|
connection->I2PConnect (reinterpret_cast<const uint8_t*>(m_send_buf.data()), m_send_buf.length());
|
||||||
Done (shared_from_this());
|
Done (shared_from_this());
|
||||||
|
@ -236,14 +236,63 @@ namespace client
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
I2PTunnelConnectionHTTP::I2PTunnelConnectionHTTP (I2PService * owner, std::shared_ptr<i2p::stream::Stream> stream,
|
void I2PClientTunnelConnectionHTTP::Write (const uint8_t * buf, size_t len)
|
||||||
|
{
|
||||||
|
if (m_HeaderSent)
|
||||||
|
I2PTunnelConnection::Write (buf, len);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_InHeader.clear ();
|
||||||
|
m_InHeader.write ((const char *)buf, len);
|
||||||
|
std::string line;
|
||||||
|
bool endOfHeader = false;
|
||||||
|
while (!endOfHeader)
|
||||||
|
{
|
||||||
|
std::getline(m_InHeader, line);
|
||||||
|
if (!m_InHeader.fail ())
|
||||||
|
{
|
||||||
|
if (line == "\r") endOfHeader = true;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!m_ConnectionSent && !line.compare(0, 10, "Connection"))
|
||||||
|
{
|
||||||
|
m_OutHeader << "Connection: close\r\n";
|
||||||
|
m_ConnectionSent = true;
|
||||||
|
}
|
||||||
|
else if (!m_ProxyConnectionSent && !line.compare(0, 16, "Proxy-Connection"))
|
||||||
|
{
|
||||||
|
m_OutHeader << "Proxy-Connection: close\r\n";
|
||||||
|
m_ProxyConnectionSent = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
m_OutHeader << line << "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (endOfHeader)
|
||||||
|
{
|
||||||
|
if (!m_ConnectionSent) m_OutHeader << "Connection: close\r\n";
|
||||||
|
if (!m_ProxyConnectionSent) m_OutHeader << "Proxy-Connection: close\r\n";
|
||||||
|
m_OutHeader << "\r\n"; // end of header
|
||||||
|
m_OutHeader << m_InHeader.str ().substr (m_InHeader.tellg ()); // data right after header
|
||||||
|
m_InHeader.str ("");
|
||||||
|
m_HeaderSent = true;
|
||||||
|
I2PTunnelConnection::Write ((uint8_t *)m_OutHeader.str ().c_str (), m_OutHeader.str ().length ());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
I2PServerTunnelConnectionHTTP::I2PServerTunnelConnectionHTTP (I2PService * owner, std::shared_ptr<i2p::stream::Stream> stream,
|
||||||
std::shared_ptr<boost::asio::ip::tcp::socket> socket,
|
std::shared_ptr<boost::asio::ip::tcp::socket> socket,
|
||||||
const boost::asio::ip::tcp::endpoint& target, const std::string& host):
|
const boost::asio::ip::tcp::endpoint& target, const std::string& host):
|
||||||
I2PTunnelConnection (owner, stream, socket, target), m_Host (host), m_HeaderSent (false), m_From (stream->GetRemoteIdentity ())
|
I2PTunnelConnection (owner, stream, socket, target), m_Host (host), m_HeaderSent (false), m_From (stream->GetRemoteIdentity ())
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void I2PTunnelConnectionHTTP::Write (const uint8_t * buf, size_t len)
|
void I2PServerTunnelConnectionHTTP::Write (const uint8_t * buf, size_t len)
|
||||||
{
|
{
|
||||||
if (m_HeaderSent)
|
if (m_HeaderSent)
|
||||||
I2PTunnelConnection::Write (buf, len);
|
I2PTunnelConnection::Write (buf, len);
|
||||||
@ -282,6 +331,7 @@ namespace client
|
|||||||
{
|
{
|
||||||
m_OutHeader << "\r\n"; // end of header
|
m_OutHeader << "\r\n"; // end of header
|
||||||
m_OutHeader << m_InHeader.str ().substr (m_InHeader.tellg ()); // data right after header
|
m_OutHeader << m_InHeader.str ().substr (m_InHeader.tellg ()); // data right after header
|
||||||
|
m_InHeader.str ("");
|
||||||
m_HeaderSent = true;
|
m_HeaderSent = true;
|
||||||
I2PTunnelConnection::Write ((uint8_t *)m_OutHeader.str ().c_str (), m_OutHeader.str ().length ());
|
I2PTunnelConnection::Write ((uint8_t *)m_OutHeader.str ().c_str (), m_OutHeader.str ().length ());
|
||||||
}
|
}
|
||||||
@ -532,7 +582,7 @@ namespace client
|
|||||||
|
|
||||||
std::shared_ptr<I2PTunnelConnection> I2PServerTunnelHTTP::CreateI2PConnection (std::shared_ptr<i2p::stream::Stream> stream)
|
std::shared_ptr<I2PTunnelConnection> I2PServerTunnelHTTP::CreateI2PConnection (std::shared_ptr<i2p::stream::Stream> stream)
|
||||||
{
|
{
|
||||||
return std::make_shared<I2PTunnelConnectionHTTP> (this, stream,
|
return std::make_shared<I2PServerTunnelConnectionHTTP> (this, stream,
|
||||||
std::make_shared<boost::asio::ip::tcp::socket> (GetService ()), GetEndpoint (), m_Host);
|
std::make_shared<boost::asio::ip::tcp::socket> (GetService ()), GetEndpoint (), m_Host);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
23
I2PTunnel.h
23
I2PTunnel.h
@ -64,11 +64,30 @@ namespace client
|
|||||||
bool m_IsQuiet; // don't send destination
|
bool m_IsQuiet; // don't send destination
|
||||||
};
|
};
|
||||||
|
|
||||||
class I2PTunnelConnectionHTTP: public I2PTunnelConnection
|
class I2PClientTunnelConnectionHTTP: public I2PTunnelConnection
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
I2PClientTunnelConnectionHTTP (I2PService * owner, std::shared_ptr<boost::asio::ip::tcp::socket> socket,
|
||||||
|
std::shared_ptr<i2p::stream::Stream> stream):
|
||||||
|
I2PTunnelConnection (owner, socket, stream), m_HeaderSent (false),
|
||||||
|
m_ConnectionSent (false), m_ProxyConnectionSent (false) {};
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
void Write (const uint8_t * buf, size_t len);
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
std::stringstream m_InHeader, m_OutHeader;
|
||||||
|
bool m_HeaderSent, m_ConnectionSent, m_ProxyConnectionSent;
|
||||||
|
};
|
||||||
|
|
||||||
|
class I2PServerTunnelConnectionHTTP: public I2PTunnelConnection
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
I2PTunnelConnectionHTTP (I2PService * owner, std::shared_ptr<i2p::stream::Stream> stream,
|
I2PServerTunnelConnectionHTTP (I2PService * owner, std::shared_ptr<i2p::stream::Stream> stream,
|
||||||
std::shared_ptr<boost::asio::ip::tcp::socket> socket,
|
std::shared_ptr<boost::asio::ip::tcp::socket> socket,
|
||||||
const boost::asio::ip::tcp::endpoint& target, const std::string& host);
|
const boost::asio::ip::tcp::endpoint& target, const std::string& host);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user