lokinet/llarp/service/intro.cpp

109 lines
2.6 KiB
C++
Raw Normal View History

#include "intro.hpp"
2023-01-09 17:47:41 +00:00
#include <llarp/util/time.hpp>
namespace llarp::service
{
util::StatusObject
Introduction::ExtractStatus() const
{
util::StatusObject obj{
{"router", router.ToHex()},
{"path", path_id.ToHex()},
{"expiresAt", to_json(expiry)},
{"latency", to_json(latency)},
{"version", uint64_t(version)}};
return obj;
}
2019-02-08 19:43:25 +00:00
bool
Introduction::decode_key(const llarp_buffer_t& key, llarp_buffer_t* buf)
{
bool read = false;
if (!BEncodeMaybeReadDictEntry("k", router, read, key, buf))
return false;
if (!BEncodeMaybeReadDictInt("l", latency, read, key, buf))
return false;
if (!BEncodeMaybeReadDictEntry("p", path_id, read, key, buf))
return false;
if (!BEncodeMaybeReadDictInt("v", version, read, key, buf))
return false;
if (!BEncodeMaybeReadDictInt("x", expiry, read, key, buf))
return false;
return read;
}
2023-10-03 20:00:23 +00:00
Introduction::Introduction(std::string buf)
{
try
{
oxenc::bt_dict_consumer btdc{std::move(buf)};
router.from_string(btdc.require<std::string>("k"));
2023-10-03 20:00:23 +00:00
latency = std::chrono::milliseconds{btdc.require<uint64_t>("l")};
path_id.from_string(btdc.require<std::string>("p"));
expiry = std::chrono::milliseconds{btdc.require<uint64_t>("x")};
}
catch (...)
{
log::critical(intro_cat, "Error: Introduction failed to populate with bt encoded contents");
}
}
void
2023-10-03 20:00:23 +00:00
Introduction::bt_encode(oxenc::bt_list_producer& btlp) const
{
try
{
2023-10-03 20:00:23 +00:00
auto subdict = btlp.append_dict();
subdict.append("k", router.ToView());
subdict.append("l", latency.count());
subdict.append("p", path_id.ToView());
subdict.append("x", expiry.count());
}
catch (...)
{
log::critical(intro_cat, "Error: Introduction failed to bt encode contents!");
}
}
2019-02-24 23:46:37 +00:00
void
Introduction::bt_encode(oxenc::bt_dict_producer& subdict) const
{
try
{
subdict.append("k", router.ToView());
subdict.append("l", latency.count());
subdict.append("p", path_id.ToView());
subdict.append("x", expiry.count());
}
catch (...)
{
log::critical(intro_cat, "Error: Introduction failed to bt encode contents!");
}
}
void
Introduction::Clear()
{
router.Zero();
path_id.Zero();
latency = 0s;
expiry = 0s;
}
std::string
Introduction::ToString() const
{
return fmt::format(
"[Intro k={} l={} p={} v={} x={}]",
RouterID{router},
latency.count(),
path_id,
version,
expiry.count());
}
} // namespace llarp::service