0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-12-26 07:23:53 +01:00

modules/s_listen: Allow connections only after runlevel RUN; add log msgs.

This commit is contained in:
Jason Volk 2019-01-18 09:47:32 -08:00
parent aeea524ac9
commit 0c3bf20d33

View file

@ -18,6 +18,7 @@ static bool load_listener(const m::event &);
extern "C" bool unload_listener(const string_view &name);
extern "C" bool load_listener(const string_view &name);
static void init_listeners();
static void on_run();
static void on_unload();
static void on_load();
@ -27,6 +28,13 @@ IRCD_MODULE
"Server listeners", on_load, on_unload
};
const ircd::run::changed
_on_run{[](const auto &level)
{
if(level == run::level::RUN)
on_run();
}};
/// Active listener state
decltype(listeners)
listeners;
@ -55,9 +63,28 @@ on_load()
void
on_unload()
{
log::debug
{
"Clearing %zu listeners...",
listeners.size()
};
listeners.clear();
}
void
on_run()
{
log::debug
{
"Allowing %zu listeners to accept connections...",
listeners.size()
};
for(auto &listener : listeners)
listener.start();
}
void
init_listeners()
{
@ -159,7 +186,7 @@ load_listener(const m::event &event)
}
static bool
_listener_proffer(net::listener &,
_listener_proffer(net::listener &listener,
const net::ipport &ipport)
{
if(unlikely(ircd::run::level != ircd::run::level::RUN))
@ -174,6 +201,10 @@ _listener_proffer(net::listener &,
return false;
}
// Sets the asynchronous handler for the next accept. We can play with
// delaying this call under certain conditions to provide flow control.
listener.start();
if(unlikely(client::map.size() >= size_t(client::settings::max_client)))
{
log::warning