2018-07-11 13:20:14 +00:00
|
|
|
|
|
|
|
#include <llarp/dht/context.hpp>
|
|
|
|
#include <llarp/dht/messages/gotintro.hpp>
|
|
|
|
#include <llarp/messages/dht.hpp>
|
|
|
|
#include "router.hpp"
|
|
|
|
|
|
|
|
namespace llarp
|
|
|
|
{
|
|
|
|
namespace dht
|
|
|
|
{
|
2018-07-18 03:10:21 +00:00
|
|
|
GotIntroMessage::GotIntroMessage(
|
2018-07-20 04:50:28 +00:00
|
|
|
const std::vector< llarp::service::IntroSet > &results, uint64_t tx)
|
2018-07-19 04:58:39 +00:00
|
|
|
: IMessage({}), I(results), T(tx)
|
2018-07-11 13:20:14 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
GotIntroMessage::~GotIntroMessage()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
GotIntroMessage::HandleMessage(llarp_dht_context *ctx,
|
|
|
|
std::vector< IMessage * > &replies) const
|
2018-07-12 13:43:37 +00:00
|
|
|
{
|
|
|
|
auto &dht = ctx->impl;
|
|
|
|
auto crypto = &dht.router->crypto;
|
2018-07-18 20:58:16 +00:00
|
|
|
|
|
|
|
for(const auto &introset : I)
|
2018-07-12 13:43:37 +00:00
|
|
|
{
|
|
|
|
if(!introset.VerifySignature(crypto))
|
|
|
|
{
|
|
|
|
llarp::LogWarn(
|
2018-07-18 20:58:16 +00:00
|
|
|
"Invalid introset signature while handling direct GotIntro "
|
|
|
|
"from ",
|
2018-07-12 13:43:37 +00:00
|
|
|
From);
|
|
|
|
return false;
|
|
|
|
}
|
2018-07-18 20:58:16 +00:00
|
|
|
}
|
2018-08-29 20:40:26 +00:00
|
|
|
TXOwner owner(From, T);
|
|
|
|
auto tagLookup = dht.pendingTagLookups.GetPendingLookupFrom(owner);
|
|
|
|
if(tagLookup)
|
2018-07-18 20:58:16 +00:00
|
|
|
{
|
2018-08-29 20:40:26 +00:00
|
|
|
dht.pendingTagLookups.Inform(owner, tagLookup->target, I);
|
2018-07-12 13:43:37 +00:00
|
|
|
return true;
|
|
|
|
}
|
2018-08-29 20:40:26 +00:00
|
|
|
auto serviceLookup =
|
|
|
|
dht.pendingIntrosetLookups.GetPendingLookupFrom(owner);
|
|
|
|
if(serviceLookup)
|
2018-07-18 20:58:16 +00:00
|
|
|
{
|
2018-08-29 20:40:26 +00:00
|
|
|
dht.pendingIntrosetLookups.Inform(owner, serviceLookup->target, I);
|
|
|
|
return true;
|
2018-07-18 20:58:16 +00:00
|
|
|
}
|
2018-08-29 20:40:26 +00:00
|
|
|
llarp::LogError("no pending TX for GIM from ", From, " txid=", T);
|
|
|
|
return false;
|
2018-07-12 13:43:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
RelayedGotIntroMessage::HandleMessage(
|
|
|
|
llarp_dht_context *ctx, std::vector< IMessage * > &replies) const
|
2018-07-11 13:20:14 +00:00
|
|
|
{
|
|
|
|
// TODO: implement me better?
|
2018-07-11 16:11:19 +00:00
|
|
|
auto pathset = ctx->impl.router->paths.GetLocalPathSet(pathID);
|
|
|
|
if(pathset)
|
2018-07-11 13:20:14 +00:00
|
|
|
{
|
2018-07-11 16:11:19 +00:00
|
|
|
return pathset->HandleGotIntroMessage(this);
|
2018-07-11 13:20:14 +00:00
|
|
|
}
|
2018-07-11 16:11:19 +00:00
|
|
|
llarp::LogWarn("No path for got intro message pathid=", pathID);
|
2018-07-11 13:20:14 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
GotIntroMessage::DecodeKey(llarp_buffer_t key, llarp_buffer_t *buf)
|
|
|
|
{
|
|
|
|
if(llarp_buffer_eq(key, "I"))
|
|
|
|
{
|
2018-07-20 04:50:28 +00:00
|
|
|
return BEncodeReadList(I, buf);
|
2018-07-11 13:20:14 +00:00
|
|
|
}
|
|
|
|
bool read = false;
|
|
|
|
if(!BEncodeMaybeReadDictInt("T", T, read, key, buf))
|
|
|
|
return false;
|
|
|
|
if(!BEncodeMaybeReadDictInt("V", version, read, key, buf))
|
|
|
|
return false;
|
|
|
|
return read;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
GotIntroMessage::BEncode(llarp_buffer_t *buf) const
|
|
|
|
{
|
|
|
|
if(!bencode_start_dict(buf))
|
|
|
|
return false;
|
|
|
|
if(!BEncodeWriteDictMsgType(buf, "A", "G"))
|
|
|
|
return false;
|
|
|
|
if(!BEncodeWriteDictList("I", I, buf))
|
|
|
|
return false;
|
2018-07-23 21:59:43 +00:00
|
|
|
if(!BEncodeWriteDictInt("T", T, buf))
|
2018-07-11 13:20:14 +00:00
|
|
|
return false;
|
2018-07-23 21:59:43 +00:00
|
|
|
if(!BEncodeWriteDictInt("V", version, buf))
|
2018-07-11 13:20:14 +00:00
|
|
|
return false;
|
|
|
|
return bencode_end(buf);
|
|
|
|
}
|
2018-07-12 13:43:37 +00:00
|
|
|
} // namespace dht
|
2018-08-29 20:40:26 +00:00
|
|
|
} // namespace llarp
|