aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authordaurnimator <quae@daurnimator.com>2014-04-29 18:50:30 -0400
committerdaurnimator <quae@daurnimator.com>2014-04-29 18:50:30 -0400
commit202f300c96a891adbd5b1cceaf68bff73161faff (patch)
tree27f1cba901a312525a3bba1fd84b580117c80851 /plugins
parentbbd26576162f33990375f01db262a90d4121f091 (diff)
downloadprosody-202f300c96a891adbd5b1cceaf68bff73161faff.tar.gz
prosody-202f300c96a891adbd5b1cceaf68bff73161faff.zip
plugins/muc/lock.lib: lock inside of pre-create instead of 'created'
Diffstat (limited to 'plugins')
-rw-r--r--plugins/muc/lock.lib.lua14
1 files changed, 5 insertions, 9 deletions
diff --git a/plugins/muc/lock.lib.lua b/plugins/muc/lock.lib.lua
index 7cf19be3..319a6973 100644
--- a/plugins/muc/lock.lib.lua
+++ b/plugins/muc/lock.lib.lua
@@ -23,7 +23,10 @@ local function is_locked(room)
end
if lock_rooms then
- module:hook("muc-room-created", function(event)
+ module:hook("muc-room-pre-create", function(event)
+ -- Older groupchat protocol doesn't lock
+ if not event.stanza:get_child("x", "http://jabber.org/protocol/muc") then return end
+ -- Lock room at creation
local room = event.room;
lock(room);
if lock_room_timeout and lock_room_timeout > 0 then
@@ -33,16 +36,9 @@ if lock_rooms then
end
end);
end
- end);
+ end, 10);
end
--- Older groupchat protocol doesn't lock
-module:hook("muc-room-pre-create", function(event)
- if is_locked(event.room) and not event.stanza:get_child("x", "http://jabber.org/protocol/muc") then
- unlock(event.room);
- end
-end, 10);
-
-- Don't let users into room while it is locked
module:hook("muc-occupant-pre-join", function(event)
if not event.is_new_room and is_locked(event.room) then -- Deny entry