Book Image

RestKit for iOS

By : Taras Kalapun
Book Image

RestKit for iOS

By: Taras Kalapun

Overview of this book

<p>RestKit is an iOS framework for streamlining communication with web services, and it relies on the AFNetworking library that is used by thousands of app developers. It has an interface that is elegant and well designed, and it provides a powerful object-mapping engine that integrates well with the CoreData database. RestKit for iOS will teach you everything from loading a simple list of objects to creating a fully-featured app.<br /><br />RestKit for iOS delivers constructive tools and insights into app development that will benefit any app developer. The book starts with a simple example and then moves on to more complex ones as your knowledge increases. By the end of the guide, you will be able to build a fully-featured app that uses RESTful web services and performs CRUD object manipulation.<br /><br />RestKit for iOS will provide you with all the information you need to boost the development process of both simple and complex apps. Once you have executed a simple example and reviewed the basic theory, you will move on to more advanced concepts with descriptions of real-life scenarios and how to overcome bottlenecks. RestKit for iOS is full of real-life examples that show you how to simplify data loading, basic and advanced object mapping, metadata mapping, and routing. This book also teaches you about routing, RESTful object manipulation and synchronization, integration with the user interface, and caching</p>
Table of Contents (13 chapters)

Authorization


All authorizations are done through the AFNetworking library. The authorizations are mentioned in the following sections.

Basic

To authorize against the basic (or the simplest) authorization:

// client is instance of AFHTTPClient
[client setAuthorizationHeaderWithUsername:@"username" password:@"password"];

Token-based

The token-based authorization is mostly used with OAuth 1.0 / OAuth 2.0 authorization schemes. After authorizing with them, you will get a token string, which you need to supply to your AFHTTPClient:

// client is instance of AFHTTPClient
NSString *token = @"1q2w3e4r";
[client setAuthorizationHeaderWithToken:token];

Here, the setAuthorizationHeaderWithToken method actually sets an HTTP header Authorization with the Token token=1q2w3e4r value. Sometimes, the web service you are using will require more custom HTTP headers to be set. For such cases, use setDefaultHeader:value: of AFHTTPClient:

[client setDefaultHeader:@"MongoHQ-API-Token" value:@"1q2w3e4r"];

OAuth 1.0

"OAuth...