aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2020-04-06 22:39:56 +0200
committerGitHub <noreply@github.com>2020-04-06 22:39:56 +0200
commitfbe296aaba774b01348a55a6c9e10097bfd61b60 (patch)
tree50c8f0c71bd4703b78c7ce7b021469018d6be613
parent467234aa96058aa2cc74c0111b491b74c911d3d6 (diff)
parent901c0f6ede67b419e263eb1876f8720c791ed07f (diff)
downloadmitmproxy-fbe296aaba774b01348a55a6c9e10097bfd61b60.tar.gz
mitmproxy-fbe296aaba774b01348a55a6c9e10097bfd61b60.tar.bz2
mitmproxy-fbe296aaba774b01348a55a6c9e10097bfd61b60.zip
Merge pull request #3893 from matosconsulting/mitmenhancedhostcheck
#3885 handle hyphens in domain name, enhance validation checks
-rw-r--r--mitmproxy/net/check.py3
-rw-r--r--test/mitmproxy/net/test_check.py58
2 files changed, 60 insertions, 1 deletions
diff --git a/mitmproxy/net/check.py b/mitmproxy/net/check.py
index a19ad6fe..ffb5e163 100644
--- a/mitmproxy/net/check.py
+++ b/mitmproxy/net/check.py
@@ -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:
diff --git a/test/mitmproxy/net/test_check.py b/test/mitmproxy/net/test_check.py
index 0ffd6b2e..649e71da 100644
--- a/test/mitmproxy/net/test_check.py
+++ b/test/mitmproxy/net/test_check.py
@@ -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') \ No newline at end of file