Diff

plugins/muc/muc.lib.lua @ 1768:802c40384dd0

MUC: Don't kick on errors in private messages.
author Waqas Hussain <waqas20@gmail.com>
date Wed, 09 Sep 2009 20:32:37 +0500
parent 1764:c00d4ba8d2f3
child 1769:39865fbbb2f7
line wrap: on
line diff
--- a/plugins/muc/muc.lib.lua	Wed Sep 09 19:28:36 2009 +0500
+++ b/plugins/muc/muc.lib.lua	Wed Sep 09 20:32:37 2009 +0500
@@ -295,9 +295,6 @@
 		origin.send(st.error_reply(stanza, "cancel", "not-acceptable"));
 	elseif stanza.name == "message" and type == "groupchat" then -- groupchat messages not allowed in PM
 		origin.send(st.error_reply(stanza, "modify", "bad-request"));
-	elseif stanza.name == "message" and type == "error" and get_kickable_error(stanza) then
-		log("debug", "%s kicked from %s for sending an error message", current_nick, room);
-		self:handle_to_occupant(origin, st.presence({type='unavailable', from=from, to=to}):tag('status'):text('This participant is kicked from the room because he sent an error message to another occupant')); -- send unavailable
 	else -- private stanza
 		local o_data = self._occupants[to];
 		if o_data then
@@ -446,6 +443,11 @@
 				self:broadcast_message(stanza, true);
 			end
 		end
+	elseif stanza.name == "message" and type == "error" and get_kickable_error(stanza) then
+		local current_nick = self._jid_nick[stanza.attr.from];
+		log("debug", "%s kicked from %s for sending an error message", current_nick, self.jid);
+		self:handle_to_occupant(origin, st.presence({type='unavailable', from=stanza.attr.from, to=stanza.attr.to})
+			:tag('status'):text('This participant is kicked from the room because he sent an error message to another occupant')); -- send unavailable
 	elseif stanza.name == "presence" then -- hack - some buggy clients send presence updates to the room rather than their nick
 		local to = stanza.attr.to;
 		local current_nick = self._jid_nick[stanza.attr.from];