Integration

Supported iOS Versions

The Marketing Cloud Personalization iOS SDK supports the following:

  • iOS versions of 12.0 and higher
  • Swift and Objective-C, with Module support
  • Integrations via Cocoapods or direct/manual integrations using static and dynamic XCFrameworks

Add Your App to Your Dataset

To add your app to your dataset in the Personalization UI, do the following.

  1. Log in to the Personalization UI, and choose the desired dataset.

    NOTE

    For an initial integration, we recommend using a non-production dataset.

  2. From the left-hand menu, choose Mobile > Native App Setup.

    Note

    If this feature is disabled for your dataset, contact the Personalization support team to enable it.

  3. In the Platform drop-down menu, select iOS.
  4. Enter an App Name.
  5. Enter the exact Bundle ID for your app, which can be found in XCode. To retrieve the Bundle ID from Xcode, select the app Target, the General tab, and look under the first Identity section for Bundle Identifier.
  6. Click Create New App.

Personalization supports two modes of integration:

  • Integration with CocoaPods
  • Direct or manual integration

Integration with CocoaPods

The Personalization iOS SDK is available as a vendored XCFramework via CocoaPods version 1.10 and higher. The podspec is configured to use the static XCFramework. However, you can use the dynamic XCFramework with a slight podspec edit. To integrate via CocoaPods, add a dependency on the Evergage pod, as shown in the following example.

Simply add a dependency on the Evergage pod:

pod 'Evergage', '1.4.1'

Next, proceed to initialize and start the Personalization SDK.

Direct or Manual Integration

The Personalization iOS SDK is available as a static and dynamic XCFramework.

For a manual integration, do the following.

  1. Extract the SDK zip file.
  2. Open either the static or dynamic folder and locate the Evergage.xcframework folder within.

    Note

    We recommend using the static integration.

  3. Drag the chosen Evergage.xcframework folder from a Finder window onto the left Project Navigator pane in your XCode project.
    • If you already have a folder/location where all your other Frameworks are, drag it there alongside the others.
    • In the resulting add files popup window:
      • Ensure Copy items if needed is checked. Some apps will be unable to build/archive without this step, reporting a not found error.
      • Ensure your app target(s) are checked.
      • Click Finish.

        Note

        If you are using the dynamic Evergage.xcframework, ensure that it gets embedded alongside the app. For more information, see Troubleshooting Manual Integrations below for details.

  4. Clean build products and rebuild your app.

Troubleshooting Manual Integrations

If you encounter build or runtime linking problems during manual integration, do the following to troubleshoot.

  • In the Project navigator, click the top/root project/workspace
  • For each applicable app target:
    • Click the app target under Targets
    • Click the General tab
    • Scroll down to Frameworks, Libraries, and Embedded Content section
    • Verify Evergage.xcframework appears as an entry, and for its Embed column:
      • If using the static framework, verify the Embed value has its initial/unchanged “Do Not Embed” setting.
      • If using the dynamic framework, ensure the Embed value has either Embed Without Signing or Embed & Sign.
    • Click the Build Settings tab
    • Check the Framework Search Paths setting contains a path to where Evergage.xcframework was copied/installed into your project. If this setting is missing or inaccurate you may see ‘not found’ errors upon building/archiving/running the app.
    • Check the Link Frameworks Automatically setting is YES. If you desire otherwise, under the General tab and Linked Frameworks and Libraries section, ensure the following have been added:
      • UIKit.framework
      • SystemConfiguration.framework
      • CoreGraphics.framework
      • QuartzCore.framework
      • libz.tbd
      • UserNotifications.framework (can be Optional/weak-linked)

Next, proceed to Initialize and Start the Personalization SDK section below.

Initialize and Start the Personalization SDK

For sample code in Objective-C and Swift to call in your UIApplicationDelegate -willFinishLaunchingWithOptions implementation to initialize and start the Personalization SDK, see the Evergage class documentation.

User Detail

You can use other methods in the Evergage class to add information about the user. In the startup example code, setting the [Evergage userId] provides Personalization with the user’s authenticated ID. If the user’s ID is unknown at startup, you could call this method later to then send the user’s ID with subsequent events.

Next

To know more about tracking events and actions and sending them to Personalization, see the Tracking Guide.