Chromium Code Reviews| Index: chrome/installer/mac/app/NetworkCommunication.h |
| diff --git a/chrome/installer/mac/app/NetworkCommunication.h b/chrome/installer/mac/app/NetworkCommunication.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..5c96114742eb879eb3e1f4b3d5abb1de2ee43b94 |
| --- /dev/null |
| +++ b/chrome/installer/mac/app/NetworkCommunication.h |
| @@ -0,0 +1,43 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CHROME_INSTALLER_MAC_APP_NETWORKCOMMUNICATION_H_ |
| +#define CHROME_INSTALLER_MAC_APP_NETWORKCOMMUNICATION_H_ |
| + |
| +#import <Foundation/Foundation.h> |
| + |
| +typedef void (^DataTaskCompletionHandler)(NSData*, NSURLResponse*, NSError*); |
| +typedef void (^DownloadTaskCompletionHandler)(NSURL*, NSURLResponse*, NSError*); |
| + |
| +@interface NetworkCommunication : NSObject |
| + |
| +@property(nonatomic, copy) NSMutableURLRequest* request; |
| +// Question: Our current design of the project thus far involves having one |
| +// NSURLSession run the whole show. Thoughts? Is this one of those |
| +// things that don't really matter, or does it have a positive / |
|
Elly Fong-Jones
2016/07/06 15:22:01
I think it's fine to just have one NSURLSession, b
|
| +// negative impact on our project? |
| +@property(nonatomic, copy) NSURLSession* session; |
| +// The user of this class must set these handlers if functionality is needed at |
| +// the completion of a URLSession task. |
| +@property(nonatomic, copy) DataTaskCompletionHandler dataResponseHandler; |
| +@property(nonatomic, copy) DownloadTaskCompletionHandler downloadResponseHandler; |
| + |
| +- (id)init; |
| +- (id)initWithDelegate:(id) delegate; |
| + |
| +// Creates a mutable URLRequest object as an instance variable, then returns it |
| +// so the caller has a chance to edit it before sending the request out. |
| +// Contrary to the assumption in Objective-C that all return values are returned |
| +// by VALUE, it seems that changes made to the returned object outside of this |
| +// class are retained. |
| +- (NSMutableURLRequest*)createRequestWithURLasString:(NSString*) urlString |
| + andXMLBody:(NSXMLDocument*) body; |
| +// Adds a data task to the run loop using the request instance variable. |
| +- (NSURLSessionDataTask*)sendDataRequest; |
|
Elly Fong-Jones
2016/07/06 15:22:01
Hm... sendDataRequestWithCompletionHandler:? Will
Anna Zeng
2016/07/07 15:24:53
including the completion handler means that delega
|
| +// Adds a download task to the run loop using the request instance variable. |
| +- (NSURLSessionDownloadTask*)sendDownloadRequest; |
| + |
| +@end |
| + |
| +#endif // CHROME_INSTALLER_MAC_APP_NETWORKCOMMUNICATION_H_ |