mirror of https://github.com/oxen-io/lokinet
add link level keepalive
remove debugging messages start handling more messagespull/1/head
parent
93f0e03958
commit
c51d29a0c6
@ -0,0 +1,12 @@
|
||||
#ifndef LLARP_ENCRYPTED_FRAME_HPP
|
||||
#define LLARP_ENCRYPTED_FRAME_HPP
|
||||
|
||||
#include <llarp/mem.h>
|
||||
#include <vector>
|
||||
|
||||
namespace llarp
|
||||
{
|
||||
typedef std::vector< byte_t > EncryptedFrame;
|
||||
}
|
||||
|
||||
#endif
|
@ -0,0 +1,102 @@
|
||||
#ifndef LLARP_RELAY_COMMIT_HPP
|
||||
#define LLARP_RELAY_COMMIT_HPP
|
||||
#include <llarp/crypto.h>
|
||||
#include <llarp/encrypted_frame.hpp>
|
||||
#include <vector>
|
||||
|
||||
namespace llarp
|
||||
{
|
||||
struct LR_CommitRecord
|
||||
{
|
||||
llarp_pubkey_t commkey;
|
||||
llarp_pubkey_t nextHop;
|
||||
llarp_tunnel_nonce_t nonce;
|
||||
uint64_t lifetime;
|
||||
uint64_t pathid;
|
||||
uint64_t version;
|
||||
|
||||
bool
|
||||
BDecode(llarp_buffer_t *buf);
|
||||
|
||||
bool
|
||||
BEncode(llarp_buffer_t *buf);
|
||||
};
|
||||
|
||||
struct LR_AcceptRecord
|
||||
{
|
||||
uint64_t pathid;
|
||||
uint64_t version;
|
||||
std::vector< byte_t > padding;
|
||||
|
||||
bool
|
||||
BDecode(llarp_buffer_t *buf);
|
||||
|
||||
bool
|
||||
BEncode(llarp_buffer_t *buf);
|
||||
};
|
||||
|
||||
struct LR_StatusMessage
|
||||
{
|
||||
std::vector< EncryptedFrame > replies;
|
||||
uint64_t version;
|
||||
|
||||
bool
|
||||
BDecode(llarp_buffer_t *buf);
|
||||
|
||||
bool
|
||||
BEncode(llarp_buffer_t *buf);
|
||||
};
|
||||
|
||||
struct LR_CommitMessage
|
||||
{
|
||||
std::vector< EncryptedFrame > frames;
|
||||
uint64_t version;
|
||||
|
||||
void
|
||||
Clear();
|
||||
|
||||
bool
|
||||
BDecode(llarp_buffer_t *buf);
|
||||
|
||||
bool
|
||||
BEncode(llarp_buffer_t *buf);
|
||||
};
|
||||
|
||||
struct AsyncPathDecryption
|
||||
{
|
||||
static void
|
||||
Decrypted(void *data);
|
||||
|
||||
LR_CommitMessage lrcm;
|
||||
LR_CommitRecord ourRecord;
|
||||
llarp_threadpool *worker = nullptr;
|
||||
llarp_crypto *crypto = nullptr;
|
||||
llarp_logic *logic = nullptr;
|
||||
llarp_thread_job result;
|
||||
|
||||
void
|
||||
AsyncDecryptOurHop();
|
||||
};
|
||||
|
||||
struct AsyncPathEncryption
|
||||
{
|
||||
static void
|
||||
EncryptedFrame(void *data);
|
||||
|
||||
std::vector< LR_CommitRecord > hops;
|
||||
LR_CommitMessage lrcm;
|
||||
llarp_threadpool *worker = nullptr;
|
||||
llarp_crypto *crypto = nullptr;
|
||||
llarp_logic *logic = nullptr;
|
||||
llarp_thread_job result;
|
||||
|
||||
void
|
||||
AsyncEncrypt();
|
||||
|
||||
private:
|
||||
void
|
||||
EncryptNext();
|
||||
};
|
||||
}
|
||||
|
||||
#endif
|
@ -0,0 +1,31 @@
|
||||
#ifndef LLARP_ENCODE_HPP
|
||||
#define LLARP_ENCODE_HPP
|
||||
#include "buffer.hpp"
|
||||
|
||||
namespace llarp
|
||||
{
|
||||
/// encode V as hex to stack
|
||||
/// null terminate
|
||||
/// return pointer to base of stack buffer on success otherwise returns
|
||||
/// nullptr
|
||||
template < typename V, typename Stack >
|
||||
const char*
|
||||
HexEncode(const V& value, Stack& stack)
|
||||
{
|
||||
size_t idx = 0;
|
||||
char* ptr = &stack[0];
|
||||
char* end = ptr + sizeof(stack);
|
||||
while(idx < value.size())
|
||||
{
|
||||
auto wrote = snprintf(ptr, end - ptr, "%.2x", value[idx]);
|
||||
if(wrote == -1)
|
||||
return nullptr;
|
||||
ptr += wrote;
|
||||
idx++;
|
||||
}
|
||||
*ptr = 0;
|
||||
return &stack[0];
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
@ -0,0 +1,41 @@
|
||||
#ifndef LLARP_LINK_ENCODER_HPP
|
||||
#define LLARP_LINK_ENCODER_HPP
|
||||
|
||||
#include <llarp/bencode.h>
|
||||
#include <llarp/buffer.h>
|
||||
#include <llarp/router_contact.h>
|
||||
|
||||
namespace llarp
|
||||
{
|
||||
/// encode Link Introduce Message onto a buffer
|
||||
/// if router is nullptr then the LIM's r member is omitted.
|
||||
bool
|
||||
EncodeLIM(llarp_buffer_t* buff, llarp_rc* router)
|
||||
{
|
||||
if(!bencode_start_dict(buff))
|
||||
return false;
|
||||
|
||||
// message type
|
||||
if(!bencode_write_bytestring(buff, "a", 1))
|
||||
return false;
|
||||
if(!bencode_write_bytestring(buff, "i", 1))
|
||||
return false;
|
||||
|
||||
// router contact
|
||||
if(router)
|
||||
{
|
||||
if(!bencode_write_bytestring(buff, "r", 1))
|
||||
return false;
|
||||
if(!llarp_rc_bencode(router, buff))
|
||||
return false;
|
||||
}
|
||||
|
||||
// version
|
||||
if(!bencode_write_version_entry(buff))
|
||||
return false;
|
||||
|
||||
return bencode_end(buff);
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue