The intercom API reference.
- Attach a Contact to a Company
Intercom API (Unstable)
https://api.intercom.io/
https://api.eu.intercom.io/
https://api.au.intercom.io/
AI Content
With the AI Content APIs, you can create and manage External Pages and Content Import Sources for your Fin Content Library.
External Pages are pages that you want Fin to be able to answer questions about. The API for External Pages is a great way to ingest into your Fin Content Library pages that are not publicly accessible and hence can't be crawled by Intercom.
Content Import Sources are the sources of those pages, and they are used to determine the default audience for the pages (configured via the UI). You should create a Content Import Source for each source of External Pages that you want to ingest into your Fin Content Library.
You can then iterate through the content from that source via its API and POST it to the External Pages endpoint. That endpoint has an external_id parameter which allows you to specify the identifier from the source. The endpoint will then either create a new External Page or update an existing one as appropriate.",
Company
Companies allow you to represent organizations using your product. Each company will have its own description and be associated with contacts. You can fetch, create, update and list companies.
The Intercom defined code of the workspace the company is associated to.
The custom attributes you have set on the company.
{ "type": "company", "id": "531ee472cce572a6ec000006", "name": "Blue Sun", "app_id": "ecahpwf5", "plan": { "type": "plan", "id": "269315", "name": "Pro" }, "company_id": "6", "remote_created_at": 1663597223, "created_at": 1663597223, "updated_at": 1663597223, "last_request_at": 1663597223, "size": 100, "website": "https://www.intercom.com", "industry": "Software", "monthly_spend": 100, "session_count": 100, "user_count": 100, "custom_attributes": { "paid_subscriber": true, "monthly_spend": 155.5, "team_mates": 9 }, "tags": { "type": "tag.list", "tags": [ … ] }, "segments": { "type": "segment.list", "segments": [ … ] }, "notes": { "type": "note.list", "notes": [ … ] } }
Request
You can create or update a company.
Companies will be only visible in Intercom when there is at least one associated user.
Companies are looked up via company_id in a POST request, if not found via company_id, the new company will be created, if found, that company will be updated.
You can set a unique company_id value when creating a company. However, it is not possible to update company_id. Be sure to set a unique value once upon creation of the company.
The company id you have defined for the company. Can't be updated
The URL for this company's website. Please note that the value specified here is not validated. Accepts any string.
A hash of key/value pairs containing any other data about the company you want Intercom to store.
- The production API serverhttps://api.intercom.io/companies 
- The european API serverhttps://api.eu.intercom.io/companies 
- The australian API serverhttps://api.au.intercom.io/companies 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X POST \
  https://api.intercom.io/companies \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Content-Type: application/json' \
  -H 'Intercom-Version: Unstable' \
  -d '{
    "company_id": "company_remote_id",
    "name": "my company",
    "remote_created_at": 1374138000
  }'{ "type": "company", "company_id": "company_remote_id", "id": "6762f0761bb69f9f2193bae2", "app_id": "this_is_an_id147_that_should_be_at_least_", "name": "my company", "remote_created_at": 1374138000, "created_at": 1734537334, "updated_at": 1734537334, "monthly_spend": 0, "session_count": 0, "user_count": 0, "tags": { "type": "tag.list", "tags": [] }, "segments": { "type": "segment.list", "segments": [] }, "notes": { "type": "note.list", "data": [], "url": "/companies/6762f0761bb69f9f2193bae2/notes", "total_count": 0, "has_more": false }, "plan": {}, "custom_attributes": { "creation_source": "api" } }
