all lists on lists.proxmox.com
 help / color / mirror / Atom feed
* [pve-devel] [PATCH http-server v2] fix #4859: properly configure TLSv1.3 only mode
@ 2023-07-19  9:15 Fabian Grünbichler
  2023-07-20 15:20 ` [pve-devel] applied: " Thomas Lamprecht
  0 siblings, 1 reply; 2+ messages in thread
From: Fabian Grünbichler @ 2023-07-19  9:15 UTC (permalink / raw)
  To: pve-devel

set_min/max_proto_version is recommended upstream nowadays, and it seems to be
required for some reason if *only* TLS v1.3 is supposed to be enabled.

querying via get_options gives us the union of
- system-wide openssl defaults
- our internal SSL defaults
- flags configured by the user via /etc/default/pveproxy

note that by default only 1.2 and 1.3 are enabled in the first place, so
disabling either leaves a single version being set as min and max.

Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
---
use `&Net::..` instead of `Net::..` for the constants, else spiceproxy chokes
on the usage. either variant seems to work for pveproxy.. ?

 src/PVE/APIServer/AnyEvent.pm | 17 +++++++++++++++++
 1 file changed, 17 insertions(+)

diff --git a/src/PVE/APIServer/AnyEvent.pm b/src/PVE/APIServer/AnyEvent.pm
index 1fd7a74..7a07193 100644
--- a/src/PVE/APIServer/AnyEvent.pm
+++ b/src/PVE/APIServer/AnyEvent.pm
@@ -2012,6 +2012,23 @@ sub new {
 	    warn "Failed to set TLS 1.3 ciphersuites '$ciphersuites'\n"
 		if !Net::SSLeay::CTX_set_ciphersuites($self->{tls_ctx}->{ctx}, $ciphersuites);
 	}
+
+	my $opts = Net::SSLeay::CTX_get_options($self->{tls_ctx}->{ctx});
+	my $min_version = Net::SSLeay::TLS1_1_VERSION();
+	my $max_version = Net::SSLeay::TLS1_3_VERSION();
+	if ($opts & &Net::SSLeay::OP_NO_TLSv1_1) {
+	    $min_version = Net::SSLeay::TLS1_2_VERSION();
+	}
+	if ($opts & &Net::SSLeay::OP_NO_TLSv1_2) {
+	    $min_version = Net::SSLeay::TLS1_3_VERSION();
+	}
+	if ($opts & &Net::SSLeay::OP_NO_TLSv1_3) {
+	    die "misconfigured TLS settings - cannot disable all supported TLS versions!\n"
+		if $min_version && $min_version == Net::SSLeay::TLS1_3_VERSION();
+	    $max_version = Net::SSLeay::TLS1_2_VERSION();
+	}
+	Net::SSLeay::CTX_set_min_proto_version($self->{tls_ctx}->{ctx}, $min_version) if $min_version;
+	Net::SSLeay::CTX_set_max_proto_version($self->{tls_ctx}->{ctx}, $max_version);
     }
 
     if ($self->{spiceproxy}) {
-- 
2.39.2





^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2023-07-20 15:21 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-07-19  9:15 [pve-devel] [PATCH http-server v2] fix #4859: properly configure TLSv1.3 only mode Fabian Grünbichler
2023-07-20 15:20 ` [pve-devel] applied: " Thomas Lamprecht

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.
Service provided by Proxmox Server Solutions GmbH | Privacy | Legal