You have arrived at the source repository for the Salesforce Mobile SDK for iOS. Welcome! Starting with our 2.0 release, there are now three ways you can choose to work with the Mobile SDK:
- If you'd like to work with the source code of the SDK itself, you've come to the right place! You can browse sample app source code and debug down through the layers to get a feel for how everything works under the covers. Read on for instructions on how to get started with the SDK in your development environment.
- If you're just eager to start developing your own new application, the quickest way is to use our npm binary distribution package, called forceios, which is hosted on npmjs.org. Getting started is as simple as installing the npm package and launching your template app. You'll find more details on the forceios package page.
- If you would like to add the Mobile SDK components to your existing native application, check out the SalesforceMobileSDK-iOS-Distribution repository, which contains our binary distributions as well as information on how to add them to your native app.
Working with this repository requires working with git. Any workflow that leaves you with a functioning git clone of this repository should set you up for success. Downloading the ZIP file from GitHub, on the other hand, is likely to put you at a dead end.
First, clone the repo:
- Open the Terminal App
cdto the parent directory where the repo directory will live
git clone https://github.com/forcedotcom/SalesforceMobileSDK-iOS.git
After cloning the repo:
This script pulls the submodule dependencies from GitHub, to finalize setup of the workspace. You can then work with the Mobile SDK by opening
SalesforceMobileSDK.xcworkspace from Xcode.
See build.md for information on generating binary distributions and app templates.
The Salesforce Mobile SDK for iOS requires iOS 6.0 or greater. The install.sh script checks for this, and aborts if the configured SDK version is incorrect. Building from the command line has been tested using ant 1.8. Older versions might work, but we recommend using the latest version of ant.
If you have problems building any of the projects, take a look at the online FAQ for troubleshooting tips.
- Registration and delivery of push notifications are now supported from a Salesforce org that enables push notifications.
- The underlying networking library has been replaced with MKNetworkKit. MKNetworkKit provides the ability to configure advanced features, such as managing the network queue and cancelation of requests.
Files API Support
- The Salesforce Mobile SDK now provides convenience methods that build specialized REST requests for file upload/download and sharing operations.
- A native sample app,
FileExplorer, and a hybrid sample app,
HybridFileExplorer, have been added to demonstrate these features.
- You can now access custom endpoints using the
- You can now access Apex REST endpoints using the
- This feature is only available on hybrid apps.
Other Technical Improvements
- OAuth error handling is now configurable.
- Upgraded the
v1.0.1eto fix possible security concerns with older versions of
- You can now add one or more delegates to SFAuthenticationManager. This gives you more granular access to the authentication process.
- Various bug fixes.
The Salesforce Mobile SDK provides the essential libraries for quickly building native mobile apps that interact with the Salesforce cloud platform. The OAuth2 library abstracts away the complexity of securely storing the refresh token or fetching a new session ID when it expires. The SDK also provides Objective-C wrappers for the Salesforce REST API, making it easy to retrieve and manipulate data.
The Mobile SDK provides the means to generate your new app from a template, to quickly construct the foundation of native and hybrid applications. These apps come with a fully functioning demo app, as well as configurable Settings bundles that allow the user to log out of the app or switch between Production and Sandbox orgs. See build.md for more information on how to generate and use the templates.
Native App Template For native apps that need to access the Salesforce REST API, create your app using the native template. The template includes a default AppDelegate implementation that you can customize to perform any app-specific interaction.
- Salesforce Mobile SDK Development Guide
- Salesforce Hybrid SDK
- Salesforce Native SDK
- Salesforce Network SDK
- Salesforce OAuth
- Salesforce SDK Core
If you would like to make suggestions, have questions, or encounter any issues, we'd love to hear from you. Post any feedback you have to the Mobile Community Discussion Board on developerforce.com.