Software /
code /
prosody
Diff
plugins/muc/mod_muc.lua @ 8703:416b8ae3857d
MUC: Prevent creation of room that could not be loaded from storage (see #1091)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Fri, 09 Mar 2018 02:10:44 +0100 |
parent | 8702:7e7aa0f770c7 |
child | 8704:c0e812dd9dfc |
line wrap: on
line diff
--- a/plugins/muc/mod_muc.lua Wed Mar 07 16:01:58 2018 +0100 +++ b/plugins/muc/mod_muc.lua Fri Mar 09 02:10:44 2018 +0100 @@ -112,15 +112,21 @@ local persistent_errors = false; for jid in pairs(persistent_rooms) do local node = jid_split(jid); - local data = room_configs:get(node); + local data, err = room_configs:get(node); if data then local room = create_room(jid); room._data = data._data; room._affiliations = data._affiliations; - else -- missing room data + elseif not err then -- missing room data persistent_rooms[jid] = nil; module:log("error", "Missing data for room '%s', removing from persistent room list", jid); persistent_errors = true; + else -- error + module:log("error", "Error loading data for room '%s', locking it until service restart. Error was: %s", jid, err); + local room = muc_new_room(jid); + room.locked = true; + room._affiliations = { [muc_host] = "owner" }; -- To prevent unlocking + rooms[jid] = room; end end if persistent_errors then persistent_rooms_storage:set(nil, persistent_rooms); end