summaryrefslogtreecommitdiff
path: root/lib/libssl
diff options
context:
space:
mode:
authorJoel Sing <jsing@cvs.openbsd.org>2019-11-18 02:44:21 +0000
committerJoel Sing <jsing@cvs.openbsd.org>2019-11-18 02:44:21 +0000
commitd6a6c7e9619f553eee2e068a54ccd6248072dbe8 (patch)
tree3318a8b2c4c0fe74e524f6b3ae1f2d465aac13e6 /lib/libssl
parentfe89b6ea985b8d090bf266451179675df0929bf9 (diff)
Provide a clean interface for sending TLSv1.3 alerts.
ok beck@
Diffstat (limited to 'lib/libssl')
-rw-r--r--lib/libssl/tls13_internal.h6
-rw-r--r--lib/libssl/tls13_record_layer.c16
2 files changed, 17 insertions, 5 deletions
diff --git a/lib/libssl/tls13_internal.h b/lib/libssl/tls13_internal.h
index df5f13eb668..5fd1956cfdd 100644
--- a/lib/libssl/tls13_internal.h
+++ b/lib/libssl/tls13_internal.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: tls13_internal.h,v 1.32 2019/11/17 21:47:01 jsing Exp $ */
+/* $OpenBSD: tls13_internal.h,v 1.33 2019/11/18 02:44:20 jsing Exp $ */
/*
* Copyright (c) 2018 Bob Beck <beck@openbsd.org>
* Copyright (c) 2018 Theo Buehler <tb@openbsd.org>
@@ -120,8 +120,6 @@ int tls13_record_layer_set_read_traffic_key(struct tls13_record_layer *rl,
struct tls13_secret *read_key);
int tls13_record_layer_set_write_traffic_key(struct tls13_record_layer *rl,
struct tls13_secret *write_key);
-ssize_t tls13_record_layer_alert(struct tls13_record_layer *rl,
- uint8_t alert_level, uint8_t alert_desc);
ssize_t tls13_record_layer_phh(struct tls13_record_layer *rl, CBS *cbs);
ssize_t tls13_read_handshake_data(struct tls13_record_layer *rl, uint8_t *buf, size_t n);
@@ -131,6 +129,8 @@ ssize_t tls13_read_application_data(struct tls13_record_layer *rl, uint8_t *buf,
ssize_t tls13_write_application_data(struct tls13_record_layer *rl, const uint8_t *buf,
size_t n);
+ssize_t tls13_send_alert(struct tls13_record_layer *rl, uint8_t alert_desc);
+
/*
* Handshake Messages.
*/
diff --git a/lib/libssl/tls13_record_layer.c b/lib/libssl/tls13_record_layer.c
index ebefac0a25e..188f56e0b48 100644
--- a/lib/libssl/tls13_record_layer.c
+++ b/lib/libssl/tls13_record_layer.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tls13_record_layer.c,v 1.14 2019/11/17 21:47:01 jsing Exp $ */
+/* $OpenBSD: tls13_record_layer.c,v 1.15 2019/11/18 02:44:20 jsing Exp $ */
/*
* Copyright (c) 2018, 2019 Joel Sing <jsing@openbsd.org>
*
@@ -328,7 +328,7 @@ tls13_record_layer_send_pending(struct tls13_record_layer *rl)
return TLS13_IO_SUCCESS;
}
-ssize_t
+static ssize_t
tls13_record_layer_alert(struct tls13_record_layer *rl,
uint8_t alert_level, uint8_t alert_desc)
{
@@ -967,3 +967,15 @@ tls13_write_application_data(struct tls13_record_layer *rl, const uint8_t *buf,
return tls13_record_layer_write(rl, SSL3_RT_APPLICATION_DATA, buf, n);
}
+
+ssize_t
+tls13_send_alert(struct tls13_record_layer *rl, uint8_t alert_desc)
+{
+ uint8_t alert_level = SSL3_AL_FATAL;
+
+ if (alert_desc == SSL_AD_CLOSE_NOTIFY ||
+ alert_desc == SSL_AD_USER_CANCELLED)
+ alert_level = SSL3_AL_WARNING;
+
+ return tls13_record_layer_alert(rl, alert_level, alert_desc);
+}