// The Construct // // Copyright (C) The Construct Developers, Authors & Contributors // Copyright (C) 2016-2020 Jason Volk <jason@zemos.net> // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice is present in all copies. The // full license for this software is available in the LICENSE file. namespace ircd::m::burst { static void cache_warming(const node &, const opts &); static void gossip(const node &, const opts &); extern conf::item<seconds> cache_warmup_time; } decltype(ircd::m::burst::log) ircd::m::burst::log { "m.burst" }; decltype(ircd::m::burst::cache_warmup_time) ircd::m::burst::cache_warmup_time { { "name", "ircd.m.cache_warmup_time" }, { "default", 3600L }, }; ircd::m::burst::burst::burst(const node &node, const opts &opts) try { log::debug { log, "Bursting to node %s", string_view{node.node_id}, }; fed::clear_error(node.node_id); if(opts.cache_warming) if(ircd::uptime() < seconds(cache_warmup_time)) cache_warming(node, opts); if(opts.gossip) gossip(node, opts); } catch(const ctx::interrupted &e) { throw; } catch(const std::exception &e) { log::derror { log, "Burst to '%s' :%s", string_view{node.node_id}, e.what() }; } void ircd::m::burst::gossip(const node &node, const opts &opts) try { } catch(const ctx::interrupted &e) { throw; } catch(const std::exception &e) { log::derror { log, "Gossip to '%s' :%s", string_view{node.node_id}, e.what() }; } /// We can smoothly warmup some memory caches after daemon startup as the /// requests trickle in from remote servers. This function is invoked after /// a remote contacts and reveals its identity with the X-Matrix verification. void ircd::m::burst::cache_warming(const node &node, const opts &opts) try { // Make a query through SRV and A records. //net::dns::resolve(origin, net::dns::prefetch_ipport); } catch(const ctx::interrupted &e) { throw; } catch(const std::exception &e) { log::derror { log, "Cache warming for '%s' :%s", string_view{node.node_id}, e.what() }; }