Only load plugins that are lua files

Before trying to load a plugin or checking its version verify if it
looks like a lua file.

Close issue #349.
This commit is contained in:
Francesco Abbate 2021-07-27 23:16:33 +02:00
parent af22a6a824
commit 8103f21991
1 changed files with 15 additions and 14 deletions

View File

@ -664,8 +664,8 @@ local function check_plugin_version(filename)
if info ~= nil and info.type == "dir" then if info ~= nil and info.type == "dir" then
filename = filename .. "/init.lua" filename = filename .. "/init.lua"
info = system.get_file_info(filename) info = system.get_file_info(filename)
if not info then return true end
end end
if not info or not filename:match("%.lua$") then return false end
local f = io.open(filename, "r") local f = io.open(filename, "r")
if not f then return false end if not f then return false end
local version_match = false local version_match = false
@ -685,7 +685,7 @@ local function check_plugin_version(filename)
end end
end end
f:close() f:close()
return version_match return true, version_match
end end
@ -700,13 +700,13 @@ function core.load_plugins()
local files = system.list_dir(plugin_dir) local files = system.list_dir(plugin_dir)
for _, filename in ipairs(files or {}) do for _, filename in ipairs(files or {}) do
local basename = filename:match("(.-)%.lua$") or filename local basename = filename:match("(.-)%.lua$") or filename
local version_match = check_plugin_version(plugin_dir .. '/' .. filename) local is_lua_file, version_match = check_plugin_version(plugin_dir .. '/' .. filename)
if is_lua_file then
if not version_match then if not version_match then
core.log_quiet("Version mismatch for plugin %q from %s", basename, plugin_dir) core.log_quiet("Version mismatch for plugin %q from %s", basename, plugin_dir)
local ls = refused_list[root_dir == USERDIR and 'userdir' or 'datadir'].plugins local ls = refused_list[root_dir == USERDIR and 'userdir' or 'datadir'].plugins
ls[#ls + 1] = filename ls[#ls + 1] = filename
end elseif config.plugins[basename] ~= false then
if version_match and config.plugins[basename] ~= false then
local modname = "plugins." .. basename local modname = "plugins." .. basename
local ok = core.try(require, modname) local ok = core.try(require, modname)
if ok then core.log_quiet("Loaded plugin %q from %s", basename, plugin_dir) end if ok then core.log_quiet("Loaded plugin %q from %s", basename, plugin_dir) end
@ -716,6 +716,7 @@ function core.load_plugins()
end end
end end
end end
end
return no_errors, refused_list return no_errors, refused_list
end end