Skip to contentSkip to navigationSkip to topbar
On this page
Looking for more inspiration?Visit the
(information)
You're in the right place! Segment documentation is now part of Twilio Docs. The content you are used to is still here—just in a new home with a refreshed look.

Analytics Kotlin Intercom Plugin


Intercom(link takes you to an external page) makes customer messaging apps for sales, marketing, and support, connected on one platform. The Intercom Destination Plugin is open-source. You can browse the Kotlin code for Android(link takes you to an external page) on GitHub.


Getting started

getting-started page anchor
  1. From the Segment Destinations page, click Add Destination.
  2. Search for "Intercom" and select it in the results that appear.
  3. Select a source to connect to your Intercom destination.
  4. Authorize your Intercom account in Segment and select the Intercom Account to sync with Segment.
  5. Find your "App ID" in the Intercom UI(link takes you to an external page) or by navigating to the Gear Menu and selecting App Settings > API Keys. It should look something like 9iefb489.

To install the Segment-Intercom integration, add this line to your gradle file:

implementation com.segment.analytics.kotlin.destinations:intercom:<latest_version>

Or the following for Kotlin DSL:

implementation(com.segment.analytics.kotlin.destinations:intercom:<latest_version>)

Using the plugin in your app

using-the-plugin-in-your-app page anchor

Open the file where you set up and configured the Analytics-Kotlin library. Add this plugin to the list of imports.

import com.segment.analytics.kotlin.destinations.intercom.IntercomDestination

Under your Analytics-Kotlin library setup, call analytics.add(plugin = ...) to add an instance of the plugin to the Analytics timeline.

1
analytics = Analytics("<YOUR WRITE KEY>", applicationContext) {
2
this.flushAt = 3
3
this.trackApplicationLifecycleEvents = true
4
}
5
analytics.add(plugin = IntercomDestination(applicationContext))

Your events will now begin to flow to Intercom in device-mode.


If you're not familiar with the Segment Spec, take a look to understand what the Identify method does. An example call would look like:

1
analytics.identify("user-123", buildJsonObject {
2
put("name", "Iñigo Montoya")
3
put("email", "avenger@example.com")
4
put("company", {
5
"id": 123,
6
"name": "Iñigo & Friends Holding Company"
7
})
8
put("createdAt", "Mon Mar 26 2018 17:44:51 GMT+0000 (UTC)")
9
});

When you call Identify, Segment creates or updates the user in Intercom using their Contacts API(link takes you to an external page). Segment doesn't support creating leads(link takes you to an external page)

(information)

Info

Intercom associates Track events with known users. An Identify call with a userId is required before Track events are associated properly. Segment's bundled mobile SDKs also require that Identify is called before Track, but accepts setting an unknown user in Intercom using the anonymousId.

Intercom supports both logged-in or logged-out users. You must register your users with Intercom before you can talk to them or see what they do in your app. This means that Identify must be called before Track.

Intercom allows you to track only known or only unknown users, or all users regardless of identification status. Segment supports the ability to track all users regardless of identification status by checking for logged in users (determined by the userId) and falling back to setting the user as "Unidentified" when this is not present.

Intercom knows when your app is backgrounded and comes alive again, so you won't need to re-register your users.

Segment maps the following Intercom standard attributes on Identify.

Segment ParameterIntercom ParameterDescription
traits.userIduser_idThe user ID for this user.
traits.emailemailThe email of this user.
traits.namenameThe full name of this user.
traits.phonephoneThe phone number for this user.
traits.companycompanyThe company associated for this user.
traits.signedUpAtcreated_atThe signed up date as an NSDate (iOS) & Long (Android)
integrations.intercom.language_overridelanguageOverrideThe language override(link takes you to an external page) code for this user.
integrations.intercom.unsubscribedunsubscribedFromEmailsA boolean indicating if the user has unsubscribed from emails.
remaining traitscustomAttributesCustom attributes for this user.
(information)

Info

Intercom supports String, Long, Float, Double, Boolean, Character, Byte, Short or Integer type values on Android. Pass Android traits using camel case to conform with Java convention.

Collect context

collect-context page anchor

When this option is selected, Identify calls include contextual information collected by Segment's mobile libraries if it is available. This info is set as Custom Attributes on the Intercom user.

The fields collected from the context object are device.type, device.manufacturer, device.model, os.name, os.version, app.name, app.version and appear in Intercom as device_type, device_manufacturer, device_model, os_name, os_version, app_name and app_version.


If you're not familiar with the Segment Spec, take a look to understand what the Track method does. An example call would look like:

1
analytics.track("View Product", buildJsonObject {
2
put("productId", 123)
3
put("productName" "Striped trousers")
4
});
(information)

Info

Because Intercom only associates Track events with known users, an Identify call with a userId is required before Track events are associated properly.

Revenue and currency properties

revenue-and-currency-properties page anchor

If you send properties.revenue and properties.currency to Intercom, Segment formats those properties according to Intercom's Monetary Amount(link takes you to an external page) and sends them to Segment as:

1
price: {
2
amount: <properties.revenue> * 100, // since Intercom requires this in cents
3
currency: <properties.currency> // defaults to 'usd'
4
}

If properties.revenue is not present, the bundled mobile integrations check properties.total and assign the total value as the properties.revenue or amount value.

Intercom can only store 5 event properties(link takes you to an external page) per event. If you send an event to Segment with more than 5 properties, Intercom only shows the first 5 properties.

In Intercom, an "Active" event is an event that hasn't been archived. Intercom only allows a total of 120 unique active event names. If you're sending Segment more than 120 unique event names, Intercom only accepts the first 120 events that their servers encounter. Any additional unique event names will result in an error.

If you need to bring your account back under the 120 event limit, archive some events from in the Intercom UI by navigating to Settings > (workspace name) data > Events, then click on the event to archive.


If you're not familiar with the Segment Spec, take a look to understand what the Group method does. An example call would look like:

1
analytics.group("user-123", buildJsonObject {
2
put("username", "MisterWhiskers")
3
put("email", "hello@test.com")
4
put("plan", "premium")
5
});

Segment supports Intercom companies in all sources. Users can be put into multiple groups, which associate them to multiple companies in Intercom.

When you call Group from any of any server-side libraries or mobile sources in cloud-mode (without Segment's mobile Intercom SDK installed), you must include either the userId or email of an existing user in Intercom.

(information)

Info

In order for the Company Sessions Count to update within Intercom, the company must first be recorded in an Identify call.

Segment ParameterIntercom ParameterDescription
groupIdcompanyIdThe ID for the company.
traits.namenameThe name of the company.
traits.planplanThe plan of the company.
traits.monthly_spendmonthlySpendThe monthly spend of the company.
traits.companyintercomSettings.companyThe company associated for this user.
traits.createdAtintercomSettings.created_atThe UNIX timestamp when the user was created.
remaining traitscustomAttributesCustom attributes for this user.
(information)

Info

Intercom supports String, Long, Float, Double, Boolean, Character, Byte, Short or Integer type values on Android. Pass Android traits using camel case to conform with Java convention.


The bundled mobile SDK reset method un-registers a user in Intercom. When users want to log out of your app and you call Segment's reset method, Segment calls:

intercom.logout()

Intercom doesn't support custom arrays or objects. If you want to send a certain user trait or event property to Intercom, you must send them at the top level instead of in an array or object.

This limitation does not apply if you are mapping custom traits or properties to company objects on Identify calls.