|
|
@ -58,22 +58,14 @@ |
|
|
|
// Default initializer. |
|
|
|
// Default initializer. |
|
|
|
- (instancetype)initWithAddress:(NSString *)address { |
|
|
|
- (instancetype)initWithAddress:(NSString *)address { |
|
|
|
|
|
|
|
|
|
|
|
// Verify and normalize the address, and decide whether to use SSL. |
|
|
|
// To provide a default port, we try to interpret the address. If it's just a host name without |
|
|
|
if (![address rangeOfString:@"://"].length) { |
|
|
|
// scheme and without port, we'll use port 443. If it has a scheme, we pass it untouched to the C |
|
|
|
// No scheme provided; assume https. |
|
|
|
// gRPC library. |
|
|
|
address = [@"https://" stringByAppendingString:address]; |
|
|
|
// TODO(jcanizales): Add unit tests for the types of addresses we want to let pass untouched. |
|
|
|
|
|
|
|
NSURL *hostURL = [NSURL URLWithString:[@"https://" stringByAppendingString:address]]; |
|
|
|
|
|
|
|
if (hostURL && !hostURL.port) { |
|
|
|
|
|
|
|
address = [hostURL.host stringByAppendingString:@":443"]; |
|
|
|
} |
|
|
|
} |
|
|
|
NSURL *hostURL = [NSURL URLWithString:address]; |
|
|
|
|
|
|
|
if (!hostURL) { |
|
|
|
|
|
|
|
[NSException raise:NSInvalidArgumentException format:@"Invalid URL: %@", address]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
NSString *scheme = hostURL.scheme; |
|
|
|
|
|
|
|
if (![scheme isEqualToString:@"https"] && ![scheme isEqualToString:@"http"]) { |
|
|
|
|
|
|
|
[NSException raise:NSInvalidArgumentException format:@"URL scheme %@ isn't supported.", scheme]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
// If the user didn't specify a port (hostURL.port is nil), provide a default one. |
|
|
|
|
|
|
|
NSNumber *port = hostURL.port ?: [scheme isEqualToString:@"https"] ? @443 : @80; |
|
|
|
|
|
|
|
address = [@[hostURL.host, port] componentsJoinedByString:@":"]; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Look up the GRPCHost in the cache. |
|
|
|
// Look up the GRPCHost in the cache. |
|
|
|
static NSMutableDictionary *hostCache; |
|
|
|
static NSMutableDictionary *hostCache; |
|
|
@ -84,19 +76,15 @@ |
|
|
|
@synchronized(hostCache) { |
|
|
|
@synchronized(hostCache) { |
|
|
|
GRPCHost *cachedHost = hostCache[address]; |
|
|
|
GRPCHost *cachedHost = hostCache[address]; |
|
|
|
if (cachedHost) { |
|
|
|
if (cachedHost) { |
|
|
|
// We could verify here that the cached host uses the same protocol that we're expecting. But |
|
|
|
|
|
|
|
// creating non-SSL channels by adding "http://" to the address is going away (to make the use |
|
|
|
|
|
|
|
// of insecure channels less subtle), so it's not worth it now. |
|
|
|
|
|
|
|
return cachedHost; |
|
|
|
return cachedHost; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if ((self = [super init])) { |
|
|
|
if ((self = [super init])) { |
|
|
|
_address = address; |
|
|
|
_address = address; |
|
|
|
_secure = [scheme isEqualToString:@"https"]; |
|
|
|
_secure = YES; |
|
|
|
hostCache[address] = self; |
|
|
|
hostCache[address] = self; |
|
|
|
} |
|
|
|
|
|
|
|
return self; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return self; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
- (grpc_call *)unmanagedCallWithPath:(NSString *)path completionQueue:(GRPCCompletionQueue *)queue { |
|
|
|
- (grpc_call *)unmanagedCallWithPath:(NSString *)path completionQueue:(GRPCCompletionQueue *)queue { |
|
|
@ -131,4 +119,7 @@ |
|
|
|
return _hostNameOverride ?: _address; |
|
|
|
return _hostNameOverride ?: _address; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO(jcanizales): Don't let set |secure| to |NO| if |pathToCertificates| or |hostNameOverride| |
|
|
|
|
|
|
|
// have been set. Don't let set either of the latter if |secure| has been set to |NO|. |
|
|
|
|
|
|
|
|
|
|
|
@end |
|
|
|
@end |
|
|
|