# HG changeset patch # User Kim Alvefur # Date 1359654061 -3600 # Node ID 518d864b2ab8e4e1cd53a491f7e611fb2f419582 # Parent d20861bf900bd360e4ea92b47d761edf0010748e mod_pubsub, util.pubsub: Add delete action diff -r d20861bf900b -r 518d864b2ab8 plugins/mod_pubsub.lua --- a/plugins/mod_pubsub.lua Thu Jan 31 15:48:55 2013 +0100 +++ b/plugins/mod_pubsub.lua Thu Jan 31 18:41:01 2013 +0100 @@ -119,6 +119,22 @@ return origin.send(reply); end +function handlers.set_delete(origin, stanza, delete) + local node = delete.attr.node; + + local reply, notifier; + if not node then + return origin.send(pubsub_error_reply(stanza, "nodeid-required")); + end + local ok, ret = service:delete(node, stanza.attr.from); + if ok then + reply = st.reply(stanza); + else + reply = pubsub_error_reply(stanza, ret); + end + return origin.send(reply); +end + function handlers.set_subscribe(origin, stanza, subscribe) local node, jid = subscribe.attr.node, subscribe.attr.jid; if not (node and jid) then @@ -258,6 +274,7 @@ retract = { "delete-items", "retract-items" }; purge = { "purge-nodes" }; publish = { "publish", autocreate_on_publish and "auto-create" }; + delete = { "delete-nodes" }; get_items = { "retrieve-items" }; add_subscription = { "subscribe" }; get_subscriptions = { "retrieve-subscriptions" }; @@ -418,6 +435,7 @@ create = true; publish = true; retract = true; + delete = true; get_nodes = true; subscribe = true; diff -r d20861bf900b -r 518d864b2ab8 util/pubsub.lua --- a/util/pubsub.lua Thu Jan 31 15:48:55 2013 +0100 +++ b/util/pubsub.lua Thu Jan 31 18:41:01 2013 +0100 @@ -226,6 +226,18 @@ return ok, err; end +function service:delete(node, actor) + -- Access checking + if not self:may(node, actor, "delete") then + return false, "forbidden"; + end + -- + local node_obj = self.nodes[node]; + self.nodes[node] = nil; + self.config.broadcaster("delete", node, node_obj.subscribers); + return true; +end + function service:publish(node, actor, id, item) -- Access checking if not self:may(node, actor, "publish") then