summaryrefslogtreecommitdiff
path: root/src/lib/libssl/tls13_server.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libssl/tls13_server.c')
-rw-r--r--src/lib/libssl/tls13_server.c17
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
376static int
377tls13_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
376int 389int
377tls13_server_hello_send(struct tls13_ctx *ctx, CBB *cbb) 390tls13_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