/* * Copyright (C) 2017 Twitter, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #import NS_ASSUME_NONNULL_BEGIN @protocol TWTRNetworkingResponseValidating; typedef void (^TWTRNetworkingPipelineCallback)(NSData *_Nullable data, NSURLResponse *_Nullable response, NSError *_Nullable error); @interface TWTRNetworkingPipeline : NSObject /** *if set, this object will be used to validate network responses. */ @property (nonatomic, readonly, nullable) id responseValidator; /** * Use the initWithURLSession: method instead. */ - (instancetype)init NS_UNAVAILABLE; /** * Returns an instance of the networking pipeline * * @param URLSession URLSession object to invoke network requests on. * @param responseValidator an optional response validator to use to validate responses. */ - (instancetype)initWithURLSession:(NSURLSession *)URLSession responseValidator:(nullable id)responseValidator NS_DESIGNATED_INITIALIZER; /** * Enqueues a request in the pipeline. * * @param request The HTTP Request to send * @param sessionStore The session store that will provide the session. * @param userID The userId to sign the request for or nil if using the guest session * @param completion The completion block to invoke on completion. */ - (NSProgress *)enqueueRequest:(NSURLRequest *)request sessionStore:(id)sessionStore; - (NSProgress *)enqueueRequest:(NSURLRequest *)request sessionStore:(id)sessionStore requestingUser:(nullable NSString *)userID; /** * Enqueues a request in the pipeline. * * @param request The HTTP request to send. * @param sessionStore The session store that will provide the session. * @param userID The user to sign the request for or nil if using the guest session. * @param completion The completion block to invoke on completion. */ - (NSProgress *)enqueueRequest:(NSURLRequest *)request sessionStore:(id)sessionStore requestingUser:(nullable NSString *)userID completion:(nullable TWTRNetworkingPipelineCallback)completion; @end @protocol TWTRNetworkingResponseValidating @required /** * This method should return an NO if the response represents an error state. */ - (BOOL)validateResponse:(nullable NSURLResponse *)response data:(nullable NSData *)data error:(NSError **)error; @end NS_ASSUME_NONNULL_END