summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/stack/stack.c
diff options
context:
space:
mode:
authortb <>2023-04-23 18:51:53 +0000
committertb <>2023-04-23 18:51:53 +0000
commit7af2fcf80381969850949d04fe5368f75e9f7f03 (patch)
treefa6d649a58d3a734a4bc9dea3b97a71426074f8b /src/lib/libcrypto/stack/stack.c
parentfab2227d2aa5f7fca413e38be5705216b0100c26 (diff)
downloadopenbsd-7af2fcf80381969850949d04fe5368f75e9f7f03.tar.gz
openbsd-7af2fcf80381969850949d04fe5368f75e9f7f03.tar.bz2
openbsd-7af2fcf80381969850949d04fe5368f75e9f7f03.zip
Randomize the order of TLS extensions
On creation of an SSL using SSL_new(), randomize the order in which the extensions will be sent. There are several constraints: the PSK extension must always come last. The order cannot be randomized on a per-message basis as the strict interpretation of the standard chosen in the CH hashing doesn't allow changing the order between first and second ClientHello. Another constraint is that the current code calls callbacks directly on parsing an extension, which means that the order callbacks are called depends on the order in which the peer sent the extensions. This results in breaking apache-httpd setups using virtual hosts with full ranomization because virtual hosts don't work if the SNI is unknown at the time the ALPN callback is called. So for the time being, we ensure that SNI always precedes ALPN to avoid issues until this issue is fixed. This is based on an idea by David Benjamin https://boringssl-review.googlesource.com/c/boringssl/+/48045 Input & ok jsing
Diffstat (limited to '')
0 files changed, 0 insertions, 0 deletions