Files
RestKit/Code/RestKit/RKRequest.h
2010-02-18 12:35:09 -05:00

116 lines
2.8 KiB
Objective-C

//
// RKRequest.h
// RestKit
//
// Created by Jeremy Ellison on 7/27/09.
// Copyright 2009 Two Toasters. All rights reserved.
//
#import <Foundation/Foundation.h>
#import "DocumentRoot.h"
#import "RKRequestSerializable.h"
@interface RKRequest : NSObject {
NSURL* _URL;
NSMutableURLRequest* _URLRequest;
NSDictionary* _additionalHTTPHeaders;
NSObject<RKRequestSerializable>* _params;
id _delegate;
SEL _callback;
id _userData;
NSString* _username;
NSString* _password;
}
/**
* used for http auth chalange
*/
@property(nonatomic, retain) NSString* username;
@property(nonatomic, retain) NSString* password;
@property(nonatomic, readonly) NSURL* URL;
/**
* The NSMutableURLRequest being sent for the Restful request
*/
@property(nonatomic, readonly) NSMutableURLRequest* URLRequest;
/**
* The HTTP Method used for this request
*/
@property(nonatomic, readonly) NSString* HTTPMethod;
/**
* The delegate to inform when the request is completed
*/
@property(nonatomic, retain) id delegate;
/**
* The selector to invoke when the request is completed
*/
@property(nonatomic, assign) SEL callback;
/**
* An opaque pointer to associate user defined data with the request.
*/
@property(nonatomic, assign) id userData;
/**
* A Dictionary of additional HTTP Headers to send with the request
*/
@property(nonatomic, retain) NSDictionary* additionalHTTPHeaders;
/**
* A serializable collection of parameters sent as the HTTP Body of the request
*/
@property(nonatomic, readonly) NSObject<RKRequestSerializable>* params;
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
/**
* Return a REST request that is ready for dispatching
*/
+ (RKRequest*)requestWithURL:(NSURL*)URL delegate:(id)delegate callback:(SEL)callback;
/**
* Initialize a REST request and prepare it for dispatching
*/
- (id)initWithURL:(NSURL*)URL delegate:(id)delegate callback:(SEL)callback;
/**
* GET the resource and invoke the callback with the response payload
*/
- (void)get;
/**
* POST a collection of params to the resource and invoke the callback with the response payload
*/
- (void)postParams:(NSObject<RKRequestSerializable>*)params;
/**
* PUT a collection of params to the resource and invoke the callback with the response payload
*/
- (void)putParams:(NSObject<RKRequestSerializable>*)params;
/**
* DELETE the resource and invoke the callback with the response payload
*/
- (void)delete;
@end
/**
* Lifecycle events for RKRequests
*
* Modeled off of TTURLRequest
*/
@protocol RKRequestDelegate
@optional
- (void)requestDidStartLoad:(RKRequest*)request;
- (void)requestDidFinishLoad:(RKRequest*)request;
- (void)request:(RKRequest*)request didFailLoadWithError:(NSError*)error;
- (void)requestDidCancelLoad:(RKRequest*)request; // not yet implemented
@end