lokinet/llarp/service/info.cpp

106 lines
2.4 KiB
C++
Raw Permalink Normal View History

#include "info.hpp"
#include <llarp/crypto/crypto.hpp>
#include "address.hpp"
#include <llarp/util/buffer.hpp>
2018-12-12 02:15:08 +00:00
2018-07-16 03:32:13 +00:00
#include <cassert>
2018-10-23 12:40:34 +00:00
#include <sodium/crypto_generichash.h>
2020-01-27 21:30:41 +00:00
#include <sodium/crypto_sign_ed25519.h>
2018-12-12 02:15:08 +00:00
2018-07-16 03:32:13 +00:00
namespace llarp
{
namespace service
{
bool
ServiceInfo::Verify(const llarp_buffer_t& payload, const Signature& sig) const
{
return CryptoManager::instance()->verify(signkey, payload, sig);
}
2020-01-27 21:30:41 +00:00
bool
2020-05-20 22:48:13 +00:00
ServiceInfo::Update(
const byte_t* sign, const byte_t* enc, const std::optional<VanityNonce>& nonce)
2020-01-27 21:30:41 +00:00
{
signkey = sign;
enckey = enc;
if (nonce)
2020-01-27 21:30:41 +00:00
{
vanity = *nonce;
2020-01-27 21:30:41 +00:00
}
return UpdateAddr();
}
2018-07-16 03:32:13 +00:00
bool
ServiceInfo::DecodeKey(const llarp_buffer_t& key, llarp_buffer_t* val)
2018-07-16 03:32:13 +00:00
{
bool read = false;
if (!BEncodeMaybeReadDictEntry("e", enckey, read, key, val))
2018-07-16 03:32:13 +00:00
return false;
if (!BEncodeMaybeReadDictEntry("s", signkey, read, key, val))
2018-07-16 03:32:13 +00:00
return false;
if (!BEncodeMaybeReadDictInt("v", version, read, key, val))
2018-07-16 03:32:13 +00:00
return false;
if (!BEncodeMaybeReadDictEntry("x", vanity, read, key, val))
2018-07-16 03:32:13 +00:00
return false;
return read;
}
bool
ServiceInfo::BEncode(llarp_buffer_t* buf) const
{
if (!bencode_start_dict(buf))
2018-07-16 03:32:13 +00:00
return false;
if (!BEncodeWriteDictEntry("e", enckey, buf))
2018-07-16 03:32:13 +00:00
return false;
if (!BEncodeWriteDictEntry("s", signkey, buf))
2018-07-16 03:32:13 +00:00
return false;
2022-05-26 15:59:44 +00:00
if (!BEncodeWriteDictInt("v", llarp::constants::proto_version, buf))
2018-07-16 03:32:13 +00:00
return false;
if (!vanity.IsZero())
2018-07-16 03:32:13 +00:00
{
if (!BEncodeWriteDictEntry("x", vanity, buf))
2018-07-16 03:32:13 +00:00
return false;
}
return bencode_end(buf);
}
std::string
ServiceInfo::Name() const
{
if (m_CachedAddr.IsZero())
2018-07-18 03:10:21 +00:00
{
Address addr;
CalculateAddress(addr.as_array());
2018-07-18 03:10:21 +00:00
return addr.ToString();
}
return m_CachedAddr.ToString();
2018-07-16 03:32:13 +00:00
}
bool
ServiceInfo::CalculateAddress(std::array<byte_t, 32>& data) const
2018-07-16 03:32:13 +00:00
{
2020-01-27 21:30:41 +00:00
data = signkey.as_array();
return true;
2018-07-16 03:32:13 +00:00
}
2018-07-18 03:10:21 +00:00
bool
ServiceInfo::UpdateAddr()
{
if (m_CachedAddr.IsZero())
2019-12-14 18:50:52 +00:00
{
return CalculateAddress(m_CachedAddr.as_array());
}
return true;
2018-07-18 03:10:21 +00:00
}
std::string
ServiceInfo::ToString() const
{
2022-07-18 17:56:09 +00:00
return fmt::format("[ServiceInfo e={} s={} v={} x={}]", enckey, signkey, version, vanity);
}
2018-07-16 03:32:13 +00:00
} // namespace service
2018-10-23 11:29:37 +00:00
} // namespace llarp