2020-05-22 16:18:41 +03:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013-2020, The PurpleI2P Project
|
|
|
|
*
|
|
|
|
* This file is part of Purple i2pd project and licensed under BSD3
|
|
|
|
*
|
|
|
|
* See full license text in LICENSE file at top of project tree
|
|
|
|
*/
|
|
|
|
|
2013-11-11 03:19:49 +04:00
|
|
|
#include <string.h>
|
2014-01-09 23:56:07 +04:00
|
|
|
#include "I2PEndian.h"
|
2013-11-11 03:19:49 +04:00
|
|
|
#include "Log.h"
|
|
|
|
#include "RouterContext.h"
|
|
|
|
#include "I2NPProtocol.h"
|
|
|
|
#include "Tunnel.h"
|
|
|
|
#include "Transports.h"
|
|
|
|
#include "TransitTunnel.h"
|
|
|
|
|
|
|
|
namespace i2p
|
|
|
|
{
|
|
|
|
namespace tunnel
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
|
|
|
TransitTunnel::TransitTunnel (uint32_t receiveTunnelID,
|
2020-03-01 13:25:50 +03:00
|
|
|
const uint8_t * nextIdent, uint32_t nextTunnelID,
|
2018-01-06 06:48:51 +03:00
|
|
|
const uint8_t * layerKey,const uint8_t * ivKey):
|
2015-11-03 17:15:49 +03:00
|
|
|
TunnelBase (receiveTunnelID, nextTunnelID, nextIdent)
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
2014-05-16 01:55:09 +04:00
|
|
|
m_Encryption.SetKeys (layerKey, ivKey);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
2013-11-11 03:19:49 +04:00
|
|
|
|
2015-06-25 05:19:56 +03:00
|
|
|
void TransitTunnel::EncryptTunnelMsg (std::shared_ptr<const I2NPMessage> in, std::shared_ptr<I2NPMessage> out)
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
|
|
|
m_Encryption.Encrypt (in->GetPayload () + 4, out->GetPayload () + 4);
|
2017-05-02 21:20:00 +03:00
|
|
|
i2p::transport::transports.UpdateTotalTransitTransmittedBytes (TUNNEL_DATA_MSG_SIZE);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
2015-01-22 05:50:46 +03:00
|
|
|
|
|
|
|
TransitTunnelParticipant::~TransitTunnelParticipant ()
|
|
|
|
{
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
|
2015-06-26 04:49:16 +03:00
|
|
|
void TransitTunnelParticipant::HandleTunnelDataMsg (std::shared_ptr<const i2p::I2NPMessage> tunnelMsg)
|
2013-11-11 03:19:49 +04:00
|
|
|
{
|
2021-06-27 22:49:57 +03:00
|
|
|
auto newMsg = CreateEmptyTunnelDataMsg (false);
|
2015-06-26 04:49:16 +03:00
|
|
|
EncryptTunnelMsg (tunnelMsg, newMsg);
|
2018-01-06 06:48:51 +03:00
|
|
|
|
2014-08-02 18:06:38 +04:00
|
|
|
m_NumTransmittedBytes += tunnelMsg->GetLength ();
|
2015-06-26 04:49:16 +03:00
|
|
|
htobe32buf (newMsg->GetPayload (), GetNextTunnelID ());
|
2018-01-06 06:48:51 +03:00
|
|
|
newMsg->FillI2NPMessageHeader (eI2NPTunnelData);
|
2015-06-26 04:49:16 +03:00
|
|
|
m_TunnelDataMsgs.push_back (newMsg);
|
2013-11-11 03:19:49 +04:00
|
|
|
}
|
|
|
|
|
2015-01-22 05:50:46 +03:00
|
|
|
void TransitTunnelParticipant::FlushTunnelDataMsgs ()
|
|
|
|
{
|
|
|
|
if (!m_TunnelDataMsgs.empty ())
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
2015-04-11 02:58:32 +03:00
|
|
|
auto num = m_TunnelDataMsgs.size ();
|
|
|
|
if (num > 1)
|
2015-12-21 05:20:36 +03:00
|
|
|
LogPrint (eLogDebug, "TransitTunnel: ", GetTunnelID (), "->", GetNextTunnelID (), " ", num);
|
2015-01-22 05:50:46 +03:00
|
|
|
i2p::transport::transports.SendMessages (GetNextIdentHash (), m_TunnelDataMsgs);
|
|
|
|
m_TunnelDataMsgs.clear ();
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-19 21:38:31 +03:00
|
|
|
void TransitTunnel::SendTunnelDataMsg (std::shared_ptr<i2p::I2NPMessage> msg)
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
2015-12-21 05:20:36 +03:00
|
|
|
LogPrint (eLogError, "TransitTunnel: We are not a gateway for ", GetTunnelID ());
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
2013-11-29 16:52:09 +04:00
|
|
|
|
2015-06-26 04:49:16 +03:00
|
|
|
void TransitTunnel::HandleTunnelDataMsg (std::shared_ptr<const i2p::I2NPMessage> tunnelMsg)
|
2015-01-22 05:50:46 +03:00
|
|
|
{
|
2015-12-21 05:20:36 +03:00
|
|
|
LogPrint (eLogError, "TransitTunnel: Incoming tunnel message is not supported ", GetTunnelID ());
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
|
2015-06-19 21:38:31 +03:00
|
|
|
void TransitTunnelGateway::SendTunnelDataMsg (std::shared_ptr<i2p::I2NPMessage> msg)
|
2013-11-29 16:52:09 +04:00
|
|
|
{
|
2014-02-20 07:08:57 +04:00
|
|
|
TunnelMessageBlock block;
|
|
|
|
block.deliveryType = eDeliveryTypeLocal;
|
|
|
|
block.data = msg;
|
2014-06-26 23:41:12 +04:00
|
|
|
std::unique_lock<std::mutex> l(m_SendMutex);
|
2015-01-24 06:05:33 +03:00
|
|
|
m_Gateway.PutTunnelDataMsg (block);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
2013-11-29 16:52:09 +04:00
|
|
|
|
2015-01-24 06:05:33 +03:00
|
|
|
void TransitTunnelGateway::FlushTunnelDataMsgs ()
|
|
|
|
{
|
2015-02-12 02:47:20 +03:00
|
|
|
std::unique_lock<std::mutex> l(m_SendMutex);
|
2015-01-24 06:05:33 +03:00
|
|
|
m_Gateway.SendBuffer ();
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
|
2015-06-26 04:49:16 +03:00
|
|
|
void TransitTunnelEndpoint::HandleTunnelDataMsg (std::shared_ptr<const i2p::I2NPMessage> tunnelMsg)
|
2013-11-29 16:52:09 +04:00
|
|
|
{
|
2021-06-27 22:49:57 +03:00
|
|
|
auto newMsg = CreateEmptyTunnelDataMsg (true);
|
2015-06-26 04:49:16 +03:00
|
|
|
EncryptTunnelMsg (tunnelMsg, newMsg);
|
2018-01-06 06:48:51 +03:00
|
|
|
|
2015-12-21 05:20:36 +03:00
|
|
|
LogPrint (eLogDebug, "TransitTunnel: handle msg for endpoint ", GetTunnelID ());
|
2018-01-06 06:48:51 +03:00
|
|
|
m_Endpoint.HandleDecryptedTunnelDataMsg (newMsg);
|
2013-11-29 16:52:09 +04:00
|
|
|
}
|
2018-01-06 06:48:51 +03:00
|
|
|
|
2016-03-01 23:22:36 +03:00
|
|
|
std::shared_ptr<TransitTunnel> CreateTransitTunnel (uint32_t receiveTunnelID,
|
2018-01-06 06:48:51 +03:00
|
|
|
const uint8_t * nextIdent, uint32_t nextTunnelID,
|
2020-03-01 13:25:50 +03:00
|
|
|
const uint8_t * layerKey,const uint8_t * ivKey,
|
2013-11-29 16:52:09 +04:00
|
|
|
bool isGateway, bool isEndpoint)
|
2013-11-11 03:19:49 +04:00
|
|
|
{
|
2013-11-29 16:52:09 +04:00
|
|
|
if (isEndpoint)
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
2016-06-27 16:00:00 +03:00
|
|
|
LogPrint (eLogDebug, "TransitTunnel: endpoint ", receiveTunnelID, " created");
|
2016-03-01 23:22:36 +03:00
|
|
|
return std::make_shared<TransitTunnelEndpoint> (receiveTunnelID, nextIdent, nextTunnelID, layerKey, ivKey);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
2013-11-29 16:52:09 +04:00
|
|
|
else if (isGateway)
|
2018-01-06 06:48:51 +03:00
|
|
|
{
|
2015-12-21 05:20:36 +03:00
|
|
|
LogPrint (eLogInfo, "TransitTunnel: gateway ", receiveTunnelID, " created");
|
2016-03-01 23:22:36 +03:00
|
|
|
return std::make_shared<TransitTunnelGateway> (receiveTunnelID, nextIdent, nextTunnelID, layerKey, ivKey);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-06-27 16:00:00 +03:00
|
|
|
LogPrint (eLogDebug, "TransitTunnel: ", receiveTunnelID, "->", nextTunnelID, " created");
|
2016-03-01 23:22:36 +03:00
|
|
|
return std::make_shared<TransitTunnelParticipant> (receiveTunnelID, nextIdent, nextTunnelID, layerKey, ivKey);
|
2018-01-06 06:48:51 +03:00
|
|
|
}
|
|
|
|
}
|
2013-11-11 03:19:49 +04:00
|
|
|
}
|
2014-06-26 23:41:12 +04:00
|
|
|
}
|