Comparison

plugins/mod_pubsub/pubsub.lib.lua @ 6450:25d86b0f2147

Merge 0.10->trunk
author Kim Alvefur <zash@zash.se>
date Sun, 28 Sep 2014 03:08:03 +0200
parent 6448:f799b45cf735
child 6473:7c8f58d2b331
comparison
equal deleted inserted replaced
6449:24cd03cd1847 6450:25d86b0f2147
1 local st = require "util.stanza"; 1 local st = require "util.stanza";
2 local uuid_generate = require "util.uuid".generate; 2 local uuid_generate = require "util.uuid".generate;
3 local dataform = require"util.dataforms".new;
3 4
4 local xmlns_pubsub = "http://jabber.org/protocol/pubsub"; 5 local xmlns_pubsub = "http://jabber.org/protocol/pubsub";
5 local xmlns_pubsub_errors = "http://jabber.org/protocol/pubsub#errors"; 6 local xmlns_pubsub_errors = "http://jabber.org/protocol/pubsub#errors";
6 local xmlns_pubsub_owner = "http://jabber.org/protocol/pubsub#owner"; 7 local xmlns_pubsub_owner = "http://jabber.org/protocol/pubsub#owner";
7 8
28 end 29 end
29 return reply; 30 return reply;
30 end 31 end
31 _M.pubsub_error_reply = pubsub_error_reply; 32 _M.pubsub_error_reply = pubsub_error_reply;
32 33
34 local node_config_form = require"util.dataforms".new {
35 {
36 type = "hidden";
37 name = "FORM_TYPE";
38 value = "http://jabber.org/protocol/pubsub#node_config";
39 };
40 {
41 type = "text-single";
42 name = "pubsub#max_items";
43 label = "Max # of items to persist";
44 };
45 };
46
33 function handlers.get_items(origin, stanza, items, service) 47 function handlers.get_items(origin, stanza, items, service)
34 local node = items.attr.node; 48 local node = items.attr.node;
35 local item = items:get_child("item"); 49 local item = items:get_child("item");
36 local id = item and item.attr.id; 50 local id = item and item.attr.id;
37 51
228 local node = config.attr.node; 242 local node = config.attr.node;
229 if not node then 243 if not node then
230 return origin.send(pubsub_error_reply(stanza, "nodeid-required")); 244 return origin.send(pubsub_error_reply(stanza, "nodeid-required"));
231 end 245 end
232 246
233 if not service:may(node, actor, "configure") then 247 if not service:may(node, stanza.attr.from, "configure") then
234 return origin.send(pubsub_error_reply(stanza, "forbidden")); 248 return origin.send(pubsub_error_reply(stanza, "forbidden"));
235 end 249 end
236 250
237 local node_obj = service.nodes[node]; 251 local node_obj = service.nodes[node];
238 if not node_obj then 252 if not node_obj then
239 return origin.send(pubsub_error_reply(stanza, "item-not-found")); 253 return origin.send(pubsub_error_reply(stanza, "item-not-found"));
240 end 254 end
241 255
242 local form = self.config.node_config_form;
243 if not form then
244 return origin.send(pubsub_error_reply(stanza, "not-allowed"));
245 end
246
247 local reply = st.reply(stanza) 256 local reply = st.reply(stanza)
248 :tag("pubsub", { xmlns = xmlns_pubsub_owner }) 257 :tag("pubsub", { xmlns = xmlns_pubsub_owner })
249 :tag("configure", { node = node }) 258 :tag("configure", { node = node })
250 :add_child(form:form(node_obj.config)); 259 :add_child(node_config_form:form(node_obj.config));
251 return origin.send(reply); 260 return origin.send(reply);
252 end 261 end
253 262
254 function handlers.set_configure(origin, stanza, config, service) 263 function handlers.set_configure(origin, stanza, config, service)
255 local node = config.attr.node; 264 local node = config.attr.node;
256 if not node then 265 if not node then
257 return origin.send(pubsub_error_reply(stanza, "nodeid-required")); 266 return origin.send(pubsub_error_reply(stanza, "nodeid-required"));
258 end 267 end
259 local form, node_obj = service:get_node_config_form(node, stanza.attr.from); 268 if not service:may(node, stanza.attr.from, "configure") then
260 if not form then 269 return origin.send(pubsub_error_reply(stanza, "forbidden"));
261 return origin.send(pubsub_error_reply(stanza, node_obj)); 270 end
262 end 271 local new_config, err = node_config_form:data(config.tags[1]);
263 local new_config, err = form:data(config.tags[1]);
264 if not new_config then 272 if not new_config then
265 return origin.send(st.error_reply(stanza, "modify", "bad-request", err)); 273 return origin.send(st.error_reply(stanza, "modify", "bad-request", err));
266 end 274 end
267 local ok, err = service:set_node_config(node, stanza.attr.from, new_config); 275 local ok, err = service:set_node_config(node, stanza.attr.from, new_config);
268 if not ok then 276 if not ok then
272 end 280 end
273 281
274 function handlers.get_default(origin, stanza, default, service) 282 function handlers.get_default(origin, stanza, default, service)
275 local reply = st.reply(stanza) 283 local reply = st.reply(stanza)
276 :tag("pubsub", { xmlns = xmlns_pubsub_owner }) 284 :tag("pubsub", { xmlns = xmlns_pubsub_owner })
277 :tag("configure", { node = node }) 285 :tag("default")
278 :add_child(form:form(service.node_default_config)); 286 :add_child(node_config_form:form(service.node_defaults));
279 return origin.send(reply); 287 return origin.send(reply);
280 end 288 end
281 289
282 return _M; 290 return _M;