aboutsummaryrefslogtreecommitdiffstats
path: root/core/certmanager.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2016-02-03 23:02:36 +0100
committerKim Alvefur <zash@zash.se>2016-02-03 23:02:36 +0100
commit189039bd778c59fd5cb5c366160e3223635b18b1 (patch)
treeab08d20e6221fcbbef8a751617c0a4bac36065f1 /core/certmanager.lua
parent6b679da5299ada6254e8f5bf8e8e3284a812dc1d (diff)
parentc32b0e36d62da5b9bcfb46bbb0f81d124e1d4f57 (diff)
downloadprosody-189039bd778c59fd5cb5c366160e3223635b18b1.tar.gz
prosody-189039bd778c59fd5cb5c366160e3223635b18b1.zip
Merge 0.10->trunk
Diffstat (limited to 'core/certmanager.lua')
-rw-r--r--core/certmanager.lua28
1 files changed, 28 insertions, 0 deletions
diff --git a/core/certmanager.lua b/core/certmanager.lua
index 05f0f809..db3cf58e 100644
--- a/core/certmanager.lua
+++ b/core/certmanager.lua
@@ -23,6 +23,7 @@ local ssl_context = ssl.context or softreq"ssl.context";
local ssl_x509 = ssl.x509 or softreq"ssl.x509";
local ssl_newcontext = ssl.newcontext;
local new_config = require"util.sslconfig".new;
+local stat = require "lfs".attributes;
local tostring = tostring;
local pairs = pairs;
@@ -50,6 +51,32 @@ local _ENV = nil;
-- Global SSL options if not overridden per-host
local global_ssl_config = configmanager.get("*", "ssl");
+local global_certificates = configmanager.get("*", "certificates") or "certs";
+
+local crt_try = { "", "/%s.crt", "/%s/fullchain.pem", "/%s.pem", };
+local key_try = { "", "/%s.key", "/%s/privkey.pem", "/%s.pem", };
+
+local function find_cert(host)
+ local certs = configmanager.get(host, "certificate") or global_certificates;
+ certs = resolve_path(config_path, certs);
+ for i = 1, #crt_try do
+ local crt_path = certs .. crt_try[i]:format(host);
+ local key_path = certs .. key_try[i]:format(host);
+
+ if stat(crt_path, "mode") == "file" then
+ if stat(key_path, "mode") == "file" then
+ return { certificate = crt_path, key = key_path };
+ end
+ if key_path:sub(-4) == ".crt" then
+ key_path = key_path:sub(1, -4) .. "key";
+ if stat(key_path, "mode") == "file" then
+ return { certificate = crt_path, key = key_path };
+ end
+ end
+ end
+ end
+end
+
-- Built-in defaults
local core_defaults = {
capath = "/etc/ssl/certs";
@@ -82,6 +109,7 @@ local function create_context(host, mode, ...)
local cfg = new_config();
cfg:apply(core_defaults);
cfg:apply(global_ssl_config);
+ cfg:apply(find_cert(host) or find_cert(host:match("%.(.*)")));
cfg:apply({
mode = mode,
-- We can't read the password interactively when daemonized