annotate mod_s2s_reload_newcomponent/mod_s2s_reload_newcomponent.lua @ 5173:460f78654864

mod_muc_rtbl: also filter messages This was a bit tricky because we don't want to run the JIDs through SHA256 on each message. Took a while to come up with this simple plan of just caching the SHA256 of the JIDs on the occupants. This will leave some dirt in the occupants after unloading the module, but that should be ok; once they cycle the room, the hashes will be gone. This is direly needed, otherwise, there is a tight race between the moderation activities and the actors joining the room.
author Jonas Schäfer <jonas@wielicki.name>
date Tue, 21 Feb 2023 21:37:27 +0100
parents fe5bb7b13a59
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
213
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
1 local modulemanager = require "core.modulemanager";
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
2 local config = require "core.configmanager";
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
3
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
4 module.host = "*";
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
5
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
6 local function reload_components()
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
7 local defined_hosts = config.getconfig();
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
8
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
9 for host in pairs(defined_hosts) do
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
10 if (not hosts[host] and host ~= "*") then
214
7487f8b47662 mod_s2s_reload_newcomponent: fix debug logs
Gaurav <gauravsri@gmail.com>
parents: 213
diff changeset
11 module:log ("debug", "loading new component %s", host);
2781
fe5bb7b13a59 mod_s2s_reload_newcomponent: Fix to use imported configmanager instead of global
Matthew Wild <mwild1@gmail.com>
parents: 214
diff changeset
12 modulemanager.load(host, config.get(host, "core", "component_module"));
213
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
13 end
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
14 end;
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
15
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
16 return;
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
17 end
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
18
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
19 module:hook("config-reloaded", reload_components);
89051a926f74 initial creation of module for reloading new components
Gaurav <gauravsri@gmail.com>
parents:
diff changeset
20