To send Google Advertising Id of the device as device id to the Amplitude, add the below code in the AndroidManifest.xml of your app under <application> tag:
Make sure to enable Use Advertising ID for device ID under the Android SDK settings in the RudderStack dashboard.
For iOS platform, make sure that the minimum deployment target for your application’s target is at least 10.
Identify
You can use the identify call to associate a user with their actions and capture all relevant traits about them. This includes a unique userId and other optional information like name, email address, etc.
In device mode, RudderStack automatically captures and sends the device-specific identifiers like deviceId to Amplitude. These identifiers are used by Amplitude to track unique devices and sessions.
This feature is available only for the mobile platforms.
You can opt out of an identify call in a current session by passing a optOutOfSession trait and setting it to true. If there is no active session, passing optOutOfSession: true does not start a new session.
Unset user properties
To unset the user traits in device mode, specify them in the integrations.Amplitude.fieldsToUnset object.
When you unset fields using fieldsToUnset, RudderStack notifies Amplitude to delete the fields along with their schema (if they exist).
The page call allows you to record your website’s page views, with the additional relevant information about the viewed page. RudderStack recommends calling this method at least once per page load.
In device mode, page views are automatically tracked as events in Amplitude with the event type as [RudderStack] Page.
In the above example, RudderStack captures information related to the page being viewed such as the category of the page (Category) and the page name (Sample).
Screen
The screen call lets you record screen views with any additional information about the viewed screen.
In device mode, screen views are automatically tracked as events in Amplitude with the event type as [RudderStack] Screen.
A sample screen call looks like the following code snippet:
You can use the group event to link an identified user with a group, like a company, organization, or an account.
Note that RudderStack does not support associating a user to more than one group per group call sent to Amplitude.
To send more than one group per user, you must call the group API multiple times with the relevant group information specified in the group settings.
Use Amplitude Groups
Note the following:
This feature is only available for web (JavaScript) device mode.
Groups are an enterprise-only feature in Amplitude. You need to purchase the Accounts add-on to use this feature.
To use the Amplitude Groups feature with RudderStack:
Configure the Group name trait and Group value trait fields in the Group trait settings.
In device mode, RudderStack triggers a group call for a groupId by mentioning groupType as '[RudderStack] Group' and value as groupId.
Even if you don’t have an enterprise account or the Groups add-on, RudderStack adds groups as a user property in the user’s profile with Group Name Trait as its type and Group Value Trait as its value.
For example, if you define the Group Name Trait as RS and Group Value Trait as RudderStack and make the group call, the user would then be associated with the group name as RS and the group value as RudderStack.
Note that in device mode:
Group properties are limited to scalar values and arrays.
Nested objects in group properties are not supported.
Group property values cannot exceed 1000 characters.
Track
The track call lets you record the user’s actions along with any properties associated with them.
In device mode, events are processed and sent immediately to Amplitude. The SDK also supports offline event caching and automatic retries when the device is back online.
A sample track call looks like the following:
rudderanalytics.track("Track me")
Opt out of track calls
This feature is available only for the mobile platforms.
If you set a property with the name optOutOfSession with value set to true, then this track call will be opted out of the current session if it exists. If there is no active session, passing optOutOfSession: true does not start a new session.
Track revenue events
Revenue events are available only in web device mode.
To track revenue events, RudderStack uses Amplitude’s logRevenueV2() API which expects revenue as a top level attribute.
To track a revenue event, you must include a revenue key in the event, as shown:
Revenue is tracked as an aggregate at the event level.
Track completed orders
This feature is available only in web device mode.
In device mode, revenue tracking for orders is handled by the Amplitude SDK’s logRevenueV2 API, which ensures accurate revenue attribution even in offline scenarios.
While tracking completed orders with multiple products, RudderStack generates events as follows:
If Track revenue per product setting is enabled: Each product is tracked individually with its own revenue calculation, regardless of the total order revenue.
If Track revenue per product setting is disabled: The total revenue specified at the order level is used.
In both the cases, any discrepancy between the sum of product revenues and the order-level revenue is ignored.
This section covers some advanced features that you can use to enhance your Amplitude device mode integration with RudderStack.
Reset
This feature is currently available only for the mobile platforms.
You can use the reset method to reset the previously identified user and related information. This is particularly useful in scenarios like user logout.
[[RSClientsharedInstance]reset];
rudderClient.reset()
Send event_id
RudderStack supports sending event_id to Amplitude in device mode. You can include it under the integrations object and it is supported for all API calls (identify, track, page, screen, and group).
If you don’t specify an event_id, the SDK automatically generates one to ensure event uniqueness.
A sample identify call with event_id is shown below:
When you send an event to Amplitude via RudderStack, Amplitude updates the existing user properties and appends any new ones. You can change this behavior by setting the skip_user_properties_sync property to true in the integrations object.
Can I send more than one group per user to Amplitude?
RudderStack does not support associating a user to more than one group per group call sent to Amplitude. To send more than one group per user, you need to call the group API multiple times with the relevant group information specified in the group settings.
This site uses cookies to improve your experience while you navigate through the website. Out of
these
cookies, the cookies that are categorized as necessary are stored on your browser as they are as
essential
for the working of basic functionalities of the website. We also use third-party cookies that
help
us
analyze and understand how you use this website. These cookies will be stored in your browser
only
with
your
consent. You also have the option to opt-out of these cookies. But opting out of some of these
cookies
may
have an effect on your browsing experience.
Necessary
Always Enabled
Necessary cookies are absolutely essential for the website to function properly. This
category only includes cookies that ensures basic functionalities and security
features of the website. These cookies do not store any personal information.
This site uses cookies to improve your experience. If you want to
learn more about cookies and why we use them, visit our cookie
policy. We'll assume you're ok with this, but you can opt-out if you wish Cookie Settings.