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);