Software /
code /
prosody
Comparison
plugins/adhoc/mod_adhoc.lua @ 5761:91f8cd53584c
mod_adhoc: Use mod_disco for disco handling
author | Florian Zeitz <florob@babelmonkeys.de> |
---|---|
date | Wed, 24 Jul 2013 22:58:44 +0200 |
parent | 5760:e599d9a367cf |
child | 5762:785da1854eb9 |
comparison
equal
deleted
inserted
replaced
5760:e599d9a367cf | 5761:91f8cd53584c |
---|---|
9 local keys = require "util.iterators".keys; | 9 local keys = require "util.iterators".keys; |
10 local array_collect = require "util.array".collect; | 10 local array_collect = require "util.array".collect; |
11 local is_admin = require "core.usermanager".is_admin; | 11 local is_admin = require "core.usermanager".is_admin; |
12 local adhoc_handle_cmd = module:require "adhoc".handle_cmd; | 12 local adhoc_handle_cmd = module:require "adhoc".handle_cmd; |
13 local xmlns_cmd = "http://jabber.org/protocol/commands"; | 13 local xmlns_cmd = "http://jabber.org/protocol/commands"; |
14 local xmlns_disco = "http://jabber.org/protocol/disco"; | |
15 local commands = {}; | 14 local commands = {}; |
16 | 15 |
17 module:add_feature(xmlns_cmd); | 16 module:add_feature(xmlns_cmd); |
18 | 17 |
19 module:hook("iq/host/"..xmlns_disco.."#info:query", function (event) | 18 module:hook("host-disco-info-node", function (event) |
20 local origin, stanza = event.origin, event.stanza; | 19 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; |
21 local node = stanza.tags[1].attr.node; | 20 if commands[node] then |
22 if stanza.attr.type == "get" and node then | 21 local privileged = is_admin(stanza.attr.from, stanza.attr.to); |
23 if commands[node] then | 22 local global_admin = is_admin(stanza.attr.from); |
24 local privileged = is_admin(stanza.attr.from, stanza.attr.to); | 23 local command = commands[node]; |
25 if (commands[node].permission == "admin" and privileged) | 24 if (command.permission == "admin" and privileged) |
26 or (commands[node].permission == "user") then | 25 or (command.permission == "global_admin" and global_admin) |
27 reply = st.reply(stanza); | 26 or (command.permission == "user") then |
28 reply:tag("query", { xmlns = xmlns_disco.."#info", | 27 reply:tag("identity", { name = command.name, |
29 node = node }); | 28 category = "automation", type = "command-node" }):up(); |
30 reply:tag("identity", { name = commands[node].name, | 29 reply:tag("feature", { var = xmlns_cmd }):up(); |
31 category = "automation", type = "command-node" }):up(); | 30 reply:tag("feature", { var = "jabber:x:data" }):up(); |
32 reply:tag("feature", { var = xmlns_cmd }):up(); | 31 event.exists = true; |
33 reply:tag("feature", { var = "jabber:x:data" }):up(); | 32 else |
34 else | 33 return origin.send(st.error_reply(stanza, "auth", "forbidden", "This item is not available to you")); |
35 reply = st.error_reply(stanza, "auth", "forbidden", "This item is not available to you"); | |
36 end | |
37 origin.send(reply); | |
38 return true; | |
39 elseif node == xmlns_cmd then | |
40 reply = st.reply(stanza); | |
41 reply:tag("query", { xmlns = xmlns_disco.."#info", | |
42 node = node }); | |
43 reply:tag("identity", { name = "Ad-Hoc Commands", | |
44 category = "automation", type = "command-list" }):up(); | |
45 origin.send(reply); | |
46 return true; | |
47 | |
48 end | 34 end |
35 elseif node == xmlns_cmd then | |
36 reply:tag("identity", { name = "Ad-Hoc Commands", | |
37 category = "automation", type = "command-list" }):up(); | |
38 event.exists = true; | |
49 end | 39 end |
50 end); | 40 end); |
51 | 41 |
52 module:hook("iq/host/"..xmlns_disco.."#items:query", function (event) | 42 module:hook("host-disco-items-node", function (event) |
53 local origin, stanza = event.origin, event.stanza; | 43 local stanza, origin, reply, node = event.stanza, event.origin, event.reply, event.node; |
54 if stanza.attr.type == "get" and stanza.tags[1].attr.node | 44 if node ~= xmlns_cmd then |
55 and stanza.tags[1].attr.node == xmlns_cmd then | 45 return; |
56 local admin = is_admin(stanza.attr.from, stanza.attr.to); | 46 end |
57 local global_admin = is_admin(stanza.attr.from); | 47 |
58 reply = st.reply(stanza); | 48 local admin = is_admin(stanza.attr.from, stanza.attr.to); |
59 reply:tag("query", { xmlns = xmlns_disco.."#items", | 49 local global_admin = is_admin(stanza.attr.from); |
60 node = xmlns_cmd }); | 50 local nodes = array_collect(keys(commands)):sort(); |
61 local nodes = array_collect(keys(commands)):sort(); | 51 for _, node in ipairs(nodes) do |
62 for _, node in ipairs(nodes) do | 52 local command = commands[node]; |
63 local command = commands[node]; | 53 if (command.permission == "admin" and admin) |
64 if (command.permission == "admin" and admin) | 54 or (command.permission == "global_admin" and global_admin) |
65 or (command.permission == "global_admin" and global_admin) | 55 or (command.permission == "user") then |
66 or (command.permission == "user") then | 56 reply:tag("item", { name = command.name, |
67 reply:tag("item", { name = command.name, | 57 node = node, jid = module:get_host() }); |
68 node = node, jid = module:get_host() }); | 58 reply:up(); |
69 reply:up(); | |
70 end | |
71 end | 59 end |
72 origin.send(reply); | |
73 return true; | |
74 end | 60 end |
75 end, 500); | 61 event.exists = true; |
62 end); | |
76 | 63 |
77 module:hook("iq/host/"..xmlns_cmd..":command", function (event) | 64 module:hook("iq/host/"..xmlns_cmd..":command", function (event) |
78 local origin, stanza = event.origin, event.stanza; | 65 local origin, stanza = event.origin, event.stanza; |
79 if stanza.attr.type == "set" then | 66 if stanza.attr.type == "set" then |
80 local node = stanza.tags[1].attr.node | 67 local node = stanza.tags[1].attr.node |