util.prosodyctl.cert: Look for certificates in a consistent order

Shortest first, then alphabetically, so that it prefers the base domain
over subdomains.

Fixes that it might otherwise pick a random sub-domain for filename on
each run, cluttering the certs directory and potentially tricking
Prosody into using an older certificate that might be about to expire.
This commit is contained in:
Kim Alvefur 2022-01-26 13:24:23 +01:00
parent b0e565598a
commit 04910e15b6

View file

@ -221,6 +221,15 @@ function cert_commands.import(arg)
cm.index_certs(dir, files_by_name);
end
local imported = {};
table.sort(hostnames, function (a, b)
-- Try to find base domain name before sub-domains, then alphabetically, so
-- that the order and choice of file name is deterministic.
if #a == #b then
return a < b;
else
return #a < #b;
end
end);
for _, host in ipairs(hostnames) do
local paths = cm.find_cert_in_index(files_by_name, host);
if paths and imported[paths.certificate] then