aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/mod_pubsub/pubsub.lib.lua
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/mod_pubsub/pubsub.lib.lua')
-rw-r--r--plugins/mod_pubsub/pubsub.lib.lua34
1 files changed, 21 insertions, 13 deletions
diff --git a/plugins/mod_pubsub/pubsub.lib.lua b/plugins/mod_pubsub/pubsub.lib.lua
index 8a22fa69..5c6054d1 100644
--- a/plugins/mod_pubsub/pubsub.lib.lua
+++ b/plugins/mod_pubsub/pubsub.lib.lua
@@ -1,5 +1,6 @@
local st = require "util.stanza";
local uuid_generate = require "util.uuid".generate;
+local dataform = require"util.dataforms".new;
local xmlns_pubsub = "http://jabber.org/protocol/pubsub";
local xmlns_pubsub_errors = "http://jabber.org/protocol/pubsub#errors";
@@ -30,6 +31,19 @@ local function pubsub_error_reply(stanza, error)
end
_M.pubsub_error_reply = pubsub_error_reply;
+local node_config_form = require"util.dataforms".new {
+ {
+ type = "hidden";
+ name = "FORM_TYPE";
+ value = "http://jabber.org/protocol/pubsub#node_config";
+ };
+ {
+ type = "text-single";
+ name = "pubsub#max_items";
+ label = "Max # of items to persist";
+ };
+};
+
function handlers.get_items(origin, stanza, items, service)
local node = items.attr.node;
local item = items:get_child("item");
@@ -230,7 +244,7 @@ function handlers.get_configure(origin, stanza, config, service)
return origin.send(pubsub_error_reply(stanza, "nodeid-required"));
end
- if not service:may(node, actor, "configure") then
+ if not service:may(node, stanza.attr.from, "configure") then
return origin.send(pubsub_error_reply(stanza, "forbidden"));
end
@@ -239,15 +253,10 @@ function handlers.get_configure(origin, stanza, config, service)
return origin.send(pubsub_error_reply(stanza, "item-not-found"));
end
- local form = self.config.node_config_form;
- if not form then
- return origin.send(pubsub_error_reply(stanza, "not-allowed"));
- end
-
local reply = st.reply(stanza)
:tag("pubsub", { xmlns = xmlns_pubsub_owner })
:tag("configure", { node = node })
- :add_child(form:form(node_obj.config));
+ :add_child(node_config_form:form(node_obj.config));
return origin.send(reply);
end
@@ -256,11 +265,10 @@ function handlers.set_configure(origin, stanza, config, service)
if not node then
return origin.send(pubsub_error_reply(stanza, "nodeid-required"));
end
- local form, node_obj = service:get_node_config_form(node, stanza.attr.from);
- if not form then
- return origin.send(pubsub_error_reply(stanza, node_obj));
+ if not service:may(node, stanza.attr.from, "configure") then
+ return origin.send(pubsub_error_reply(stanza, "forbidden"));
end
- local new_config, err = form:data(config.tags[1]);
+ local new_config, err = node_config_form:data(config.tags[1]);
if not new_config then
return origin.send(st.error_reply(stanza, "modify", "bad-request", err));
end
@@ -274,8 +282,8 @@ end
function handlers.get_default(origin, stanza, default, service)
local reply = st.reply(stanza)
:tag("pubsub", { xmlns = xmlns_pubsub_owner })
- :tag("configure", { node = node })
- :add_child(form:form(service.node_default_config));
+ :tag("default")
+ :add_child(node_config_form:form(service.node_defaults));
return origin.send(reply);
end