Use the Behavioral Cohorts API to list all your cohorts in Amplitude, export a cohort in Amplitude, or upload a cohort.
This API uses basic authentication, using the API key and secret key for your project. Pass base64-encoded credentials in the request header like {api-key}:{secret-key}. api-key replaces username, and secret-key replaces the password.
Your authorization header should look something like this:
--header 'Authorization: Basic YWhhbWwsdG9uQGFwaWdlZS5jb206bClwYXNzdzByZAo'
For more information, see Find your API Credentials
| Region | Endpoint | 
|---|---|
| Standard server | https://amplitude.com/api/3/cohorts | 
| EU residency server | https://analytics.eu.amplitude.com/api/3/cohorts | 
Get all discoverable cohorts for an app. Use the id for each cohort returned in the response to get a single cohort.
curl --location --request GET 'https://amplitude.com/api/3/cohorts' \
-u '{api_key}:{secret_key}'
GET /api/3/cohorts HTTP/1.1
Host: amplitude.com
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
| Name | Description | 
|---|---|
| includeSyncInfo | Optional. Boolean. Set to true to include cohort sync metadata in response (one-time + disabled sync will be excluded) . | 
The response is a JSON object with this schema:
{
    "cohorts": [
        { COHORT_OBJECT },
        ...
        { COHORT_OBJECT },
    ]
}
Each COHORT_OBJECT returned has this schema:
{
    "appId": integer,
    "archived": boolean, // whether cohort is archived
    "definition": { COHORT_DEFINITION }, // Amplitude internal representation of Cohort Definition
    "description": string,
    "finished": boolean, // Amplitude internal use to decide whether a training cohort has finished ML training
    "id": string,
    "name": string,
    "owners": string[],
    "viewers": string[],
    "published": boolean, // whether cohort is discoverable by other users
    "size": integer,
    "type": string, // Amplitude internal representation on different cohort types
    "lastMod": timestamp, // last modified date
    "createdAt": timestamp,
    "lastComputed": timestamp,
    "hidden": boolean, // Amplitude internal use case to hide a cohort
    "metadata": string[], // cohort created from funnel/microscope might have this
    "view_count": integer,
    "popularity": integer, // cohort created from chart might have this
    "last_viewed": timestamp,
    "chart_id": string, // cohort created from chart will have this
    "edit_id": string, // cohort created from chart will have this
    "is_predictive": boolean,
    "is_official_content": boolean,
    "location_id": string, // cohort created from chart might have this
    "shortcut_ids": string[],
    "syncMetadata": COHORT_SYNC_METADATA[]
}
Each COHORT_SYNC_METADATA has this schema:
{
    "target": string,
    "frequency": string, // support minute (real-time), hourly, daily
    "last_successful": timestamp,
    "last_failure": timestamp,
    "params": { COHORT_SYNC_LEVEL_PARAM }
}
Below is a sample result:
"cohorts": [{
    "appId": 123456,
    "archived": false,
    "definition": {
        "version": 3,
        "countGroup": {
            "name": "User",
            "is_computed": false
        },
        "cohortType": "UNIQUES",
        "andClauses": [{
            "negated": false,
            "orClauses": [{
                "type": "event",
                "time_type": "rolling",
                "time_value": 30,
                "offset": 0,
                "interval": 1,
                "type_value": "_active",
                "operator": ">=",
                "operator_value": 1,
                "group_by": [],
                "metric": null
            }]
        }],
        "referenceFrameTimeParams": {}
    },
    "description": "test description",
    "finished": true,
    "id": "id_12345",
    "name": "Test Cohort 1",
    "owners": [
        "demo@amplitude.com"
    ],
    "viewers": [],
    "published": true,
    "size": 111,
    "type": "redshift",
    "lastMod": 1679437294,
    "createdAt": 1679437288,
    "lastComputed": 1679440233,
    "hidden": false,
    "metadata": null,
    "view_count": null,
    "popularity": null,
    "last_viewed": null,
    "chart_id": null,
    "edit_id": null,
    "is_predictive": false,
    "is_official_content": false,
    "location_id": null,
    "shortcut_ids": [],
    "syncMetadata": [{
        "target": "braze",
        "frequency": "hourly",
        "last_successful": "2023-03-21T16:09:58.848454-07:00",
        "last_failure": null,
        "params": {
            "user_id": "demo@amplitude.com"
        }
    }]
}],
Get a discoverable cohort using its cohort_id.
This is step one in the download a cohort operation. Use the request_id returned in the response to poll export status.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request/id'
-u '{api_key}:{secret_key}'
GET /api/5/cohorts/request/id HTTP/1.1
Host: amplitude.com
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Example: Get a cohort with specific properties
            
    26umsb5 and includes the properties Property1 and Property2.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request/26umsb5?props=1&propKeys=Property1&propKeys=Property2'
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA='
GET /api/5/cohorts/request/26umsb5?props=1&propKeys=Property1&propKeys=Property2 HTTP/1.1
Host: amplitude.com
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
Example: Get cohort with all properties
            
    curl --location --request GET 'https://amplitude.com/api/5/cohorts/request/26umsb5?props=1'
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA='
GET /api/5/cohorts/request/26umsb5?props=1 HTTP/1.1
Host: amplitude.com
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
| Name | Description | 
|---|---|
| id | Required. Cohort ID. | 
| Name | Description | 
|---|---|
| props | Optional. Integer. Set to 1 to include user properties in the response object. Set this to 0or unset if the request keeps timing out. | 
| propKeys | Optional. string[]. One or more user properties to include in the response. Add as many propKeysparameters as needed. If left undefined and props=1, response object returns all available user properties. | 
Requesting a single cohort returns 202 response code with the following JSON object:
{
    "request_id": "<request_id>",
    "cohort_id": "<cohort_id>"
}
If your authorization or the cohort_id is invalid, the request returns an error.
Poll the request status using the request_id retrieved for the cohort. This is the second phase in a cohort download operation.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request-status/:request_id' \
-u '{api_key}:{secret_key}''
GET /api/5/cohorts/request-status/:request_id HTTP/1.1
Host: amplitude.com
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Example: Get the status of a request
            
    qfaZya.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request-status/qfaZya' \
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA='
GET /api/5/cohorts/request-status/qfaZya HTTP/1.1
Host: amplitude.com
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
| Name | Description | 
|---|---|
| request_id | Required. The request ID retrieved with the get one cohort request. | 
If the job is still running, polling the request status returns a 202 code and the async_status 'JOB INPROGRESS'.
{
    "request_id": "<request_id>",
    "cohort_id": "<cohort_id>",
    "async_status": "JOB INPROGRESS"
}
If the job has finished running, polling the request status returns a 200 code and the async_status 'JOB COMPLETED'.
{
    "request_id": "<request_id>",
    "cohort_id": "<cohort_id>",
    "async_status": "JOB COMPLETED"
}
When the job has finished running, download the cohort.
This is a basic request.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request/:requestId/file' \
-u '{api_key}:{secret_key}'
GET /api/5/cohorts/request/requestId/file HTTP/1.1
Host: amplitude.com
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Example: Download a requested cohort
            
    Sf7M9j.
