lokinet/llarp/dht/recursiverouterlookup.cpp

73 lines
1.9 KiB
C++
Raw Normal View History

2019-01-22 01:14:02 +00:00
#include <dht/recursiverouterlookup.hpp>
#include <dht/context.hpp>
#include <dht/messages/findrouter.hpp>
#include <dht/messages/gotrouter.hpp>
2020-01-14 20:48:39 +00:00
#include <router/abstractrouter.hpp>
#include <router/i_rc_lookup_handler.hpp>
2019-07-30 23:42:13 +00:00
#include <utility>
2019-01-22 01:14:02 +00:00
namespace llarp
{
namespace dht
{
2019-08-02 09:27:27 +00:00
RecursiveRouterLookup::RecursiveRouterLookup(const TXOwner &_whoasked,
const RouterID &_target,
AbstractContext *ctx,
2019-01-22 01:14:02 +00:00
RouterLookupHandler result)
2019-08-02 09:27:27 +00:00
: TX< RouterID, RouterContact >(_whoasked, _target, ctx)
2019-07-30 23:42:13 +00:00
, resultHandler(std::move(result))
2019-01-22 01:14:02 +00:00
{
peersAsked.insert(ctx->OurKey());
}
bool
RecursiveRouterLookup::Validate(const RouterContact &rc) const
{
if(!rc.Verify(parent->Now()))
2019-01-22 01:14:02 +00:00
{
llarp::LogWarn("rc from lookup result is invalid");
return false;
}
return true;
}
void
RecursiveRouterLookup::Start(const TXOwner &peer)
{
parent->DHTSendTo(peer.node.as_array(),
new FindRouterMessage(peer.txid, target));
}
void
RecursiveRouterLookup::SendReply()
{
if(valuesFound.size())
{
RouterContact found;
for(const auto &rc : valuesFound)
{
2020-01-14 20:48:39 +00:00
if(found.OtherIsNewer(rc)
&& parent->GetRouter()->rcLookupHandler().CheckRC(rc))
found = rc;
}
valuesFound.clear();
valuesFound.emplace_back(found);
}
2019-01-22 01:14:02 +00:00
if(resultHandler)
{
resultHandler(valuesFound);
}
if(whoasked.node != parent->OurKey())
{
2019-01-22 01:14:02 +00:00
parent->DHTSendTo(
whoasked.node.as_array(),
2019-02-23 17:22:34 +00:00
new GotRouterMessage({}, whoasked.txid, valuesFound, false), false);
}
2019-01-22 01:14:02 +00:00
}
} // namespace dht
} // namespace llarp