Commit cdd89c2a authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Fixed endless loop. JM-544

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@3360 b35dd754-fafc-0310-a699-88a17e54d16e
parent 0b213e57
...@@ -141,13 +141,24 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -141,13 +141,24 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
} }
private void returnErrorToSender(Packet packet) { private void returnErrorToSender(Packet packet) {
XMPPServer server = XMPPServer.getInstance();
JID from = packet.getFrom();
JID to = packet.getTo();
if (!server.isLocal(from) && !XMPPServer.getInstance().matchesComponent(from) &&
!server.isLocal(to) && !XMPPServer.getInstance().matchesComponent(to)) {
// Do nothing since the sender and receiver of the packet that failed to reach a remote
// server are not local users. This prevents endless loops if the FROM or TO address
// are non-existen addresses
return;
}
// TODO Send correct error condition: timeout or not_found depending on the real error // TODO Send correct error condition: timeout or not_found depending on the real error
try { try {
if (packet instanceof IQ) { if (packet instanceof IQ) {
IQ reply = new IQ(); IQ reply = new IQ();
reply.setID(((IQ) packet).getID()); reply.setID(((IQ) packet).getID());
reply.setTo(packet.getFrom()); reply.setTo(from);
reply.setFrom(packet.getTo()); reply.setFrom(to);
reply.setChildElement(((IQ) packet).getChildElement().createCopy()); reply.setChildElement(((IQ) packet).getChildElement().createCopy());
reply.setError(PacketError.Condition.remote_server_not_found); reply.setError(PacketError.Condition.remote_server_not_found);
ChannelHandler route = routingTable.getRoute(reply.getTo()); ChannelHandler route = routingTable.getRoute(reply.getTo());
...@@ -158,8 +169,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -158,8 +169,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
else if (packet instanceof Presence) { else if (packet instanceof Presence) {
Presence reply = new Presence(); Presence reply = new Presence();
reply.setID(packet.getID()); reply.setID(packet.getID());
reply.setTo(packet.getFrom()); reply.setTo(from);
reply.setFrom(packet.getTo()); reply.setFrom(to);
reply.setError(PacketError.Condition.remote_server_not_found); reply.setError(PacketError.Condition.remote_server_not_found);
ChannelHandler route = routingTable.getRoute(reply.getTo()); ChannelHandler route = routingTable.getRoute(reply.getTo());
if (route != null) { if (route != null) {
...@@ -169,8 +180,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler { ...@@ -169,8 +180,8 @@ public class OutgoingSessionPromise implements RoutableChannelHandler {
else if (packet instanceof Message) { else if (packet instanceof Message) {
Message reply = new Message(); Message reply = new Message();
reply.setID(packet.getID()); reply.setID(packet.getID());
reply.setTo(packet.getFrom()); reply.setTo(from);
reply.setFrom(packet.getTo()); reply.setFrom(to);
reply.setType(((Message)packet).getType()); reply.setType(((Message)packet).getType());
reply.setThread(((Message)packet).getThread()); reply.setThread(((Message)packet).getThread());
reply.setError(PacketError.Condition.remote_server_not_found); reply.setError(PacketError.Condition.remote_server_not_found);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment