Capture Profile Data (Version 3.x)
The Data 360 Module for the Engagement Mobile SDK enables collection of profile data through the SDK’s Identity APIs.
Before engagement data can be sent to Data 360:
- The Data 360 Module for the Engagement Mobile SDK must be configured and initialized.
- Consent to track profile data must be granted.
All iOS code examples on this page require the following imports:
Profile attributes are set through the SFMCSDK identity module using the identity.edit API. The Data 360 Module subscribes to identity events via the SFMCSDK EventBus and automatically converts them into profile events.
Maps to the identity schema.
Maps to the contactPointEmail schema.
Maps to the contactPointPhone schema.
Maps to the contactPointAddress schema.
The Data 360 Module only emits a contact point event if the required fields for that type are present in the accumulated attributes and have changed since the last emission (diff-based). The identity modifier closure for iOS must return the modifier object.
When a profile attribute changes, the Data 360 Module triggers an identity profile event containing all set attributes. You can set any name-value pair for profile attributes.
The Identity Schema provided by the recommended Mobile Connector schema for Data 360 contains profile attributes that support identity resolution features when mapped to the appropriate Customer 360 Data Model.
Each identity event contains mappable fields.
- Individual
firstNamelastName
- Software Application
registrationIdsoftwareApplicationName
- Device
advertiserIddeviceTypeosName
- Contact Point App
registrationId
Starting with Android 13 (API level 33), permission is required to request the device’s advertiserId. In Data 360 2.0.2, this permission is included by default. To prevent this permission from getting merged into your app, add this element to your AndroidManifest.xml:
Each supported contact point has required attributes that must be provided to the SDK’s Identity API. After all attributes are provided, the Data 360 Module triggers a profile event with contact points and an identity event.
The contact points and required attributes that trigger them are:
- Contact Point Email Schema
email
- Contact Point Phone Schema
phoneNumber
- Contact Point Address Schema
addressLine1citystateProvincecountry
In the Data 360 Module, all customers are considered known by default. To mark a customer as anonymous, set the isAnonymous profile attribute to "1". Setting isAnonymous to "0" ensures customers are considered known.
SFMCSdk.cdp is the accessor for the CDP module on the unified SDK object. CdpModule.shared and SFMCSdk.cdp refer to the same module instance.
The Engagement Mobile SDK supports sharing identifiers between modules for integration with other Salesforce systems. For example, match an individual using a mobile application with both Data 360 and MobilePush modules to send push notifications to specific anonymous mobile users.
The identity event contains fields that can be mapped to the Party Identification model.
registrationId: Identification Number
When the MobilePush module obtains a resolved identity for a mobile customer, it sets a profileId using the SDK’s Identity API. The Data 360 Module is notified and sends a partyIdentification event with these fields:
userId: Identification NumberIDName: Party Identification NameIDType: Party Identification Type
On Android, you can set the profileId directly to link the device to a known subscriber or profile: