3 local configmanager = require "core.configmanager";
4 local eventmanager = require "core.eventmanager";
6 local log = require "util.logger".init("hostmanager");
12 local hosts_loaded_once;
14 local function load_enabled_hosts(config)
15 local defined_hosts = config or configmanager.getconfig();
17 for host, host_config in pairs(defined_hosts) do
18 if host ~= "*" and (host_config.core.enabled == nil or host_config.core.enabled) then
19 activate(host, host_config);
22 eventmanager.fire_event("hosts-activated", defined_hosts);
23 hosts_loaded_once = true;
26 eventmanager.add_event_hook("server-starting", load_enabled_hosts);
28 function activate(host, host_config)
29 hosts[host] = {type = "local", connected = true, sessions = {}, host = host, s2sout = {} };
30 log((hosts_loaded_once and "info") or "debug", "Activated host: %s", host);
31 eventmanager.fire_event("host-activated", host, host_config);
34 function deactivate(host)
35 local host_session = hosts[host];
36 log("info", "Deactivating host: %s", host);
37 eventmanager.fire_event("host-deactivating", host, host_session);
39 -- Disconnect local users, s2s connections
40 for user, session_list in pairs(host_session.sessions) do
41 for resource, session in pairs(session_list) do
42 session:close("host-gone");
48 eventmanager.fire_event("host-deactivated", host);
49 log("info", "Deactivated host: %s", host);
52 function getconfig(name)