Merge pull request #3893 from matosconsulting/mitmenhancedhostcheck

#3885 handle hyphens in domain name, enhance validation checks
This commit is contained in:
Maximilian Hils 2020-04-06 22:39:56 +02:00 committed by GitHub
commit fbe296aaba
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 60 additions and 1 deletions

View File

@ -2,7 +2,8 @@ import ipaddress
import re
# Allow underscore in host name
_label_valid = re.compile(br"(?!-)[A-Z\d\-_]{1,63}(?<!-)$", re.IGNORECASE)
# Note: This could be a DNS label, a hostname, a FQDN, or an IP
_label_valid = re.compile(br"[A-Z\d\-_]{1,63}$", re.IGNORECASE)
def is_valid_host(host: bytes) -> bool:

View File

@ -12,3 +12,61 @@ def test_is_valid_host():
# Allow underscore
assert check.is_valid_host(b"one_two")
assert check.is_valid_host(b"::1")
# IP Address Validations
assert check.is_valid_host(b'127.0.0.1')
assert check.is_valid_host(b'2001:0db8:85a3:0000:0000:8a2e:0370:7334')
assert check.is_valid_host(b'2001:db8:85a3:0:0:8a2e:370:7334')
assert check.is_valid_host(b'2001:db8:85a3::8a2e:370:7334')
assert not check.is_valid_host(b'2001:db8::85a3::7334')
assert check.is_valid_host(b'2001-db8-85a3-8d3-1319-8a2e-370-7348.ipv6-literal.net')
# TLD must be between 2 and 63 chars
assert check.is_valid_host(b'example.tl')
assert check.is_valid_host(b'example.tld')
assert check.is_valid_host(b'example.' + b"x" * 63)
assert not check.is_valid_host(b'example.' + b"x" * 64)
# misc characters test
assert not check.is_valid_host(b'ex@mple')
assert not check.is_valid_host(b'ex@mple.com')
assert not check.is_valid_host(b'example..com')
assert not check.is_valid_host(b'.example.com')
assert not check.is_valid_host(b'@.example.com')
assert not check.is_valid_host(b'!.example.com')
# Every label must be between 1 and 63 chars
assert not check.is_valid_host(b'.tld')
assert check.is_valid_host(b'x' * 1 + b'.tld')
assert check.is_valid_host(b'x' * 30 + b'.tld')
assert not check.is_valid_host(b'x' * 64 + b'.tld')
assert check.is_valid_host(b'x' * 1 + b'.example.tld')
assert check.is_valid_host(b'x' * 30 + b'.example.tld')
assert not check.is_valid_host(b'x' * 64 + b'.example.tld')
# Misc Underscore Test Cases
assert check.is_valid_host(b'_example')
assert check.is_valid_host(b'_example_')
assert check.is_valid_host(b'example_')
assert check.is_valid_host(b'_a.example.tld')
assert check.is_valid_host(b'a_.example.tld')
assert check.is_valid_host(b'_a_.example.tld')
# Misc Dash/Hyphen/Minus Test Cases
assert check.is_valid_host(b'-example')
assert check.is_valid_host(b'-example_')
assert check.is_valid_host(b'example-')
assert check.is_valid_host(b'-a.example.tld')
assert check.is_valid_host(b'a-.example.tld')
assert check.is_valid_host(b'-a-.example.tld')
# Misc Combo Test Cases
assert check.is_valid_host(b'api-.example.com')
assert check.is_valid_host(b'__a.example-site.com')
assert check.is_valid_host(b'_-a.example-site.com')
assert check.is_valid_host(b'_a_.example-site.com')
assert check.is_valid_host(b'-a-.example-site.com')
assert check.is_valid_host(b'api-.a.example.com')
assert check.is_valid_host(b'api-._a.example.com')
assert check.is_valid_host(b'api-.a_.example.com')
assert check.is_valid_host(b'api-.ab.example.com')