Mercurial > prosody-modules
view mod_s2s_blacklist/mod_s2s_blacklist.lua @ 5295:98d5acb93439
mod_authz_delegate: make resistant against startup order issues
There is no guarantee that the target_host gets activated and
initialized before the host this module is loaded on. As
add_default_permission is called during load time by many modules,
we need to be prepared to queue stuff.
author | Jonas Schäfer <jonas@wielicki.name> |
---|---|
date | Fri, 31 Mar 2023 16:56:42 +0200 |
parents | d958558e0058 |
children |
line wrap: on
line source
local st = require "util.stanza"; local blacklist = module:get_option_inherited_set("s2s_blacklist", {}); module:hook("route/remote", function (event) if blacklist:contains(event.to_host) then if event.stanza.attr.type ~= "error" then module:send(st.error_reply(event.stanza, "cancel", "not-allowed", "Communication with this domain is restricted")); end return true; end end, 100); module:hook("s2s-stream-features", function (event) if blacklist:contains(event.origin.from_host) then event.origin:close({ condition = "policy-violation"; text = "Communication with this domain is restricted"; }); end end, 1000);