MUC: Separate force-save parameter from save-entire-state flag
authorKim Alvefur <zash@zash.se>
Fri, 29 Apr 2016 14:54:45 +0000 (16:54 +0200)
committerKim Alvefur <zash@zash.se>
Fri, 29 Apr 2016 14:54:45 +0000 (16:54 +0200)
plugins/muc/mod_muc.lua
plugins/muc/muc.lib.lua

index c50567e911f0a7f57313805363815f38762440d8..5b342c02c2c21ef5083306f51c604edb75cff8e3 100644 (file)
@@ -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);
index 9a7b1f859bcd915aa76fd4dfc1508c42aaf19256..eeb531a90c02c3783718d9a9bf2e8455d706a7eb 100644 (file)
@@ -769,7 +769,7 @@ function room_mt:process_form(origin, stanza)
                end
                event.field, event.value = nil, nil;
 
-               self:save();
+               self:save(true);
                origin.send(st.reply(stanza));
 
                if next(event.status_codes) then
@@ -852,7 +852,7 @@ function room_mt:handle_admin_query_set_command(origin, stanza)
        else
                success, errtype, err = nil, "cancel", "bad-request";
        end
-       self:save();
+       self:save(true);
        if not success then
                origin.send(st.error_reply(stanza, errtype, err));
        else
@@ -1219,7 +1219,7 @@ function room_mt:set_affiliation(actor, jid, affiliation, reason)
                end
        end
 
-       self:save();
+       self:save(true);
 
        module:fire_event("muc-set-affiliation", {
                room = self;