curl --location --request GET 'https://amplitude.com/api/5/cohorts/request/Sf7M9j/file'
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA='
GET /api/5/cohorts/request/Sf7M9j/file HTTP/1.1
Host: amplitude.com
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
| Name | Description | 
|---|---|
| request_id | Required. The request ID retrieved with the get one cohort request. | 
https://amplitude.com/api/5/cohorts/request/:requestId/file) is valid for seven days. During the seven days, you can make the same request to get a new S3 download link. Each S3 link is valid for one minute.Generate a new cohort or update an existing cohort by uploading a set of User IDs or Amplitude IDs. This is a basic request example with placeholder values.
curl --location --request POST 'https://amplitude.com/api/3/cohorts/upload' \
--header 'Content-Type: application/json' \
-u '{api_key}:{secret_key}''
--data-raw '{
    "name": "Cohort Name",
    "app_id": amplitude_project,
    "id_type": "BY_AMP_ID",
    "cg": "group_id",
    "ids": [
            "amplitude_id",
            "amplitude_id"
    ],
    "owner": "cohort_owner",
    "published": true
}'
POST /api/3/cohorts/upload HTTP/1.1
Host: amplitude.com
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Content-Type: application/json
Content-Length: 201
{
"name": "Cohort Name",
"app_id": amplitude_project,
"id_type": "BY_AMP_ID",
"cg": "group_id",
"ids": [
            "amplitude_id",
            "amplitude_id"
],
"owner": "cohort_owner",
"published": true
}
Example: Create a new cohort
            
    10101010101010ID1, and 00000010101010ID2.
curl --location --request POST 'https://amplitude.com/api/3/cohorts/upload' \
--header 'Content-Type: application/json' \
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=' \
-u '{api_key}:{secret_key}' \
--data-raw '{
    "name": "New Cohort",
    "app_id": 153957,
    "id_type": "BY_AMP_ID",
    "ids": [
            "10101010101010ID1",
            "00000010101010ID2"
    ],
    "owner": "datamonster@amplitude.com",
    "published": true
}'
POST /api/3/cohorts/upload HTTP/1.1
Host: amplitude.com
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Content-Type: application/json
Content-Length: 280
{
    "name": "New Cohort",
    "app_id": 153957,
    "id_type": "BY_AMP_ID",
    "ids": [
        "10101010101010ID1",
        "00000010101010ID2"
    ],
    "owner": "datamonster@amplitude.com",
    "published": true
}
| Parameter | Description | 
|---|---|
| name | Required. String. A name for the cohort. | 
| app_id | Required. Integer. An identifier for the Amplitude project containing the cohort. | 
| id_type | Required. String. The kind of ID sent in the ids field. Valid options are BY_AMP_IDorBY_USER_ID. | 
| cg | Optional. String. Enter the name of an existing group to create a cohort based on it. | 
| ids | Required. String[]. One or more user or Amplitude IDs to include in the cohort. Specify the ID type in the id_typefield. | 
| owner | Required. String. The login email of the cohort's owner in Amplitude. | 
| published | Required. Boolean. Whether the cohort is discoverable or hidden. | 
| skip_save | Optional. Boolean. Set to trueif you want to validate the upload without saving. Default isfalse. | 
| skip_invalid_ids | Optional. Boolean. Setting skip_invalid_idstotrueskips invalid IDs and upload the remaining valid IDs. Setting this parameter tofalseends the upload if the request has invalid IDs. Default istrue. | 
| existing_cohort_id | Optional. String. The ID of an existing cohort. This replaces the contents for the specified cohort with the IDs uploaded in the request. For example, '1a2bc3d' is your cohort's ID, found in the cohort's URL. https://analytics.amplitude.com/accountname/cohort/**1a2bc3d** | 
The response is a JSON object with this schema:
{
    "cohortId": "COHORT_ID",
    "metadata": {
        "matched": 1234,
        "totals": 1232,
        "invalid_ids_sample": ["INVALID_ID1", "INVALID_ID2"]
    }
}
| Parameter | Type | Description | 
|---|---|---|
| error | error json | Error details. | 
| Parameter | Description | 
|---|---|
| http_code | Integer. Provides the HTTP error, if available. | 
| type | String. Describes the type of error. | 
| message | String. Describes the error. | 
| metadata | JSON object. Describes in more detail the cause of the error. For example, which user ID values are invalid. | 
Add and remove IDs to incrementally update existing cohort membership.
curl --location --request POST 'https://amplitude.com/api/3/cohorts/membership' \
--header 'Content-Type: application/json' \
-u '{api_key}:{secret_key}' \
--data-raw '{
    "cohort_id": "COHORT_ID",
    "memberships": [
        {
            "ids": [
                "ID",
                "ID"
            ],
            "id_type": "BY_ID",
            "operation": "ADD"
        },
        {
            "ids": [
                "ID",
                "ID"
            ],
            "id_type": "BY_ID",
            "operation": "REMOVE"
        },
        {
            "ids": [
                "name",
                "name"
            ],
            "id_type": "BY_NAME",
            "operation": "ADD"
        }
    ],
    "skip_invalid_ids": true
}
POST /api/3/cohorts/membership HTTP/1.1
Host: amplitude.com
Content-Type: application/json
Authorization: Basic {api-key}:{secret-key} #credentials must be base64 encoded
Content-Length: 362
{
"cohort_id":"COHORT_ID",
"memberships": [
    {
        "ids" : ["ID","ID"],
        "id_type" : "BY_ID",
        "operation" : "ADD"
    },
    {
        "ids" : ["ID","ID"],
        "id_type" : "BY_ID",
        "operation" : "REMOVE"
    },
    {
        "ids" : ["name","name"],
        "id_type" : "BY_NAME",
        "operation" : "ADD"
    }
    ],
"skip_invalid_ids":true,
}
Example: Remove and add cohort members
            
    111 and 222 by ID, removes IDs 333 and 444 by ID, and removes IDs asd and qwe by name from the the cohort with ID 1a2bc3d. The operation is set to skip invalid IDs.
curl --location --request POST 'https://amplitude.com/api/3/cohorts/membership' \
--header 'Content-Type: application/json' \
--header 'Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=' \
--data-raw '{
"cohort_id":"1a2bc3d",
"memberships": [
    {
        "ids" : ["111","222"],
        "id_type" : "BY_ID",
        "operation" : "ADD"
    },
    {
        "ids" : ["333","444"],
        "id_type" : "BY_ID",
        "operation" : "REMOVE"
    },
    {
        "ids" : ["asd","qwe"],
        "id_type" : "BY_NAME",
        "operation" : "ADD"
    }
    ],
"skip_invalid_ids":true,
}'
POST /api/3/cohorts/membership HTTP/1.1
Host: amplitude.com
Content-Type: application/json
Authorization: Basic MTIzNDU2NzgwMDoxMjM0NTY3MDA=
Content-Length: 362
{
"cohort_id":"1a2bc3d",
"memberships": [
    {
        "ids" : ["111","222"],
        "id_type" : "BY_ID",
        "operation" : "ADD"
    },
    {
        "ids" : ["333","444"],
        "id_type" : "BY_ID",
        "operation" : "REMOVE"
    },
    {
        "ids" : ["asd","qwe"],
        "id_type" : "BY_NAME",
        "operation" : "ADD"
    }
    ],
"skip_invalid_ids":true,
}
Perform incremental update (add / remove) to existing cohort membership.
| Parameter | Description | 
|---|---|
| cohort_id | Required. String. The ID of an existing cohort. This updates the membership for the specified cohort with the IDs being uploaded in this request. | 
| count_group | Optional. String. The count group of the given IDs. This must be the same as the cohort’s existing count group. Count_groupdefaults to User. | 
| memberships | Required. List of membership json An array of JSON objects identifying IDs to add or remove. | 
| skip_invalid_ids | Optional. Boolean. Setting this parameter to falseends the request without updating cohort membership if the request has invalid IDs. Settingskip_invalid_idstotrueskips invalid IDs while applying the remaining valid ids. Default istrue. | 
| Parameter | Description | 
|---|---|
| ids | Required. String[]. List of IDs to add or remove. | 
| id_type | Required. String. The kind of ID sent in the idsfield. Valid options are: - BY_ID - BY_NAME For Usercount_group, BY_ID is amplitude ID and BY_NAME is user ID. For any othercount_group,BY_IDis group ID andBY_NAMEis group name. | 
| operation | Required. String. The operation to apply on idsfield. Valid options are:ADDandREMOVE | 
| Parameter | Description | 
|---|---|
| cohort_id | String. The ID of an existing cohort for which the membership information was updated. | 
| memberships_result | List of memberships_resultjson. An array of JSON objects identifying result of membership update (add or remove) operation. | 
| Parameter | Description | 
|---|---|
| skipped_ids | List of strings. List of skipped IDs in the membership operation entry. | 
| id_type | String. The kind of ID sent for the idsfield in this membership operation entry. | 
| operation | String. The operation applied on idsfield in this membership operation entry | 
May 21st, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.