2020-05-22 15:18:41 +02:00
/*
2023-03-06 02:08:15 +01:00
* Copyright ( c ) 2013 - 2023 , The PurpleI2P Project
2020-05-22 15:18:41 +02:00
*
* 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-10-27 16:20:29 +01:00
# ifndef I2NP_PROTOCOL_H__
# define I2NP_PROTOCOL_H__
# include <inttypes.h>
2015-02-06 00:53:43 +01:00
# include <string.h>
2014-01-05 15:53:44 +01:00
# include <set>
2015-02-06 00:53:43 +01:00
# include <memory>
2016-05-11 21:12:38 +02:00
# include "Crypto.h"
2014-02-07 17:26:00 +01:00
# include "I2PEndian.h"
2014-12-30 18:25:08 +01:00
# include "Identity.h"
2013-10-27 16:20:29 +01:00
# include "RouterInfo.h"
2014-07-29 20:31:55 +02:00
# include "LeaseSet.h"
2013-10-27 16:20:29 +01:00
namespace i2p
2018-01-06 04:48:51 +01:00
{
2015-01-01 22:51:15 +01:00
// I2NP header
const size_t I2NP_HEADER_TYPEID_OFFSET = 0 ;
const size_t I2NP_HEADER_MSGID_OFFSET = I2NP_HEADER_TYPEID_OFFSET + 1 ;
const size_t I2NP_HEADER_EXPIRATION_OFFSET = I2NP_HEADER_MSGID_OFFSET + 4 ;
const size_t I2NP_HEADER_SIZE_OFFSET = I2NP_HEADER_EXPIRATION_OFFSET + 8 ;
const size_t I2NP_HEADER_CHKS_OFFSET = I2NP_HEADER_SIZE_OFFSET + 2 ;
2015-01-02 00:53:44 +01:00
const size_t I2NP_HEADER_SIZE = I2NP_HEADER_CHKS_OFFSET + 1 ;
2015-01-02 05:00:33 +01:00
// I2NP short header
const size_t I2NP_SHORT_HEADER_TYPEID_OFFSET = 0 ;
const size_t I2NP_SHORT_HEADER_EXPIRATION_OFFSET = I2NP_SHORT_HEADER_TYPEID_OFFSET + 1 ;
const size_t I2NP_SHORT_HEADER_SIZE = I2NP_SHORT_HEADER_EXPIRATION_OFFSET + 4 ;
2018-01-06 04:48:51 +01:00
2018-07-17 21:17:05 +02:00
// I2NP NTCP2 header
2020-03-01 11:25:50 +01:00
const size_t I2NP_NTCP2_HEADER_SIZE = I2NP_HEADER_EXPIRATION_OFFSET + 4 ;
2018-07-17 21:17:05 +02:00
2015-01-02 00:53:44 +01:00
// Tunnel Gateway header
const size_t TUNNEL_GATEWAY_HEADER_TUNNELID_OFFSET = 0 ;
const size_t TUNNEL_GATEWAY_HEADER_LENGTH_OFFSET = TUNNEL_GATEWAY_HEADER_TUNNELID_OFFSET + 4 ;
const size_t TUNNEL_GATEWAY_HEADER_SIZE = TUNNEL_GATEWAY_HEADER_LENGTH_OFFSET + 2 ;
2015-01-02 23:39:35 +01:00
2018-01-06 04:48:51 +01:00
// DeliveryStatus
2015-01-02 23:39:35 +01:00
const size_t DELIVERY_STATUS_MSGID_OFFSET = 0 ;
const size_t DELIVERY_STATUS_TIMESTAMP_OFFSET = DELIVERY_STATUS_MSGID_OFFSET + 4 ;
const size_t DELIVERY_STATUS_SIZE = DELIVERY_STATUS_TIMESTAMP_OFFSET + 8 ;
2015-01-03 03:11:40 +01:00
// DatabaseStore
const size_t DATABASE_STORE_KEY_OFFSET = 0 ;
const size_t DATABASE_STORE_TYPE_OFFSET = DATABASE_STORE_KEY_OFFSET + 32 ;
const size_t DATABASE_STORE_REPLY_TOKEN_OFFSET = DATABASE_STORE_TYPE_OFFSET + 1 ;
const size_t DATABASE_STORE_HEADER_SIZE = DATABASE_STORE_REPLY_TOKEN_OFFSET + 4 ;
2015-01-03 15:47:24 +01:00
2018-01-06 04:48:51 +01:00
// TunnelBuild
2015-01-03 15:47:24 +01:00
const size_t TUNNEL_BUILD_RECORD_SIZE = 528 ;
2021-06-22 19:11:02 +02:00
const size_t SHORT_TUNNEL_BUILD_RECORD_SIZE = 218 ;
2021-11-27 21:30:35 +01:00
2018-01-06 04:48:51 +01:00
// BuildRequestRecordEncrypted
2015-01-03 22:31:44 +01:00
const size_t BUILD_REQUEST_RECORD_TO_PEER_OFFSET = 0 ;
const size_t BUILD_REQUEST_RECORD_ENCRYPTED_OFFSET = BUILD_REQUEST_RECORD_TO_PEER_OFFSET + 16 ;
2018-01-06 04:48:51 +01:00
2020-10-23 21:53:22 +02:00
// ECIES BuildRequestRecordClearText
const size_t ECIES_BUILD_REQUEST_RECORD_RECEIVE_TUNNEL_OFFSET = 0 ;
const size_t ECIES_BUILD_REQUEST_RECORD_NEXT_TUNNEL_OFFSET = ECIES_BUILD_REQUEST_RECORD_RECEIVE_TUNNEL_OFFSET + 4 ;
const size_t ECIES_BUILD_REQUEST_RECORD_NEXT_IDENT_OFFSET = ECIES_BUILD_REQUEST_RECORD_NEXT_TUNNEL_OFFSET + 4 ;
const size_t ECIES_BUILD_REQUEST_RECORD_LAYER_KEY_OFFSET = ECIES_BUILD_REQUEST_RECORD_NEXT_IDENT_OFFSET + 32 ;
const size_t ECIES_BUILD_REQUEST_RECORD_IV_KEY_OFFSET = ECIES_BUILD_REQUEST_RECORD_LAYER_KEY_OFFSET + 32 ;
const size_t ECIES_BUILD_REQUEST_RECORD_REPLY_KEY_OFFSET = ECIES_BUILD_REQUEST_RECORD_IV_KEY_OFFSET + 32 ;
const size_t ECIES_BUILD_REQUEST_RECORD_REPLY_IV_OFFSET = ECIES_BUILD_REQUEST_RECORD_REPLY_KEY_OFFSET + 32 ;
const size_t ECIES_BUILD_REQUEST_RECORD_FLAG_OFFSET = ECIES_BUILD_REQUEST_RECORD_REPLY_IV_OFFSET + 16 ;
const size_t ECIES_BUILD_REQUEST_RECORD_MORE_FLAGS_OFFSET = ECIES_BUILD_REQUEST_RECORD_FLAG_OFFSET + 1 ;
const size_t ECIES_BUILD_REQUEST_RECORD_REQUEST_TIME_OFFSET = ECIES_BUILD_REQUEST_RECORD_MORE_FLAGS_OFFSET + 3 ;
const size_t ECIES_BUILD_REQUEST_RECORD_REQUEST_EXPIRATION_OFFSET = ECIES_BUILD_REQUEST_RECORD_REQUEST_TIME_OFFSET + 4 ;
const size_t ECIES_BUILD_REQUEST_RECORD_SEND_MSG_ID_OFFSET = ECIES_BUILD_REQUEST_RECORD_REQUEST_EXPIRATION_OFFSET + 4 ;
const size_t ECIES_BUILD_REQUEST_RECORD_PADDING_OFFSET = ECIES_BUILD_REQUEST_RECORD_SEND_MSG_ID_OFFSET + 4 ;
const size_t ECIES_BUILD_REQUEST_RECORD_CLEAR_TEXT_SIZE = 464 ;
// ECIES BuildResponseRecord
2020-11-03 00:49:07 +01:00
const size_t ECIES_BUILD_RESPONSE_RECORD_OPTIONS_OFFSET = 0 ;
2020-10-23 21:53:22 +02:00
const size_t ECIES_BUILD_RESPONSE_RECORD_RET_OFFSET = 511 ;
2021-06-03 01:50:29 +02:00
// ShortRequestRecordClearText
2021-06-06 19:55:38 +02:00
const size_t SHORT_REQUEST_RECORD_ENCRYPTED_OFFSET = 16 ;
2021-06-08 00:28:36 +02:00
const size_t SHORT_REQUEST_RECORD_RECEIVE_TUNNEL_OFFSET = 0 ;
const size_t SHORT_REQUEST_RECORD_NEXT_TUNNEL_OFFSET = SHORT_REQUEST_RECORD_RECEIVE_TUNNEL_OFFSET + 4 ;
const size_t SHORT_REQUEST_RECORD_NEXT_IDENT_OFFSET = SHORT_REQUEST_RECORD_NEXT_TUNNEL_OFFSET + 4 ;
const size_t SHORT_REQUEST_RECORD_FLAG_OFFSET = SHORT_REQUEST_RECORD_NEXT_IDENT_OFFSET + 32 ;
const size_t SHORT_REQUEST_RECORD_MORE_FLAGS_OFFSET = SHORT_REQUEST_RECORD_FLAG_OFFSET + 1 ;
const size_t SHORT_REQUEST_RECORD_LAYER_ENCRYPTION_TYPE = SHORT_REQUEST_RECORD_MORE_FLAGS_OFFSET + 2 ;
const size_t SHORT_REQUEST_RECORD_REQUEST_TIME_OFFSET = SHORT_REQUEST_RECORD_LAYER_ENCRYPTION_TYPE + 1 ;
const size_t SHORT_REQUEST_RECORD_REQUEST_EXPIRATION_OFFSET = SHORT_REQUEST_RECORD_REQUEST_TIME_OFFSET + 4 ;
const size_t SHORT_REQUEST_RECORD_SEND_MSG_ID_OFFSET = SHORT_REQUEST_RECORD_REQUEST_EXPIRATION_OFFSET + 4 ;
2021-07-03 04:06:24 +02:00
const size_t SHORT_REQUEST_RECORD_PADDING_OFFSET = SHORT_REQUEST_RECORD_SEND_MSG_ID_OFFSET + 4 ;
2021-06-22 19:11:02 +02:00
const size_t SHORT_REQUEST_RECORD_CLEAR_TEXT_SIZE = 154 ;
2021-07-12 01:29:16 +02:00
// ShortResponseRecord
const size_t SHORT_RESPONSE_RECORD_OPTIONS_OFFSET = 0 ;
const size_t SHORT_RESPONSE_RECORD_RET_OFFSET = 201 ;
2021-11-27 21:30:35 +01:00
2013-10-27 16:20:29 +01:00
enum I2NPMessageType
{
2020-03-01 11:25:50 +01:00
eI2NPDummyMsg = 0 ,
2013-10-27 16:20:29 +01:00
eI2NPDatabaseStore = 1 ,
eI2NPDatabaseLookup = 2 ,
eI2NPDatabaseSearchReply = 3 ,
eI2NPDeliveryStatus = 10 ,
eI2NPGarlic = 11 ,
eI2NPTunnelData = 18 ,
eI2NPTunnelGateway = 19 ,
eI2NPData = 20 ,
2014-04-30 20:08:57 +02:00
eI2NPTunnelBuild = 21 ,
eI2NPTunnelBuildReply = 22 ,
2013-10-27 16:20:29 +01:00
eI2NPVariableTunnelBuild = 23 ,
2021-06-06 19:55:38 +02:00
eI2NPVariableTunnelBuildReply = 24 ,
2021-06-08 21:36:27 +02:00
eI2NPShortTunnelBuild = 25 ,
2021-07-13 01:40:40 +02:00
eI2NPShortTunnelBuildReply = 26
2018-01-06 04:48:51 +01:00
} ;
2013-10-27 16:20:29 +01:00
2021-06-08 21:36:27 +02:00
const uint8_t TUNNEL_BUILD_RECORD_GATEWAY_FLAG = 0x80 ;
const uint8_t TUNNEL_BUILD_RECORD_ENDPOINT_FLAG = 0x40 ;
2018-01-06 04:48:51 +01:00
const int NUM_TUNNEL_BUILD_RECORDS = 8 ;
2014-04-30 20:08:57 +02:00
2015-02-02 17:06:36 +01:00
// DatabaseLookup flags
const uint8_t DATABASE_LOOKUP_DELIVERY_FLAG = 0x01 ;
2018-01-06 04:48:51 +01:00
const uint8_t DATABASE_LOOKUP_ENCRYPTION_FLAG = 0x02 ;
2020-04-07 17:40:18 +02:00
const uint8_t DATABASE_LOOKUP_ECIES_FLAG = 0x10 ;
2015-02-02 17:06:36 +01:00
const uint8_t DATABASE_LOOKUP_TYPE_FLAGS_MASK = 0x0C ;
const uint8_t DATABASE_LOOKUP_TYPE_NORMAL_LOOKUP = 0 ;
const uint8_t DATABASE_LOOKUP_TYPE_LEASESET_LOOKUP = 0x04 ; // 0100
2018-01-06 04:48:51 +01:00
const uint8_t DATABASE_LOOKUP_TYPE_ROUTERINFO_LOOKUP = 0x08 ; // 1000
2015-02-02 17:06:36 +01:00
const uint8_t DATABASE_LOOKUP_TYPE_EXPLORATORY_LOOKUP = 0x0C ; // 1100
2014-03-13 01:13:49 +01:00
namespace tunnel
2018-01-06 04:48:51 +01:00
{
2014-03-13 01:13:49 +01:00
class InboundTunnel ;
2014-10-07 02:18:18 +02:00
class TunnelPool ;
2014-03-13 01:13:49 +01:00
}
2018-10-10 17:31:55 +02:00
const size_t I2NP_MAX_MESSAGE_SIZE = 62708 ;
2018-01-06 04:48:51 +01:00
const size_t I2NP_MAX_SHORT_MESSAGE_SIZE = 4096 ;
2023-03-18 20:32:05 +01:00
const size_t I2NP_MAX_MEDIUM_MESSAGE_SIZE = 16384 ;
2016-01-19 17:16:50 +01:00
const unsigned int I2NP_MESSAGE_EXPIRATION_TIMEOUT = 8000 ; // in milliseconds (as initial RTT)
2018-01-06 04:48:51 +01:00
const unsigned int I2NP_MESSAGE_CLOCK_SKEW = 60 * 1000 ; // 1 minute in milliseconds
2016-01-19 17:16:50 +01:00
2013-10-27 16:20:29 +01:00
struct I2NPMessage
2018-01-06 04:48:51 +01:00
{
uint8_t * buf ;
2014-07-31 00:20:42 +02:00
size_t len , offset , maxLen ;
2015-02-06 00:53:43 +01:00
std : : shared_ptr < i2p : : tunnel : : InboundTunnel > from ;
2018-01-06 04:48:51 +01:00
I2NPMessage ( ) : buf ( nullptr ) , len ( I2NP_HEADER_SIZE + 2 ) ,
2022-05-20 18:56:05 +02:00
offset ( 2 ) , maxLen ( 0 ) , from ( nullptr ) { } ; // reserve 2 bytes for NTCP header
2018-01-06 04:48:51 +01:00
2015-01-01 22:51:15 +01:00
// header accessors
2015-01-02 23:39:35 +01:00
uint8_t * GetHeader ( ) { return GetBuffer ( ) ; } ;
const uint8_t * GetHeader ( ) const { return GetBuffer ( ) ; } ;
void SetTypeID ( uint8_t typeID ) { GetHeader ( ) [ I2NP_HEADER_TYPEID_OFFSET ] = typeID ; } ;
uint8_t GetTypeID ( ) const { return GetHeader ( ) [ I2NP_HEADER_TYPEID_OFFSET ] ; } ;
void SetMsgID ( uint32_t msgID ) { htobe32buf ( GetHeader ( ) + I2NP_HEADER_MSGID_OFFSET , msgID ) ; } ;
uint32_t GetMsgID ( ) const { return bufbe32toh ( GetHeader ( ) + I2NP_HEADER_MSGID_OFFSET ) ; } ;
void SetExpiration ( uint64_t expiration ) { htobe64buf ( GetHeader ( ) + I2NP_HEADER_EXPIRATION_OFFSET , expiration ) ; } ;
uint64_t GetExpiration ( ) const { return bufbe64toh ( GetHeader ( ) + I2NP_HEADER_EXPIRATION_OFFSET ) ; } ;
void SetSize ( uint16_t size ) { htobe16buf ( GetHeader ( ) + I2NP_HEADER_SIZE_OFFSET , size ) ; } ;
uint16_t GetSize ( ) const { return bufbe16toh ( GetHeader ( ) + I2NP_HEADER_SIZE_OFFSET ) ; } ;
2018-01-06 04:48:51 +01:00
void UpdateSize ( ) { SetSize ( GetPayloadLength ( ) ) ; } ;
2015-01-02 23:39:35 +01:00
void SetChks ( uint8_t chks ) { GetHeader ( ) [ I2NP_HEADER_CHKS_OFFSET ] = chks ; } ;
2018-01-06 04:48:51 +01:00
void UpdateChks ( )
2015-01-01 22:51:15 +01:00
{
uint8_t hash [ 32 ] ;
2015-11-03 15:15:49 +01:00
SHA256 ( GetPayload ( ) , GetPayloadLength ( ) , hash ) ;
2015-01-02 23:39:35 +01:00
GetHeader ( ) [ I2NP_HEADER_CHKS_OFFSET ] = hash [ 0 ] ;
2018-01-06 04:48:51 +01:00
}
2015-01-01 22:51:15 +01:00
// payload
2015-01-02 05:00:33 +01:00
uint8_t * GetPayload ( ) { return GetBuffer ( ) + I2NP_HEADER_SIZE ; } ;
2015-06-25 04:19:56 +02:00
const uint8_t * GetPayload ( ) const { return GetBuffer ( ) + I2NP_HEADER_SIZE ; } ;
2013-10-27 16:20:29 +01:00
uint8_t * GetBuffer ( ) { return buf + offset ; } ;
2014-03-20 14:47:02 +01:00
const uint8_t * GetBuffer ( ) const { return buf + offset ; } ;
2018-01-06 04:48:51 +01:00
size_t GetLength ( ) const { return len - offset ; } ;
size_t GetPayloadLength ( ) const { return GetLength ( ) - I2NP_HEADER_SIZE ; } ;
void Align ( size_t alignment )
2014-11-26 17:04:49 +01:00
{
2015-03-11 17:17:38 +01:00
if ( len + alignment > maxLen ) return ;
2014-11-26 17:04:49 +01:00
size_t rem = ( ( size_t ) GetBuffer ( ) ) % alignment ;
if ( rem )
2014-11-26 17:54:35 +01:00
{
2014-11-26 17:04:49 +01:00
offset + = ( alignment - rem ) ;
2014-11-26 17:54:35 +01:00
len + = ( alignment - rem ) ;
2018-01-06 04:48:51 +01:00
}
2014-11-26 17:04:49 +01:00
}
2013-11-11 00:23:26 +01:00
2016-01-05 20:29:18 +01:00
size_t Concat ( const uint8_t * buf1 , size_t len1 )
{
// make sure with don't write beyond maxLen
if ( len + len1 > maxLen ) len1 = maxLen - len ;
memcpy ( buf + len , buf1 , len1 ) ;
len + = len1 ;
return len1 ;
}
2013-11-11 00:23:26 +01:00
I2NPMessage & operator = ( const I2NPMessage & other )
{
memcpy ( buf + offset , other . buf + other . offset , other . GetLength ( ) ) ;
len = offset + other . GetLength ( ) ;
2014-03-13 01:13:49 +01:00
from = other . from ;
2013-11-11 00:23:26 +01:00
return * this ;
2018-01-06 04:48:51 +01:00
}
2014-02-07 17:26:00 +01:00
// for SSU only
2018-01-06 04:48:51 +01:00
uint8_t * GetSSUHeader ( ) { return buf + offset + I2NP_HEADER_SIZE - I2NP_SHORT_HEADER_SIZE ; } ;
2014-02-07 17:26:00 +01:00
void FromSSU ( uint32_t msgID ) // we have received SSU message and convert it to regular
{
2015-01-02 05:00:33 +01:00
const uint8_t * ssu = GetSSUHeader ( ) ;
2015-01-02 23:39:35 +01:00
GetHeader ( ) [ I2NP_HEADER_TYPEID_OFFSET ] = ssu [ I2NP_SHORT_HEADER_TYPEID_OFFSET ] ; // typeid
2015-01-02 05:00:33 +01:00
SetMsgID ( msgID ) ;
SetExpiration ( bufbe32toh ( ssu + I2NP_SHORT_HEADER_EXPIRATION_OFFSET ) * 1000LL ) ;
SetSize ( len - offset - I2NP_HEADER_SIZE ) ;
SetChks ( 0 ) ;
2014-02-07 17:26:00 +01:00
}
2014-02-10 00:28:34 +01:00
uint32_t ToSSU ( ) // return msgID
{
2015-01-02 05:00:33 +01:00
uint8_t header [ I2NP_HEADER_SIZE ] ;
2015-01-02 23:39:35 +01:00
memcpy ( header , GetHeader ( ) , I2NP_HEADER_SIZE ) ;
2015-01-02 05:00:33 +01:00
uint8_t * ssu = GetSSUHeader ( ) ;
ssu [ I2NP_SHORT_HEADER_TYPEID_OFFSET ] = header [ I2NP_HEADER_TYPEID_OFFSET ] ; // typeid
htobe32buf ( ssu + I2NP_SHORT_HEADER_EXPIRATION_OFFSET , bufbe64toh ( header + I2NP_HEADER_EXPIRATION_OFFSET ) / 1000LL ) ;
len = offset + I2NP_SHORT_HEADER_SIZE + bufbe16toh ( header + I2NP_HEADER_SIZE_OFFSET ) ;
return bufbe32toh ( header + I2NP_HEADER_MSGID_OFFSET ) ;
2018-01-06 04:48:51 +01:00
}
2018-07-17 21:17:05 +02:00
// for NTCP2 only
uint8_t * GetNTCP2Header ( ) { return GetPayload ( ) - I2NP_NTCP2_HEADER_SIZE ; } ;
2018-07-18 17:16:40 +02:00
size_t GetNTCP2Length ( ) const { return GetPayloadLength ( ) + I2NP_NTCP2_HEADER_SIZE ; } ;
2018-07-17 21:17:05 +02:00
void FromNTCP2 ( )
{
const uint8_t * ntcp2 = GetNTCP2Header ( ) ;
memcpy ( GetHeader ( ) + I2NP_HEADER_TYPEID_OFFSET , ntcp2 + I2NP_HEADER_TYPEID_OFFSET , 5 ) ; // typeid + msgid
SetExpiration ( bufbe32toh ( ntcp2 + I2NP_HEADER_EXPIRATION_OFFSET ) * 1000LL ) ;
SetSize ( len - offset - I2NP_HEADER_SIZE ) ;
SetChks ( 0 ) ;
2020-03-01 11:25:50 +01:00
}
2018-07-17 21:17:05 +02:00
void ToNTCP2 ( )
{
uint8_t * ntcp2 = GetNTCP2Header ( ) ;
htobe32buf ( ntcp2 + I2NP_HEADER_EXPIRATION_OFFSET , bufbe64toh ( GetHeader ( ) + I2NP_HEADER_EXPIRATION_OFFSET ) / 1000LL ) ;
memcpy ( ntcp2 + I2NP_HEADER_TYPEID_OFFSET , GetHeader ( ) + I2NP_HEADER_TYPEID_OFFSET , 5 ) ; // typeid + msgid
}
2015-07-03 17:11:07 +02:00
2020-05-02 17:13:40 +02:00
void FillI2NPMessageHeader ( I2NPMessageType msgType , uint32_t replyMsgID = 0 , bool checksum = true ) ;
2015-07-03 17:11:07 +02:00
void RenewI2NPMessageHeader ( ) ;
2016-01-19 03:13:43 +01:00
bool IsExpired ( ) const ;
2018-01-06 04:48:51 +01:00
} ;
2014-07-30 22:52:35 +02:00
template < int sz >
struct I2NPMessageBuffer : public I2NPMessage
{
2014-07-31 00:20:42 +02:00
I2NPMessageBuffer ( ) { buf = m_Buffer ; maxLen = sz ; } ;
2016-01-01 23:39:12 +01:00
uint8_t m_Buffer [ sz + 32 ] ; // 16 alignment + 16 padding
2014-07-30 22:52:35 +02:00
} ;
2015-11-24 19:09:12 +01:00
std : : shared_ptr < I2NPMessage > NewI2NPMessage ( ) ;
std : : shared_ptr < I2NPMessage > NewI2NPShortMessage ( ) ;
2023-03-18 20:32:05 +01:00
std : : shared_ptr < I2NPMessage > NewI2NPMediumMessage ( ) ;
2021-06-27 21:49:57 +02:00
std : : shared_ptr < I2NPMessage > NewI2NPTunnelMessage ( bool endpoint ) ;
2015-11-24 19:09:12 +01:00
std : : shared_ptr < I2NPMessage > NewI2NPMessage ( size_t len ) ;
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateI2NPMessage ( I2NPMessageType msgType , const uint8_t * buf , size_t len , uint32_t replyMsgID = 0 ) ;
2016-01-05 20:29:18 +01:00
std : : shared_ptr < I2NPMessage > CreateI2NPMessage ( const uint8_t * buf , size_t len , std : : shared_ptr < i2p : : tunnel : : InboundTunnel > from = nullptr ) ;
2016-02-01 00:27:47 +01:00
std : : shared_ptr < I2NPMessage > CopyI2NPMessage ( std : : shared_ptr < I2NPMessage > msg ) ;
2015-06-24 16:45:58 +02:00
std : : shared_ptr < I2NPMessage > CreateDeliveryStatusMsg ( uint32_t msgID ) ;
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateRouterInfoDatabaseLookupMsg ( const uint8_t * key , const uint8_t * from ,
2015-01-04 23:25:16 +01:00
uint32_t replyTunnelID , bool exploratory = false , std : : set < i2p : : data : : IdentHash > * excludedPeers = nullptr ) ;
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateLeaseSetDatabaseLookupMsg ( const i2p : : data : : IdentHash & dest ,
2021-11-27 21:30:35 +01:00
const std : : set < i2p : : data : : IdentHash > & excludedFloodfills ,
2022-05-20 18:56:05 +02:00
std : : shared_ptr < const i2p : : tunnel : : InboundTunnel > replyTunnel ,
const uint8_t * replyKey , const uint8_t * replyTag , bool replyECIES = false ) ;
2015-11-03 15:15:49 +01:00
std : : shared_ptr < I2NPMessage > CreateDatabaseSearchReply ( const i2p : : data : : IdentHash & ident , std : : vector < i2p : : data : : IdentHash > routers ) ;
2018-01-06 04:48:51 +01:00
2021-02-06 20:49:42 +01:00
std : : shared_ptr < I2NPMessage > CreateDatabaseStoreMsg ( std : : shared_ptr < const i2p : : data : : RouterInfo > router = nullptr , uint32_t replyToken = 0 , std : : shared_ptr < const i2p : : tunnel : : InboundTunnel > replyTunnel = nullptr ) ;
2019-06-09 03:23:25 +02:00
std : : shared_ptr < I2NPMessage > CreateDatabaseStoreMsg ( const i2p : : data : : IdentHash & storeHash , std : : shared_ptr < const i2p : : data : : LeaseSet > leaseSet ) ; // for floodfill only
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateDatabaseStoreMsg ( std : : shared_ptr < const i2p : : data : : LocalLeaseSet > leaseSet , uint32_t replyToken = 0 , std : : shared_ptr < const i2p : : tunnel : : InboundTunnel > replyTunnel = nullptr ) ;
bool IsRouterInfoMsg ( std : : shared_ptr < I2NPMessage > msg ) ;
2016-01-05 01:56:46 +01:00
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateTunnelDataMsg ( const uint8_t * buf ) ;
std : : shared_ptr < I2NPMessage > CreateTunnelDataMsg ( uint32_t tunnelID , const uint8_t * payload ) ;
2021-06-27 21:49:57 +02:00
std : : shared_ptr < I2NPMessage > CreateEmptyTunnelDataMsg ( bool endpoint ) ;
2018-01-06 04:48:51 +01:00
2015-11-24 19:09:12 +01:00
std : : shared_ptr < I2NPMessage > CreateTunnelGatewayMsg ( uint32_t tunnelID , const uint8_t * buf , size_t len ) ;
2018-01-06 04:48:51 +01:00
std : : shared_ptr < I2NPMessage > CreateTunnelGatewayMsg ( uint32_t tunnelID , I2NPMessageType msgType ,
2013-11-11 00:23:26 +01:00
const uint8_t * buf , size_t len , uint32_t replyMsgID = 0 ) ;
2015-06-19 20:38:31 +02:00
std : : shared_ptr < I2NPMessage > CreateTunnelGatewayMsg ( uint32_t tunnelID , std : : shared_ptr < I2NPMessage > msg ) ;
2013-12-14 02:07:35 +01:00
2017-12-01 18:57:05 +01:00
size_t GetI2NPMessageLength ( const uint8_t * msg , size_t len ) ;
2023-05-08 17:33:40 +02:00
void HandleTunnelBuildI2NPMessage ( std : : shared_ptr < I2NPMessage > msg ) ;
2015-06-19 20:38:31 +02:00
void HandleI2NPMessage ( std : : shared_ptr < I2NPMessage > msg ) ;
2015-01-23 04:00:41 +01:00
class I2NPMessagesHandler
{
public :
~ I2NPMessagesHandler ( ) ;
2021-10-17 17:31:37 +02:00
void PutNextMessage ( std : : shared_ptr < I2NPMessage > & & msg ) ;
2015-01-23 04:00:41 +01:00
void Flush ( ) ;
2018-01-06 04:48:51 +01:00
2015-01-23 04:00:41 +01:00
private :
2015-06-19 20:38:31 +02:00
std : : vector < std : : shared_ptr < I2NPMessage > > m_TunnelMsgs , m_TunnelGatewayMsgs ;
2015-01-23 04:00:41 +01:00
} ;
2018-01-06 04:48:51 +01:00
}
2013-10-27 16:20:29 +01:00
# endif