Browse Source

* HTTPProxy.cpp : extract IsI2PAddress() from class and generalize

pull/509/merge
hagen 9 years ago
parent
commit
0de1e2c6fc
  1. 24
      HTTPProxy.cpp

24
HTTPProxy.cpp

@ -24,6 +24,15 @@ @@ -24,6 +24,15 @@
namespace i2p {
namespace proxy {
bool str_rmatch(std::string & str, const char *suffix) {
auto pos = str.rfind (suffix);
if (pos == std::string::npos)
return false; /* not found */
if (str.length() == (pos + std::strlen(suffix)))
return true; /* match */
return false;
}
static const size_t http_buffer_size = 8192;
class HTTPReqHandler: public i2p::client::I2PServiceHandler, public std::enable_shared_from_this<HTTPReqHandler>
{
@ -45,7 +54,6 @@ namespace proxy { @@ -45,7 +54,6 @@ namespace proxy {
void HTTPRequestFailed(const char *message);
void RedirectToJumpService(std::string & host);
void ExtractRequest();
bool IsI2PAddress();
bool ValidateHTTPRequest();
void HandleJumpServices();
bool CreateHTTPRequest(uint8_t *http_buff, std::size_t len);
@ -198,16 +206,6 @@ namespace proxy { @@ -198,16 +206,6 @@ namespace proxy {
m_path.erase(addressHelperPos);
}
bool HTTPReqHandler::IsI2PAddress()
{
auto pos = m_address.rfind (".i2p");
if (pos != std::string::npos && (pos+4) == m_address.length ())
{
return true;
}
return false;
}
bool HTTPReqHandler::CreateHTTPRequest(uint8_t *http_buff, std::size_t len)
{
ExtractRequest(); //TODO: parse earlier
@ -215,7 +213,7 @@ namespace proxy { @@ -215,7 +213,7 @@ namespace proxy {
HandleJumpServices();
i2p::data::IdentHash identHash;
if (IsI2PAddress ())
if (str_rmatch(m_address, ".i2p"))
{
if (!i2p::client::context.GetAddressBook ().GetIdentHash (m_address, identHash)){
RedirectToJumpService(m_address);
@ -223,7 +221,6 @@ namespace proxy { @@ -223,7 +221,6 @@ namespace proxy {
}
}
m_request = m_method;
m_request.push_back(' ');
m_request += m_path;
@ -335,7 +332,6 @@ namespace proxy { @@ -335,7 +332,6 @@ namespace proxy {
else
AsyncSockRead();
}
}
void HTTPReqHandler::SentHTTPFailed(const boost::system::error_code & ecode)

Loading…
Cancel
Save