2019-09-30 10:41:16 -04:00
|
|
|
From 93a6a9a753c541e04875648cf5671e422e4621df Mon Sep 17 00:00:00 2001
|
|
|
|
|
From: lvying <lvying6@huawei.com>
|
|
|
|
|
Date: Sat, 8 Jun 2019 22:36:10 -0400
|
|
|
|
|
Subject: [PATCH] fix ipv6 handshake failed
|
|
|
|
|
|
|
|
|
|
reason: fix ipv6 handshake failed
|
|
|
|
|
|
|
|
|
|
Signed-off-by: lvying <lvying6@huawei.com>
|
2024-01-29 14:49:47 +08:00
|
|
|
|
2019-09-30 10:41:16 -04:00
|
|
|
---
|
2024-01-29 14:49:47 +08:00
|
|
|
lib/ext/server_name.c | 4 +++-
|
|
|
|
|
lib/str.h | 10 ++++++++++
|
2019-09-30 10:41:16 -04:00
|
|
|
2 files changed, 13 insertions(+), 1 deletion(-)
|
|
|
|
|
|
|
|
|
|
diff --git a/lib/ext/server_name.c b/lib/ext/server_name.c
|
2024-01-29 14:49:47 +08:00
|
|
|
index a7329d0..7be1ca1 100644
|
2019-09-30 10:41:16 -04:00
|
|
|
--- a/lib/ext/server_name.c
|
|
|
|
|
+++ b/lib/ext/server_name.c
|
2024-01-29 14:49:47 +08:00
|
|
|
@@ -108,7 +108,9 @@ static int _gnutls_server_name_recv_params(gnutls_session_t session,
|
2019-09-30 10:41:16 -04:00
|
|
|
DECR_LEN(data_size, len);
|
|
|
|
|
|
2024-01-29 14:49:47 +08:00
|
|
|
if (type == 0) { /* NAME_DNS */
|
2023-07-20 21:13:38 +08:00
|
|
|
- if (!_gnutls_dnsname_is_valid((char *)p, len)) {
|
2024-01-29 14:49:47 +08:00
|
|
|
+ _gnutls_debug_log("HSK[%p]: recieve server name: '%.*s'\n", session, len, p);
|
|
|
|
|
+ /* fix ipv6 format server name invaild problem */
|
|
|
|
|
+ if (!_gnutls_dnsname_is_valid((char*)p, len) && !_gnutls_ipv6_is_valid((char*)p, len)) {
|
|
|
|
|
_gnutls_handshake_log(
|
|
|
|
|
"HSK[%p]: Server name is not acceptable: '%.*s'\n",
|
|
|
|
|
session, (int)len, p);
|
2019-09-30 10:41:16 -04:00
|
|
|
diff --git a/lib/str.h b/lib/str.h
|
2024-01-29 14:49:47 +08:00
|
|
|
index 1f670cd..aa4b5b2 100644
|
2019-09-30 10:41:16 -04:00
|
|
|
--- a/lib/str.h
|
|
|
|
|
+++ b/lib/str.h
|
2024-01-29 14:49:47 +08:00
|
|
|
@@ -64,6 +64,16 @@ inline static unsigned _gnutls_str_is_print(const char *str, unsigned size)
|
2019-09-30 10:41:16 -04:00
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
+inline static unsigned _gnutls_ipv6_is_valid(const char *str, unsigned size)
|
|
|
|
|
+{
|
|
|
|
|
+ unsigned i;
|
|
|
|
|
+ for (i=0;i<size;i++) {
|
|
|
|
|
+ if (!(c_isalnum(str[i]) || str[i] == ':' || str[i] == '%' || str[i] == '.'))
|
|
|
|
|
+ return 0;
|
|
|
|
|
+ }
|
|
|
|
|
+ return 1;
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
inline static unsigned _gnutls_dnsname_is_valid(const char *str, unsigned size)
|
|
|
|
|
{
|
|
|
|
|
unsigned i;
|
|
|
|
|
--
|
2024-01-29 14:49:47 +08:00
|
|
|
2.33.0
|
2019-09-30 10:41:16 -04:00
|
|
|
|