aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/muc/mod_muc.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2016-04-29 16:54:45 +0200
committerKim Alvefur <zash@zash.se>2016-04-29 16:54:45 +0200
commite4a91c1d8f3d8f1a673b220e6812c7038964525b (patch)
tree1fe5344de5de5607753222bdae8341db44375b3f /plugins/muc/mod_muc.lua
parentf97b2a1f08778717d657f788a78193b945dce633 (diff)
downloadprosody-e4a91c1d8f3d8f1a673b220e6812c7038964525b.tar.gz
prosody-e4a91c1d8f3d8f1a673b220e6812c7038964525b.zip
MUC: Separate force-save parameter from save-entire-state flag
Diffstat (limited to 'plugins/muc/mod_muc.lua')
-rw-r--r--plugins/muc/mod_muc.lua14
1 files changed, 7 insertions, 7 deletions
diff --git a/plugins/muc/mod_muc.lua b/plugins/muc/mod_muc.lua
index c50567e9..5b342c02 100644
--- a/plugins/muc/mod_muc.lua
+++ b/plugins/muc/mod_muc.lua
@@ -97,15 +97,15 @@ local room_configs = module:open_store("config");
local room_items_cache = {};
-local function room_save(room, forced)
+local function room_save(room, forced, savestate)
local node = jid_split(room.jid);
local is_persistent = persistent.get(room);
room_items_cache[room.jid] = room:get_public() and room:get_name() or nil;
- if is_persistent or forced then
+ if is_persistent or savestate then
persistent_rooms:set(nil, room.jid, true);
- local data = room:freeze(forced);
+ local data = room:freeze(savestate);
return room_configs:set(node, data);
- else
+ elseif forced then
persistent_rooms:set(nil, room.jid, nil);
return room_configs:set(node, nil);
end
@@ -113,7 +113,7 @@ end
local rooms = cache.new(module:get_option_number("muc_room_cache_size", 100), function (_, room)
module:log("debug", "%s evicted", room);
- room_save(room, true); -- Force to disk
+ room_save(room, nil, true); -- Force to disk
end);
-- Automatically destroy empty non-persistent rooms
@@ -155,7 +155,7 @@ end
function module.unload()
for room in rooms:values() do
- room:save(true);
+ room:save(nil, true);
forget_room(room);
end
end
@@ -287,7 +287,7 @@ end
function shutdown_component()
for room in each_room(true) do
- room:save(true);
+ room:save(nil, true);
end
end
module:hook_global("server-stopping", shutdown_component);