core.certmanager: Validate that 'tls_profile' is one of the valid values

A typo should not result in ending up with "legacy"
This commit is contained in:
Kim Alvefur 2023-10-27 19:03:59 +02:00
parent 4d9916d1e5
commit e8128c1d60

View file

@ -336,8 +336,11 @@ local function create_context(host, mode, ...)
password = function() log("error", "Encrypted certificate for %s requires 'ssl' 'password' to be set in config", host); end;
});
local profile = configmanager.get("*", "tls_profile") or "intermediate";
if profile ~= "legacy" then
if mozilla_ssl_configs[profile] then
cfg:apply(mozilla_ssl_configs[profile]);
elseif profile ~= "legacy" then
log("error", "Invalid value for 'tls_profile': expected one of \"modern\", \"intermediate\" (default), \"old\" or \"legacy\" but got %q", profile);
return nil, "Invalid configuration, 'tls_profile' had an unknown value.";
end
cfg:apply(global_ssl_config);