Diff

plugins/muc/mod_muc.lua @ 8662:a4e63b037a2a

MUC: Catch and log error in case of storage failure in iterator over rooms
author Kim Alvefur <zash@zash.se>
date Thu, 15 Mar 2018 06:19:57 +0100
parent 8661:7fc0784491ef
child 8707:fd39c44c0113
line wrap: on
line diff
--- a/plugins/muc/mod_muc.lua	Thu Mar 22 20:08:32 2018 +0100
+++ b/plugins/muc/mod_muc.lua	Thu Mar 15 06:19:57 2018 +0100
@@ -230,7 +230,15 @@
 			coroutine.yield(room);
 			seen[room.jid] = true;
 		end
-		for room_jid in pairs(persistent_rooms_storage:get(nil) or {}) do
+		local all_persistent_rooms, err = persistent_rooms_storage:get(nil);
+		if not all_persistent_rooms then
+			if err then
+				module:log("error", "Error loading list of persistent rooms, only rooms live in memory were iterated over");
+				module:log("debug", "%s", debug.traceback(err));
+			end
+			return nil;
+		end
+		for room_jid in pairs(all_persistent_rooms) do
 			if not seen[room_jid] then
 				local room = restore_room(room_jid);
 				if room then