This repository contains the distribution (binary) packages for the Salesforce Mobile SDK for iOS. Distributions will be tagged by SDK release version, so grab the binaries you want associated with the version you support.
- If you would like to work with the Mobile SDK and its sample apps directly, go to the iOS source repo.
- If you would like to create a new native or hybrid Mobile SDK app for iOS, take a look at our forceios npm package.
If you would like to leverage the Salesforce Mobile SDK functionality in your existing native app, you can add our pre-built binary packages. You can either download the binaries directly from GitHub, or sync this repository locally, checking out the tag associated with the version you want. The following sections describe how to add Salesforce Mobile SDK libraries to your existing native app.
If syncing this repository locally, make sure to also sync the submodules using following commands:
$ git submodule update --init
The following Mobile SDK libraries and resources are required for native apps. For library archives, choose the -Debug.zip or -Release.zip file according to whether you want debug symbols included with the libraries. The libraries in ThirdParty folder are already uncompressed, so just add those folders to your app directly.
- openssl (ThirdParty/openssl)
- sqlcipher (ThirdParty/sqlcipher)
- SalesforceCommonUtils (ThirdParty/SalesforceCommonUtils)
- SalesforceRestAPI (SalesforceRestAPI-[Debug/Release].zip)
- SalesforceNetworkSDK (SalesforceNetworkSDK-[Debug/Release].zip)
- MKNetworkKit (MKNetworkKit-iOS-[Debug/Release].zip)
- SalesforceOAuth (SalesforceOAuth-[Debug/Release].zip)
- SalesforceSDKCore (SalesforceSDKCore-[Debug/Release].zip)
- SalesforceSecurity (SalesforceSecurity-[Debug/Release].zip)
- SalesforceSDKCommon (SalesforceSDKCommon-[Debug/Release].zip)
You may add the SmartSync (SmartSync-[Debug/Release].zip) library to your native app as well, if you wish to leverage the SmartSync capabilities of the SDK.
In addition, the following iOS dependencies are required. Go to the "Build Phases" tab of the project settings and add these dependencies under "Link Binary with Libraries" section.
- libxml2.dylib
- libz.dylib
- UIKit.framework
- ImageIO.framework
- Foundation.framework
- CFNetwork.framework
- CoreData.framework
- CoreGraphics.framework
- MessageUI.framework
- MobileCoreServices.framework
- QuartzCore.framework
- Security.framework
- SystemConfiguration.framework
Add the following resource bundles:
- SalesforceSDKResources.bundle
- Settings.bundle
Under the project build settings, add "Header Search Paths" for the SDK libraries (SalesforceCommonUtils, SalesforceRestAPI, SalesforceNetworkSDK, SalesforceOAuth, SalesforceSDKCore, SalesforceSecurity, and optionally SmartSync) added earlier. Also make sure to set the -ObjC
and -all_load
flags in the "Other Linker Flags" section.
Now you are ready to use the Salesforce Mobile SDK in your existing app. To launch authentication flow, add the following code to your class:
-
Import the SalesforceSDKManager header
#import <SalesforceSDKCore/SalesforceSDKManager.h>
-
Set your Connected App Consumer Key
[SalesforceSDKManager sharedManager].connectedAppId = @"3MVG9Iu66FKeHhINkB1l7xt7kR8czFcCTUhgoA8Ol2Ltf1eYHOU4SqQRSEitYFDUpqRWcoQ2.dBv_a1Dyu5xa";
-
Set your Connected App's Callback URL
[SalesforceSDKManager sharedManager].connectedAppCallbackUri = @"testsfdc:///mobilesdk/detect/oauth/done";
-
Set the OAuth scopes that your Connected App will request
[[SalesforceSDKManager sharedManager].authScopes = @[ @"web", @"api" ];
-
Add your post-launch action:
__weak AppDelegate *weakSelf = self; [SalesforceSDKManager sharedManager].postLaunchAction = ^(SFSDKLaunchAction launchActionList) { [weakSelf setupRootViewController]; };
-
Launch the Mobile SDK
[[SalesforceSDKManager sharedManager] launch];