RestKit is a library for interacting with Restful web services in Objective C. It provides a set of primitives for interacting with web services wrapping GET, POST, PUT and DELETE HTTP verbs behind a clean, simple interface. RestKit also provides a system for modeling remote resources by mapping them from JSON (or XML) payloads back into domain objects. Object mapping functions with normal NSObject derived classes with properties. There is also an object mapping implementation included that provides a Core Data backed store for persisting objects loaded from the web.
RestKit was first publicly introduced in April of 2010 in a blog post on the Two Toasters website: http://twotoasters.com/index.php/2010/04/06/introducing-restkit/
To get started with installation, skip down the document below the Design & Dependencies section.
RestKit is composed of 3 main pieces: Network, Object Mapping, and Core Data. Each layer provides a higher level of abstraction around the problem of accessing web services and representing the data returned as an object. The primary goal of RestKit is to allow the application programmer to think more in terms of their application's data model and less about the details of fetching, parsing, and representing resources. Functionally, each piece provides...
- Network - The network layer provides a request/response abstraction on top of NSURLConnection. The main interface for the end developer is the RKClient, which provides an interface for sending GET, POST, PUT, and DELETE requests asynchronously. This wraps the construction and dispatch of RKRequest and RKResponse objects, that provide a nice interface for working with HTTP requests. Sending parameters with your request is as easy as providing an NSDictionary of key/value pairs. File uploading support from NSData and files is supported through the use of an RKParams object, which serializes into a multipart form representation suitable for submission to a remote web server for processing. SSL & HTTP AUTH is fully supported for requests. RKResponse objects provide access to the string of JSON parsed versions of the response body in one line of code. There are also a number of helpful method for inspecting the request and response such as isXHTML, isJSON, isRedirect, isOK, etc.
- Object Mapping - The object mapping layer provides a simple API for turning remote JSON responses into local domain objects declaratively. Rather than working directly with RKClient, the developer works with RKObjectManager. RKObjectManager provides support for loading a remote resource path (see below for discussion) and calling back a delegate with object representations of the data loaded. Remote payloads are parsed to NSDictionary representation and are then mapped to local objects using Key-Value Coding. Any class implementing the RKObjectMappable protocol can be object mapped. For convenience, RestKit ships with a RKObject implementation that can serve as a turn-key superclass for modeling your resources. You need only inherit & implement elementToPropertyMappings to begin loading resources via RKObjectManager's loadObjectsAtResourcePath:objectClass:delegate: method.
- Core Data - The Core Data layer provides additional support on top of the object mapper for mapping from remote resources to persist local objects. This is useful for providing offline support, holding on to transient data, and speeding up user interfaces by avoiding expensive trips to the web server. The Core Data support requires that you initialize an instance of RKManagedObjectStore and assign it to the RKObjectManager. For each persistent class you wish to model, you need to inherit from RKManagedObject and implement the appropriate RKObjectMappable methods. See the Examples/ subdirectory for examples of how to get this running. The Core Data support also provides RKObjectSeeder, a tool for creating a local "seed database" to bootstrap an object model from local JSON files. This allows you to ship an app to the store that already has data pre-loaded and then synchronize with the cloud to keep your clients up to date.
RestKit utilizes the concepts of the Base URL and resource paths throughout the library. Basically the base URL is a prefix URL that all requests will be sent to. This prevents you from spreading server name details across the code base and repeatedly constructing URL fragments. The RKClient and RKObjectManager are both initialized with a base URL initially. All other operations dispatched through these objects work of a resource path, which is basically just a URL path fragment that is appended to the base URL before constructing the request. This allows you to switch between development, staging, and production servers very easily and reduces redundancy.
Note that you can send RKRequest objects to arbitrary URL's by constructing them yourself.
RestKit provides JSON parser implementations using SBJSON & YAJL. The recommended parser is YAJL (as it is known to be faster), but you can use the SBJSON backend instead by adding a dependency on libRestKitJSONParserSBJSON linking against libRestKitJSONParserSBJSON.a instead of the libRestKitJSONParserYAJL.a
The sources for SBJSON and YAJL are included in the Vendor/ subdirectory. The headers are copied into the RestKit headers path at build time and can be imported into your project via: #import <RestKit/Support/JSON/SBJSON/JSON.h> #import <RestKit/Support/JSON/YAJL/YAJL.h>
Currently bundled version of these dependencies are:
- YAJLIOS - 0.2.21
- SBJSON - 2.3.1
If you currently link against or include SBJSON or YAJL in your project, you can disable the RKJSONParser targets and compile the appropriate RKJSONParser implementation directly into your application.
XML parsing is not currently supported.
Additional parsing backend support is expected in future versions.
Documentation and example code is being added as quickly as possible. Please check the Docs/ and Examples/ subdirectories to see what's available. The RestKit Google Group is an invaluable resource for getting help working with the library.
- Add Git submodule to your project:
git submodule add git://github.com/twotoasters/RestKit.git RestKit
- Add cross-project reference by dragging RestKit.xcodeproj to your project
- Open build settings editor for your project
- Add Header Search Path to the
"RestKit/Build"
directory - Add Other Linker Flags for
-ObjC -all_load
- Open target settings editor for the target you want to link RestKit into
- Add direct dependency on the RestKit aggregate target
- Link against required frameworks:
- CFNetwork.framework
- CoreData.framework
- MobileCoreServices.framework
- SystemConfiguration.framework
- libxml2.dylib
- Link against RestKit static library products:
- libRestKitSupport.a
- libRestKitObjectMapping.a
- libRestKitNetwork.a
- A JSON parser implementation (either libRestKitJSONParserJSONKit.a OR **libRestKitJSONParserYAJL.a OR libRestKitJSONParserSBJSON.a but NOT more than ONE). We recommend JSONKit or YAJL.
- Import the RestKit headers via
#import <RestKit/RestKit.h>
- Build the project to verify installation is successful.
To add RestKit to your project (you're using git, right?):
- Add the submodule:
git submodule add git://github.com/twotoasters/RestKit.git RestKit
- Open RestKit.xcodeproj and drag the RestKit project file into your XCode project.
- Click on the entry for RestKit.xcodeproj in your project's Groups & Files section. In the right hand pane, find the entries for libRestKitSupport.a libRestKitObjectMapping.a libRestKitNetwork.a and libRestKitJSONParserYAJL.a and click the checkboxes on the far right underneath the silver target icon. This will link your project against RestKit. If you wish to use the Core Data support, click the checkbox next to libRestKitCoreData.a also.
- Look to the bottom of the General pane labeled Linked Libraries. You will need to add the following frameworks:
- CFNetwork.framework - Required for networking support.
- SystemConfiguration.framework - Required for detection of network availability.
- MobileCoreServices.framework - Required. Provides support for MIME type auto-detection for uploaded files.
- CoreData.framework - Optional. Provides support for use of the Core Data backed persistent object store. libxml2.dylib - Optional. Only necessary if you are mapping from XML payloads and link libRestKitXMLParserLibxml.a into your app.
- Get Info on your target and you should be looking at the General tag. In the top Direct Dependencies section, click the plus button and add a direct dependency on the RestKit target.
- Switch to the 'Build' tab in your project inspector. Make sure that your Configuration pop-up menu reads All Configurations so that your changes will work for all build configurations.
- Find the Header Search Paths setting. Double click and add a new entry. When RestKit is compiled, it will copy all relevant headers to the appropriate location under the /Build directory within the RestKit checkout. You need to add a path to the /Build directory of RestKit, relative to your project file. For example, if you checked the submodule out to the 'Libraries' subdirectory of your project, your header path would be 'Libraries/RestKit/Build'.
- Now find the Other Linker Flags setting. Double click it and add entries for -all_load and -ObjC.
- You may now close out the inspector window.
- Add the submodule:
git submodule add git://github.com/twotoasters/RestKit.git RestKit
- Open the project you wish to add RestKit to in Xcode.
- Open the RestKit.xcodeproj from the submodule you checked out.
- Focus your project and select the "View" menu > "Navigators" > "Project" to bring the project file list into view.
- Drag the RestKit.xcodeproj file from the RestKit project window and drop it on your "<Your Project's Name>".xcodeproj.
- Click on your project's name in the sidebar on the left to open the project settings view in the right pane of the window.
- In the middle pane you will see PROJECT and TARGETS headers for your project. Click on your project name, then select Build Settings along the top to open the Build Settings editor for your entire project.
- Find the Header Search Paths setting. Double click and add a new entry. Add a search path to the RestKit/Build directory you have added to your project. For example, if you checked the submodule out to the 'Libraries' subdirectory of your project, your header path would be 'Libraries/RestKit/Build'. DO NOT check the
Recursive
checkbox. - Find the Other Linker Flags entry and double click it. Use the + button to add a new entry and enter
-ObjC -all_load
. Dismiss the editor with the Done button. - Locate the target you wish to add RestKit to in the TARGETS list in the middle of the editor pane. Select it to open the target settings editor in the right pane of the window.
- Click the Build Phases tab along the top of the window to open the Build Phases editor.
- Click the disclosure triangles next to the Target Dependencies and Link Binary with Libraries items.
- In the Target Dependencies section, click the + button to open the Target selection sheet. Click on the RestKit aggregate target (it will have the bulls-eye icon) and click the Add button to create a dependency.
- In the Link Binary with Libraries section, click the + button to open the Library selection sheet. Here we need to instruct the target to link against all the required RestKit libraries and several system libraries. Select each of the following items (one at a time or while holding down the Command key to select all of them at once) and then click the Add button:
- libRestKitCoreData.a
- libRestKitJSONParserYAJL.a
- libRestKitNetwork.a
- libRestKitObjectMapping.a
- libRestKitSupport.a
- CFNetwork.framework
- CoreData.framework - Optional. Only necessary if you are using Core Data
- MobileCoreServices.framework
- SystemConfiguration.framework
- libxml2.dylib - Optional. Only necessary if you are mapping from XML payloads and link libRestKitXMLParserLibxml.a into your app.
- Verify that all of the libraries are showing up in the Link Binary with Libraries section before continuing.
Congratulations, you are now done adding RestKit into your Xcode 4 based project!
You now only need to add includes for the RestKit libraries at the appropriate places in your application. The relevant includes are: #import <RestKit/RestKit.h> // And if you are using Core Data... #import <RestKit/CoreData/CoreData.h>
Please see the Examples/ directory for details on utilizing the library.
Forks, patches and other feedback are always welcome.
A Google Group for development and usage of library is available at: http://groups.google.com/group/restkit
Follow RestKit on Twitter:http://twitter.com/restkit