lokinet/llarp/dht/messages/gotintro.hpp

65 lines
1.6 KiB
C++
Raw Normal View History

#ifndef LLARP_DHT_MESSAGES_GOT_INTRO_HPP
#define LLARP_DHT_MESSAGES_GOT_INTRO_HPP
2018-12-12 02:15:08 +00:00
2018-12-12 00:48:54 +00:00
#include <dht/message.hpp>
2018-12-12 02:15:08 +00:00
#include <service/IntroSet.hpp>
2018-07-20 04:50:28 +00:00
#include <vector>
namespace llarp
{
namespace dht
{
2018-11-08 15:15:02 +00:00
/// acknowledgement to PublishIntroMessage or reply to FindIntroMessage
struct GotIntroMessage : public IMessage
{
2018-11-08 15:15:02 +00:00
/// the found introsets
2018-07-20 04:50:28 +00:00
std::vector< llarp::service::IntroSet > I;
2018-11-08 15:15:02 +00:00
/// txid
uint64_t T = 0;
2018-11-08 15:15:02 +00:00
/// the key of a router closer in keyspace if iterative lookup
std::unique_ptr< Key_t > K;
GotIntroMessage(const Key_t& from) : IMessage(from)
{
}
2018-11-08 15:15:02 +00:00
/// for iterative reply
GotIntroMessage(const Key_t& from, const Key_t& closer, uint64_t txid)
: IMessage(from), T(txid), K(new Key_t(closer))
{
}
/// for recursive reply
2018-07-20 04:50:28 +00:00
GotIntroMessage(const std::vector< llarp::service::IntroSet >& results,
2018-07-18 03:10:21 +00:00
uint64_t txid);
~GotIntroMessage();
bool
BEncode(llarp_buffer_t* buf) const override;
bool
DecodeKey(llarp_buffer_t key, llarp_buffer_t* val) override;
virtual bool
HandleMessage(
llarp_dht_context* ctx,
std::vector< std::unique_ptr< IMessage > >& replies) const override;
};
struct RelayedGotIntroMessage final : public GotIntroMessage
{
RelayedGotIntroMessage() : GotIntroMessage({})
{
}
bool
HandleMessage(
llarp_dht_context* ctx,
std::vector< std::unique_ptr< IMessage > >& replies) const override;
};
} // namespace dht
} // namespace llarp
2018-08-29 20:40:26 +00:00
#endif