/* 
 | 
 * 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. 
 | 
 * 
 | 
 */ 
 | 
  
 | 
/** 
 | 
 This header is private to the Twitter Core SDK and not exposed for public SDK consumption 
 | 
 */ 
 | 
  
 | 
#import <Foundation/Foundation.h> 
 | 
  
 | 
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 
 |