uTLS ServerHellos are accepted without checking TLS 1.3 downgrade canaries
Moderate severity
GitHub Reviewed
Published
Apr 23, 2025
in
refraction-networking/utls
•
Updated Apr 23, 2025
Description
Published to the GitHub Advisory Database
Apr 23, 2025
Reviewed
Apr 23, 2025
Last updated
Apr 23, 2025
Description
Before version 1.7.0, utls did not implement the TLS 1.3 downgrade protection mechanism specified in RFC 8446 Section 4.1.3 when using a utls ClientHello spec. This allowed an active network adversary to downgrade TLS 1.3 connections initiated by a utls client to a lower TLS version (e.g., TLS 1.2) by modifying the ClientHello message to exclude the SupportedVersions extension, causing the server to respond with a TLS 1.2 ServerHello (along with a downgrade canary in the ServerHello random field). Because utls did not check the downgrade canary in the ServerHello random field, clients would accept the downgraded connection without detecting the attack. This attack could also be used by an active network attacker to fingerprint utls connections.
Fix Commit or Pull Request
refraction-networking/utls#337, specifically refraction-networking/utls@f889276
References
References