Backed out changeset 73a45ba6e3f1 in favour of 427dd01f0864

New behaviour (muc_room_allow_persistent = true, the default):

- Parent host users are not restricted by default (prosody:user)
- Users without roles (by default that is non-admins, non-parent-host users,
  and users on other servers) can no longer configure persistence by default.

muc_room_allow_persistent = false will restrict persistence to prosody:admin.

Parent-host users should not be restricted by default, and this can be
configured via the new roles/permissions options.
This commit is contained in:
Matthew Wild 2022-09-29 12:43:09 +01:00
parent 856a482013
commit 53ccf68cdf

View file

@ -8,7 +8,10 @@
--
local restrict_persistent = not module:get_option_boolean("muc_room_allow_persistent", true);
module:default_permission("prosody:admin", ":create-persistent-room"); -- Admins can always create, by default
module:default_permission(
restrict_persistent and "prosody:admin" or "prosody:user",
":create-persistent-room"
);
local function get_persistent(room)
return room._data.persistent;
@ -22,7 +25,7 @@ local function set_persistent(room, persistent)
end
module:hook("muc-config-form", function(event)
if restrict_persistent and not module:may(":create-persistent-room", event.actor) then
if not module:may(":create-persistent-room", event.actor) then
-- Hide config option if this user is not allowed to create persistent rooms
return;
end
@ -36,7 +39,7 @@ module:hook("muc-config-form", function(event)
end, 100-5);
module:hook("muc-config-submitted/muc#roomconfig_persistentroom", function(event)
if restrict_persistent and not module:may(":create-persistent-room", event.actor) then
if not module:may(":create-persistent-room", event.actor) then
return; -- Not allowed
end
if set_persistent(event.room, event.value) then