The intercom API reference.
- List subscriptions for a contact
Intercom API (2.10)
https://api.intercom.io/
https://api.eu.intercom.io/
https://api.au.intercom.io/
- The production API serverhttps://api.intercom.io/contacts/{contact_id}/segments 
- The european API serverhttps://api.eu.intercom.io/contacts/{contact_id}/segments 
- The australian API serverhttps://api.au.intercom.io/contacts/{contact_id}/segments 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/contacts/63a07ddf05a32042dffac965/segments \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: 2.10'{ "type": "list", "data": [ { … } ] }
Request
You can fetch a list of subscription types that are attached to a contact. These can be subscriptions that a user has 'opted-in' to or has 'opted-out' from, depending on the subscription type. This will return a list of Subscription Type objects that the contact is associated with.
The data property will show a combined list of:
1.Opt-out subscription types that the user has opted-out from. 2.Opt-in subscription types that the user has opted-in to receiving.
- The production API serverhttps://api.intercom.io/contacts/{contact_id}/subscriptions 
- The european API serverhttps://api.eu.intercom.io/contacts/{contact_id}/subscriptions 
- The australian API serverhttps://api.au.intercom.io/contacts/{contact_id}/subscriptions 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/contacts/63a07ddf05a32042dffac965/subscriptions \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: 2.10'{ "type": "list", "data": [ { … }, { … } ] }
Request
You can add a specific subscription to a contact. In Intercom, we have two different subscription types based on user consent - opt-out and opt-in:
1.Attaching a contact to an opt-out subscription type will opt that user out from receiving messages related to that subscription type.
2.Attaching a contact to an opt-in subscription type will opt that user in to receiving messages related to that subscription type.
This will return a subscription type model for the subscription type that was added to the contact.
The unique identifier for the subscription which is given by Intercom
- The production API serverhttps://api.intercom.io/contacts/{contact_id}/subscriptions 
- The european API serverhttps://api.eu.intercom.io/contacts/{contact_id}/subscriptions 
- The australian API serverhttps://api.au.intercom.io/contacts/{contact_id}/subscriptions 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X POST \
  https://api.intercom.io/contacts/63a07ddf05a32042dffac965/subscriptions \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Content-Type: application/json' \
  -H 'Intercom-Version: 2.10' \
  -d '{
    "id": 154,
    "consent_type": "opt_in"
  }'{ "type": "subscription", "id": "154", "state": "live", "consent_type": "opt_in", "default_translation": { "name": "Newsletters", "description": "Lorem ipsum dolor sit amet", "locale": "en" }, "translations": [ { … } ], "content_types": [ "sms_message" ] }