mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 08:14:15 +00:00
parse address in AddressBook
This commit is contained in:
parent
ec3462fabe
commit
07654212f8
@ -18,6 +18,29 @@ namespace data
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool AddressBook::GetIdentHash (const std::string& address, IdentHash& ident)
|
||||||
|
{
|
||||||
|
auto pos = address.find(".b32.i2p");
|
||||||
|
if (pos != std::string::npos)
|
||||||
|
{
|
||||||
|
Base32ToByteStream (address.c_str(), pos, ident, 32);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pos = address.find (".i2p");
|
||||||
|
if (pos != std::string::npos)
|
||||||
|
{
|
||||||
|
auto identHash = FindAddress (address);
|
||||||
|
if (identHash)
|
||||||
|
{
|
||||||
|
ident = *identHash;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
const IdentHash * AddressBook::FindAddress (const std::string& address)
|
const IdentHash * AddressBook::FindAddress (const std::string& address)
|
||||||
{
|
{
|
||||||
|
@ -18,6 +18,7 @@ namespace data
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
AddressBook ();
|
AddressBook ();
|
||||||
|
bool GetIdentHash (const std::string& address, IdentHash& ident);
|
||||||
const IdentHash * FindAddress (const std::string& address);
|
const IdentHash * FindAddress (const std::string& address);
|
||||||
void InsertAddress (const std::string& address, const std::string& base64); // for jump service
|
void InsertAddress (const std::string& address, const std::string& base64); // for jump service
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ namespace proxy
|
|||||||
{
|
{
|
||||||
LogPrint ("Jump service for ", r.host, " found. Inserting to address book");
|
LogPrint ("Jump service for ", r.host, " found. Inserting to address book");
|
||||||
auto base64 = r.uri.substr (addressPos + 1);
|
auto base64 = r.uri.substr (addressPos + 1);
|
||||||
i2p::data::netdb.InsertAddress (r.host, base64);
|
i2p::data::netdb.GetAddressBook ().InsertAddress (r.host, base64);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -829,34 +829,12 @@ namespace util
|
|||||||
void HTTPConnection::SendToAddress (const std::string& address, const char * buf, size_t len)
|
void HTTPConnection::SendToAddress (const std::string& address, const char * buf, size_t len)
|
||||||
{
|
{
|
||||||
i2p::data::IdentHash destination;
|
i2p::data::IdentHash destination;
|
||||||
if (address.find(".b32.i2p") != std::string::npos)
|
if (!i2p::data::netdb.GetAddressBook ().GetIdentHash (address, destination))
|
||||||
{
|
{
|
||||||
if (i2p::data::Base32ToByteStream(address.c_str(), address.length() - strlen(".b32.i2p"), (uint8_t *)destination, 32) != 32)
|
LogPrint ("Unknown address ", address);
|
||||||
{
|
SendReply ("<html>" + itoopieImage + "<br>Unknown address " + address + "</html>", 404);
|
||||||
LogPrint ("Invalid Base32 address ", address);
|
return;
|
||||||
SendReply ("<html>" + itoopieImage + "<br>Invalid Base32 address</html>", 400);
|
}
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (address.find(".i2p") != std::string::npos)
|
|
||||||
{
|
|
||||||
auto addr = i2p::data::netdb.FindAddress(address);
|
|
||||||
if (!addr)
|
|
||||||
{
|
|
||||||
LogPrint ("Unknown address ", address);
|
|
||||||
SendReply ("<html>" + itoopieImage + "<br>Unknown address " + address + "</html>", 404);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
destination = *addr;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SendReply ("<html>Unexpected address " + address + "</html>", 404);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
SendToDestination (destination, buf, len);
|
SendToDestination (destination, buf, len);
|
||||||
}
|
}
|
||||||
|
@ -153,23 +153,9 @@ namespace stream
|
|||||||
|
|
||||||
void I2PClientTunnel::Start ()
|
void I2PClientTunnel::Start ()
|
||||||
{
|
{
|
||||||
auto pos = m_Destination.find(".b32.i2p");
|
i2p::data::IdentHash identHash;
|
||||||
if (pos != std::string::npos)
|
if (i2p::data::netdb.GetAddressBook ().GetIdentHash (m_Destination, identHash))
|
||||||
{
|
m_DestinationIdentHash = new i2p::data::IdentHash (identHash);
|
||||||
uint8_t hash[32];
|
|
||||||
i2p::data::Base32ToByteStream (m_Destination.c_str(), pos, hash, 32);
|
|
||||||
m_DestinationIdentHash = new i2p::data::IdentHash (hash);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
pos = m_Destination.find (".i2p");
|
|
||||||
if (pos != std::string::npos)
|
|
||||||
{
|
|
||||||
auto identHash = i2p::data::netdb.FindAddress (m_Destination);
|
|
||||||
if (identHash)
|
|
||||||
m_DestinationIdentHash = new i2p::data::IdentHash (*identHash);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (m_DestinationIdentHash)
|
if (m_DestinationIdentHash)
|
||||||
{
|
{
|
||||||
i2p::data::netdb.Subscribe (*m_DestinationIdentHash, GetLocalDestination ()->GetTunnelPool ());
|
i2p::data::netdb.Subscribe (*m_DestinationIdentHash, GetLocalDestination ()->GetTunnelPool ());
|
||||||
@ -206,10 +192,10 @@ namespace stream
|
|||||||
m_RemoteLeaseSet = i2p::data::netdb.FindLeaseSet (*m_DestinationIdentHash);
|
m_RemoteLeaseSet = i2p::data::netdb.FindLeaseSet (*m_DestinationIdentHash);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
auto identHash = i2p::data::netdb.FindAddress (m_Destination);
|
i2p::data::IdentHash identHash;
|
||||||
if (identHash)
|
if (i2p::data::netdb.GetAddressBook ().GetIdentHash (m_Destination, identHash))
|
||||||
{
|
{
|
||||||
m_DestinationIdentHash = new i2p::data::IdentHash (*identHash);
|
m_DestinationIdentHash = new i2p::data::IdentHash (identHash);
|
||||||
i2p::data::netdb.Subscribe (*m_DestinationIdentHash, GetSharedLocalDestination ()->GetTunnelPool ());
|
i2p::data::netdb.Subscribe (*m_DestinationIdentHash, GetSharedLocalDestination ()->GetTunnelPool ());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
3
NetDb.h
3
NetDb.h
@ -66,8 +66,7 @@ namespace data
|
|||||||
void AddLeaseSet (const IdentHash& ident, const uint8_t * buf, int len);
|
void AddLeaseSet (const IdentHash& ident, const uint8_t * buf, int len);
|
||||||
RouterInfo * FindRouter (const IdentHash& ident) const;
|
RouterInfo * FindRouter (const IdentHash& ident) const;
|
||||||
LeaseSet * FindLeaseSet (const IdentHash& destination) const;
|
LeaseSet * FindLeaseSet (const IdentHash& destination) const;
|
||||||
const IdentHash * FindAddress (const std::string& address) { return m_AddressBook.FindAddress (address); }; // TODO: move AddressBook away from NetDb
|
AddressBook& GetAddressBook () { return m_AddressBook; };// TODO: move AddressBook away from NetDb
|
||||||
void InsertAddress (const std::string& address, const std::string& base64) { m_AddressBook.InsertAddress (address, base64); };
|
|
||||||
|
|
||||||
void Subscribe (const IdentHash& ident, i2p::tunnel::TunnelPool * pool = nullptr); // keep LeaseSets upto date
|
void Subscribe (const IdentHash& ident, i2p::tunnel::TunnelPool * pool = nullptr); // keep LeaseSets upto date
|
||||||
void Unsubscribe (const IdentHash& ident);
|
void Unsubscribe (const IdentHash& ident);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user