[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[tor-commits] [tor/master] Simplify hostname validation code
commit ee1fca727cd739ba94c215a4a45a416bfcc8956e
Author: rl1987 <rl1987@xxxxxxxxxxxxxxxx>
Date: Mon Feb 19 21:08:51 2018 +0100
Simplify hostname validation code
---
src/common/util.c | 26 +++++++-------------------
1 file changed, 7 insertions(+), 19 deletions(-)
diff --git a/src/common/util.c b/src/common/util.c
index a55f7a3cd..1402462fb 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -1113,6 +1113,9 @@ string_is_valid_hostname(const char *string)
if (!string || strlen(string) == 0)
return 0;
+ if (string_is_valid_ipv4_address(string))
+ return 0;
+
components = smartlist_new();
smartlist_split_string(components,string,".",0,0);
@@ -1134,25 +1137,10 @@ string_is_valid_hostname(const char *string)
break;
}
- if (c_sl_idx == c_sl_len - 1) { // TLD validation.
- int is_punycode = (strlen(c) > 4 &&
- (c[0] == 'X' || c[0] == 'x') &&
- (c[1] == 'N' || c[1] == 'n') &&
- c[2] == '-' && c[3] == '-');
-
- if (is_punycode)
- c += 4;
-
- do {
- result = is_punycode ? TOR_ISALNUM(*c) : TOR_ISALPHA(*c);
- c++;
- } while (result && *c);
- } else { // Regular hostname label validation.
- do {
- result = (TOR_ISALNUM(*c) || (*c == '-') || (*c == '_'));
- c++;
- } while (result > 0 && *c);
- }
+ do {
+ result = (TOR_ISALNUM(*c) || (*c == '-') || (*c == '_'));
+ c++;
+ } while (result > 0 && *c);
if (result == 0) {
break;
_______________________________________________
tor-commits mailing list
tor-commits@xxxxxxxxxxxxxxxxxxxx
https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-commits