lokinet/llarp/service/info.hpp

155 lines
3.3 KiB
C++
Raw Normal View History

2018-07-09 17:32:11 +00:00
#ifndef LLARP_SERVICE_INFO_HPP
#define LLARP_SERVICE_INFO_HPP
2018-12-12 02:15:08 +00:00
#include <crypto/types.hpp>
#include <service/address.hpp>
#include <service/vanity.hpp>
#include <util/bencode.hpp>
2018-07-09 17:32:11 +00:00
#include <absl/types/optional.h>
2018-07-09 17:32:11 +00:00
namespace llarp
{
struct Crypto;
2018-07-09 17:32:11 +00:00
namespace service
{
struct ServiceInfo final : public IBEncodeMessage
2018-07-09 17:32:11 +00:00
{
2018-08-10 21:34:11 +00:00
private:
PubKey enckey;
PubKey signkey;
2018-08-10 21:34:11 +00:00
public:
2018-11-27 21:48:12 +00:00
VanityNonce vanity;
using OptNonce = absl::optional< VanityNonce >;
2018-08-10 21:34:11 +00:00
ServiceInfo() = default;
2018-11-08 12:31:50 +00:00
ServiceInfo(ServiceInfo&& other)
2018-08-10 21:34:11 +00:00
{
enckey = std::move(other.enckey);
signkey = std::move(other.signkey);
version = std::move(other.version);
vanity = std::move(other.vanity);
m_CachedAddr = std::move(other.m_CachedAddr);
}
ServiceInfo(const ServiceInfo& other)
: IBEncodeMessage(other.version)
, enckey(other.enckey)
2018-08-29 20:40:26 +00:00
, signkey(other.signkey)
, vanity(other.vanity)
, m_CachedAddr(other.m_CachedAddr)
2018-08-10 21:34:11 +00:00
{
2018-08-29 20:40:26 +00:00
version = other.version;
2018-08-10 21:34:11 +00:00
}
void
RandomizeVanity()
{
vanity.Randomize();
}
bool
Verify(Crypto* crypto, const llarp_buffer_t& payload,
const Signature& sig) const;
2018-08-10 21:34:11 +00:00
const PubKey&
EncryptionPublicKey() const
2018-08-10 21:34:11 +00:00
{
return enckey;
}
2018-07-09 17:32:11 +00:00
2018-08-10 21:34:11 +00:00
bool
Update(const byte_t* enc, const byte_t* sign,
const OptNonce& nonce = OptNonce())
2018-08-10 21:34:11 +00:00
{
enckey = enc;
signkey = sign;
2018-11-27 21:54:06 +00:00
if(nonce)
{
vanity = nonce.value();
}
2018-08-10 21:34:11 +00:00
return UpdateAddr();
}
2018-07-09 17:32:11 +00:00
bool
operator==(const ServiceInfo& other) const
{
return enckey == other.enckey && signkey == other.signkey
&& version == other.version && vanity == other.vanity;
}
2018-08-10 21:34:11 +00:00
bool
operator!=(const ServiceInfo& other) const
{
return !(*this == other);
}
2018-07-09 17:32:11 +00:00
ServiceInfo&
operator=(const ServiceInfo& other)
{
enckey = other.enckey;
signkey = other.signkey;
version = other.version;
vanity = other.vanity;
2018-09-17 15:32:37 +00:00
version = other.version;
2018-07-18 03:10:21 +00:00
UpdateAddr();
2018-07-09 17:32:11 +00:00
return *this;
}
2018-07-09 17:32:11 +00:00
2018-07-18 03:10:21 +00:00
bool
operator<(const ServiceInfo& other) const
{
return Addr() < other.Addr();
}
2019-02-24 23:46:37 +00:00
std::ostream&
print(std::ostream& stream, int level, int spaces) const;
2018-07-09 17:32:11 +00:00
2018-08-10 21:34:11 +00:00
/// .loki address
2018-07-16 03:32:13 +00:00
std::string
Name() const;
2018-07-18 03:10:21 +00:00
bool
UpdateAddr();
const Address&
Addr() const
{
return m_CachedAddr;
}
2018-07-09 17:32:11 +00:00
/// calculate our address
bool CalculateAddress(std::array< byte_t, 32 >& data) const;
2018-07-09 17:32:11 +00:00
2018-07-19 04:58:39 +00:00
bool
BDecode(llarp_buffer_t* buf) override
2018-07-19 04:58:39 +00:00
{
2018-08-10 21:34:11 +00:00
if(IBEncodeMessage::BDecode(buf))
return CalculateAddress(m_CachedAddr.as_array());
2018-08-10 21:34:11 +00:00
return false;
2018-07-19 04:58:39 +00:00
}
2018-07-09 17:32:11 +00:00
bool
BEncode(llarp_buffer_t* buf) const override;
2018-07-09 17:32:11 +00:00
bool
DecodeKey(const llarp_buffer_t& key, llarp_buffer_t* buf) override;
2018-07-18 03:10:21 +00:00
private:
Address m_CachedAddr;
2018-07-09 17:32:11 +00:00
};
2019-02-24 23:46:37 +00:00
inline std::ostream&
operator<<(std::ostream& out, const ServiceInfo& i)
{
return i.print(out, -1, -1);
}
2018-07-09 17:32:11 +00:00
} // namespace service
} // namespace llarp
2018-08-29 20:40:26 +00:00
#endif