aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2017-09-13 18:18:57 +0200
committerKim Alvefur <zash@zash.se>2017-09-13 18:18:57 +0200
commit06f3d4c7466e3efd6e1c149a60ca9d4740353f5c (patch)
tree7b86b1eab7b22d7ca285e37d847fd9f5dccb85a9
parentadd610b2f5cc53815a431c94e5ccbbfcca6a83d6 (diff)
downloadprosody-06f3d4c7466e3efd6e1c149a60ca9d4740353f5c.tar.gz
prosody-06f3d4c7466e3efd6e1c149a60ca9d4740353f5c.zip
mod_c2s: Iterate over child tags instead of child nodes in stream error (fixes traceback from #987)
-rw-r--r--plugins/mod_c2s.lua18
1 files changed, 8 insertions, 10 deletions
diff --git a/plugins/mod_c2s.lua b/plugins/mod_c2s.lua
index 2bb919f8..fdb3b211 100644
--- a/plugins/mod_c2s.lua
+++ b/plugins/mod_c2s.lua
@@ -98,16 +98,14 @@ function stream_callbacks.error(session, error, data)
session:close("not-well-formed");
elseif error == "stream-error" then
local condition, text = "undefined-condition";
- for child in data:children() do
- if child.attr.xmlns == xmlns_xmpp_streams then
- if child.name ~= "text" then
- condition = child.name;
- else
- text = child:get_text();
- end
- if condition ~= "undefined-condition" and text then
- break;
- end
+ for child in data:childtags(nil, xmlns_xmpp_streams) do
+ if child.name ~= "text" then
+ condition = child.name;
+ else
+ text = child:get_text();
+ end
+ if condition ~= "undefined-condition" and text then
+ break;
end
end
text = condition .. (text and (" ("..text..")") or "");