#ifndef LLARP_RC_HPP #define LLARP_RC_HPP #include #include #include #include #include #include #include #include #include #define MAX_RC_SIZE (1024) #define NICKLEN (32) namespace llarp { /// NetID struct NetID final : public AlignedBuffer< 8 > { static NetID & DefaultValue(); NetID(); explicit NetID(const byte_t *val); explicit NetID(const NetID &other) = default; bool operator==(const NetID &other) const; bool operator!=(const NetID &other) const { return !(*this == other); } std::ostream & print(std::ostream &stream, int level, int spaces) const { Printer printer(stream, level, spaces); printer.printValue(ToString()); return stream; } std::string ToString() const; bool BDecode(llarp_buffer_t *buf); bool BEncode(llarp_buffer_t *buf) const; }; inline std::ostream & operator<<(std::ostream &out, const NetID &id) { return id.print(out, -1, -1); } /// RouterContact struct RouterContact { /// for unit tests static bool IgnoreBogons; static llarp_time_t Lifetime; static llarp_time_t UpdateInterval; RouterContact() { Clear(); } struct Hash { size_t operator()(const RouterContact &r) const { return PubKey::Hash()(r.pubkey); } }; // advertised addresses std::vector< AddressInfo > addrs; // network identifier NetID netID; // public encryption public key llarp::PubKey enckey; // public signing public key llarp::PubKey pubkey; // advertised exits std::vector< ExitInfo > exits; // signature llarp::Signature signature; /// node nickname, yw kee llarp::AlignedBuffer< NICKLEN > nickname; uint64_t last_updated = 0; uint64_t version = LLARP_PROTO_VERSION; util::StatusObject ExtractStatus() const; bool BEncode(llarp_buffer_t *buf) const; bool operator==(const RouterContact &other) const { return addrs == other.addrs && enckey == other.enckey && pubkey == other.pubkey && signature == other.signature && nickname == other.nickname && last_updated == other.last_updated && netID == other.netID; } bool operator<(const RouterContact &other) const { return pubkey < other.pubkey; } bool operator!=(const RouterContact &other) const { return !(*this == other); } void Clear(); bool IsExit() const { return exits.size() > 0; } bool BDecode(llarp_buffer_t *buf) { Clear(); return bencode_decode_dict(*this, buf); } bool DecodeKey(const llarp_buffer_t &k, llarp_buffer_t *buf); RouterContact & operator=(const RouterContact &other); bool HasNick() const; std::string Nick() const; bool IsPublicRouter() const; void SetNick(const std::string &nick); bool Verify(llarp_time_t now, bool allowExpired = true) const; bool Sign(const llarp::SecretKey &secret); /// does this RC expire soon? default delta is 1 minute bool ExpiresSoon(llarp_time_t now, llarp_time_t dlt = 60000) const; /// returns true if this RC is expired and should be removed bool IsExpired(llarp_time_t now) const; bool OtherIsNewer(const RouterContact &other) const { return last_updated < other.last_updated; } std::ostream & print(std::ostream &stream, int level, int spaces) const; bool Read(const char *fname); bool Write(const char *fname) const; private: bool VerifySignature() const; }; inline std::ostream & operator<<(std::ostream &out, const RouterContact &rc) { return rc.print(out, -1, -1); } using RouterLookupHandler = std::function< void(const std::vector< RouterContact > &) >; } // namespace llarp #endif