API Keys
API keys offer an alternate method of authentication to the Meltano Cloud API using a client ID and secret.
Objects
API Key
| Path | JSON Type | Format | Description |
|---|---|---|---|
id | string | Version 4 UUID | The API key ID |
created | string | ISO 8601 timestamp | The instant when the API key was created |
lastModified | string | ISO 8601 timestamp | The instant when the API key was last modified |
name | string | The API key name | |
clientId | string | The API key client ID | |
profileId | string | The API key owner profile ID |
{
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.285718",
"lastModified" : "2026-06-10T07:06:21.285718",
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)",
"clientId" : "ujgEZzEFlgkoCm5mgYURq69eYlC99Wow",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
}
Requests
View all API keys
GET /api/apikeys
Returns all API keys owned by the authenticated user profile.
Prerequisites
- The authenticated user must own a Meltano Cloud account
- The API key
{apikey-id}must exist
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys' -i -X GET
import requests
url = "https://app.matatika.com/api/apikeys"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("GET", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
API key collection with HAL links.
{
"_embedded" : {
"apikeys" : [ {
"id" : "5a39750c-e0a8-45ca-8626-2c4e88707f8e",
"created" : "2026-06-10T07:06:17.917971",
"lastModified" : "2026-06-10T07:06:17.917972",
"name" : "default",
"clientId" : "egQpD6EjFA8oOXEA9HUsQcE1549NJFry",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"accessToken" : "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6IlJFRkNRamczTlRRMk16QTROalpHT0RjNFFUWkJOemMyTkRGR1FUSkVOVEEyUkRkR1JrSkRPQSJ9.eyJpc3MiOiJodHRwczovL2lkZW50aXR5Lm1hdGF0aWthLmNvbS8iLCJzdWIiOiJlZ1FwRDZFakZBOG9PWEVBOUhVc1FjRTE1NDlOSkZyeUBjbGllbnRzIiwiYXVkIjoiaHR0cHM6Ly9hcHAubWF0YXRpa2EuY29tL2FwaSIsImlhdCI6MTc4MTA3NTE3OCwiZXhwIjoxNzgxMTYxNTc4LCJndHkiOiJjbGllbnQtY3JlZGVudGlhbHMiLCJhenAiOiJlZ1FwRDZFakZBOG9PWEVBOUhVc1FjRTE1NDlOSkZyeSJ9.s3aKMLjGYaTbrdZ34fEjJkUZzA5CDPu6W90tQ_k0R5r5GOoOQcqP82_UnziSvn7S8x5vdzDCADiPs6N60sesXcS7tsYi_PglAofAAbvRa90AJd-mjOFfFzXrHZG46N3MTuXWe9Pnic4AFn8UmJ2uwlM3bryg9qWZ5L7Gy2blCr1NjM6iHTDppQkpVk1EKise2jx7lfa7myZ7-R-Jjz5Gc8-T2uZnQ2kk8pclBp-YPNnN6k8ULhhUi6VUY-FBfGQ0eRfA9lAdnXGWpVPL3Cqd-ixmSv_S6iLdyvK8MS8nssnCvemD1uoe3P4bkKR5S2ysIFputA8lPIOo-avoRH0rmw",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/5a39750c-e0a8-45ca-8626-2c4e88707f8e"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/5a39750c-e0a8-45ca-8626-2c4e88707f8e"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/5a39750c-e0a8-45ca-8626-2c4e88707f8e"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
}, {
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.285718",
"lastModified" : "2026-06-10T07:06:21.285718",
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)",
"clientId" : "ujgEZzEFlgkoCm5mgYURq69eYlC99Wow",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
} ]
},
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys?page=0&size=20"
}
},
"page" : {
"size" : 20,
"totalElements" : 2,
"totalPages" : 1,
"number" : 0
}
}
View an API key
GET /api/apikeys/{apikey-id}
Returns the API key {apikey-id}.
Prerequisites
- The authenticated user must own a Meltano Cloud account
- The API key
{apikey-id}must exist
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3' -i -X GET
import requests
url = "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("GET", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
API key with HAL links.
{
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.285718",
"lastModified" : "2026-06-10T07:06:21.285718",
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)",
"clientId" : "ujgEZzEFlgkoCm5mgYURq69eYlC99Wow",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
}
Initialise an API key
POST /api/apikeys
Initialises a new API key.
Prerequisites
- The authenticated user must own a Meltano Cloud account
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys' -i -X POST \
-H 'Content-Type: application/json'
import requests
url = "https://app.matatika.com/api/apikeys"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("POST", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
API key with HAL links.
{
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.219662491",
"lastModified" : "2026-06-10T07:06:21.219662856",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"create apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
}
}
}
Create an API key
PUT /api/apikeys/{apikey-id}
Creates the API key {apikey-id}.
Prerequisites
- The authenticated user must own a Meltano Cloud account
Body
API key resource.
{
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)"
}
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3' -i -X PUT \
-H 'Content-Type: application/json' \
-d '{
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)"
}'
import requests
url = "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
data = {
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)"
}
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("PUT", url, headers=headers, data=data)
print(response.text.encode('utf8'))
Response
201 Created
API key with HAL links.
{
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.285717813",
"lastModified" : "2026-06-10T07:06:21.285718144",
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573)",
"clientId" : "ujgEZzEFlgkoCm5mgYURq69eYlC99Wow",
"clientSecret" : "1xSxlXgoUkBUvk9gi0CFZqMogJ76gKYm5A4Ip1krYEgdb1KJZ0rjtZZ7tay50vlT",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
}
Update an API key
PUT /api/apikeys/{apikey-id}
Updates the API key {apikey-id}.
Prerequisites
- The authenticated user must own a Meltano Cloud account
Body
API key resource.
{
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573) (updated)"
}
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3' -i -X PUT \
-H 'Content-Type: application/json' \
-d '{
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573) (updated)"
}'
import requests
url = "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
data = {
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573) (updated)"
}
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("PUT", url, headers=headers, data=data)
print(response.text.encode('utf8'))
Response
200 OK
API key with HAL links.
{
"id" : "00a0e0c8-d37a-4e9e-b896-074fc498eeb3",
"created" : "2026-06-10T07:06:21.285718",
"lastModified" : "2026-06-10T07:06:22.54975249",
"name" : "SIT-generated api key (2026-06-10T07:06:21.243220573) (updated)",
"clientId" : "ujgEZzEFlgkoCm5mgYURq69eYlC99Wow",
"profileId" : "auth0|6a21dc7aa1db2e036a222942",
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"update apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"delete apikey" : {
"href" : "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
},
"profile" : {
"href" : "https://app.matatika.com/api/profiles/auth0%7C6a21dc7aa1db2e036a222942"
}
}
}
Delete an API key
DELETE /api/apikeys/{apikey-id}
Deletes the API key {apikey-id}.
Prerequisites
- The authenticated user must own a Meltano Cloud account
- The API key
{apikey-id}must exist
Examples
- cURL
- Python (requests)
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3' -i -X DELETE
import requests
url = "https://app.matatika.com/api/apikeys/00a0e0c8-d37a-4e9e-b896-074fc498eeb3"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("DELETE", url, headers=headers)
print(response.text.encode('utf8'))
Response
204 No Content
No response body provided.