diff options
Diffstat (limited to 'src/lib/libssl/tls13_server.c')
-rw-r--r-- | src/lib/libssl/tls13_server.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/src/lib/libssl/tls13_server.c b/src/lib/libssl/tls13_server.c index 621e51d501..181ba583a0 100644 --- a/src/lib/libssl/tls13_server.c +++ b/src/lib/libssl/tls13_server.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: tls13_server.c,v 1.53 2020/05/23 11:58:46 jsing Exp $ */ | 1 | /* $OpenBSD: tls13_server.c,v 1.54 2020/05/29 17:47:30 jsing Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 2019, 2020 Joel Sing <jsing@openbsd.org> | 3 | * Copyright (c) 2019, 2020 Joel Sing <jsing@openbsd.org> |
4 | * Copyright (c) 2020 Bob Beck <beck@openbsd.org> | 4 | * Copyright (c) 2020 Bob Beck <beck@openbsd.org> |
@@ -373,6 +373,19 @@ tls13_client_hello_retry_recv(struct tls13_ctx *ctx, CBS *cbs) | |||
373 | return 1; | 373 | return 1; |
374 | } | 374 | } |
375 | 375 | ||
376 | static int | ||
377 | tls13_servername_process(struct tls13_ctx *ctx) | ||
378 | { | ||
379 | uint8_t alert = TLS13_ALERT_INTERNAL_ERROR; | ||
380 | |||
381 | if (!tls13_legacy_servername_process(ctx, &alert)) { | ||
382 | ctx->alert = alert; | ||
383 | return 0; | ||
384 | } | ||
385 | |||
386 | return 1; | ||
387 | } | ||
388 | |||
376 | int | 389 | int |
377 | tls13_server_hello_send(struct tls13_ctx *ctx, CBB *cbb) | 390 | tls13_server_hello_send(struct tls13_ctx *ctx, CBB *cbb) |
378 | { | 391 | { |
@@ -380,6 +393,8 @@ tls13_server_hello_send(struct tls13_ctx *ctx, CBB *cbb) | |||
380 | return 0; | 393 | return 0; |
381 | if (!tls13_key_share_generate(ctx->hs->key_share)) | 394 | if (!tls13_key_share_generate(ctx->hs->key_share)) |
382 | return 0; | 395 | return 0; |
396 | if (!tls13_servername_process(ctx)) | ||
397 | return 0; | ||
383 | 398 | ||
384 | ctx->hs->server_group = 0; | 399 | ctx->hs->server_group = 0; |
385 | 400 | ||