2018-09-22 10:17:22 +00:00
|
|
|
#ifndef LIBLLARP_DNS_DOTLOKILOOKUP_HPP
|
|
|
|
#define LIBLLARP_DNS_DOTLOKILOOKUP_HPP
|
|
|
|
|
|
|
|
#include <llarp/service/address.hpp>
|
|
|
|
//#include <llarp/service.hpp>
|
|
|
|
//#include <llarp/service/endpoint.hpp>
|
|
|
|
//#include <llarp/handlers/tun.hpp>
|
|
|
|
//#include <llarp/handlers/tun.hpp>
|
|
|
|
|
|
|
|
#include "dnsd.hpp"
|
|
|
|
|
2018-09-22 10:20:15 +00:00
|
|
|
typedef bool (*map_address_hook_func)(const llarp::service::Address &addr,
|
|
|
|
uint32_t ip);
|
2018-09-22 10:17:22 +00:00
|
|
|
|
2018-10-03 10:48:31 +00:00
|
|
|
/// dotLokiLookup context/config
|
2018-09-22 10:17:22 +00:00
|
|
|
struct dotLokiLookup
|
|
|
|
{
|
|
|
|
/// for timers (MAYBEFIXME? maybe we decouple this, yes pls have a generic
|
|
|
|
/// passed in)
|
|
|
|
struct llarp_logic *logic;
|
|
|
|
/// which ip tracker to use
|
|
|
|
struct dns_iptracker *ip_tracker;
|
2018-10-03 10:48:31 +00:00
|
|
|
|
2018-09-22 10:17:22 +00:00
|
|
|
/// tunEndpoint
|
2018-09-22 10:20:15 +00:00
|
|
|
// llarp::handlers::TunEndpoint *tunEndpoint; // is this even needed here?
|
2018-10-03 10:48:31 +00:00
|
|
|
void *user; // well dotLokiLookup current uses it to access the tun if
|
2018-09-22 10:17:22 +00:00
|
|
|
// pointer to tunendpoint properties?
|
2018-10-03 10:48:31 +00:00
|
|
|
// llarp::service::Context *hiddenServiceContext;
|
2018-09-22 10:17:22 +00:00
|
|
|
|
|
|
|
// need a way to reference
|
|
|
|
// 1. mapaddress
|
|
|
|
map_address_hook_func map_address_handler;
|
2018-09-22 10:20:15 +00:00
|
|
|
// std::function< bool(const llarp::service::Address &addr, uint32_t ip),
|
|
|
|
// llarp::handlers::TunEndpoint * > callback;
|
2018-09-22 10:17:22 +00:00
|
|
|
// 2. prefetch
|
|
|
|
};
|
|
|
|
|
|
|
|
dnsd_query_hook_response *
|
|
|
|
llarp_dotlokilookup_handler(std::string name, const struct sockaddr *from,
|
2018-10-03 10:48:31 +00:00
|
|
|
struct dnsd_question_request *const request);
|
2018-09-22 10:17:22 +00:00
|
|
|
|
|
|
|
#endif
|