Software /
code /
prosody-modules
Changeset
938:d0e71a3bd2c4
mod_s2s_auth_fingerprint: New module for authenticating s2s connections based on preconfigured fingerprints.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Mon, 25 Mar 2013 03:54:32 +0100 (2013-03-25) |
parents | 937:5276e1fc26b6 |
children | 939:1415fc2a0ac0 |
files | mod_s2s_auth_fingerprint/mod_s2s_auth_fingerprint.lua |
diffstat | 1 files changed, 38 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_s2s_auth_fingerprint/mod_s2s_auth_fingerprint.lua Mon Mar 25 03:54:32 2013 +0100 @@ -0,0 +1,38 @@ +-- Copyright (C) 2013 Kim Alvefur +-- This file is MIT/X11 licensed. + +module:set_global(); + +local digest_algo = module:get_option_string(module:get_name().."_digest", "sha1"); + +local fingerprints = {}; + +local function hashprep(h) + return tostring(h):lower():gsub(":",""); +end + +for host, set in pairs(module:get_option("s2s_trusted_fingerprints", {})) do + local host_set = {} + if type(set) == "table" then -- list of fingerprints + for i=1,#set do + host_set[hashprep(set[i])] = true; + end + else -- assume single fingerprint + host_set[hashprep(set)] = true; + end + fingerprints[host] = host_set; +end + +module:hook("s2s-check-certificate", function(event) + local session, host, cert = event.session, event.host, event.cert; + + local host_fingerprints = fingerprints[host]; + if host_fingerprints then + local digest = cert:digest(digest_algo); + if host_fingerprints[digest] then + session.cert_chain_status = "valid"; + session.cert_identity_status = "valid"; + return true; + end + end +end);