Software /
code /
prosody
Comparison
plugins/mod_pubsub/mod_pubsub.lua @ 5970:6a2c3293d4d7
mod_pubsub: Don't sent error replies from service disco events, let mod_disco handle that
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Mon, 30 Dec 2013 21:49:17 +0100 |
parent | 5690:630e7224a65f |
child | 5973:905b4fd863b4 |
child | 6434:382e03a40dd2 |
comparison
equal
deleted
inserted
replaced
5969:0a3b8003ac9c | 5970:6a2c3293d4d7 |
---|---|
84 end | 84 end |
85 | 85 |
86 module:hook("host-disco-info-node", function (event) | 86 module:hook("host-disco-info-node", function (event) |
87 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; | 87 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; |
88 local ok, ret = service:get_nodes(stanza.attr.from); | 88 local ok, ret = service:get_nodes(stanza.attr.from); |
89 if ok and not ret[node] then | 89 if not ok or not ret[node] then |
90 return; | 90 return; |
91 end | |
92 if not ok then | |
93 return origin.send(pubsub_error_reply(stanza, ret)); | |
94 end | 91 end |
95 event.exists = true; | 92 event.exists = true; |
96 reply:tag("identity", { category = "pubsub", type = "leaf" }); | 93 reply:tag("identity", { category = "pubsub", type = "leaf" }); |
97 end); | 94 end); |
98 | 95 |
99 module:hook("host-disco-items-node", function (event) | 96 module:hook("host-disco-items-node", function (event) |
100 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; | 97 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; |
101 local ok, ret = service:get_items(node, stanza.attr.from); | 98 local ok, ret = service:get_items(node, stanza.attr.from); |
102 if not ok then | 99 if not ok then |
103 return origin.send(pubsub_error_reply(stanza, ret)); | 100 return; |
104 end | 101 end |
105 | 102 |
106 for id, item in pairs(ret) do | 103 for id, item in pairs(ret) do |
107 reply:tag("item", { jid = module.host, name = id }):up(); | 104 reply:tag("item", { jid = module.host, name = id }):up(); |
108 end | 105 end |
112 | 109 |
113 module:hook("host-disco-items", function (event) | 110 module:hook("host-disco-items", function (event) |
114 local stanza, origin, reply = event.stanza, event.origin, event.reply; | 111 local stanza, origin, reply = event.stanza, event.origin, event.reply; |
115 local ok, ret = service:get_nodes(event.stanza.attr.from); | 112 local ok, ret = service:get_nodes(event.stanza.attr.from); |
116 if not ok then | 113 if not ok then |
117 return origin.send(pubsub_error_reply(event.stanza, ret)); | 114 return; |
118 end | 115 end |
119 for node, node_obj in pairs(ret) do | 116 for node, node_obj in pairs(ret) do |
120 reply:tag("item", { jid = module.host, node = node, name = node_obj.config.name }):up(); | 117 reply:tag("item", { jid = module.host, node = node, name = node_obj.config.name }):up(); |
121 end | 118 end |
122 end); | 119 end); |