executables: Reject Lua 5.1 early

Prevents attempting to load libraries that may no longer be found and
crashing with a traceback.

Platforms like Debian where multiple Lua versions can be installed at
the same time and 'lua' pointing to one of the installed interpreters
via symlinks, there's the possibility that prosody/prosodyctl may be
invoked with Lua 5.1, which will no longer have any of the rest of
Prosody libraries available to be require(), and thus would immediately
fail with an unfriendly traceback.

Checking and aborting early with a friendlier message and reference to
more information is better.

Part of #1600
This commit is contained in:
Kim Alvefur 2022-07-02 17:27:39 +02:00
parent c8a49ad144
commit 8ee6441fc5
2 changed files with 13 additions and 0 deletions

View file

@ -44,6 +44,12 @@ if CFG_DATADIR then
end
-- Check before first require, to preempt the probable failure
if _VERSION < "Lua 5.2" then
io.stderr:write("Prosody is no longer compatible with Lua 5.1\n")
io.stderr:write("See https://prosody.im/doc/depends#lua for more information\n")
return os.exit(1);
end
local startup = require "util.startup";
local async = require "util.async";

View file

@ -44,6 +44,13 @@ end
-----------
-- Check before first require, to preempt the probable failure
if _VERSION < "Lua 5.2" then
io.stderr:write("Prosody is no longer compatible with Lua 5.1\n")
io.stderr:write("See https://prosody.im/doc/depends#lua for more information\n")
return os.exit(1);
end
local startup = require "util.startup";
startup.prosodyctl();