-
Notifications
You must be signed in to change notification settings - Fork 717
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
FIPS security policies do not work when using Provider::from_version("default_fips")
#4594
Comments
Thanks for bringing this issue to our attention! The problem here isn't actually related to FIPS. The problem is that "default_fips" doesn't support TLS1.3 (yet) and QUIC requires TLS1.3. It seems reasonable to error if we're constructing a ClientHello and discover no cipher suites are valid. We shouldn't send a ClientHello with no cipher suites. But detecting setting an invalid security policy on a quic connection might be trickier, since order of operations would matter. We could error when a non-TLS1.3 policy is set on a quic connection or on a quic config. But we'd potentially run into ordering issues if we tried to error on a non-TLS1.3 policy set on a config which is then set on a quic connection. For example: setting a default config with the default policy on a quic connection, then overriding the policy at the connection level. |
Thanks for the info! I can't find any issues directly addressing the first problem you described above:
Is this something the team is tracking or is on the road-map? As far as error behavior goes, my 2 cents: It seems reasonable to me to fail on the call to Of course, this still leaves the potential runtime issue when the policy is modified at the connection level. I don't know that I have a great answer on that as I'm not familiar with that part of the API. |
It's not really a problem per-se that default_fips doesn't support TLS1.3, unless you try to use it with QUIC. There are many immutable, versioned policies that will never support TLS1.3 and therefore never be usable with QUIC. However, we do plan to add TLS1.3 support to default_fips.
Oh, definitely agreed. The issue is that while we have a builder in Rust, we don't have one in the underlying C 🙃 Although I suppose since this is a quic-specific problem and the primary customer is therefore s2n-quic, fixing those edge cases I called out only in Rust might not be the end of the world. |
While working on fixes for this I realized I removed documentation of the suggested TLS1.3 + FIPS policy when I updated our default policies: 5b316bd That's an oversight since the updated policies still don't cover that TLS1.3 + FIPS niche. I'll put the documentation back. In the meantime, if you were wondering which policy to use, the suggested TLS1.3 + FIPS policy was 20230317. |
Problem:
When using the Rust bindings, I call
security::Policy::from_version("default_fips")
. I then pass this policy to aconfig::Builder
and create aConfig
. The config is eventually used to create ans2n-quic
Client
&Server
. However, it appears when using the"default_fips"
policy, the generatedClientHello
s, do not include any CipherSuites. See the attached pcap for details.Solution:
ClientHellos are generated with some number of acceptable FIPS CipherSuites, or if there are no acceptable CipherSuites, the call to
from_version
fails.Requirements / Acceptance Criteria:
ClientHellos are generated with some number of acceptable FIPS CipherSuites.
no_client_hello.pcapng.tar.gz
The text was updated successfully, but these errors were encountered: