#ifndef LLARP_SERVICE_INFO_HPP #define LLARP_SERVICE_INFO_HPP #include #include #include #include #include namespace llarp { namespace service { struct ServiceInfo { private: PubKey enckey; PubKey signkey; mutable Address m_CachedAddr; public: VanityNonce vanity; uint64_t version = LLARP_PROTO_VERSION; void RandomizeVanity() { vanity.Randomize(); } bool Verify(const llarp_buffer_t& payload, const Signature& sig) const; const PubKey& EncryptionPublicKey() const { if (m_CachedAddr.IsZero()) { CalculateAddress(m_CachedAddr.as_array()); } return enckey; } bool Update(const byte_t* sign, const byte_t* enc, const std::optional& nonce = {}); bool operator==(const ServiceInfo& other) const { return enckey == other.enckey && signkey == other.signkey && version == other.version && vanity == other.vanity; } bool operator!=(const ServiceInfo& other) const { return !(*this == other); } bool operator<(const ServiceInfo& other) const { return Addr() < other.Addr(); } std::ostream& print(std::ostream& stream, int level, int spaces) const; /// .loki address std::string Name() const; bool UpdateAddr(); const Address& Addr() const { if (m_CachedAddr.IsZero()) { CalculateAddress(m_CachedAddr.as_array()); } return m_CachedAddr; } /// calculate our address bool CalculateAddress(std::array& data) const; bool BDecode(llarp_buffer_t* buf) { if (not bencode_decode_dict(*this, buf)) return false; return UpdateAddr(); } bool BEncode(llarp_buffer_t* buf) const; bool DecodeKey(const llarp_buffer_t& key, llarp_buffer_t* buf); }; inline std::ostream& operator<<(std::ostream& out, const ServiceInfo& i) { return i.print(out, -1, -1); } } // namespace service } // namespace llarp #endif