mod_admin_shell: Fix reporting origin module for commands

The field `_provided_by` comes from module:provides(), but these items
comes from moduel:add_item(), which include the originating module as a
'source' field of the event. However, this is absent when items are
retrieved at a later time than the initial event.
This commit is contained in:
Kim Alvefur 2025-01-08 08:11:02 +01:00
parent 0fe28ddb09
commit 63690dd4a0

View file

@ -2543,7 +2543,7 @@ local host_commands = {};
local function new_item_handlers(command_host)
local function on_command_added(event)
local command = event.item;
local mod_name = command._provided_by and ("mod_"..command._provided_by) or "<unknown module>";
local mod_name = event.source and ("mod_"..event.source.name) or "<unknown module>";
if not schema.validate(command_metadata_schema, command) or type(command.handler) ~= "function" then
module:log("warn", "Ignoring command added by %s: missing or invalid data", mod_name);
return;