diff options
| author | tb <> | 2024-08-02 15:00:01 +0000 | 
|---|---|---|
| committer | tb <> | 2024-08-02 15:00:01 +0000 | 
| commit | b406bf2119594dc725dd7e537eb049151f94db87 (patch) | |
| tree | 61d7fc5b40064d7fad6956a89b7a64bd8e33c1a9 /src/lib/libtls/tls.c | |
| parent | 3f8ee49b42e8a18a7e21ac4d0b5091931372b9a0 (diff) | |
| download | openbsd-b406bf2119594dc725dd7e537eb049151f94db87.tar.gz openbsd-b406bf2119594dc725dd7e537eb049151f94db87.tar.bz2 openbsd-b406bf2119594dc725dd7e537eb049151f94db87.zip | |
libtls: fix legacy protocol parsing
Redefining TLS_PROTOCOL_TLSv1_0 and TLS_PROTOCOL_TLSv1_1 to be the same
as TLS_PROTOCOL_TLSv1_2 had undesired side effects, as witnessed in the
accompanying regress tests. The protocol string all:tlsv1.0 would disable
TLSv1.2 (so only enable TLSv1.3) and tlsv1.2:!tlsv1.1 would disable all
protocols.
It makes more sense to ignore any setting of TLSv1.0 and TLSv1.1, so if
you request 'tlsv1.1' you get no protocol, but 'all:!tlsv1.1' will enable
the two supported protocols TLSv1.3 and TLSv1.2.
Restore the defines to their original values and adjust the parsing code
to set/unset them.
Issue reported by Kenjiro Nakayama
Fixes https://github.com/libressl/openbsd/issues/151
with/ok jsing
Diffstat (limited to 'src/lib/libtls/tls.c')
0 files changed, 0 insertions, 0 deletions
