It's not uncommon for user IDs for the same user to differ across projects within the same organization. The user mapping (aliasing) API lets you map users with different user IDs together in Amplitude.
In this example, three user records, each with a different user ID, are all merged into the user ID hank@globex.net. This new user ID is that user's "global" user ID in the cross-project view. This way, you can get an accurate count of the number of unique users across your entire product portfolio.
This API uses your API key passed in the body of the request:
api-key=API_KEY
For more information, see Find your API Credentials
| Region | Endpoint | 
|---|---|
| Standard server | https://api.amplitude.com/usermap | 
Keep these considerations in mind when using this API.
user_id and aren't transferred between User 1 and User 2.The aliasing API has the following limits:
| Name | Description | 
|---|---|
| api_key | Required. String. an API Key for any project in your organization. | 
| mapping | Required. Either a single JSON mapping object or an array of JSON objects, each of which represents a single mapping. | 
| Name | Description | 
|---|---|
| user_id | Required. String. A UUID (unique user ID) specified by you, for the user you want to map. Each JSON mapping object can contain one user_idto map. | 
| global_user_id | Required unless unmapis true. String. A UUID (unique user ID) specified by you. The unified identity you want to map the otheruser_idto. | 
| unmap | Optional. Boolean. When true, the current mapping for user_idis removed. | 
Map a user ID to a global user ID. Remember that you can map a single user ID per JSON mapping object.
This is a basic request with only the required parameters. See the examples below for more detailed requests.
curl --location -g --request POST 'https://api.amplitude.com/usermap?mapping=[{"user_id":"<USER_ID", "global_user_id": "<GLOBAL_USER_ID"}]&api_key=API_KEY'
POST /usermap?mapping=[{"user_id":"<USER_ID", "global_user_id": "<GLOBAL_USER_ID"}]&api_key=API_KEY
HTTP/1.1
Host: api.amplitude.com
Example: Map a user ID to a global user ID
            
    curl --location -g --request POST 'https://api.amplitude.com/usermap?mapping=[{"user_id":"63629@hmail.com", "global_user_id": "hank@globex.net"}]&api_key=123456789'
POST /usermap?mapping=[{"user_id":"63629@hmail.com", "global_user_id": "hank@globex.net"}]]&api_key=123456789 HTTP/1.1
Host: api.amplitude.com
Example: Map multiple users in one request
            
    curl --location -g --request POST 'curl --location -g --request POST 'https://api.amplitude.com/usermap?mapping=[{"user_id":"63629@hmail.com", "global_user_id": "hank@globex.net"}, {"user_id":"12345@hmail.com", "global_user_id": "hank@globex.net"}]&api_key=123456789'
POST /usermap?mapping=[{"user_id":"63629@hmail.com", "global_user_id": "hank@globex.net"}, {"user_id":"12345@hmail.com", "global_user_id": "hank@globex.net"}]&api_key=123456789 HTTP/1.1
Host: api.amplitude.com
This is a basic request with only the required parameters. Remember that you can unmap a single user ID per JSON mapping object. See the examples below for more detailed requests.
curl --location -g --request POST 'https://api.amplitude.com/usermap?mapping=[{"user_id":"<USER_ID", "unmap": true}]&api_key=API_KEY'
POST /usermap?mapping=[{"user_id":"<USER_ID>", "unmap": true}]&api_key=API_KEY
HTTP/1.1
Host: api.amplitude.com
Example: Unmap a user ID
            
    curl --location -g --request POST 'curl --location -g --request POST 'https://api.amplitude.com/usermap?mapping=[{"user_id":"63629@hmail.com", "unmap":true}, {"user_id":"12345@hmail.com", "unmap":true}]&api_key=123456789'
POST /usermap?mapping=[{"user_id":"63629@hmail.com", "unmap":true}, {"user_id":"12345@hmail.com", "unmap":true}]&api_key=123456789 HTTP/1.1
Host: api.amplitude.com
Get the list of mappings that involve the provided user ids.
https://amplitude.com/api/2/usermap.    user_ids = ["<REPLACE ME WITH LIST OF USER IDS>"]
    request_data = {
        "user_ids": user_ids,
    }
    url = 'https://amplitude.com/api/2/usermap'
    API_KEY = "REPLACE_ME"
    SECRET_KEY = "REPLACE_ME"
    result = requests.get(url, auth=HTTPBasicAuth(API_KEY, SECRET_KEY), data=request_data)
    if result.status_code != 200:
        raise AssertionError(
            "Request failed. Error: code - %s, text - %s" % (result.status_code, result.text))
    else:
        print(result.json())
| Name | Description | 
|---|---|
| api_key | Required. String. an API Key for any project in your organization. | 
| secret_key | Required. String. an API Secret Key for any project in your organization. | 
| user_ids | Required. A list of user ids. Minimum 1 user id, maximum 100 user ids in a single request. | 
The response for a POST request contains these fields:
| Name | Description | 
|---|---|
| user id | A user id in the request list. | 
| mappings | The mappings associated with this user id. See next section. Empty if the requested user isn't found | 
The mappings key contains these fields:
| Name | Description | 
|---|---|
| amplitude_id | The Amplitude ID of the requested user | 
| mapped_from | A list of objects that map into the requested user. {"amplitude_id": 1234, "user_id": "mappedUser"} | 
| mapped_to | A list of objects that the requested user maps into {"amplitude_id": 1234, "user_id": "globalUser"} | 
 {
    "user1":
        {
           "mapped_from": [{
               "amplitude_id": 1234567,
               "user_id": "user3"
           }],
           "mapped_to": [{
               "amplitude_id": 1234567,
               "user_id": "user2"
           }]
         },
    "user2":
        {
           "mapped_from": [{
               "amplitude_id": 9988676,
               "user_id": "user1"
           }],
           "mapped_to": []
         }
}
 
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.