Request
You can fetch a single company by passing in company_id or name.
https://api.intercom.io/companies?name={name}
https://api.intercom.io/companies?company_id={company_id}
You can fetch all companies and filter by segment_id or tag_id as a query parameter.
https://api.intercom.io/companies?tag_id={tag_id}
https://api.intercom.io/companies?segment_id={segment_id}
- The production API serverhttps://api.intercom.io/companies 
- The european API serverhttps://api.eu.intercom.io/companies 
- The australian API serverhttps://api.au.intercom.io/companies 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  'https://api.intercom.io/companies?name=my+company&company_id=12345&tag_id=678910&segment_id=98765&page=1&per_page=15' \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "list", "data": [ { … } ], "pages": { "type": "pages", "next": null, "page": 1, "per_page": 15, "total_pages": 1 }, "total_count": 1 }
- The production API serverhttps://api.intercom.io/companies/{id} 
- The european API serverhttps://api.eu.intercom.io/companies/{id} 
- The australian API serverhttps://api.au.intercom.io/companies/{id} 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "company", "company_id": "1", "id": "6762f07f1bb69f9f2193baf5", "app_id": "this_is_an_id159_that_should_be_at_least_", "name": "company1", "remote_created_at": 1734537343, "created_at": 1734537343, "updated_at": 1734537343, "monthly_spend": 0, "session_count": 0, "user_count": 1, "tags": { "type": "tag.list", "tags": [] }, "segments": { "type": "segment.list", "segments": [] }, "notes": { "type": "note.list", "data": [], "url": "/companies/6762f07f1bb69f9f2193baf5/notes", "total_count": 0, "has_more": false }, "plan": {}, "custom_attributes": {} }
- The production API serverhttps://api.intercom.io/companies/{id} 
- The european API serverhttps://api.eu.intercom.io/companies/{id} 
- The australian API serverhttps://api.au.intercom.io/companies/{id} 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X PUT \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "company", "company_id": "1", "id": "6762f0841bb69f9f2193baff", "app_id": "this_is_an_id165_that_should_be_at_least_", "name": "company2", "remote_created_at": 1734537348, "created_at": 1734537348, "updated_at": 1734537348, "monthly_spend": 0, "session_count": 0, "user_count": 1, "tags": { "type": "tag.list", "tags": [] }, "segments": { "type": "segment.list", "segments": [] }, "notes": { "type": "note.list", "data": [], "url": "/companies/6762f0841bb69f9f2193baff/notes", "total_count": 0, "has_more": false }, "plan": {}, "custom_attributes": {} }
- The production API serverhttps://api.intercom.io/companies/{id} 
- The european API serverhttps://api.eu.intercom.io/companies/{id} 
- The australian API serverhttps://api.au.intercom.io/companies/{id} 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X DELETE \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632 \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "id": "6762f0881bb69f9f2193bb09", "object": "company", "deleted": true }
- The production API serverhttps://api.intercom.io/companies/{id}/contacts 
- The european API serverhttps://api.eu.intercom.io/companies/{id}/contacts 
- The australian API serverhttps://api.au.intercom.io/companies/{id}/contacts 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632/contacts \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "list", "data": [], "total_count": 0, "pages": { "type": "pages", "page": 1, "per_page": 50, "total_pages": 0 } }
- The production API serverhttps://api.intercom.io/companies/{id}/segments 
- The european API serverhttps://api.eu.intercom.io/companies/{id}/segments 
- The australian API serverhttps://api.au.intercom.io/companies/{id}/segments 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632/segments \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "list", "data": [] }
- The production API serverhttps://api.intercom.io/companies/{id}/notes 
- The european API serverhttps://api.eu.intercom.io/companies/{id}/notes 
- The australian API serverhttps://api.au.intercom.io/companies/{id}/notes 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/companies/5f4d3c1c-7b1b-4d7d-a97e-6095715c6632/notes \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'Successful response
Cursor-based pagination is a technique used in the Intercom API to navigate through large amounts of data. A "cursor" or pointer is used to keep track of the current position in the result set, allowing the API to return the data in small chunks or "pages" as needed.
{ "type": "list", "data": [ { … }, { … }, { … } ], "total_count": 3, "pages": { "type": "pages", "next": null, "page": 1, "per_page": 50, "total_pages": 1 } }
Request
You can list companies. The company list is sorted by the last_request_at field and by default is ordered descending, most recently requested first.
Note that the API does not include companies who have no associated users in list responses.
When using the Companies endpoint and the pages object to iterate through the returned companies, there is a limit of 10,000 Companies that can be returned. If you need to list or iterate on more than 10,000 Companies, please use the Scroll API.
You can use pagination to limit the number of results returned. The default is 20 results per page. See the pagination section for more details on how to use the starting_after param.
- The production API serverhttps://api.intercom.io/companies/list 
- The european API serverhttps://api.eu.intercom.io/companies/list 
- The australian API serverhttps://api.au.intercom.io/companies/list 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X POST \
  'https://api.intercom.io/companies/list?page=1&per_page=15&order=desc' \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "list", "data": [ { … } ], "pages": { "type": "pages", "next": null, "page": 1, "per_page": 15, "total_pages": 1 }, "total_count": 1 }
