mirror of
https://github.com/status-im/react-native.git
synced 2025-01-23 16:00:37 +00:00
f88bc3eb73
Summary: @public This is a refactor of @philikon's original diff that decouples the dependencies between the Network and Image modules, and replaces RCTDataQueryExecutor with a more useful abstraction. I've introduced the RCTURLRequestHandler protocol, which is a new type of bridge module used for loading data using an NSURLRequest. RCTURLRequestHandlers can be registered using RCT_EXPORT_MODULE() and are then available at runtime for use by the RCTDataManager, which will automatically select the appropriate handler for a given request based on the handler's self-reported capabilities. The currently implemented handlers are: - RCTHTTPRequestHandler - the standard open source HTTP request handler that uses NSURLSession - RKHTTPRequestHandler - the internal FB HTTP request handler that uses FBNetworking - RCTImageRequestHandler - a handler for loading local images from the iOS asset-library Depends on D2108193 Test Plan: - Internal apps still work - OSS port still compiles, Movies app and a sample Parse app still work - uploading image to Parse using the above code snippet works - tested `FormData` with string and image parameters using http://www.posttestserver.com/
55 lines
1.9 KiB
Objective-C
55 lines
1.9 KiB
Objective-C
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
|
|
#import "RCTBridgeModule.h"
|
|
#import "RCTURLRequestDelegate.h"
|
|
|
|
/**
|
|
* Provides the interface needed to register a request handler. Request handlers
|
|
* are also bridge modules, so should be registered using RCT_EXPORT_MODULE().
|
|
*/
|
|
@protocol RCTURLRequestHandler <RCTBridgeModule>
|
|
|
|
/**
|
|
* Indicates whether this handler is capable of processing the specified
|
|
* request. Typically the handler would examine the scheme/protocol of the
|
|
* request URL (and possibly the HTTP method and/or headers) to determine this.
|
|
*/
|
|
- (BOOL)canHandleRequest:(NSURLRequest *)request;
|
|
|
|
/**
|
|
* Send a network request and call the delegate with the response data. The
|
|
* method should return a token, which can be anything, including the request
|
|
* itself. This will be used later to refer to the request in callbacks. The
|
|
* `sendRequest:withDelegate:` method *must* return before calling any of the
|
|
* delegate methods, or the delegate won't recognize the token.
|
|
*/
|
|
- (id)sendRequest:(NSURLRequest *)request
|
|
withDelegate:(id<RCTURLRequestDelegate>)delegate;
|
|
|
|
@optional
|
|
|
|
/**
|
|
* Not all request types can be cancelled, but this method can be implemented
|
|
* for ones that can. It should be used to free up any resources on ongoing
|
|
* processes associated with the request.
|
|
*/
|
|
- (void)cancelRequest:(id)requestToken;
|
|
|
|
/**
|
|
* If more than one RCTURLRequestHandler responds YES to `canHandleRequest:`
|
|
* then `handlerPriority` is used to determine which one to use. The handler
|
|
* with the highest priority will be selected. Default priority is zero. If
|
|
* two or more valid handlers have the same priority, the selection order is
|
|
* undefined.
|
|
*/
|
|
- (float)handlerPriority;
|
|
|
|
@end
|