# HG changeset patch # User Kim Alvefur # Date 1460999973 -7200 # Node ID d5ba0dec0c955c24187a054ac8fda4e21c36c545 # Parent 0ebc7ff1fff50f16baa90ce5353c07cb1eaff4f8 MUC: Cache public rooms and their names to speed up disco#items diff -r 0ebc7ff1fff5 -r d5ba0dec0c95 plugins/muc/mod_muc.lua --- a/plugins/muc/mod_muc.lua Mon Apr 18 19:18:37 2016 +0200 +++ b/plugins/muc/mod_muc.lua Mon Apr 18 19:19:33 2016 +0200 @@ -95,9 +95,12 @@ local persistent_rooms = module:open_store("persistent", "map"); local room_configs = module:open_store("config"); +local room_items_cache = {}; + local function room_save(room, forced) 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 persistent_rooms:set(nil, room.jid, true); local data = room:freeze(forced); @@ -147,6 +150,7 @@ module:log("debug", "Deleting %s", room); room_configs:set(jid_split(room.jid), nil); persistent_rooms:set(nil, room.jid, nil); + room_items_cache[room.jid] = nil; end function module.unload() @@ -191,9 +195,17 @@ module:hook("host-disco-items", function(event) local reply = event.reply; module:log("debug", "host-disco-items called"); - for room in each_room() do - if not room:get_hidden() then - reply:tag("item", {jid=room.jid, name=room:get_name()}):up(); + if next(room_items_cache) ~= nil then + for jid, room_name in pairs(room_items_cache) do + reply:tag("item", { jid = jid, name = room_name }):up(); + end + else + for room in each_room() do + if not room:get_hidden() then + local jid, room_name = room.jid, room:get_name(); + room_items_cache[jid] = name; + reply:tag("item", { jid = jid, name = room_name }):up(); + end end end end);