0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-20 11:31:51 +01:00

ircd::net::dns: Expose more cache utils to public interface.

This commit is contained in:
Jason Volk 2019-03-24 12:55:59 -07:00
parent 59b0b633cb
commit a1ac9cb356
4 changed files with 64 additions and 29 deletions
include/ircd/net
ircd
modules

View file

@ -83,6 +83,10 @@ namespace ircd::net::dns::cache
{ {
using closure = std::function<bool (const string_view &, const json::object &)>; using closure = std::function<bool (const string_view &, const json::object &)>;
bool is_error(const json::object &rr);
time_t get_ttl(const json::object &rr);
bool expired(const json::object &rr, const time_t &rr_ts, const time_t &min_ttl);
bool expired(const json::object &rr, const time_t &rr_ts);
string_view make_type(const mutable_buffer &out, const string_view &); string_view make_type(const mutable_buffer &out, const string_view &);
string_view make_type(const mutable_buffer &out, const uint16_t &); string_view make_type(const mutable_buffer &out, const uint16_t &);

View file

@ -3507,6 +3507,63 @@ ircd::net::dns::cache::make_type(const mutable_buffer &out,
}; };
} }
bool
ircd::net::dns::cache::expired(const json::object &rr,
const time_t &rr_ts)
{
static mods::import<conf::item<seconds>> min_ttl
{
"s_dns", "ircd::net::dns::cache::min_ttl"
};
static mods::import<conf::item<seconds>> error_ttl
{
"s_dns", "ircd::net::dns::cache::error_ttl"
};
const conf::item<seconds> &min_ttl_item
{
static_cast<conf::item<seconds> &>(min_ttl)
};
const conf::item<seconds> &error_ttl_item
{
static_cast<conf::item<seconds> &>(error_ttl)
};
const seconds &min_seconds(min_ttl_item);
const seconds &err_seconds(error_ttl_item);
const time_t &min
{
is_error(rr)?
err_seconds.count():
min_seconds.count()
};
return expired(rr, rr_ts, min);
}
bool
ircd::net::dns::cache::expired(const json::object &rr,
const time_t &rr_ts,
const time_t &min_ttl)
{
const auto ttl(get_ttl(rr));
return rr_ts + std::max(ttl, min_ttl) < ircd::time();
}
time_t
ircd::net::dns::cache::get_ttl(const json::object &rr)
{
return rr.get<time_t>("ttl", 0L);
}
bool
ircd::net::dns::cache::is_error(const json::object &rr)
{
return rr.has("error");
}
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
// //
// net/ipport.h // net/ipport.h

View file

@ -760,29 +760,6 @@ ircd::net::dns::cache::call_waiter(const string_view &type,
return true; return true;
} }
bool
ircd::net::dns::cache::expired(const json::object &rr,
const time_t &ts)
{
const auto ttl(get_ttl(rr));
return ts + ttl < ircd::time();
}
time_t
ircd::net::dns::cache::get_ttl(const json::object &rr)
{
const seconds &min_ttl_s(min_ttl);
const seconds &err_ttl_s(error_ttl);
const time_t min_ttl_t(min_ttl_s.count());
const time_t err_ttl_t(err_ttl_s.count());
const time_t rr_ttl
{
rr.get<time_t>("ttl", err_ttl_t)
};
return std::max(rr_ttl, min_ttl_t);
}
// //
// cache room creation // cache room creation
// //

View file

@ -34,15 +34,12 @@ namespace ircd::net::dns::cache
{ {
struct waiter; struct waiter;
static time_t get_ttl(const json::object &rr);
static bool expired(const json::object &rr, const time_t &ts);
static bool call_waiter(const string_view &, const string_view &, const json::array &, waiter &); static bool call_waiter(const string_view &, const string_view &, const json::array &, waiter &);
static void handle(const m::event &, m::vm::eval &); static void handle(const m::event &, m::vm::eval &);
extern conf::item<seconds> min_ttl; extern conf::item<seconds> min_ttl IRCD_MODULE_EXPORT_DATA;
extern conf::item<seconds> error_ttl; extern conf::item<seconds> error_ttl IRCD_MODULE_EXPORT_DATA;
extern conf::item<seconds> nxdomain_ttl; extern conf::item<seconds> nxdomain_ttl IRCD_MODULE_EXPORT_DATA;
extern const m::room::id::buf room_id; extern const m::room::id::buf room_id;
extern m::hookfn<m::vm::eval &> hook; extern m::hookfn<m::vm::eval &> hook;