/* * 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 typedef void (^TWTRMultipartFormDocumentLoadDataCallback)(NSData *data); @interface TWTRMultipartFormElement : NSObject /** * The name of the form element. */ @property (nonatomic, copy, readonly) NSString *name; /** * The content type of the form element. */ @property (nonatomic, copy, readonly) NSString *contentType; /** * An optional filename for this element. */ @property (nonatomic, copy, readonly, nullable) NSString *fileName; /** * The content's data. */ @property (nonatomic, copy, readonly) NSData *content; /** * Returns a fully initialized form element to be used in a multipart for document. * * @param name the name of the element * @param contentType the elements content type * @param fileName an optional file name * @param content the data associated with this item */ - (instancetype)initWithName:(NSString *)name contentType:(NSString *)contentType fileName:(nullable NSString *)fileName content:(NSData *)content NS_DESIGNATED_INITIALIZER; - (instancetype)init NS_UNAVAILABLE; @end /** * A class representing a multipart form document. */ @interface TWTRMultipartFormDocument : NSObject /** * The forms boundary */ @property (nonatomic, copy, readonly) NSString *boundary; /** * Returns a value appropriate for the Content-Type header field */ @property (nonatomic, copy, readonly) NSString *contentTypeHeaderField; /** * Instantiates the document with the given elements. * * @param formElements the elements to append to this document */ - (instancetype)initWithFormElements:(NSArray *)formElements NS_DESIGNATED_INITIALIZER; /** * Asynchrounously loads the body data. * * @param callbackQueue the queue to invoke the handler on * @param completion the completion block to call with the loaded data. */ - (void)loadBodyDataWithCallbackQueue:(dispatch_queue_t)callbackQueue completion:(TWTRMultipartFormDocumentLoadDataCallback)completion; @end NS_ASSUME_NONNULL_END