mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 05:37:39 +03:00
net: isolate LuaSec-specifics
For this, various accessor functions are now provided directly on the sockets, which reach down into the LuaSec implementation to obtain the information. While this may seem of little gain at first, it hides the implementation detail of the LuaSec+LuaSocket combination that the actual socket and the TLS layer are separate objects. The net gain here is that an alternative implementation does not have to emulate that specific implementation detail and "only" has to expose LuaSec-compatible data structures on the new functions.
This commit is contained in:
parent
07ee0f4470
commit
38346dd6f1
12 changed files with 237 additions and 82 deletions
|
@ -9,7 +9,7 @@ local measure_cert_statuses = module:metric("counter", "checked", "", "Certifica
|
|||
|
||||
module:hook("s2s-check-certificate", function(event)
|
||||
local session, host, cert = event.session, event.host, event.cert;
|
||||
local conn = session.conn:socket();
|
||||
local conn = session.conn;
|
||||
local log = session.log or log;
|
||||
|
||||
if not cert then
|
||||
|
@ -18,8 +18,8 @@ module:hook("s2s-check-certificate", function(event)
|
|||
end
|
||||
|
||||
local chain_valid, errors;
|
||||
if conn.getpeerverification then
|
||||
chain_valid, errors = conn:getpeerverification();
|
||||
if conn.ssl_peerverification then
|
||||
chain_valid, errors = conn:ssl_peerverification();
|
||||
else
|
||||
chain_valid, errors = false, { { "Chain verification not supported by this version of LuaSec" } };
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue