mirror of
https://github.com/oxen-io/lokinet.git
synced 2024-11-17 15:25:35 +00:00
139 lines
3.1 KiB
C++
139 lines
3.1 KiB
C++
#ifndef LLARP_SERVICE_INTROSET_HPP
|
|
#define LLARP_SERVICE_INTROSET_HPP
|
|
#include <llarp/time.h>
|
|
#include <iostream>
|
|
#include <llarp/bencode.hpp>
|
|
#include <llarp/crypto.hpp>
|
|
#include <llarp/pow.hpp>
|
|
#include <llarp/service/Info.hpp>
|
|
#include <llarp/service/Intro.hpp>
|
|
#include <llarp/service/tag.hpp>
|
|
|
|
#include <vector>
|
|
|
|
namespace llarp
|
|
{
|
|
namespace service
|
|
{
|
|
constexpr std::size_t MAX_INTROSET_SIZE = 4096;
|
|
// 10 seconds clock skew permitted for introset expiration
|
|
constexpr llarp_time_t MAX_INTROSET_TIME_DELTA = (10 * 1000);
|
|
struct IntroSet : public llarp::IBEncodeMessage
|
|
{
|
|
ServiceInfo A;
|
|
std::vector< Introduction > I;
|
|
PQPubKey K;
|
|
Tag topic;
|
|
llarp::PoW* W = nullptr;
|
|
llarp::Signature Z;
|
|
|
|
IntroSet() = default;
|
|
|
|
IntroSet(IntroSet&& other)
|
|
{
|
|
A = std::move(other.A);
|
|
I = std::move(other.I);
|
|
K = std::move(other.K);
|
|
version = std::move(other.version);
|
|
topic = std::move(other.topic);
|
|
W = std::move(other.W);
|
|
Z = std::move(other.Z);
|
|
}
|
|
|
|
IntroSet(const IntroSet& other)
|
|
{
|
|
A = other.A;
|
|
I = other.I;
|
|
K = other.K;
|
|
version = other.version;
|
|
topic = other.topic;
|
|
if(other.W)
|
|
W = new llarp::PoW(*other.W);
|
|
Z = other.Z;
|
|
}
|
|
|
|
~IntroSet();
|
|
|
|
IntroSet&
|
|
operator=(const IntroSet& other)
|
|
{
|
|
A = other.A;
|
|
I = other.I;
|
|
K = other.K;
|
|
version = other.version;
|
|
topic = other.topic;
|
|
if(W)
|
|
delete W;
|
|
if(other.W)
|
|
W = new llarp::PoW(*other.W);
|
|
Z = other.Z;
|
|
return *this;
|
|
}
|
|
|
|
bool
|
|
operator<(const IntroSet& other) const
|
|
{
|
|
return A < other.A;
|
|
}
|
|
|
|
bool
|
|
OtherIsNewer(const IntroSet& other) const
|
|
{
|
|
return GetNewestIntroExpiration() < other.GetNewestIntroExpiration();
|
|
}
|
|
|
|
friend std::ostream&
|
|
operator<<(std::ostream& out, const IntroSet& i)
|
|
{
|
|
out << "A=[" << i.A << "] I=[";
|
|
for(const auto& intro : i.I)
|
|
{
|
|
out << intro << ",";
|
|
}
|
|
out << "]";
|
|
out << "K=" << i.K;
|
|
auto topic = i.topic.ToString();
|
|
if(topic.size())
|
|
{
|
|
out << " topic=" << topic;
|
|
}
|
|
else
|
|
{
|
|
out << " topic=" << i.topic;
|
|
}
|
|
if(i.W)
|
|
{
|
|
out << " W=" << *i.W;
|
|
}
|
|
return out << " V=" << i.version << " Z=" << i.Z;
|
|
}
|
|
|
|
llarp_time_t
|
|
GetNewestIntroExpiration() const
|
|
{
|
|
llarp_time_t t = 0;
|
|
for(const auto& intro : I)
|
|
t = std::max(intro.expiresAt, t);
|
|
return t;
|
|
}
|
|
|
|
bool
|
|
HasExpiredIntros(llarp_time_t now) const;
|
|
|
|
bool
|
|
IsExpired(llarp_time_t now) const;
|
|
|
|
bool
|
|
BEncode(llarp_buffer_t* buf) const;
|
|
|
|
bool
|
|
DecodeKey(llarp_buffer_t key, llarp_buffer_t* buf);
|
|
|
|
bool
|
|
Verify(llarp_crypto* crypto) const;
|
|
};
|
|
} // namespace service
|
|
} // namespace llarp
|
|
|
|
#endif
|