diff options
Diffstat (limited to 'src/lib/libssl/ssl_tlsext.c')
| -rw-r--r-- | src/lib/libssl/ssl_tlsext.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/lib/libssl/ssl_tlsext.c b/src/lib/libssl/ssl_tlsext.c index 46f30aa47e..58ba11954d 100644 --- a/src/lib/libssl/ssl_tlsext.c +++ b/src/lib/libssl/ssl_tlsext.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: ssl_tlsext.c,v 1.58 2020/01/30 17:09:23 jsing Exp $ */ | 1 | /* $OpenBSD: ssl_tlsext.c,v 1.59 2020/02/01 12:41:58 jsing Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright (c) 2016, 2017, 2019 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2016, 2017, 2019 Joel Sing <jsing@openbsd.org> |
| 4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> | 4 | * Copyright (c) 2017 Doug Hogan <doug@openbsd.org> |
| @@ -1274,7 +1274,7 @@ tlsext_keyshare_client_build(SSL *s, CBB *cbb) | |||
| 1274 | int | 1274 | int |
| 1275 | tlsext_keyshare_server_parse(SSL *s, CBS *cbs, int *alert) | 1275 | tlsext_keyshare_server_parse(SSL *s, CBS *cbs, int *alert) |
| 1276 | { | 1276 | { |
| 1277 | CBS client_shares; | 1277 | CBS client_shares, key_exchange; |
| 1278 | uint16_t group; | 1278 | uint16_t group; |
| 1279 | 1279 | ||
| 1280 | if (!CBS_get_u16_length_prefixed(cbs, &client_shares)) | 1280 | if (!CBS_get_u16_length_prefixed(cbs, &client_shares)) |
| @@ -1285,6 +1285,8 @@ tlsext_keyshare_server_parse(SSL *s, CBS *cbs, int *alert) | |||
| 1285 | /* Unpack client share. */ | 1285 | /* Unpack client share. */ |
| 1286 | if (!CBS_get_u16(&client_shares, &group)) | 1286 | if (!CBS_get_u16(&client_shares, &group)) |
| 1287 | goto err; | 1287 | goto err; |
| 1288 | if (!CBS_get_u16_length_prefixed(&client_shares, &key_exchange)) | ||
| 1289 | return 0; | ||
| 1288 | 1290 | ||
| 1289 | /* | 1291 | /* |
| 1290 | * XXX support other groups later. | 1292 | * XXX support other groups later. |
| @@ -1295,7 +1297,7 @@ tlsext_keyshare_server_parse(SSL *s, CBS *cbs, int *alert) | |||
| 1295 | continue; | 1297 | continue; |
| 1296 | 1298 | ||
| 1297 | if (!tls13_key_share_peer_public(S3I(s)->hs_tls13.key_share, | 1299 | if (!tls13_key_share_peer_public(S3I(s)->hs_tls13.key_share, |
| 1298 | group, &client_shares)) | 1300 | group, &key_exchange)) |
| 1299 | goto err; | 1301 | goto err; |
| 1300 | } | 1302 | } |
| 1301 | 1303 | ||
| @@ -1330,16 +1332,19 @@ tlsext_keyshare_server_build(SSL *s, CBB *cbb) | |||
| 1330 | int | 1332 | int |
| 1331 | tlsext_keyshare_client_parse(SSL *s, CBS *cbs, int *alert) | 1333 | tlsext_keyshare_client_parse(SSL *s, CBS *cbs, int *alert) |
| 1332 | { | 1334 | { |
| 1335 | CBS key_exchange; | ||
| 1333 | uint16_t group; | 1336 | uint16_t group; |
| 1334 | 1337 | ||
| 1335 | /* Unpack server share. */ | 1338 | /* Unpack server share. */ |
| 1336 | if (!CBS_get_u16(cbs, &group)) | 1339 | if (!CBS_get_u16(cbs, &group)) |
| 1337 | goto err; | 1340 | goto err; |
| 1341 | if (!CBS_get_u16_length_prefixed(cbs, &key_exchange)) | ||
| 1342 | return 0; | ||
| 1338 | 1343 | ||
| 1339 | /* XXX - Handle other groups and verify that they're valid. */ | 1344 | /* XXX - Handle other groups and verify that they're valid. */ |
| 1340 | 1345 | ||
| 1341 | if (!tls13_key_share_peer_public(S3I(s)->hs_tls13.key_share, | 1346 | if (!tls13_key_share_peer_public(S3I(s)->hs_tls13.key_share, |
| 1342 | group, cbs)) | 1347 | group, &key_exchange)) |
| 1343 | goto err; | 1348 | goto err; |
| 1344 | 1349 | ||
| 1345 | return 1; | 1350 | return 1; |
