mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 08:14:15 +00:00
enable NTCP2 as transport
This commit is contained in:
parent
0b36732911
commit
5575b981c8
@ -9,6 +9,7 @@
|
|||||||
#include "Ed25519.h"
|
#include "Ed25519.h"
|
||||||
#include "Siphash.h"
|
#include "Siphash.h"
|
||||||
#include "RouterContext.h"
|
#include "RouterContext.h"
|
||||||
|
#include "Transports.h"
|
||||||
#include "NTCP2.h"
|
#include "NTCP2.h"
|
||||||
|
|
||||||
namespace i2p
|
namespace i2p
|
||||||
@ -162,6 +163,13 @@ namespace transport
|
|||||||
m_Server.GetService ().post (std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
m_Server.GetService ().post (std::bind (&NTCP2Session::Terminate, shared_from_this ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NTCP2Session::Established ()
|
||||||
|
{
|
||||||
|
m_IsEstablished = true;
|
||||||
|
m_Establisher.reset (nullptr);
|
||||||
|
transports.PeerConnected (shared_from_this ());
|
||||||
|
}
|
||||||
|
|
||||||
void NTCP2Session::CreateNonce (uint64_t seqn, uint8_t * nonce)
|
void NTCP2Session::CreateNonce (uint64_t seqn, uint8_t * nonce)
|
||||||
{
|
{
|
||||||
memset (nonce, 0, 4);
|
memset (nonce, 0, 4);
|
||||||
@ -443,6 +451,7 @@ namespace transport
|
|||||||
m_ReceiveSipKey = m_Sipkeysba;
|
m_ReceiveSipKey = m_Sipkeysba;
|
||||||
memcpy (m_ReceiveIV, m_Sipkeysba + 16, 8);
|
memcpy (m_ReceiveIV, m_Sipkeysba + 16, 8);
|
||||||
memcpy (m_SendIV, m_Sipkeysab + 16, 8);
|
memcpy (m_SendIV, m_Sipkeysab + 16, 8);
|
||||||
|
Established ();
|
||||||
ReceiveLength ();
|
ReceiveLength ();
|
||||||
|
|
||||||
// TODO: remove
|
// TODO: remove
|
||||||
@ -520,6 +529,7 @@ namespace transport
|
|||||||
m_ReceiveSipKey = m_Sipkeysab;
|
m_ReceiveSipKey = m_Sipkeysab;
|
||||||
memcpy (m_ReceiveIV, m_Sipkeysab + 16, 8);
|
memcpy (m_ReceiveIV, m_Sipkeysab + 16, 8);
|
||||||
memcpy (m_SendIV, m_Sipkeysba + 16, 8);
|
memcpy (m_SendIV, m_Sipkeysba + 16, 8);
|
||||||
|
Established ();
|
||||||
ReceiveLength ();
|
ReceiveLength ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,6 +62,8 @@ namespace transport
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
void Established ();
|
||||||
|
|
||||||
void CreateNonce (uint64_t seqn, uint8_t * nonce);
|
void CreateNonce (uint64_t seqn, uint8_t * nonce);
|
||||||
void KeyDerivationFunctionDataPhase ();
|
void KeyDerivationFunctionDataPhase ();
|
||||||
|
|
||||||
|
@ -117,7 +117,8 @@ namespace transport
|
|||||||
Transports::Transports ():
|
Transports::Transports ():
|
||||||
m_IsOnline (true), m_IsRunning (false), m_IsNAT (true), m_Thread (nullptr), m_Service (nullptr),
|
m_IsOnline (true), m_IsRunning (false), m_IsNAT (true), m_Thread (nullptr), m_Service (nullptr),
|
||||||
m_Work (nullptr), m_PeerCleanupTimer (nullptr), m_PeerTestTimer (nullptr),
|
m_Work (nullptr), m_PeerCleanupTimer (nullptr), m_PeerTestTimer (nullptr),
|
||||||
m_NTCPServer (nullptr), m_SSUServer (nullptr), m_DHKeysPairSupplier (5), // 5 pre-generated keys
|
m_NTCPServer (nullptr), m_SSUServer (nullptr), m_NTCP2Server (nullptr),
|
||||||
|
m_DHKeysPairSupplier (5), // 5 pre-generated keys
|
||||||
m_TotalSentBytes(0), m_TotalReceivedBytes(0), m_TotalTransitTransmittedBytes (0),
|
m_TotalSentBytes(0), m_TotalReceivedBytes(0), m_TotalTransitTransmittedBytes (0),
|
||||||
m_InBandwidth (0), m_OutBandwidth (0), m_TransitBandwidth(0),
|
m_InBandwidth (0), m_OutBandwidth (0), m_TransitBandwidth(0),
|
||||||
m_LastInBandwidthUpdateBytes (0), m_LastOutBandwidthUpdateBytes (0),
|
m_LastInBandwidthUpdateBytes (0), m_LastOutBandwidthUpdateBytes (0),
|
||||||
@ -191,6 +192,13 @@ namespace transport
|
|||||||
LogPrint(eLogError, "Transports: invalid NTCP proxy url ", ntcpproxy);
|
LogPrint(eLogError, "Transports: invalid NTCP proxy url ", ntcpproxy);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
// create NTCP2. TODO: move to acceptor
|
||||||
|
bool ntcp2; i2p::config::GetOption("ntcp2", ntcp2);
|
||||||
|
if (ntcp2)
|
||||||
|
{
|
||||||
|
m_NTCP2Server = new NTCP2Server ();
|
||||||
|
m_NTCP2Server->Start ();
|
||||||
|
}
|
||||||
|
|
||||||
// create acceptors
|
// create acceptors
|
||||||
auto& addresses = context.GetRouterInfo ().GetAddresses ();
|
auto& addresses = context.GetRouterInfo ().GetAddresses ();
|
||||||
@ -262,6 +270,13 @@ namespace transport
|
|||||||
m_NTCPServer = nullptr;
|
m_NTCPServer = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_NTCP2Server)
|
||||||
|
{
|
||||||
|
m_NTCP2Server->Stop ();
|
||||||
|
delete m_NTCP2Server;
|
||||||
|
m_NTCP2Server = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
m_DHKeysPairSupplier.Stop ();
|
m_DHKeysPairSupplier.Stop ();
|
||||||
m_IsRunning = false;
|
m_IsRunning = false;
|
||||||
if (m_Service) m_Service->stop ();
|
if (m_Service) m_Service->stop ();
|
||||||
@ -390,6 +405,13 @@ namespace transport
|
|||||||
{
|
{
|
||||||
peer.numAttempts++;
|
peer.numAttempts++;
|
||||||
auto address = peer.router->GetNTCPAddress (!context.SupportsV6 ());
|
auto address = peer.router->GetNTCPAddress (!context.SupportsV6 ());
|
||||||
|
if (address && address->IsNTCP2 () && m_NTCP2Server) // NTCP2 have priority over NTCP if enabled
|
||||||
|
{
|
||||||
|
auto s = std::make_shared<NTCP2Session> (*m_NTCP2Server, peer.router);
|
||||||
|
m_NTCP2Server->Connect (address->host, address->port, s);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (address && m_NTCPServer)
|
if (address && m_NTCPServer)
|
||||||
{
|
{
|
||||||
#if BOOST_VERSION >= 104900
|
#if BOOST_VERSION >= 104900
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include "TransportSession.h"
|
#include "TransportSession.h"
|
||||||
#include "NTCPSession.h"
|
#include "NTCPSession.h"
|
||||||
#include "SSU.h"
|
#include "SSU.h"
|
||||||
|
#include "NTCP2.h"
|
||||||
#include "RouterInfo.h"
|
#include "RouterInfo.h"
|
||||||
#include "I2NPProtocol.h"
|
#include "I2NPProtocol.h"
|
||||||
#include "Identity.h"
|
#include "Identity.h"
|
||||||
@ -154,6 +155,7 @@ namespace transport
|
|||||||
|
|
||||||
NTCPServer * m_NTCPServer;
|
NTCPServer * m_NTCPServer;
|
||||||
SSUServer * m_SSUServer;
|
SSUServer * m_SSUServer;
|
||||||
|
NTCP2Server * m_NTCP2Server;
|
||||||
mutable std::mutex m_PeersMutex;
|
mutable std::mutex m_PeersMutex;
|
||||||
std::map<i2p::data::IdentHash, Peer> m_Peers;
|
std::map<i2p::data::IdentHash, Peer> m_Peers;
|
||||||
|
|
||||||
@ -179,6 +181,7 @@ namespace transport
|
|||||||
// for HTTP only
|
// for HTTP only
|
||||||
const NTCPServer * GetNTCPServer () const { return m_NTCPServer; };
|
const NTCPServer * GetNTCPServer () const { return m_NTCPServer; };
|
||||||
const SSUServer * GetSSUServer () const { return m_SSUServer; };
|
const SSUServer * GetSSUServer () const { return m_SSUServer; };
|
||||||
|
const NTCP2Server * GetNTCP2Server () const { return m_NTCP2Server; };
|
||||||
const decltype(m_Peers)& GetPeers () const { return m_Peers; };
|
const decltype(m_Peers)& GetPeers () const { return m_Peers; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user