Authenticate to the Buy with Prime API
Important
The Buy with Prime API is offered as a preview and might change as we receive feedback and iterate on the interfaces. We are sharing this early documentation to help you learn about the Buy with Prime API as we write and iterate on the content.
When you make a request to the Buy with Prime GraphQL API, you must provide an access token in the header of the request. To get an access token, you first get your API credentials from the Buy with Prime merchant console. You then exchange your API credentials for an access token by making a POST request to a Buy with Prime token endpoint.
This topic explains how to get your API credentials and how to use your API credentials to get an access token. After you get an access token, you use the access token to call the Buy with Prime GraphQL API. For details, see Call the Buy with Prime API.
Terminology
Access token
Buy with Prime uses the OAuth 2.0 authentication framework. In OAuth 2.0, an access token signifies that a resource owner has given a client permission to perform a list of operations on a set of resources. In this case, the resource owner is Buy with Prime, the operations are the Buy with Prime APIs, the client is your website, and the resources are information such as orders, delivery previews, and so on.
In Generate API credentials, you create a set of long-lived credentials that you use to generate an access token. An access token is a set of short-lived credentials. You use the access token to call the Buy with Prime API. For more details on how OAuth works, see the OAuth 2.0 documentation.
Buy with Prime access tokens expire every 15 minutes. After your access token expires, you can request a new access token by using the same client permissions.
API credentials
You use API credentials to get the access token that you use to call the Buy with Prime API. API credentials are a set of information that contains following elements, which you can download from the Buy with Prime merchant console:
- Client ID: This ID identifies your API client to Buy with Prime.
- Client secret: This secret authenticates your API client to Buy with Prime. It is a secret that only you and your application know.
- Target ID: The Buy with Prime account that the API credentials have access to.
- Permissions: A list of the types of site data that the API credentials have access to. For example, API credentials might provide access to view a delivery preview for a store.
Amazon identity token
Some Buy With Prime APIs optionally take (or require) a shopper's Amazon identity token. The identity token enables APIs to vend data related to the shopper, such as the shopper's location. For example, you can provide a more accurate delivery preview if you provide the optional IdentityTokenInput
field.
Buy with Prime currently supports the following types of shopper identity tokens:
-
Login with Amazon (LWA) access token: Login with Amazon is a user authentication system based on OAuth 2.0. For details about LWA, see the LWA documentation. For details about access tokens, see Login with Amazon Access Tokens. The following code shows an example
IdentityTokenInput
from LWA.{ lwaAccessToken: { value: "EXAMPLE_LWA_ACCESS_TOKEN", externalId: "EXAMPLE_EXTERNAL_ID" } }
-
Amazon Pay checkout session token: An Amazon Pay checkout session represents a single active session for a shopper on your website. Every checkout session has a session ID. You can use the session ID as the shopper identity token for Buy with Prime. For details about Amazon Pay, see Introduction to Amazon Pay. For details about checkout sessions, see Checkout Session. The following code shows an example
IdentityTokenInput
from an Amazon Pay checkout session.{ apayCheckoutSessionId: { value: "EXAMPLE_CHECKOUT_SESSION_ID", externalId: "EXAMPLE_EXTERNAL_ID" } }
The externalId
field should represent a unique property about the shopper's session on your website. It could be the shopper's sessionId
, the shopper's userId
, and so on.
Generate API credentials
You generate your API credentials by using the Buy with Prime merchant console.
To generate API credentials by using the merchant console
-
Sign in to the Buy with Prime merchant console as an owner/admin.
-
On the left, click Settings.
-
Under Settings, click API credentials.
-
Click Generate credentials.
-
For Credentials name, enter a name that helps you identify the purpose of the credentials.
-
Choose the permissions that you want the API credentials to have. You can choose Full Access or Custom. We recommend that you adhere to the principle of least privilege and choose granular access depending on the functionality that you are building using the API credentials.
- Full access: Allows edit and view access to all the listed permissions. Choosing this option automatically chooses all APIs in the list and automatically includes access to any future Buy with Prime APIs.
- Custom: Allows you to select permissions from a list. If you choose this option, you must manually choose the specific APIs that you need.
-
Click Generate.
Buy with Prime generates your API credentials and then takes you to a page where you can download a file that contains the credentials. The file contains a client ID, client secret, target ID, and a list of permissions that the credentials have access to. -
Download the credentials file to your computer.
You must download the credentials file and save it securely. If you navigate away without downloading the credentials, you will not be able to download the credentials later.
-
Locate and open the downloaded credentials file on your computer.
The file has the name that you chose for the credentials. The file looks like the following image, which contains fictitious data.
Use API credentials to get an access token
After you get your API credentials, you use the API credentials to request a Buy with Prime access token. You then use the access token to call the Buy with Prime API.
To get an access token for the Buy with Prime API
-
Make an HTTPS POST request to
https://api.buywithprime.amazon.com/token
with the following fields in the body of the request.Request Fields
Field Description Required? client_id
The client ID of the API credentials that you downloaded in Generate API credentials. Yes client_secret
The client secret of the API credentials that you downloaded in Generate API credentials. Yes grant_type
OAuth 2.0 grant type. Use client_credentials
.Yes Example Request
In the following example request, replace the following placeholders:
EXAMPLE_CLIENT_ID
with theclient_id
from the API credentials that you downloadedEXAMPLE_CLIENT_SECRET
with theclient_secret
from the API credentials that you downloaded
POST /token HTTP/1.1 Host: api.buywithprime.amazon.com Content-Type: application/x-www-form-urlencoded x-api-version: $api_version client_id=EXAMPLE_CLIENT_ID&client_secret=EXAMPLE_CLIENT_SECRET&grant_type=client_credentials
curl --location --request POST 'https://api.buywithprime.amazon.com/token' \ --header 'Content-Type: application/x-www-form-urlencoded' \ --header 'x-api-version: $api_version' \ --data-urlencode 'client_id=EXAMPLE_CLIENT_ID' \ --data-urlencode 'client_secret=EXAMPLE_CLIENT_SECRET' \ --data-urlencode 'grant_type=client_credentials'
import requests url = "https://api.buywithprime.amazon.com/token" payload='client_id=EXAMPLE_CLIENT_ID&client_secret=EXAMPLE_CLIENT_SECRET&grant_type=client_credentials' headers = { 'Content-Type': 'application/x-www-form-urlencoded', 'x-api-version': '$api_version' } response = requests.request("POST", url, headers=headers, data=payload) print(response.text)
const url = "https://api.buywithprime.amazon.com/token"; const headers = { "Content-Type": "application/x-www-form-urlencoded", "x-api-version": "$api_version" }; const payload="client_id=EXAMPLE_CLIENT_ID&client_secret=EXAMPLE_CLIENT_SECRET&grant_type=client_credentials"; fetch(url, { method: "POST", headers: headers, body: payload }).then(response => { return response.json(); }).then(json => { console.log(json); });
-
Get the access token from the response, which contains the following fields.
Example Successful Response
{ "access_token": "EXAMPLE_BUY_WITH_PRIME_ACCESS_TOKEN", "expires_in": 885 }
Successful Response Fields
Field Description access_token
Token that you use to access the Buy with Prime API. expires_in
Time until the token expires, in seconds. Example Failed Response (HTTP 400)
{ "message": "Content type is null or invalid. Ensure content type is: application/x-www-form-urlencoded", "code": "InvalidContentType", "type": "ValidationError" }
Failed Response Fields
Field Description message
Description of the cause of the error. code
(Only present for HTTP 400 InvalidParameterException
responses.) Code that further describes the cause of the HTTP 400 error. For a list of possible codes, see the table in the following section.type
The exception type thrown by the service. Examples: ValidationError
orAccessDeniedError
.Error Codes
HTTP Status Code Error Type Error Code Description 400 ValidationError
InvalidContentType
The Content-Type
field in the request is missing or invalid. TheContent-Type
field must beapplication/x-www-form-urlencoded
.400 ValidationError
NonDeserializableContent
The request payload isn't in a format that the server can interpret. 400 ValidationError
InvalidClientId
The request payload doesn't contain a client_id
field, or the specifiedclient_id
is incomplete, malformed, or invalid.400 ValidationError
InvalidClientSecret
The request payload doesn't contain a client_secret
field, or the specifiedclient_secret
is incomplete, malformed, or invalid.400 ValidationError
InvalidGrantType
The request payload doesn't contain a grant_type
field, or the specifiedgrant_type
is incomplete, malformed, or invalid. Thegrant_type
must beclient_credentials
.401 AccessDeniedError
N/A The requested payload doesn't have permission to receive an access token. 429 ThrottlingError
N/A The request was throttled by the service. Requests are throttled after a limit of 12 requests per second per client_id
is reached.500 InternalServerError
N/A An internal error occurred. Try again.
Now that you have a Buy with Prime access token, you can call the Buy with Prime API. For details, see How to Call the Buy with Prime API.
Related topics
Updated 4 days ago