aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2025-03-31 17:30:50 +0100
committerMatthew Wild <mwild1@gmail.com>2025-03-31 17:30:50 +0100
commitf0042849ba7629edd6404179c59fff7b69536d44 (patch)
tree57f5ce96f3e2d027eea5ee432b4a45e86960b987 /plugins
parent4f94d2425d03c983e8071c67f15de9af4191d9b4 (diff)
downloadprosody-f0042849ba7629edd6404179c59fff7b69536d44.tar.gz
prosody-f0042849ba7629edd6404179c59fff7b69536d44.zip
mod_admin_shell, prosodyctl shell: Report command failure when no password entered (fixes #1907)
Diffstat (limited to 'plugins')
-rw-r--r--plugins/mod_admin_shell.lua8
1 files changed, 7 insertions, 1 deletions
diff --git a/plugins/mod_admin_shell.lua b/plugins/mod_admin_shell.lua
index 28d758d0..c2b921b4 100644
--- a/plugins/mod_admin_shell.lua
+++ b/plugins/mod_admin_shell.lua
@@ -205,7 +205,13 @@ module:hook("admin/repl-requested-input", function (event)
event.origin.send(st.stanza("repl-result", { type = "error" }):text("Internal error - unexpected input"));
return true;
end
- input_promise.resolve(event.stanza:get_text());
+ local status = event.stanza.attr.status or "submit";
+ local text = event.stanza:get_text();
+ if status == "submit" then
+ input_promise.resolve(text);
+ else
+ input_promise.reject(status == "cancel" and (text ~= "" and text) or "cancelled");
+ end
return true;
end);