Scroll down for code samples, example requests and responses.
This is the microservice responsible to coordinate all the provisioning tasks for managing a data product
All the provisioning related operations
Shell
# You can also use wget
curl -X POST /datamesh.airbytespecificprovisioner/{{version}}/provision \
-H 'Content-Type: application/json' \
-H 'Accept: application/json'
JavaScript
const inputBody = '{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}';
const headers = {
'Content-Type':'application/json',
'Accept':'application/json'
};
fetch('/datamesh.airbytespecificprovisioner/{{version}}/provision',
{
method: 'POST',
body: inputBody,
headers: headers
})
.then(function(res) {
return res.json();
}).then(function(body) {
console.log(body);
});
Java
URL obj = new URL("/datamesh.airbytespecificprovisioner/{{version}}/provision");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
Python
import requests
headers = {
'Content-Type': 'application/json',
'Accept': 'application/json'
}
r = requests.post('/datamesh.airbytespecificprovisioner/{{version}}/provision', headers = headers)
print(r.json())
POST /provision
Deploy a data product starting from its descriptor
Body parameter
{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | ProvisioningRequest | true | A provisioning request descriptor wrapped as a string into a simple object |
» descriptorKind | body | DescriptorKind | true | none |
» descriptor | body | string | true | A provisioning request in yaml format |
Parameter | Value |
---|---|
» descriptorKind | DATAPRODUCT_DESCRIPTOR |
» descriptorKind | COMPONENT_DESCRIPTOR |
» descriptorKind | DATAPRODUCT_DESCRIPTOR_WITH_RESULTS |
Example responses
200 Response
{
"status": "RUNNING",
"result": "string"
}
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | It synchronously returns the request result | ProvisioningStatus |
202 | Accepted | If successful returns a provisioning deployment task token that can be used for polling the request status | string |
400 | Bad Request | Invalid input | ValidationError |
500 | Internal Server Error | System problem | SystemError |
Shell
# You can also use wget
curl -X GET /datamesh.airbytespecificprovisioner/{{version}}/provision/{token}/status \
-H 'Accept: application/json'
JavaScript
const headers = {
'Accept':'application/json'
};
fetch('/datamesh.airbytespecificprovisioner/{{version}}/provision/{token}/status',
{
method: 'GET',
headers: headers
})
.then(function(res) {
return res.json();
}).then(function(body) {
console.log(body);
});
Java
URL obj = new URL("/datamesh.airbytespecificprovisioner/{{version}}/provision/{token}/status");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
Python
import requests
headers = {
'Accept': 'application/json'
}
r = requests.get('/datamesh.airbytespecificprovisioner/{{version}}/provision/{token}/status', headers = headers)
print(r.json())
GET /provision/{token}/status
Get the status for a provisioning request
Name | In | Type | Required | Description |
---|---|---|---|---|
token | path | string | true | token that identifies the request |
Example responses
200 Response
{
"status": "RUNNING",
"result": "string"
}
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request status | ProvisioningStatus |
400 | Bad Request | Invalid input | ValidationError |
500 | Internal Server Error | System problem | SystemError |
Shell
# You can also use wget
curl -X POST /datamesh.airbytespecificprovisioner/{{version}}/validate \
-H 'Content-Type: application/json' \
-H 'Accept: application/json'
JavaScript
const inputBody = '{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}';
const headers = {
'Content-Type':'application/json',
'Accept':'application/json'
};
fetch('/datamesh.airbytespecificprovisioner/{{version}}/validate',
{
method: 'POST',
body: inputBody,
headers: headers
})
.then(function(res) {
return res.json();
}).then(function(body) {
console.log(body);
});
Java
URL obj = new URL("/datamesh.airbytespecificprovisioner/{{version}}/validate");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
Python
import requests
headers = {
'Content-Type': 'application/json',
'Accept': 'application/json'
}
r = requests.post('/datamesh.airbytespecificprovisioner/{{version}}/validate', headers = headers)
print(r.json())
POST /validate
Validate a provisioning request
Body parameter
{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | ProvisioningRequest | true | A provisioning request descriptor wrapped as a string into a simple object |
» descriptorKind | body | DescriptorKind | true | none |
» descriptor | body | string | true | A provisioning request in yaml format |
Parameter | Value |
---|---|
» descriptorKind | DATAPRODUCT_DESCRIPTOR |
» descriptorKind | COMPONENT_DESCRIPTOR |
» descriptorKind | DATAPRODUCT_DESCRIPTOR_WITH_RESULTS |
Example responses
200 Response
{
"valid": true,
"error": {
"errors": [
"string"
]
}
}
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | It synchronously returns a specific reply containing the validation result | ValidationResult |
500 | Internal Server Error | System problem | SystemError |
Shell
# You can also use wget
curl -X POST /datamesh.airbytespecificprovisioner/{{version}}/unprovision \
-H 'Content-Type: application/json' \
-H 'Accept: application/json'
JavaScript
const inputBody = '{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}';
const headers = {
'Content-Type':'application/json',
'Accept':'application/json'
};
fetch('/datamesh.airbytespecificprovisioner/{{version}}/unprovision',
{
method: 'POST',
body: inputBody,
headers: headers
})
.then(function(res) {
return res.json();
}).then(function(body) {
console.log(body);
});
Java
URL obj = new URL("/datamesh.airbytespecificprovisioner/{{version}}/unprovision");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
Python
import requests
headers = {
'Content-Type': 'application/json',
'Accept': 'application/json'
}
r = requests.post('/datamesh.airbytespecificprovisioner/{{version}}/unprovision', headers = headers)
print(r.json())
POST /unprovision
Undeploy a data product starting from its descriptor
Body parameter
{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | ProvisioningRequest | true | A provisioning request descriptor wrapped as a string into a simple object |
» descriptorKind | body | DescriptorKind | true | none |
» descriptor | body | string | true | A provisioning request in yaml format |
Parameter | Value |
---|---|
» descriptorKind | DATAPRODUCT_DESCRIPTOR |
» descriptorKind | COMPONENT_DESCRIPTOR |
» descriptorKind | DATAPRODUCT_DESCRIPTOR_WITH_RESULTS |
Example responses
200 Response
{
"status": "RUNNING",
"result": "string"
}
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | It synchronously returns the request result | ProvisioningStatus |
202 | Accepted | If successful returns a provisioning deployment task token that can be used for polling the request status | string |
400 | Bad Request | Invalid input | ValidationError |
500 | Internal Server Error | System problem | SystemError |
Shell
# You can also use wget
curl -X POST /datamesh.airbytespecificprovisioner/{{version}}/updateacl \
-H 'Content-Type: application/json' \
-H 'Accept: application/json'
JavaScript
const inputBody = '{
"acl": {
"users": [
"string"
],
"groups": [
"string"
]
},
"provisionInfo": {
"request": "string",
"result": "string"
}
}';
const headers = {
'Content-Type':'application/json',
'Accept':'application/json'
};
fetch('/datamesh.airbytespecificprovisioner/{{version}}/updateacl',
{
method: 'POST',
body: inputBody,
headers: headers
})
.then(function(res) {
return res.json();
}).then(function(body) {
console.log(body);
});
Java
URL obj = new URL("/datamesh.airbytespecificprovisioner/{{version}}/updateacl");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
System.out.println(response.toString());
Python
import requests
headers = {
'Content-Type': 'application/json',
'Accept': 'application/json'
}
r = requests.post('/datamesh.airbytespecificprovisioner/{{version}}/updateacl', headers = headers)
print(r.json())
POST /updateacl
Request the access to a specific provisioner component
Body parameter
{
"acl": {
"users": [
"string"
],
"groups": [
"string"
]
},
"provisionInfo": {
"request": "string",
"result": "string"
}
}
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | UpdateAclRequest | true | An access request object |
» acl | body | Acl | true | none |
»» users | body | [string] | true | none |
»» groups | body | [string] | true | none |
» provisionInfo | body | ProvisionInfo | true | none |
»» request | body | string | true | none |
»» result | body | string | false | none |
Example responses
200 Response
{
"status": "RUNNING",
"result": "string"
}
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | It synchronously returns the access request response | ProvisioningStatus |
202 | Accepted | It synchronously returns the access request response | string |
400 | Bad Request | Invalid input | ValidationError |
500 | Internal Server Error | System problem | SystemError |
{
"acl": {
"users": [
"string"
],
"groups": [
"string"
]
},
"provisionInfo": {
"request": "string",
"result": "string"
}
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
acl | Acl | true | none | none |
provisionInfo | ProvisionInfo | true | none | none |
"DATAPRODUCT_DESCRIPTOR"
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
anonymous | string | false | none | none |
Property | Value |
---|---|
anonymous | DATAPRODUCT_DESCRIPTOR |
anonymous | COMPONENT_DESCRIPTOR |
anonymous | DATAPRODUCT_DESCRIPTOR_WITH_RESULTS |
{
"descriptorKind": "DATAPRODUCT_DESCRIPTOR",
"descriptor": "string"
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
descriptorKind | DescriptorKind | true | none | none |
descriptor | string | true | none | A provisioning request in yaml format |
{
"status": "RUNNING",
"result": "string"
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
status | string | true | none | none |
result | string | false | none | none |
Property | Value |
---|---|
status | RUNNING |
status | COMPLETED |
status | FAILED |
{
"valid": true,
"error": {
"errors": [
"string"
]
}
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
valid | boolean | true | none | none |
error | ValidationError | false | none | none |
{
"errors": [
"string"
]
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
errors | [string] | true | none | none |
{
"users": [
"string"
],
"groups": [
"string"
]
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
users | [string] | true | none | none |
groups | [string] | true | none | none |
{
"request": "string",
"result": "string"
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
request | string | true | none | none |
result | string | false | none | none |
{
"error": "string"
}
Name | Type | Required | Restrictions | Description |
---|---|---|---|---|
error | string | true | none | none |