Tracking user attributes

User Attributes are pieces of information you know about a user. They could be demographics like age or gender, account-specific like plan, or whether a user has seen a particular A/B test variation. User attributes are a customer identity you can reference throughout the customer’s lifetime.

Identifying Users

For SDK versions below 9.23.0 refer to this document.

Setting identifiers is important to:

  • To tie user behavior across platforms, i.e., iOS, Android, Web, etc.
  • This is to ensure unnecessary or stale users are not created.
  • To identify users across installs/re-installs.

Single Identifier

Call the API below to pass the identifier on to the MoEngage SDK.

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.identifyUser(identity: "identifier")

Note: This method is a replacement for the deprecated setUniqueId(). If you are using setUniqueId() in your application, consider replacing it with identifyUser()

Multiple Identifiers

If your application has multiple identifiers using which you identify a user you can pass all the identifiers to the SDK using the below API

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.identifyUser(
identities: [
"identifierName1": "identifierValue1", "identifierName2" to "identifierValue2"
]
)

If you call identifyUser() multiple times with different identifier names, the SDK will append this identifier to the already set identifiers.

Refer to our help document to learn more about the feature.

Logout

The application needs to notify the MoEngage SDK whenever the user is logged out of the application. Call the API whenever the user is logged out of the application to notify the SDK.

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.resetUser()

Default User Attributes

Some default SDK User Attribute can be set for eg. email-id, mobile number, gender, user name, birthday. The default attributes tracked by SDK can be set as shown below :

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.setName(userName)
MoEngageSDKAnalytics.sharedInstance.setLastName(userLastname)
MoEngageSDKAnalytics.sharedInstance.setFirstName(userFirstName)
MoEngageSDKAnalytics.sharedInstance.setEmailID(userEmailID)
MoEngageSDKAnalytics.sharedInstance.setMobileNumber(userPhoneNo)
MoEngageSDKAnalytics.sharedInstance.setGender(.male) //Use UserGender enumerator for this
MoEngageSDKAnalytics.sharedInstance.setDateOfBirth(userBirthdate)//userBirthdate should be a Date instance
MoEngageSDKAnalytics.sharedInstance.setLocation(MoEngageGeoLocation(withLatitude: userLocationLat, andLongitude: userLocationLng)) //userLocationLat and userLocationLng are double values of the location coordinates
warning

Note

  • We support strings and numbers as values for UserAttributes. NSURL is not supported. If you wish to use it, please convert them to string.
  • User Phone No / Mobile Number must be tracked as a string to work properly in MoEngage systems.
  • For more information on supported data types and data tracking policies, please refer to Data Tracking Policies.

Custom User Attributes

To set custom attributes just provide custom keys different to the ones present in here. Following is an example :

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.setUserAttribute("Bengaluru", withAttributeName: "Current_city")
MoEngageSDKAnalytics.sharedInstance.setUserAttribute(["Bengaluru","Delhi","Chennai"], withAttributeName: "Current_cities")

User Attributes have the following restrictions :

  • User Attribute Names should not contain dot(.)
  • User Attribute Names should not start with dollar sign($)
  • User Attribute Values should be a String or Number
info

Note

You can not use "moe_" as a prefix while naming events, event attributes, or user attributes. It is a system prefix and using it might result in periodic blacklisting without prior communication.

JSON Attributes

From MoEngage-iOS-SDK v9.17.5, we have added support for JSON and array of JSON user attributes. Following is an example

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.setUserAttribute(["item-id" : 123,"item-type" : "books","item-cost" : ["amount" : 100,"currency" : "USD"]],withAttributeName: "product")

MoEngageSDKAnalytics.sharedInstance.setUserAttribute([["item-id" : 123,"item-cost" : ["amount" : 100,"currency" : "USD"]],["item-id" : 323,"item-cost" : ["amount" : 90,"currency" : "USD"]]],withAttributeName: "products")

Date and Time User Attributes

Date and time attributes can be set as user attributes. For this refer to the methods in the code block below:

Swift Objective-C
//1. Track UserAttribute using Date instance
MoEngageSDKAnalytics.sharedInstance.setUserAttributeDate(Date(), withAttributeName: "Date Attr 1")

//2. Track UserAttribute using ISO Date String in format "yyyy-MM-dd'T'HH:mm:ss'Z'"
MoEngageSDKAnalytics.sharedInstance.setUserAttributeISODate("2020-01-12T18:45:59Z", withAttributeName: "Date Attr 2")

//3. Track UserAttribute using Epoch value
MoEngageSDKAnalytics.sharedInstance.setUserAttributeEpochTime(663333, withAttributeName: "Date Attr 3")

Location Attributes

The location of a user or any location can be set as a user attribute. For this use setLocation(_:withAttributeName:) method and pass lat, the long value of the location as shown in the following example :

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.setLocation(MoEngageGeoLocation.init(withLatitude: 72.90909, andLongitude: 12.34567), withAttributeName: "attribute name")

Tracking User Locale

For tracking the locale settings of the user device use trackLocale() method as shown below:

Swift Objective-C
MoEngageSDKAnalytics.sharedInstance.trackLocale()

Reserved keywords for User Attributes

Below is the list of keys that should not be used when tracking user attributes.

  • USER_ATTRIBUTE_UNIQUE_ID
  • USER_ATTRIBUTE_USER_EMAIL
  • USER_ATTRIBUTE_USER_MOBILE
  • USER_ATTRIBUTE_USER_NAME
  • USER_ATTRIBUTE_USER_GENDER
  • USER_ATTRIBUTE_USER_FIRST_NAME
  • USER_ATTRIBUTE_USER_LAST_NAME
  • USER_ATTRIBUTE_USER_BDAY
  • MOE_TIME_FORMAT
  • MOE_TIME_TIMEZONE
  • USER_ATTRIBUTE_NOTIFICATION_PREF
  • USER_ATTRIBUTE_OLD_ID
  • MOE_TIME_FORMAT
  • MOE_TIME_TIMEZONE
  • USER_ATTRIBUTE_DND_START_TIME
  • USER_ATTRIBUTE_DND_END_TIME
  • MOE_GAID
  • MOE_ISLAT
  • status
  • user_id

Previous

Next

Was this article helpful?
0 out of 0 found this helpful

How can we improve this article?