Diff

plugins/muc/mod_muc.lua @ 9048:c58be87e62d0

MUC: Return 'gone' error for destroyed rooms in other cases than attempted join Lock expiry -> Reset Admin wants to join -> Reset Still locked -> cancel, gone Don't return error in response to an error
author Kim Alvefur <zash@zash.se>
date Mon, 16 Jul 2018 12:19:19 +0200
parent 9035:173c0e16e704
child 9049:5870a0a6d4b6
line wrap: on
line diff
--- a/plugins/muc/mod_muc.lua	Sun Jul 15 22:50:05 2018 +0200
+++ b/plugins/muc/mod_muc.lua	Mon Jul 16 12:19:19 2018 +0200
@@ -399,20 +399,20 @@
 		local room = get_room_from_jid(room_jid);
 
 		if room and room._data.destroyed then
-			if stanza.attr.type == nil and stanza.name == "presence" then
-				if is_admin(stanza.attr.from) or room._data.locked < os.time() then
-					-- Allow the room to be recreated by admin or after time has passed
-					delete_room(room);
-					room = nil;
-				else
+			if room._data.locked < os.time() or (is_admin(stanza.attr.from) and stanza.name == "presence" and stanza.attr.type == nil) then
+				-- Allow the room to be recreated by admin or after time has passed
+				delete_room(room);
+				room = nil;
+			else
+				if stanza.attr.type ~= "error" then
 					local reply = st.error_reply(stanza, "cancel", "gone", room._data.reason)
 					if room._data.newjid then
 						local uri = "xmpp:"..room._data.newjid.."?join";
 						reply:get_child("error"):child_with_name("gone"):text(uri);
 					end
 					event.origin.send(reply);
-					return true;
 				end
+				return true;
 			end
 		end