|
|
@ -25,12 +25,17 @@ BOOL IsNSErrorNetworkFailure(NSError *_Nullable error)
|
|
|
|
|
|
|
|
|
|
|
|
@interface TSNetworkManager ()
|
|
|
|
@interface TSNetworkManager ()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// This property should only be accessed on udSerialQueue.
|
|
|
|
|
|
|
|
@property (atomic, readonly) AFHTTPSessionManager *udSessionManager;
|
|
|
|
|
|
|
|
|
|
|
|
typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
|
|
|
|
|
|
|
|
@end
|
|
|
|
@end
|
|
|
|
|
|
|
|
|
|
|
|
@implementation TSNetworkManager
|
|
|
|
@implementation TSNetworkManager
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@synthesize udSessionManager = _udSessionManager;
|
|
|
|
|
|
|
|
|
|
|
|
#pragma mark Singleton implementation
|
|
|
|
#pragma mark Singleton implementation
|
|
|
|
|
|
|
|
|
|
|
|
+ (instancetype)sharedManager
|
|
|
|
+ (instancetype)sharedManager
|
|
|
@ -61,6 +66,17 @@ typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
return [self makeRequest:request completionQueue:dispatch_get_main_queue() success:success failure:failure];
|
|
|
|
return [self makeRequest:request completionQueue:dispatch_get_main_queue() success:success failure:failure];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- (dispatch_queue_t)udSerialQueue
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
static dispatch_queue_t _serialQueue;
|
|
|
|
|
|
|
|
static dispatch_once_t onceToken;
|
|
|
|
|
|
|
|
dispatch_once(&onceToken, ^{
|
|
|
|
|
|
|
|
_serialQueue = dispatch_queue_create("org.whispersystems.networkManager.udQueue", DISPATCH_QUEUE_SERIAL);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return _serialQueue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
- (void)makeRequest:(TSRequest *)request
|
|
|
|
- (void)makeRequest:(TSRequest *)request
|
|
|
|
completionQueue:(dispatch_queue_t)completionQueue
|
|
|
|
completionQueue:(dispatch_queue_t)completionQueue
|
|
|
|
success:(TSNetworkManagerSuccess)successBlock
|
|
|
|
success:(TSNetworkManagerSuccess)successBlock
|
|
|
@ -70,9 +86,15 @@ typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
OWSAssertDebug(successBlock);
|
|
|
|
OWSAssertDebug(successBlock);
|
|
|
|
OWSAssertDebug(failureBlock);
|
|
|
|
OWSAssertDebug(failureBlock);
|
|
|
|
|
|
|
|
|
|
|
|
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
|
|
|
|
if (request.isUDRequest) {
|
|
|
|
[self makeRequestSync:request completionQueue:completionQueue success:successBlock failure:failureBlock];
|
|
|
|
dispatch_async(self.udSerialQueue, ^{
|
|
|
|
});
|
|
|
|
[self makeUDRequestSync:request success:successBlock failure:failureBlock];
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
|
|
|
|
|
|
|
|
[self makeRequestSync:request completionQueue:completionQueue success:successBlock failure:failureBlock];
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
- (void)makeRequestSync:(TSRequest *)request
|
|
|
|
- (void)makeRequestSync:(TSRequest *)request
|
|
|
@ -84,11 +106,11 @@ typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
OWSAssertDebug(successBlock);
|
|
|
|
OWSAssertDebug(successBlock);
|
|
|
|
OWSAssertDebug(failureBlock);
|
|
|
|
OWSAssertDebug(failureBlock);
|
|
|
|
|
|
|
|
|
|
|
|
OWSLogInfo(@"Making request: %@", request);
|
|
|
|
OWSLogInfo(@"Making Non-UD request: %@", request);
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: Remove this logging when the call connection issues have been resolved.
|
|
|
|
// TODO: Remove this logging when the call connection issues have been resolved.
|
|
|
|
TSNetworkManagerSuccess success = ^(NSURLSessionDataTask *task, _Nullable id responseObject) {
|
|
|
|
TSNetworkManagerSuccess success = ^(NSURLSessionDataTask *task, _Nullable id responseObject) {
|
|
|
|
OWSLogInfo(@"request succeeded : %@", request);
|
|
|
|
OWSLogInfo(@"UD request succeeded : %@", request);
|
|
|
|
|
|
|
|
|
|
|
|
if (request.shouldHaveAuthorizationHeaders) {
|
|
|
|
if (request.shouldHaveAuthorizationHeaders) {
|
|
|
|
[TSAccountManager.sharedInstance setIsDeregistered:NO];
|
|
|
|
[TSAccountManager.sharedInstance setIsDeregistered:NO];
|
|
|
@ -110,10 +132,8 @@ typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
password:request.authPassword];
|
|
|
|
password:request.authPassword];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Honor the request's preferences about default cookie handling.
|
|
|
|
// Disable default cookie handling for all requests.
|
|
|
|
//
|
|
|
|
sessionManager.requestSerializer.HTTPShouldHandleCookies = NO;
|
|
|
|
// Default is YES.
|
|
|
|
|
|
|
|
sessionManager.requestSerializer.HTTPShouldHandleCookies = request.HTTPShouldHandleCookies;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Honor the request's headers.
|
|
|
|
// Honor the request's headers.
|
|
|
|
for (NSString *headerField in request.allHTTPHeaderFields) {
|
|
|
|
for (NSString *headerField in request.allHTTPHeaderFields) {
|
|
|
@ -121,6 +141,69 @@ typedef void (^failureBlock)(NSURLSessionDataTask *task, NSError *error);
|
|
|
|
[sessionManager.requestSerializer setValue:headerValue forHTTPHeaderField:headerField];
|
|
|
|
[sessionManager.requestSerializer setValue:headerValue forHTTPHeaderField:headerField];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[self performRequest:request sessionManager:sessionManager success:success failure:failure];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// This method should only be invoked on udSerialQueue.
|
|
|
|
|
|
|
|
- (AFHTTPSessionManager *)udSessionManager
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (!_udSessionManager) {
|
|
|
|
|
|
|
|
_udSessionManager = [OWSSignalService sharedInstance].signalServiceSessionManager;
|
|
|
|
|
|
|
|
_udSessionManager.completionQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
|
|
|
|
|
|
|
|
// Disable default cookie handling for all requests.
|
|
|
|
|
|
|
|
_udSessionManager.requestSerializer.HTTPShouldHandleCookies = NO;
|
|
|
|
|
|
|
|
_udSessionManager.session.configuration.HTTPShouldSetCookies = NO;
|
|
|
|
|
|
|
|
_udSessionManager.session.configuration.HTTPShouldUsePipelining = YES;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return _udSessionManager;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- (void)makeUDRequestSync:(TSRequest *)request
|
|
|
|
|
|
|
|
success:(TSNetworkManagerSuccess)successBlock
|
|
|
|
|
|
|
|
failure:(TSNetworkManagerFailure)failureBlock
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
OWSAssertDebug(request);
|
|
|
|
|
|
|
|
OWSAssert(!request.shouldHaveAuthorizationHeaders);
|
|
|
|
|
|
|
|
OWSAssertDebug(successBlock);
|
|
|
|
|
|
|
|
OWSAssertDebug(failureBlock);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
OWSLogInfo(@"Making UD request: %@", request);
|
|
|
|
|
|
|
|
uint64_t before = [NSDate ows_millisecondTimeStamp];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TSNetworkManagerSuccess success = ^(NSURLSessionDataTask *task, _Nullable id responseObject) {
|
|
|
|
|
|
|
|
OWSLogInfo(@"Non-UD request succeeded : %@", request);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
successBlock(task, responseObject);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[OutageDetection.sharedManager reportConnectionSuccess];
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
TSNetworkManagerFailure failure = [TSNetworkManager errorPrettifyingForFailureBlock:failureBlock request:request];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
AFHTTPSessionManager *sessionManager = self.udSessionManager;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Honor the request's headers.
|
|
|
|
|
|
|
|
for (NSString *headerField in sessionManager.requestSerializer.HTTPRequestHeaders.allKeys.copy) {
|
|
|
|
|
|
|
|
[sessionManager.requestSerializer setValue:nil forHTTPHeaderField:headerField];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
for (NSString *headerField in request.allHTTPHeaderFields) {
|
|
|
|
|
|
|
|
NSString *headerValue = request.allHTTPHeaderFields[headerField];
|
|
|
|
|
|
|
|
[sessionManager.requestSerializer setValue:headerValue forHTTPHeaderField:headerField];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[self performRequest:request sessionManager:sessionManager success:success failure:failure];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- (void)performRequest:(TSRequest *)request
|
|
|
|
|
|
|
|
sessionManager:(AFHTTPSessionManager *)sessionManager
|
|
|
|
|
|
|
|
success:(TSNetworkManagerSuccess)success
|
|
|
|
|
|
|
|
failure:(TSNetworkManagerFailure)failure
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
OWSAssertDebug(request);
|
|
|
|
|
|
|
|
OWSAssertDebug(sessionManager);
|
|
|
|
|
|
|
|
OWSAssertDebug(success);
|
|
|
|
|
|
|
|
OWSAssertDebug(failure);
|
|
|
|
|
|
|
|
|
|
|
|
if ([request.HTTPMethod isEqualToString:@"GET"]) {
|
|
|
|
if ([request.HTTPMethod isEqualToString:@"GET"]) {
|
|
|
|
[sessionManager GET:request.URL.absoluteString
|
|
|
|
[sessionManager GET:request.URL.absoluteString
|
|
|
|
parameters:request.parameters
|
|
|
|
parameters:request.parameters
|
|
|
|