API Keys
Overview
This API has been available since 1.26.0
The FusionAuth APIs are primarily secured using API keys. This API can only be accessed using an API key that has a keyManager
attribute of true
. In order to retrieve, update or delete an API key, an API key with equal or greater permissions must be used. A “tenant-scoped” API key can retrieve, create, update or delete an API key for the same tenant. This page describes APIs that are used to manage API keys.
Here’s a brief video covering the API keys API:
Please refer to the Authentication document for more details about using API keys.
The Key Manager Setting
This API can only be used by API keys with the Key manager setting enabled.
Below is an image of an API key being created in the administrative user interface with Key manager enabled:
For security purposes, the Key manager setting may be modified only using the administrative user interface or Kickstart. It can’t be changed using this API.
Create an API Key
This API is used to create a new API Key. An API key with key manager permission set to true
can create keys. An API key that is tenant scoped can create another key for the same tenant.
A key with key manager permissions can not be created using this API. Only through admin UI or kickstart can you create such a key.
Request
Request Parameters
apiKeyId
UUIDDefaults to a generated UUIDThe unique Id of the API Key to create. If not specified a secure random UUID will be generated.
Request Body
apiKey.expirationInstant
LongAvailable since 1.55.0The expiration instant of this API key. Using an expired API key for API Authentication will result in a 401 response code.
apiKey.key
StringAPI key string. When you create an API key the key is defaulted to a secure random value but the API key is simply a string, so you may call it super-secret-key
if you’d like. However a long and random value makes a good API key in that it is unique and difficult to guess.
apiKey.ipAccessControlListId
UUIDAvailable since 1.30.0The Id of the IP Access Control List limiting access to this API key.
Note: An Enterprise plan is required to utilize .
apiKey.metaData.attributes.description
StringDescription of the key.
apiKey.permissions.endpoints
ObjectEndpoint permissions for this key. Each key of the object is an endpoint, with the value being an array of the HTTP methods which can be used against the endpoint. An Empty permissions object mean that this is a super key that authorizes this key for all the endpoints.
apiKey.tenantId
StringThe unique Id of the Tenant. This value is required if the key is meant to be tenant scoped. Tenant scoped keys can only be used to access users and other tenant scoped objects for the specified tenant. This value is read-only once the key is created.
Tenant scoped keys can retrieve configuration for FusionAuth entities such as identity providers and lambdas that may be shared between tenants. Limit the API key by specifying required endpoints and permissions as well as the tenant.
Example API Key request JSON
{
"apiKey": {
"expirationInstant": 872812800000,
"key": "super-secret-key",
"ipAccessControlListId": "eae37b0e-950b-4e92-abcc-d0b310326f66",
"metaData": {
"attributes": {
"description": "my super secret key"
}
},
"permissions": {
"endpoints": {
"/api/application": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
]
}
},
"tenantId": "94f751c5-4883-4684-a817-6b106778edec"
}
}
Request Parameters
apiKeyId
UUIDDefaults to a generated UUIDThe unique Id of the API Key to create. If not specified a secure random UUID will be generated.
Request Body
sourceKeyId
UUIDrequiredThe Id of an existing API Key from which a copy will be made. The resulting key will have the same permissions of this existing key.
Note that you cannot copy a key designated as a key manager.
Example API Key request JSON
{
"sourceKeyId": "de36ce0f-70db-4d73-b0b2-9f82c1572761"
}
Response
The response for this API contains the Key that was created.
Response CodesCode | Description |
---|---|
200 | The request was successful. The response will contain a JSON body. |
400 | The request was invalid and/or malformed. The response will contain an Errors JSON Object with the specific errors. This status will also be returned if a paid FusionAuth license is required and is not present. |
401 | You did not supply a valid Authorization header. The header was omitted or your API key was not valid. The response will be empty. See Authentication. |
500 | There was an internal error. A stack trace is provided and logged in the FusionAuth log files. The response will be empty. |
Response Body
apiKey.expirationInstant
LongAvailable since 1.55.0The expiration instant of this API key. Using an expired API key for API Authentication will result in a 401 response code.
apiKey.id
UUIDThe Id of the API key.
apiKey.id
UUIDThe Id of the API key.
apiKey.insertInstant
LongThe instant when the API key was added to the FusionAuth database.
apiKey.ipAccessControlListId
UUIDAvailable since 1.30.0The Id of the IP Access Control List limiting access to this API key.
apiKey.key
StringThe API key value, this is the string value you will use in the Authorization header to authenticate API requests.
apiKey.keyManager
BooleanIndicates whether this key is a key manager. Setting this flag to true allows this key to be used to call these APIs. An attempt to call these APIs with a non-manager key (keyManager
set to false
) will always return a HTTP response status code 401.
apiKey.lastUpdateInstant
LongThe instant when the API key was last updated in the FusionAuth database.
apiKey.metaData.attributes.description
StringDescription of the key.
apiKey.permissions.endpoints
ObjectEndpoint permissions for this key. Each key of the object is an endpoint, with the value being an array of the HTTP methods which can be used against the endpoint. An empty permissions object mean that this is a super key that authorizes this key for all the endpoints.
apiKey.tenantId
StringThe unique Id of the Tenant. This value is read-only once the key is created.
Example API Key Response JSON
{
"apiKey": {
"expirationInstant": 872812800000,
"id": "de36ce0f-70db-4d73-b0b2-9f82c1572761",
"insertInstant": 1619726194060,
"ipAccessControlListId": "eae37b0e-950b-4e92-abcc-d0b310326f66",
"key": "super-secret-key",
"keyManager": false,
"lastUpdateInstant": 1619726194060,
"metaData": {
"attributes": {
"description": "my super secret key"
}
},
"permissions": {
"endpoints": {
"/api/application": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
]
}
},
"tenantId": "94f751c5-4883-4684-a817-6b106778edec"
}
}
Retrieve an API Key
This API is used to retrieve a single API Key by unique Id. To retrieve a key, an API key with equal or greater permissions must be used.
Request Parameters
apiKeyId
UUIDrequiredThe unique Id of the API Key to retrieve.
Response
The response for this API contains a single API Key. The response is defined below along with an example JSON response.
Response CodesCode | Description |
---|---|
200 | The request was successful. The response will contain a JSON body. |
400 | The request was invalid and/or malformed. The response will contain an Errors JSON Object with the specific errors. This status will also be returned if a paid FusionAuth license is required and is not present. |
401 | You did not supply a valid Authorization header. The header was omitted or your API key was not valid. The response will be empty. See Authentication. |
404 | The object you requested doesn't exist. The response will be empty. |
500 | There was an internal error. A stack trace is provided and logged in the FusionAuth log files. The response will be empty. |
Response Body
apiKey.expirationInstant
LongAvailable since 1.55.0The expiration instant of this API key. Using an expired API key for API Authentication will result in a 401 response code.
apiKey.id
UUIDThe Id of the API key.
apiKey.insertInstant
LongThe instant when the API key was added to the FusionAuth database.
apiKey.ipAccessControlListId
UUIDAvailable since 1.30.0The Id of the IP Access Control List limiting access to this API key.
apiKey.key
StringThe API key value, this is the string value you will use in the Authorization header to authenticate API requests.
apiKey.keyManager
BooleanIndicates whether this key is a key manager. Setting this flag to true allows this key to be used to call these APIs. An attempt to call these APIs with a non-manager key (keyManager
set to false
) will always return a HTTP response status code 401.
apiKey.lastUpdateInstant
LongThe instant when the API key was last updated in the FusionAuth database.
apiKey.metaData.attributes.description
StringDescription of the key.
apiKey.permissions.endpoints
ObjectEndpoint permissions for this key. Each key of the object is an endpoint, with the value being an array of the HTTP methods which can be used against the endpoint. An empty permissions object mean that this is a super key that authorizes this key for all the endpoints.
apiKey.tenantId
StringThe unique Id of the Tenant. This value is present if the key is tenant scoped. Tenant scoped keys can only be used to access users and other tenant scoped objects for the specified tenant. This value is read-only once the key is created.
Example API Key response JSON
{
"apiKey": {
"expirationInstant": 872812800000,
"id": "b016fa93-e8bc-4b79-b39f-5d37966c0178",
"insertInstant": 1619119404194,
"ipAccessControlListId": "eae37b0e-950b-4e92-abcc-d0b310326f66",
"key": "WHYugARKzum-jHvzCk5-C558EKPaYEECz5k8fDZayIaFiZHRKqy9kaQn",
"keyManager": false,
"lastUpdateInstant": 1619120513500,
"metaData": {
"attributes": {
"description": "non-manager key"
}
},
"permissions": {
"endpoints": {
"/api/application": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
],
"/api/application/oauth-configuration": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
],
"/api/application/role": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
]
}
},
"tenantId": "94f751c5-4883-4684-a817-6b106778edec"
}
}
Update an API Key
This API is used to update an existing API Key. A tenant-scoped API key can update another API key for the same tenant.
Request Parameters
apiKeyId
UUIDrequiredThe unique Id of the API Key to update.
Request Body
apiKey.expirationInstant
LongAvailable since 1.55.0The expiration instant of this API key. Using an expired API key for API Authentication will result in a 401 response code.
Note that omitting this field or providing a null value will clear the expiration instant of this API key.apiKey.key
StringAPI key string. When you create an API key the key is defaulted to a secure random value but the API key is simply a string, so you may call it super-secret-key
if you’d like. However a long and random value makes a good API key in that it is unique and difficult to guess.
apiKey.ipAccessControlListId
UUIDAvailable since 1.30.0The Id of the IP Access Control List limiting access to this API key.
Note: An Enterprise plan is required to utilize .
apiKey.metaData.attributes.description
StringDescription of the key.
apiKey.permissions.endpoints
ObjectEndpoint permissions for this key. Each key of the object is an endpoint, with the value being an array of the HTTP methods which can be used against the endpoint. An Empty permissions object mean that this is a super key that authorizes this key for all the endpoints.
apiKey.tenantId
StringThe unique Id of the Tenant. This value is required if the key is meant to be tenant scoped. Tenant scoped keys can only be used to access users and other tenant scoped objects for the specified tenant. This value is read-only once the key is created.
Tenant scoped keys can retrieve configuration for FusionAuth entities such as identity providers and lambdas that may be shared between tenants. Limit the API key by specifying required endpoints and permissions as well as the tenant.
Example API Key request JSON
{
"apiKey": {
"expirationInstant": 1878422400000,
"ipAccessControlListId": "eae37b0e-950b-4e92-abcc-d0b310326f66",
"metaData": {
"attributes": {
"description": "updating the key"
}
},
"permissions": {
"endpoints": {
"/api/application": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
]
}
}
}
}
Response
The response for this API contains the Key that was updated.
Response CodesCode | Description |
---|---|
200 | The request was successful. The response will contain a JSON body. |
400 | The request was invalid and/or malformed. The response will contain an Errors JSON Object with the specific errors. This status will also be returned if a paid FusionAuth license is required and is not present. |
401 | You did not supply a valid Authorization header. The header was omitted or your API key was not valid. The response will be empty. See Authentication. |
404 | The object you are trying to update doesn't exist. The response will be empty. |
500 | There was an internal error. A stack trace is provided and logged in the FusionAuth log files. The response will be empty. |
Response Body
apiKey.expirationInstant
LongAvailable since 1.55.0The expiration instant of this API key. Using an expired API key for API Authentication will result in a 401 response code.
apiKey.id
UUIDThe Id of the API key.
apiKey.id
UUIDThe Id of the API key.
apiKey.insertInstant
LongThe instant when the API key was added to the FusionAuth database.
apiKey.ipAccessControlListId
UUIDAvailable since 1.30.0The Id of the IP Access Control List limiting access to this API key.
apiKey.key
StringThe API key value, this is the string value you will use in the Authorization header to authenticate API requests.
apiKey.keyManager
BooleanIndicates whether this key is a key manager. Setting this flag to true allows this key to be used to call these APIs. An attempt to call these APIs with a non-manager key (keyManager
set to false
) will always return a HTTP response status code 401.
apiKey.lastUpdateInstant
LongThe instant when the API key was last updated in the FusionAuth database.
apiKey.metaData.attributes.description
StringDescription of the key.
apiKey.permissions.endpoints
ObjectEndpoint permissions for this key. Each key of the object is an endpoint, with the value being an array of the HTTP methods which can be used against the endpoint. An empty permissions object mean that this is a super key that authorizes this key for all the endpoints.
apiKey.tenantId
StringThe unique Id of the Tenant. This value is read-only once the key is created.
Example API Key Response JSON
{
"apiKey": {
"expirationInstant": 1878422400000,
"id": "b016fa93-e8bc-4b79-b39f-5d37966c0178",
"insertInstant": 1619119404194,
"ipAccessControlListId": "eae37b0e-950b-4e92-abcc-d0b310326f66",
"key": "WHYugARKzum-jHvzCk5-C558EKPaYEECz5k8fDZayIaFiZHRKqy9kaQn",
"keyManager": false,
"lastUpdateInstant": 1619121061858,
"metaData": {
"attributes": {
"description": "updating the key"
}
},
"permissions": {
"endpoints": {
"/api/application": [
"DELETE",
"POST",
"GET",
"PUT",
"PATCH"
]
}
},
"tenantId": "94f751c5-4883-4684-a817-6b106778edec"
}
}
Delete an API Key
This API is used to delete a Key. Deletion is possible only with another API key with equal or greater permissions. A tenant-scoped API key can delete another API key for the same tenant.
Request Parameters
apiKeyId
UUIDrequiredThe unique Id of the API Key to delete.
Response
This API does not return a JSON response body.
Response CodesCode | Description |
---|---|
200 | The request was successful. |
400 | The request was invalid and/or malformed. The response will contain an Errors JSON Object with the specific errors. This status will also be returned if a paid FusionAuth license is required and is not present. |
401 | You did not supply a valid Authorization header. The header was omitted or your API key was not valid. The response will be empty. See Authentication. |
404 | The object you requested doesn't exist. The response will be empty. |
500 | There was an internal error. A stack trace is provided and logged in the FusionAuth log files. The response will be empty. |