Add the #DF24 Developer Keynote to your agenda. Join us in-person on 9/18 at 2:30 p.m. PT or on Salesforce+ at 5 p.m. PT for the must-see session built just for developers.

Evergage Class Reference

Inherits fromDeclared in
NSObjectEVGContext.h

This class is primarily used to configure and start the Marketing Cloud Personalization iOS SDK.

Tracking user interactions should typically be done from a UIViewController, see [UIViewController(Evergage) evergageScreen] and EVGContext for the APIs.

Within UIApplicationDelegate -willFinishLaunchingWithOptions:, first enable logging in DEBUG builds. Set the userId as soon as the authenticated user ID is known. Finally, provide the app’s Personalization configuration and start Personalization using startWithClientConfiguration:, as shown in the following examples.

  • Objective C

  • Swift

To add information about the user, see userId and setUserAttribute:forName:. In the examples above, setting the userId provides Personalization with the user’s authenticated ID. This could also have been called later, if the user’s ID was not known at startup, and would then be sent with subsequent events. Likewise, if your users belong to an account, see accountId and setAccountAttribute:forName:.

To easily and codelessly manage test campaigns from the device, the app can add an Personalization URL scheme and define one of the iOS open-url delegate methods, see [Evergage(Swizzling) handleOpenURL:]. For more information on testing your campaigns, see the Testing guide.

Once startWithClientConfiguration: has been called at app launch, the Personalization client will track user activity, send any applicable events to the Personalization server, and support campaigns in response. Personalization will monitor network availability and store events if necessary, sending them when the network becomes available again.

The Personalization client supports automatically tracking UIViewControllers and dynamically mapping and re-mapping them to view actions using the Personalization UI. For more information, see Tracking Guide, UIViewController(Evergage), and EVGScreen.

Personalization can track how the user views and interacts with articles, blogs and products which are collectively called items. Personalization understands the actions that are possible on these items (View, Comment, Purchase, etc.) and also how they relate to each other (categories, brands, keywords, etc.). For more information, see the Tracking Guide and EVGContext.

Campaigns may be served in response to actions generated by the user interacting with the app:

  • "In-App Message" campaigns are automatically handled by Personalization.
  • "Push Notification" campaigns require APNS setup, and optionally Firebase. For more information , see Push Notifications.
  • Custom "Data" campaigns are handled by app-defined code. For more information, see Mobile Data Campaigns and EVGCampaign.

The Personalization singleton instance.

Return Value

The Personalization singleton instance.

Declared In

Evergage.h

Starts Personalization with the specified configuration. Recommended to call from willFinishLaunchingWithOptions:. For example code, see the Startup section in this article. Once started, subsequent calls will have no effect, unless reset has been called due to an environment change.

Parameters

ParameterDescription
configurationBlockClient-specific Personalization configuration defined via EVGClientConfigurationBuilder

Availability

1.3.0

See Also

Declared In

Evergage.h

Deprecated as of 1.3.0. Use startWithClientConfiguration: instead.

Parameters

ParameterDescription
accountKeyAccount within Personalization to use.
datasetDataset within the Personalization account to use.

See Also

Declared In

Evergage.h

The user’s authenticated ID. Setting this property is critical to correlate the same user’s activity across devices and platforms, and also makes it easier to find a user in Personalization.

Discussion

When the authenticated ID is null, Personalization identifies the user with a generated anonymous ID. See anonymousId for details, including how activity may be merged.

You may call this method with null to make the user anonymous again. At that point, all new activity will be attributed to the anonymous user, and push notifications can only be sent to the anonymous user (based off the anonymous activity). So after a simple log out, you may wish to continue to call this method with the previously-authenticated user ID, to continue to be able to send push notifications to the authenticated user (based off the authenticated activity) etc. You decide when the user becomes truly anonymous again.

Recommended to set this property:

  • With the ID, when the user successfully authenticates (logs in).
  • With the ID, on app launch as soon as possible, if the user is still authenticated, or previously authenticated but needs to log back in again. Personalization does not persist the ID across app restarts.
  • With nil, when the app decides the user should be anonymous again. This may not be on logout - see note about anonymous activity above. Calling this method with nil will also set accountId to nil.

See Also

Declared In

Evergage.h

The user’s anonymous ID, via identifierForVendor, which will be used if no authenticated ID is specified for the user via userId.

Availability

1.2.1

Discussion

May return nil if Personalization is disabled.

When a user transitions from anonymous to authenticated (via userId), the previous activity while anonymous will be merged into the authenticated user if Merge Anonymous Users is enabled in the Personalization UI.

This ID should be passed in SmartSearch requests if userId returns nil.

See Also

Declared In

Evergage.h

The optional account this user belongs to. Set this property to track which of your accounts users belong to inside the Personalization dataset and account. If account is no longer applicable, it can be set to nil.

This is not the main Personalization account passed in to startWithClientConfiguration:.

Declared In

Evergage.h

Sets an attribute (a name/value pair) on the user. The new value will be sent to the Personalization server with the next event.

Parameters

ParameterDescription
attributeValueThe new value of the user attribute, which replaces any existing value. Set nil to clear.
attributeNameThe name for the user attribute.

Declared In

Evergage.h

Sets an attribute (a name/value pair) on the account. The new value will be sent to the Personalization server with the next event.

Parameters

ParameterDescription
attributeValueThe new value of the account attribute, which replaces any existing value. Set nil to clear.
attributeNameThe name for the account attribute.

Declared In

Evergage.h

Typically unused, for tracking behavior outside of individual UIViewControllers.

Availability

1.2.0

Discussion

nil if Personalization is disabled.

A typical UIViewController-based app should instead use the EVGScreen returned by [UIViewController(Evergage) evergageScreen], which automatically cleans up resources and stops timing/tracking on UIViewController disappear.

However, some apps have decoupled architectures/frameworks where referencing individual UIViewControllers can be problematic/undesirable. In those scenarios, apps can choose to instead use this globalContext.

Using the globalContext means losing some cleanup/safety mechanisms the SDK automatically provides, and so you must manually do these operations, as applicable:

See Also

Declared In

Evergage.h

Configures the threshold EVGLogLevel of messages to log. Will only log messages at this level of severity or greater.

Discussion

Recommended to set only during development in DEBUG builds.

Declared In

Evergage.h

Resets the SDK so startWithClientConfiguration: can be called again with a different dataset, in order to support apps that change environments (production, demo, QA, etc) and want to change Personalization datasets as well.

Discussion

Reset will clear settings, unsent actions, held campaigns, test campaign settings, allowDesignConnections, userId, accountId, and unsent attributes.

Reset will keep existing campaign handlers, screen visibility, and items being viewed, since it would potentially be cumbersome/confusing to require once again setting handlers, potentially mocking viewWillAppear or re-navigating to screens, re-setting items being viewed, etc.

Ideally the app will avoid environment churn:

  • On app launch, if the user must select/confirm the environment before using the app, consider delaying the call to startWithClientConfiguration: to when the environment is chosen and avoid calling reset.
  • Otherwise, if the user can immediately use the app with the current environment, call startWithClientConfiguration: as normal with the corresponding dataset. And when the environment later changes, and a different Personalization dataset is desired, call reset as demonstrated below.

Recommended Usage:

Declared In

Evergage.h

Discussion

Recommended to use only during development in DEBUG builds.

See Also

Declared In

Evergage.h