aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoopesh Chander <roop@roopc.net>2018-10-23 16:14:10 +0530
committerRoopesh Chander <roop@roopc.net>2018-10-27 15:13:01 +0530
commitbcf8abb1de99e9de9d858d796552f733a1013db6 (patch)
tree684731f4fd42315d7ebd8f50f22be52453e7489e
parentModel: listenPort and persistentKeepAlive should be 16-bit integers (diff)
downloadwireguard-apple-bcf8abb1de99e9de9d858d796552f733a1013db6.tar.xz
wireguard-apple-bcf8abb1de99e9de9d858d796552f733a1013db6.zip
Model: Endpoint host should not have invalid characters
Signed-off-by: Roopesh Chander <roop@roopc.net>
-rw-r--r--WireGuard/WireGuard/Model/Endpoint.swift23
1 files changed, 13 insertions, 10 deletions
diff --git a/WireGuard/WireGuard/Model/Endpoint.swift b/WireGuard/WireGuard/Model/Endpoint.swift
index 0b1619b..c8ade2f 100644
--- a/WireGuard/WireGuard/Model/Endpoint.swift
+++ b/WireGuard/WireGuard/Model/Endpoint.swift
@@ -23,26 +23,29 @@ extension Endpoint {
// Separation of host and port is based on 'parse_endpoint' function in
// https://git.zx2c4.com/WireGuard/tree/src/tools/config.c
guard (!string.isEmpty) else { return nil }
+ let startOfPort: String.Index
+ let hostString: String
if (string.first! == "[") {
// Look for IPv6-style endpoint, like [::1]:80
let startOfHost = string.index(after: string.startIndex)
guard let endOfHost = string.dropFirst().firstIndex(of: "]") else { return nil }
let afterEndOfHost = string.index(after: endOfHost)
guard (string[afterEndOfHost] == ":") else { return nil }
- let startOfPort = string.index(after: afterEndOfHost)
- let hostString = String(string[startOfHost ..< endOfHost])
- guard let endpointPort = NWEndpoint.Port(String(string[startOfPort ..< string.endIndex])) else { return nil }
- host = NWEndpoint.Host(hostString)
- port = endpointPort
+ startOfPort = string.index(after: afterEndOfHost)
+ hostString = String(string[startOfHost ..< endOfHost])
} else {
// Look for an IPv4-style endpoint, like 127.0.0.1:80
guard let endOfHost = string.firstIndex(of: ":") else { return nil }
- let startOfPort = string.index(after: endOfHost)
- let hostString = String(string[string.startIndex ..< endOfHost])
- guard let endpointPort = NWEndpoint.Port(String(string[startOfPort ..< string.endIndex])) else { return nil }
- host = NWEndpoint.Host(hostString)
- port = endpointPort
+ startOfPort = string.index(after: endOfHost)
+ hostString = String(string[string.startIndex ..< endOfHost])
}
+ guard let endpointPort = NWEndpoint.Port(String(string[startOfPort ..< string.endIndex])) else { return nil }
+ let invalidCharacterIndex = hostString.unicodeScalars.firstIndex { (c) -> Bool in
+ return !CharacterSet.urlHostAllowed.contains(c)
+ }
+ guard (invalidCharacterIndex == nil) else { return nil }
+ host = NWEndpoint.Host(hostString)
+ port = endpointPort
}
func stringRepresentation() -> String {
switch (host) {