Comparison

core/s2smanager.lua @ 4106:e19fc274e182

s2smanager: Don't bounce error replies for error and result stanzas.
author Waqas Hussain <waqas20@gmail.com>
date Mon, 10 Jan 2011 21:11:06 +0500
parent 4028:f596e1a5e88a
child 4107:c9363102afd2
child 4127:f80b7a92da67
comparison
equal deleted inserted replaced
4105:08560575762f 4106:e19fc274e182
68 end; 68 end;
69 dummy = true; 69 dummy = true;
70 }; 70 };
71 for i, data in ipairs(sendq) do 71 for i, data in ipairs(sendq) do
72 local reply = data[2]; 72 local reply = data[2];
73 local xmlns = reply.attr.xmlns; 73 if reply and not(reply.attr.xmlns) and bouncy_stanzas[reply.name] then
74 if not(xmlns) and bouncy_stanzas[reply.name] then
75 reply.attr.type = "error"; 74 reply.attr.type = "error";
76 reply:tag("error", {type = "cancel"}) 75 reply:tag("error", {type = "cancel"})
77 :tag("remote-server-not-found", {xmlns = "urn:ietf:params:xml:ns:xmpp-stanzas"}):up(); 76 :tag("remote-server-not-found", {xmlns = "urn:ietf:params:xml:ns:xmpp-stanzas"}):up();
78 if reason then 77 if reason then
79 reply:tag("text", {xmlns = "urn:ietf:params:xml:ns:xmpp-stanzas"}):text("Connection failed: "..reason):up(); 78 reply:tag("text", {xmlns = "urn:ietf:params:xml:ns:xmpp-stanzas"}):text("Connection failed: "..reason):up();
96 -- We have a connection to this host already 95 -- We have a connection to this host already
97 if host.type == "s2sout_unauthed" and (data.name ~= "db:verify" or not host.dialback_key) then 96 if host.type == "s2sout_unauthed" and (data.name ~= "db:verify" or not host.dialback_key) then
98 (host.log or log)("debug", "trying to send over unauthed s2sout to "..to_host); 97 (host.log or log)("debug", "trying to send over unauthed s2sout to "..to_host);
99 98
100 -- Queue stanza until we are able to send it 99 -- Queue stanza until we are able to send it
101 if host.sendq then t_insert(host.sendq, {tostring(data), st.reply(data)}); 100 if host.sendq then t_insert(host.sendq, {tostring(data), data.attr.type ~= "error" and data.attr.type ~= "result" and st.reply(data)});
102 else host.sendq = { {tostring(data), st.reply(data)} }; end 101 else host.sendq = { {tostring(data), data.attr.type ~= "error" and data.attr.type ~= "result" and st.reply(data)} }; end
103 host.log("debug", "stanza [%s] queued ", data.name); 102 host.log("debug", "stanza [%s] queued ", data.name);
104 elseif host.type == "local" or host.type == "component" then 103 elseif host.type == "local" or host.type == "component" then
105 log("error", "Trying to send a stanza to ourselves??") 104 log("error", "Trying to send a stanza to ourselves??")
106 log("error", "Traceback: %s", get_traceback()); 105 log("error", "Traceback: %s", get_traceback());
107 log("error", "Stanza: %s", tostring(data)); 106 log("error", "Stanza: %s", tostring(data));
119 else 118 else
120 log("debug", "opening a new outgoing connection for this stanza"); 119 log("debug", "opening a new outgoing connection for this stanza");
121 local host_session = new_outgoing(from_host, to_host); 120 local host_session = new_outgoing(from_host, to_host);
122 121
123 -- Store in buffer 122 -- Store in buffer
124 host_session.sendq = { {tostring(data), st.reply(data)} }; 123 host_session.sendq = { {tostring(data), data.attr.type ~= "error" and data.attr.type ~= "result" and st.reply(data)} };
125 log("debug", "stanza [%s] queued until connection complete", tostring(data.name)); 124 log("debug", "stanza [%s] queued until connection complete", tostring(data.name));
126 if (not host_session.connecting) and (not host_session.conn) then 125 if (not host_session.connecting) and (not host_session.conn) then
127 log("warn", "Connection to %s failed already, destroying session...", to_host); 126 log("warn", "Connection to %s failed already, destroying session...", to_host);
128 if not destroy_session(host_session, "Connection failed") then 127 if not destroy_session(host_session, "Connection failed") then
129 -- Already destroyed, we need to bounce our stanza 128 -- Already destroyed, we need to bounce our stanza