feat: Adds a new option to disable lobby for guests. (#7094)
* feat: Adds a new option to disable lobby for guests. * squash: Rename config option. * squash: Comment update.
This commit is contained in:
parent
311d1c67ba
commit
6fbba52c6d
|
@ -33,6 +33,13 @@ log("debug",
|
||||||
tostring(host), tostring(token_util.appId), tostring(token_util.appSecret),
|
tostring(host), tostring(token_util.appId), tostring(token_util.appSecret),
|
||||||
tostring(token_util.allowEmptyToken));
|
tostring(token_util.allowEmptyToken));
|
||||||
|
|
||||||
|
-- option to disable room modification (sending muc config form) for guest that do not provide token
|
||||||
|
local require_token_for_moderation;
|
||||||
|
local function load_config()
|
||||||
|
require_token_for_moderation = module:get_option_boolean("token_verification_require_token_for_moderation");
|
||||||
|
end
|
||||||
|
load_config();
|
||||||
|
|
||||||
local function verify_user(session, stanza)
|
local function verify_user(session, stanza)
|
||||||
log("debug", "Session token: %s, session room: %s",
|
log("debug", "Session token: %s, session room: %s",
|
||||||
tostring(session.auth_token),
|
tostring(session.auth_token),
|
||||||
|
@ -70,3 +77,30 @@ module:hook("muc-occupant-pre-join", function(event)
|
||||||
log("debug", "pre join: %s %s", tostring(room), tostring(stanza));
|
log("debug", "pre join: %s %s", tostring(room), tostring(stanza));
|
||||||
return verify_user(origin, stanza);
|
return verify_user(origin, stanza);
|
||||||
end);
|
end);
|
||||||
|
|
||||||
|
for event_name, method in pairs {
|
||||||
|
-- Normal room interactions
|
||||||
|
["iq-set/bare/http://jabber.org/protocol/muc#owner:query"] = "handle_owner_query_set_to_room" ;
|
||||||
|
-- Host room
|
||||||
|
["iq-set/host/http://jabber.org/protocol/muc#owner:query"] = "handle_owner_query_set_to_room" ;
|
||||||
|
} do
|
||||||
|
module:hook(event_name, function (event)
|
||||||
|
local session, stanza = event.origin, event.stanza;
|
||||||
|
|
||||||
|
-- if we do not require token we pass it through(default behaviour)
|
||||||
|
-- or the request is coming from admin (focus)
|
||||||
|
if not require_token_for_moderation or is_admin(stanza.attr.from) then
|
||||||
|
return;
|
||||||
|
end
|
||||||
|
|
||||||
|
if not session.auth_token then
|
||||||
|
session.send(
|
||||||
|
st.error_reply(
|
||||||
|
stanza, "cancel", "not-allowed", "Room modification disabled for guests"));
|
||||||
|
return true;
|
||||||
|
end
|
||||||
|
|
||||||
|
end, -1); -- the default prosody hook is on -2
|
||||||
|
end
|
||||||
|
|
||||||
|
module:hook_global('config-reloaded', load_config);
|
||||||
|
|
Loading…
Reference in New Issue