lokinet/llarp/dht/publishservicejob.cpp

87 lines
2.4 KiB
C++
Raw Normal View History

2019-01-22 01:14:02 +00:00
#include <dht/publishservicejob.hpp>
#include <dht/context.hpp>
#include <dht/messages/pubintro.hpp>
#include <dht/messages/gotintro.hpp>
#include <path/path_context.hpp>
#include <routing/dht_message.hpp>
#include <router/abstractrouter.hpp>
2019-01-22 01:14:02 +00:00
#include <utility>
2019-01-22 01:14:02 +00:00
namespace llarp
{
namespace dht
{
2020-02-20 15:36:29 +00:00
PublishServiceJob::PublishServiceJob(
const TXOwner& asker,
const service::EncryptedIntroSet& introset_,
AbstractContext* ctx,
uint64_t relayOrder_)
: TX<TXOwner, service::EncryptedIntroSet>(asker, asker, ctx)
, relayOrder(relayOrder_)
, introset(introset_)
2019-01-22 01:14:02 +00:00
{
}
bool
PublishServiceJob::Validate(const service::EncryptedIntroSet& value) const
2019-01-22 01:14:02 +00:00
{
if (value.derivedSigningKey != introset.derivedSigningKey)
2019-01-22 01:14:02 +00:00
{
llarp::LogWarn("publish introset acknowledgement acked a different service");
2019-01-22 01:14:02 +00:00
return false;
}
2020-01-27 21:30:41 +00:00
const llarp_time_t now = llarp::time_now_ms();
return value.Verify(now);
2019-01-22 01:14:02 +00:00
}
void
PublishServiceJob::Start(const TXOwner& peer)
2019-01-22 01:14:02 +00:00
{
2020-01-27 21:30:41 +00:00
parent->DHTSendTo(
peer.node.as_array(), new PublishIntroMessage(introset, peer.txid, false, relayOrder));
2019-01-22 01:14:02 +00:00
}
void
PublishServiceJob::SendReply()
{
parent->DHTSendTo(whoasked.node.as_array(), new GotIntroMessage({introset}, whoasked.txid));
}
LocalPublishServiceJob::LocalPublishServiceJob(
const TXOwner& peer,
const PathID_t& fromID,
uint64_t _txid,
const service::EncryptedIntroSet& introset,
AbstractContext* ctx,
uint64_t relayOrder)
: PublishServiceJob(peer, introset, ctx, relayOrder), localPath(fromID), txid(_txid)
{
}
void
LocalPublishServiceJob::SendReply()
{
auto path =
parent->GetRouter()->pathContext().GetByUpstream(parent->OurKey().as_array(), localPath);
if (!path)
{
llarp::LogWarn(
"did not send reply for relayed dht request, no such local path "
"for pathid=",
localPath);
return;
}
routing::DHTMessage msg;
2020-03-01 17:33:54 +00:00
msg.M.emplace_back(new GotIntroMessage({introset}, txid));
if (!path->SendRoutingMessage(msg, parent->GetRouter()))
{
llarp::LogWarn(
"failed to send routing message when informing result of dht "
"request, pathid=",
localPath);
}
}
2019-01-22 01:14:02 +00:00
} // namespace dht
} // namespace llarp