Request
The list all companies functionality does not work well for huge datasets, and can result in errors and performance problems when paging deeply. The Scroll API provides an efficient mechanism for iterating over all companies in a dataset.
- Each app can only have 1 scroll open at a time. You'll get an error message if you try to have more than one open per app.
- If the scroll isn't used for 1 minute, it expires and calls with that scroll param will fail
- If the end of the scroll is reached, "companies" will be empty and the scroll parameter will expire
You can get the first page of companies by simply sending a GET request to the scroll endpoint. For subsequent requests you will need to use the scroll parameter from the response.
Since scroll is often used on large datasets network errors such as timeouts can be encountered. When this occurs you will see a HTTP 500 error with the following message: "Request failed due to an internal network error. Please restart the scroll operation." If this happens, you will need to restart your scroll query: It is not possible to continue from a specific point when using scroll.
- The production API serverhttps://api.intercom.io/companies/scroll 
- The european API serverhttps://api.eu.intercom.io/companies/scroll 
- The australian API serverhttps://api.au.intercom.io/companies/scroll 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  'https://api.intercom.io/companies/scroll?scroll_param=string' \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "list", "data": [ { … } ], "pages": null, "total_count": null, "scroll_param": "69352cd2-ab5b-42ac-b004-a13d4e55e9b0" }
- The production API serverhttps://api.intercom.io/contacts/{id}/companies 
- The european API serverhttps://api.eu.intercom.io/contacts/{id}/companies 
- The australian API serverhttps://api.au.intercom.io/contacts/{id}/companies 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X POST \
  'https://api.intercom.io/contacts/{id}/companies' \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Content-Type: application/json' \
  -H 'Intercom-Version: Unstable' \
  -d '{
    "id": "6762f09a1bb69f9f2193bb34"
  }'{ "type": "company", "company_id": "1", "id": "6762f09a1bb69f9f2193bb34", "app_id": "this_is_an_id197_that_should_be_at_least_", "name": "company6", "remote_created_at": 1734537370, "created_at": 1734537370, "updated_at": 1734537370, "monthly_spend": 0, "session_count": 0, "user_count": 1, "tags": { "type": "tag.list", "tags": [] }, "segments": { "type": "segment.list", "segments": [] }, "notes": { "type": "note.list", "data": [], "url": "/companies/6762f09a1bb69f9f2193bb34/notes", "total_count": 0, "has_more": false }, "plan": {}, "custom_attributes": {} }
- The production API serverhttps://api.intercom.io/contacts/{id}/companies 
- The european API serverhttps://api.eu.intercom.io/contacts/{id}/companies 
- The australian API serverhttps://api.au.intercom.io/contacts/{id}/companies 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X GET \
  https://api.intercom.io/contacts/63a07ddf05a32042dffac965/companies \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'successful
The majority of list resources in the API are paginated to allow clients to traverse data over multiple requests.
Their responses are likely to contain a pages object that hosts pagination links which a client can use to paginate through the data without having to construct a query. The link relations for the pages field are as follows.
{ "type": "list", "data": [ { … } ], "pages": { "type": "pages", "next": null, "page": 1, "per_page": 50, "total_pages": 1 }, "total_count": 1 }
- The production API serverhttps://api.intercom.io/contacts/{contact_id}/companies/{id} 
- The european API serverhttps://api.eu.intercom.io/contacts/{contact_id}/companies/{id} 
- The australian API serverhttps://api.au.intercom.io/contacts/{contact_id}/companies/{id} 
- curl
- Node.js
- Ruby
- PHP
- Python
- Java
- Go
- C#
- R
curl -i -X DELETE \
  https://api.intercom.io/contacts/58a430d35458202d41b1e65b/companies/58a430d35458202d41b1e65b \
  -H 'Authorization: Bearer <YOUR_TOKEN_HERE>' \
  -H 'Intercom-Version: Unstable'{ "type": "company", "company_id": "1", "id": "6762f0a01bb69f9f2193bb44", "app_id": "this_is_an_id205_that_should_be_at_least_", "name": "company8", "remote_created_at": 1734537376, "created_at": 1734537376, "updated_at": 1734537377, "monthly_spend": 0, "session_count": 0, "user_count": 0, "tags": { "type": "tag.list", "tags": [] }, "segments": { "type": "segment.list", "segments": [] }, "notes": { "type": "note.list", "data": [], "url": "/companies/6762f0a01bb69f9f2193bb44/notes", "total_count": 0, "has_more": false }, "plan": {}, "custom_attributes": {} }
Custom Channel Events
With the "Custom Channel" integration, you can bring Fin and Intercom capabilities to your own platform via API, enabling powerful custom integrations.
Intercom treats your integration like any other Intercom channel, allowing your application and Intercom to exchange events seamlessly. This makes it possible, for example, for your users to interact with Fin directly within your own application’s UI.
Note: "Fin over API" is currently under managed availability. Please reach out to your accounts team to discuss access and tailored, hands-on support.
Custom Object Instances
Everything about your Custom Object instances.
From now on, to access this endpoint, you need additional permissions. Please head over to the Developer Hub app package authentication settings to configure the required permissions.
Reporting Data Export
Everything about Reporting Data Export. See this article for details on using the data to generate various metrics.