mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2025-02-25 07:07:52 +01:00
Validate hostnames with punycode TLDs correctly
This commit is contained in:
parent
4413e52f9e
commit
dbb7c8e6fd
2 changed files with 17 additions and 4 deletions
|
@ -1119,7 +1119,8 @@ string_is_valid_hostname(const char *string)
|
|||
|
||||
/* Allow a single terminating '.' used rarely to indicate domains
|
||||
* are FQDNs rather than relative. */
|
||||
last_label = (char *)smartlist_get(components, smartlist_len(components) - 1);
|
||||
last_label = (char *)smartlist_get(components,
|
||||
smartlist_len(components) - 1);
|
||||
has_trailing_dot = (last_label[0] == '\0');
|
||||
if (has_trailing_dot) {
|
||||
smartlist_pop_last(components);
|
||||
|
@ -1133,12 +1134,20 @@ string_is_valid_hostname(const char *string)
|
|||
break;
|
||||
}
|
||||
|
||||
if (c_sl_idx == c_sl_len - 1) {
|
||||
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 = TOR_ISALPHA(*c);
|
||||
result = is_punycode ? TOR_ISALNUM(*c) : TOR_ISALPHA(*c);
|
||||
c++;
|
||||
} while (result && *c);
|
||||
} else {
|
||||
} else { // Regular hostname label validation.
|
||||
do {
|
||||
result = (TOR_ISALNUM(*c) || (*c == '-') || (*c == '_'));
|
||||
c++;
|
||||
|
|
|
@ -5595,6 +5595,10 @@ test_util_hostname_validation(void *arg)
|
|||
tt_assert(!string_is_valid_hostname("luck.y13"));
|
||||
tt_assert(!string_is_valid_hostname("luck.y13."));
|
||||
|
||||
// We allow punycode TLDs. For examples, see
|
||||
// http://data.iana.org/TLD/tlds-alpha-by-domain.txt
|
||||
tt_assert(string_is_valid_hostname("example.xn--l1acc"));
|
||||
|
||||
done:
|
||||
return;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue