From 5715c21a077ee1c2fe8957cb4adcea14fd2eda6b Mon Sep 17 00:00:00 2001 From: Laurent Bercot Date: Fri, 20 Nov 2020 23:24:29 +0000 Subject: Refactor tls code to support ucspi-tls That includes: - new architecture: the tls binary is now a child of the app instead of the other way around - the sbearssl_run engine now takes a post-handshake callback. This allows s6-tlsc and s6-tlsd to only exec into the app when the handshake succeeds (which was already the case with libressl). - new binaries s6-tlsc-io and s6-tlsd-io encapsulate the crypto code; they init and run the engine, connecting to 4 already open fds (stdin/stdout = network, argv[1] and argv[2] = local) - s6-tlsc is now a simple wrapper around s6-tlsc-io - s6-tlsd is now a simple wrapper around s6-tlsd-io - new binary: s6-ucspitlsd, which is also a wrapper around s6-tlsd-io, but differently: the parent execs the app which should be ucspi-tls-aware, the child waits for a command from the parent and execs into s6-tlsd-io if it receives it. --- package/modes | 3 +++ 1 file changed, 3 insertions(+) (limited to 'package/modes') diff --git a/package/modes b/package/modes index b672097..d2ff2d3 100644 --- a/package/modes +++ b/package/modes @@ -17,5 +17,8 @@ s6-taiclockd 0755 minidentd 0755 s6-tlsclient 0755 s6-tlsc 0755 +s6-tlsc-io 0755 s6-tlsserver 0755 s6-tlsd 0755 +s6-tlsd-io 0755 +s6-ucspitlsd 0755 -- cgit v1.2.3