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:
Дамян Минков 2020-06-19 14:50:31 -05:00 committed by GitHub
parent 311d1c67ba
commit 6fbba52c6d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 34 additions and 0 deletions

View File

@ -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);