Datastores
Datastores define a destination for data loaded into a workspace by pipelines. The default datastore for a workspace is its own PostgreSQL database hosted by Matatika, but this can be changed at any time to another datastore with your own credentials (see our supported dataplugins of type LOADER
).
Objects
Datastore
Path | Type | Format | Description |
---|---|---|---|
id |
String |
Version 4 UUID | The datastore ID |
created |
String |
ISO 8601 timestamp | The instant at which the datastore was created |
lastModified |
String |
ISO 8601 timestamp | The instant at which the datastore was last modified |
name |
String |
The datastore name | |
dataPlugin |
String |
Create / update with dataplugin fullyQualifiedName |
|
workspace |
String |
Version 4 UUID | The datastore workspace id |
jdbcUrl |
String |
JDBC URL | The datastore JDBC URL |
properties |
Properties |
The datastore properties |
Properties
For each setting s
in the dataplugin settings
:
Path | Type | Description |
---|---|---|
s.name |
s.kind |
Refer to s.description |
Requests
- View all datastores in a workspace
- View a datastore
- Set a datastore as the workspace default
- Initialise a new datastore in a workspace
- Create or update a datastore in a workspace
- Delete a datastore
View all datastores in a workspace
GET
/api/workspaces/{workspace-id}/datastores
Returns the datastores in the workspace {workspace-id}
.
Prerequisites
- Workspace
{workspace-id}
must exist
Request
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores' -i -X GET \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json'
Python (requests
)
import requests
url = "https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("GET", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
Datastore collection with HAL links.
{
"_embedded" : {
"datastores" : [ {
"id" : "a13753dd-e57a-4135-a1bb-24fe7f689bc0",
"created" : "2025-01-17T16:58:03.177216",
"lastModified" : "2025-01-17T16:58:03.177217",
"name" : "Warehouse",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"dbname" : "idjhevm",
"default_target_schema" : "analytics",
"port" : "5432",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm"
},
"commands" : { },
"dataPlugin" : "loaders/target-postgres--matatika",
"logoUrl" : "/assets/logos/loaders/postgres.png",
"workspace" : "5f77d82f-8802-41f0-bad8-2e7a79f37adb",
"jdbcUrl" : "jdbc:postgresql://sharp-banana.postgres.database.azure.com:5432/idjhevm",
"sqlAlchemyUrl" : "postgresql://idjhevm:NLm8T4tR_Vw02vcF5_XB0q7Ghw@sharp-banana.postgres.database.azure.com:5432/idjhevm?options=-csearch_path%3Dpublic",
"managed" : true,
"draft" : false,
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/datastores/a13753dd-e57a-4135-a1bb-24fe7f689bc0"
},
"dataplugin" : {
"href" : "https://app.matatika.com/api/dataplugins/7af26f1c-b05e-4286-8816-5f3799deab63"
}
}
} ]
},
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores?page=0&size=20"
}
},
"page" : {
"size" : 20,
"totalElements" : 1,
"totalPages" : 1,
"number" : 0
}
}
View a datastore
GET
/api/datastores/{datastore-id}
Returns the datastore {datastore-id}
.
Prerequisites
- Datastore
{datastore-id}
must exist
Request
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7' -i -X GET \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json'
Python (requests
)
import requests
url = "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("GET", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
Datastore with HAL links.
{
"id" : "2df14c2d-f3cc-456a-9c3f-7b7853419eb7",
"created" : "2025-01-17T16:58:09.745479",
"lastModified" : "2025-01-17T16:58:11.11937",
"name" : "Test datastore (updated)",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"default_target_schema" : "analytics",
"dbname" : "idjhevm",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm"
},
"commands" : { },
"dataPlugin" : "loaders/target-postgres--matatika",
"logoUrl" : "/assets/logos/loaders/postgres.png",
"workspace" : "5f77d82f-8802-41f0-bad8-2e7a79f37adb",
"jdbcUrl" : "jdbc:postgresql://sharp-banana.postgres.database.azure.com:5432/idjhevm",
"sqlAlchemyUrl" : "postgresql://idjhevm:NLm8T4tR_Vw02vcF5_XB0q7Ghw@sharp-banana.postgres.database.azure.com:5432/idjhevm?options=-csearch_path%3Dpublic",
"managed" : false,
"draft" : false,
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"update datastore" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"delete datastore" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"make-default" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7/default"
},
"dataplugin" : {
"href" : "https://app.matatika.com/api/dataplugins/7af26f1c-b05e-4286-8816-5f3799deab63"
}
}
}
Set a datastore as the workspace default
PUT
/api/datastores/{datastore-id}/default
Sets the datastore {datastore-id}
as the workspace default.
Prerequisites
- Datastore
{datastore-id}
must exist
Request
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7/default' -i -X PUT \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json'
Python (requests
)
import requests
url = "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7/default"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("PUT", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
No response body provided.
Initialise a new datastore in a workspace
POST
/api/workspaces/{workspace-id}/datastores
Initialises a new datastore in the workspace {workspace-id}
.
Prerequisites
- Workspace
{workspace-id}
must exist
Request
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores' -i -X POST \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json'
Python (requests
)
import requests
url = "https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("POST", url, headers=headers)
print(response.text.encode('utf8'))
Response
200 OK
Datastore with HAL links.
{
"id" : "2df14c2d-f3cc-456a-9c3f-7b7853419eb7",
"created" : "2025-01-17T16:58:09.53862604",
"lastModified" : "2025-01-17T16:58:09.53862654",
"properties" : { },
"commands" : { },
"workspace" : "5f77d82f-8802-41f0-bad8-2e7a79f37adb",
"managed" : false,
"draft" : false,
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"create datastore" : {
"href" : "https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
}
}
}
Create or update a datastore in a workspace
PUT
/api/workspaces/{workspace-id}/datastores/{datastore-id}
Creates or updates the datastore {datastore-id}
in the workspace {workspace-id}
.
Prerequisites
- Workspace
{workspace-id}
must exist
Request
Body
Datastore resource.
{
"name" : "Test datastore",
"dataPlugin" : "loaders/target-postgres",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm",
"default_target_schema" : "analytics",
"dbname" : "idjhevm"
}
}
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7' -i -X PUT \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json' \
-d '{
"name" : "Test datastore",
"dataPlugin" : "loaders/target-postgres",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm",
"default_target_schema" : "analytics",
"dbname" : "idjhevm"
}
}'
Python (requests
)
import requests
url = "https://app.matatika.com/api/workspaces/5f77d82f-8802-41f0-bad8-2e7a79f37adb/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
data = {
"name" : "Test datastore",
"dataPlugin" : "loaders/target-postgres",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm",
"default_target_schema" : "analytics",
"dbname" : "idjhevm"
}
}
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("PUT", url, headers=headers, data=data)
print(response.text.encode('utf8'))
Response
200 OK / 201 Created
Datastore with HAL links.
{
"id" : "2df14c2d-f3cc-456a-9c3f-7b7853419eb7",
"created" : "2025-01-17T16:58:09.745478946",
"lastModified" : "2025-01-17T16:58:09.745479746",
"name" : "Test datastore",
"properties" : {
"password" : "NLm8T4tR_Vw02vcF5_XB0q7Ghw",
"host" : "sharp-banana.postgres.database.azure.com",
"user" : "idjhevm",
"default_target_schema" : "analytics",
"dbname" : "idjhevm"
},
"commands" : { },
"dataPlugin" : "loaders/target-postgres--matatika",
"logoUrl" : "/assets/logos/loaders/postgres.png",
"workspace" : "5f77d82f-8802-41f0-bad8-2e7a79f37adb",
"jdbcUrl" : "jdbc:postgresql://sharp-banana.postgres.database.azure.com:5432/idjhevm",
"sqlAlchemyUrl" : "postgresql://idjhevm:NLm8T4tR_Vw02vcF5_XB0q7Ghw@sharp-banana.postgres.database.azure.com:5432/idjhevm?options=-csearch_path%3Dpublic",
"managed" : false,
"draft" : false,
"_links" : {
"self" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"update datastore" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"delete datastore" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
},
"make-default" : {
"href" : "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7/default"
},
"dataplugin" : {
"href" : "https://app.matatika.com/api/dataplugins/7af26f1c-b05e-4286-8816-5f3799deab63"
}
}
}
Delete a datastore
DELETE
/api/datastores/{datastore-id}
Deletes the datastore {datastore-id}
.
Prerequisites
- Datastore
{datastore-id}
must exist
Request
Example Snippets
cURL
curl -H "Authorization: Bearer $ACCESS_TOKEN" 'https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7' -i -X DELETE \
-H 'Accept: application/json, application/javascript, text/javascript, text/json' \
-H 'Content-Type: application/json'
Python (requests
)
import requests
url = "https://app.matatika.com/api/datastores/2df14c2d-f3cc-456a-9c3f-7b7853419eb7"
headers = {
'Authorization': ACCESS_TOKEN
}
response = requests.request("DELETE", url, headers=headers)
print(response.text.encode('utf8'))
Response
204 No Content
No response body provided.