mod_groups: Use module API for reading config
[prosody.git] / plugins / adhoc / adhoc.lib.lua
index 853992e06ef9e5ccbba414894f3477dccbb4039b..ecddcd1d173ec3e6e9196227ee8b3be90a39c825 100644 (file)
@@ -1,3 +1,9 @@
+-- Copyright (C) 2009-2010 Florian Zeitz
+--
+-- This file is MIT/X11 licensed. Please see the
+-- COPYING file in the source package for more information.
+--
+
 local st, uuid = require "util.stanza", require "util.uuid";
 
 local xmlns_cmd = "http://jabber.org/protocol/commands";
@@ -6,7 +12,7 @@ local states = {}
 
 local _M = {};
 
-function _cmdtag(desc, status, sessionid, action)
+local function _cmdtag(desc, status, sessionid, action)
        local cmd = st.stanza("command", { xmlns = xmlns_cmd, node = desc.node, status = status });
        if sessionid then cmd.attr.sessionid = sessionid; end
        if action then cmd.attr.action = action; end
@@ -29,6 +35,7 @@ function _M.handle_cmd(command, origin, stanza)
        local data, state = command:handler(dataIn, states[sessionid]);
        states[sessionid] = state;
        local stanza = st.reply(stanza);
+       local cmdtag;
        if data.status == "completed" then
                states[sessionid] = nil;
                cmdtag = command:cmdtag("completed", sessionid);
@@ -40,8 +47,9 @@ function _M.handle_cmd(command, origin, stanza)
                stanza = st.error_reply(stanza, data.error.type, data.error.condition, data.error.message);
                origin.send(stanza);
                return true;
-       else 
+       else
                cmdtag = command:cmdtag("executing", sessionid);
+               data.actions = data.actions or { "complete" };
        end
 
        for name, content in pairs(data) do
@@ -51,21 +59,21 @@ function _M.handle_cmd(command, origin, stanza)
                        cmdtag:tag("note", {type="warn"}):text(content):up();
                elseif name == "error" then
                        cmdtag:tag("note", {type="error"}):text(content.message):up();
-               elseif name =="actions" then
-                       local actions = st.stanza("actions");
+               elseif name == "actions" then
+                       local actions = st.stanza("actions", { execute = content.default });
                        for _, action in ipairs(content) do
                                if (action == "prev") or (action == "next") or (action == "complete") then
                                        actions:tag(action):up();
                                else
-                                       module:log("error", 'Command "'..command.name..
-                                               '" at node "'..command.node..'" provided an invalid action "'..action..'"');
+                                       module:log("error", "Command %q at node %q provided an invalid action %q",
+                                               command.name, command.node, action);
                                end
                        end
                        cmdtag:add_child(actions);
                elseif name == "form" then
-                       cmdtag:add_child(content:form());
+                       cmdtag:add_child((content.layout or content):form(content.values));
                elseif name == "result" then
-                       cmdtag:add_child(content.layout:form(content.data, "result"));
+                       cmdtag:add_child((content.layout or content):form(content.values, "result"));
                elseif name == "other" then
                        cmdtag:add_child(content);
                end