This file explains how to configure connector A and B for the preconfigured setup expected in the user guide. Additionally, it contains instructions how to ensure the correct configuration of those connectors.
All the steps included in this document are automated in a postman collection called "TestBed_Guide.postman_collection.json" available at the IDS_testbed repository.
First of all, this section will explain the necessary steps that need to be follow in order to have a data offered at the Connector A of the reference Testbed (Connector A acting as Provider).
The following steps have been extracted from the official documentation guide (https://international-data-spaces-association.github.io/DataspaceConnector/CommunicationGuide/v6/Provider) and have been modified in order to work for the reference Testbed deployment setup.
Setup the Reference Testbed and follow the next steps on Connector A to create a complete resource. Access in a browser https://localhost:8080 and enter in the Swagger UI of connector A.
Create a base resource with the following Request Body
{
"title": "DWD Weather Warnings",
"description": "DWD weather warnings for Germany.",
"keywords": [
"DWD"
],
"publisher": "https://dwd.com",
"language": "DE",
"license": "",
"sovereign": "https://dwd.com",
"endpointDocumentation": "",
"paymentModality": "undefined"
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-15T15:50:58.703+0000",
"modificationDate": "2021-12-15T15:50:58.703+0000",
"title": "DWD Weather Warnings",
"description": "DWD weather warnings for Germany.",
"keywords": [
"DWD"
],
"publisher": "https://dwd.com",
"language": "DE",
"license": "",
"version": 1,
"sovereign": "https://dwd.com",
"endpointDocumentation": "",
"paymentModality": "undefined",
"samples": [],
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991"
},
"contracts": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/contracts{?page,size}",
"templated": true
},
"representations": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/representations{?page,size}",
"templated": true
},
"catalogs": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/catalogs{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/subscriptions{?page,size}",
"templated": true
},
"brokers": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/brokers{?page,size}",
"templated": true
}
}
}
Create a base resource with the following Request body
{
"title": "IDS Catalog",
"description": "This catalog is created from an IDS infomodel catalog."
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T10:08:51.817+0000",
"modificationDate": "2021-12-16T10:08:51.817+0000",
"title": "IDS Catalog",
"description": "This catalog is created from an IDS infomodel catalog.",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f"
},
"offers": {
"href": "https://localhost:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f/offers{?page,size}",
"templated": true
}
}
}
Link the created offer to the created catalog.
Insert the catalog id
2cd59c94-54e4-4979-9842-36ee45dd354f
Use the offer as the Request body
[ "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991" ]
The response body should give code 200 and should have this structure:
{
"_embedded": {
"resources": [
{
"creationDate": "2021-12-15T15:50:58.703+0000",
"modificationDate": "2021-12-15T15:50:58.703+0000",
"title": "DWD Weather Warnings",
"description": "DWD weather warnings for Germany.",
"keywords": [
"DWD"
],
"publisher": "https://dwd.com",
"language": "DE",
"license": "",
"version": 1,
"sovereign": "https://dwd.com",
"endpointDocumentation": "",
"paymentModality": "undefined",
"samples": [],
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991"
},
"contracts": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/contracts{?page,size}",
"templated": true
},
"representations": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/representations{?page,size}",
"templated": true
},
"catalogs": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/catalogs{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/subscriptions{?page,size}",
"templated": true
},
"brokers": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/brokers{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f/offers?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
Obtain a usage policy for provide access following the documentation (https://international-data-spaces-association.github.io/DataspaceConnector/Documentation/v6/UsageControl#example-endpoint)
Insert the following Request body
{
"title": "Example Usage Policy",
"description": "",
"type": "PROVIDE_ACCESS"
}
The response body should give code 200 and should have this structure:
{
"@context" : {
"ids" : "https://w3id.org/idsa/core/",
"idsc" : "https://w3id.org/idsa/code/"
},
"@type" : "ids:Permission",
"@id" : "https://w3id.org/idsa/autogen/permission/51f5f7e4-f97f-4f91-bc57-b243714642be",
"ids:description" : [ {
"@value" : "provide-access",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:title" : [ {
"@value" : "Allow Data Usage",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:postDuty" : [ ],
"ids:assignee" : [ ],
"ids:assigner" : [ ],
"ids:preDuty" : [ ],
"ids:action" : [ {
"@id" : "https://w3id.org/idsa/code/USE"
} ],
"ids:constraint" : [ ]
}
Create a rule for provide access usage policy with the following Request body (it is used the provide access usage policy obtained from the previous call).
{
"title": "[\"Example Usage Policy\"^^http://www.w3.org/2001/XMLSchema#string]",
"description": "",
"value": "{\n \"@context\" : {\n \"ids\" : \"https://w3id.org/idsa/core/\",\n \"idsc\" : \"https://w3id.org/idsa/code/\"\n },\n \"@type\" : \"ids:Permission\",\n \"@id\" : \"https://w3id.org/idsa/autogen/permission/51f5f7e4-f97f-4f91-bc57-b243714642be\",\n \"ids:description\" : [ {\n \"@value\" : \"provide-access\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:title\" : [ {\n \"@value\" : \"Example Usage Policy\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:postDuty\" : [ ],\n \"ids:assignee\" : [ ],\n \"ids:assigner\" : [ ],\n \"ids:action\" : [ {\n \"@id\" : \"https://w3id.org/idsa/code/USE\"\n } ],\n \"ids:constraint\" : [ ],\n \"ids:preDuty\" : [ ]\n}"
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T10:22:02.982+0000",
"modificationDate": "2021-12-16T10:22:02.982+0000",
"title": "[\"Example Usage Policy\"^^http://www.w3.org/2001/XMLSchema#string]",
"description": "",
"value": "{\n \"@context\" : {\n \"ids\" : \"https://w3id.org/idsa/core/\",\n \"idsc\" : \"https://w3id.org/idsa/code/\"\n },\n \"@type\" : \"ids:Permission\",\n \"@id\" : \"https://w3id.org/idsa/autogen/permission/51f5f7e4-f97f-4f91-bc57-b243714642be\",\n \"ids:description\" : [ {\n \"@value\" : \"provide-access\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:title\" : [ {\n \"@value\" : \"Example Usage Policy\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:postDuty\" : [ ],\n \"ids:assignee\" : [ ],\n \"ids:assigner\" : [ ],\n \"ids:action\" : [ {\n \"@id\" : \"https://w3id.org/idsa/code/USE\"\n } ],\n \"ids:constraint\" : [ ],\n \"ids:preDuty\" : [ ]\n}",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802"
},
"contracts": {
"href": "https://localhost:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802/contracts{?page,size}",
"templated": true
}
}
}
Create a contract defining the provider url, the start and end dates at the following Request body
{
"title": "Contract",
"description": "This is an example contract",
"provider":"https://connectora:8080/",
"start": "2021-10-22T07:48:37.068Z",
"end": "2023-10-22T07:48:37.068Z"
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T10:24:10.248+0000",
"modificationDate": "2021-12-16T10:24:10.248+0000",
"title": "Contract",
"description": "This is an example contract",
"start": "2021-12-16T10:24:10.230+0000",
"end": "2023-10-22T07:48:37.068+0000",
"consumer": "",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea"
},
"rules": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea/rules{?page,size}",
"templated": true
},
"offers": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea/offers{?page,size}",
"templated": true
}
}
}
Link the created rule to the created contract
Insert the contract id
122355bd-f49a-423e-9a3d-15bd55b639ea
Use the rule as the Request body
[ "https://localhost:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802" ]
The response body should give code 200 and should have this structure:
{
"_embedded": {
"rules": [
{
"creationDate": "2021-12-16T10:22:02.982+0000",
"modificationDate": "2021-12-16T10:22:02.982+0000",
"title": "[\"Example Usage Policy\"^^http://www.w3.org/2001/XMLSchema#string]",
"description": "",
"value": "{\n \"@context\" : {\n \"ids\" : \"https://w3id.org/idsa/core/\",\n \"idsc\" : \"https://w3id.org/idsa/code/\"\n },\n \"@type\" : \"ids:Permission\",\n \"@id\" : \"https://w3id.org/idsa/autogen/permission/51f5f7e4-f97f-4f91-bc57-b243714642be\",\n \"ids:description\" : [ {\n \"@value\" : \"provide-access\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:title\" : [ {\n \"@value\" : \"Example Usage Policy\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:postDuty\" : [ ],\n \"ids:assignee\" : [ ],\n \"ids:assigner\" : [ ],\n \"ids:action\" : [ {\n \"@id\" : \"https://w3id.org/idsa/code/USE\"\n } ],\n \"ids:constraint\" : [ ],\n \"ids:preDuty\" : [ ]\n}",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802"
},
"contracts": {
"href": "https://localhost:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802/contracts{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea/rules?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
Create an artifact that contains DWD weather data with the following Request body
{
"title": "Artifact",
"description": "This is an example artifact",
"value": "https://maps.dwd.de/geoserver/dwd/ows?service=WFS&version=1.0.0&request=GetFeature&typeName=dwd%3AAutowarn_Analyse&maxFeatures=50&outputFormat=application%2Fjson",
"automatedDownload": true
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T10:35:37.850+0000",
"modificationDate": "2021-12-16T10:35:37.850+0000",
"remoteId": "genesis",
"title": "Artifact",
"description": "This is an example artifact",
"numAccessed": 0,
"byteSize": 0,
"checkSum": 0,
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6"
},
"data": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/data"
},
"representations": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/representations{?page,size}",
"templated": true
},
"agreements": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/agreements{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/subscriptions{?page,size}",
"templated": true
}
}
}
Create a representation with the following Request body
{
"title": "Example Representation",
"description": "",
"mediaType": "json",
"language": "https://w3id.org/idsa/code/EN"
}
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T10:37:10.751+0000",
"modificationDate": "2021-12-16T10:37:10.751+0000",
"remoteId": "genesis",
"title": "Example Representation",
"description": "",
"mediaType": "json",
"language": "https://w3id.org/idsa/code/EN",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d"
},
"artifacts": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/artifacts{?page,size}",
"templated": true
},
"offers": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/offers{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/subscriptions{?page,size}",
"templated": true
}
}
}
Link the created representation to the created artifact
Insert the representation id
b734b25b-042f-462e-8203-6c8f2ba6852d
Use the artifact as the Request body
[ "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6" ]
The response body should give code 200 and should have this structure:
{
"_embedded": {
"artifacts": [
{
"creationDate": "2021-12-16T10:35:37.850+0000",
"modificationDate": "2021-12-16T10:35:37.850+0000",
"remoteId": "genesis",
"title": "Artifact",
"description": "This is an example artifact",
"numAccessed": 0,
"byteSize": 0,
"checkSum": 0,
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6"
},
"data": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/data"
},
"representations": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/representations{?page,size}",
"templated": true
},
"agreements": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/agreements{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6/subscriptions{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/artifacts?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
Link the created representation to the created offer.
Insert the offer id
03735877-0111-49a4-b20d-51734c81a991
Use the representation as the Request body
[ "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d" ]
The response body should give code 200 and should have this structure:
{
"_embedded": {
"representations": [
{
"creationDate": "2021-12-16T10:37:10.751+0000",
"modificationDate": "2021-12-16T10:37:10.751+0000",
"remoteId": "genesis",
"title": "Example Representation",
"description": "",
"mediaType": "json",
"language": "https://w3id.org/idsa/code/EN",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d"
},
"artifacts": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/artifacts{?page,size}",
"templated": true
},
"offers": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/offers{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d/subscriptions{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/representations?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
Link the created contract to the created offer.
Insert the offer id
03735877-0111-49a4-b20d-51734c81a991
Use the contract as the Request body
[ "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea" ]
The response body should give code 200 and should have this structure:
{
"_embedded": {
"contracts": [
{
"creationDate": "2021-12-16T10:24:10.248+0000",
"modificationDate": "2021-12-16T10:24:10.248+0000",
"title": "Contract",
"description": "This is an example contract",
"start": "2021-12-16T10:24:10.230+0000",
"end": "2023-10-22T07:48:37.068+0000",
"consumer": "",
"additional": {},
"_links": {
"self": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea"
},
"rules": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea/rules{?page,size}",
"templated": true
},
"offers": {
"href": "https://localhost:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea/offers{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991/contracts?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
At the Swagger UI of the Connector A insert the following recipient url for message POST /api/ids/connector/update:
https://broker-localhost_broker-reverseproxy_1/infrastructure
The server response should give code 200.
At the Swagger UI of the Connector B insert the following recipient url for message POST /api/ids/connector/update:
https://broker-localhost_broker-reverseproxy_1/infrastructure
The server response should give code 200.
This section will explain the necessary steps that need to be follow in order to request data from Connector A (acting as data provider) using Connector B (acting as data consumer). The following steps have been extracted from the official documentation guide (https://international-data-spaces-association.github.io/DataspaceConnector/CommunicationGuide/v6/Consumer) and have been modified in order to work for the reference Testbed deployment setup.
With the Reference Testbed setup, follow the next steps on Connector B to obtain data from Connector A. Access in a browser https://localhost:8081 and conduct the following steps in the Swagger UI of connector B.
Request the self-description of Connector A utilizing POST /api/ids/description.
Insert the recipient url of Connector A
Left the elementId remains empty because the id of the requested resource is not known.
The response body should give code 200 and be euqivalent to the following:
{
"@context" : {
"ids" : "https://w3id.org/idsa/core/",
"idsc" : "https://w3id.org/idsa/code/"
}
{
"@type" : "ids:BaseConnector",
"@id" : "https://connector_A",
"ids:version" : "6.2.0",
"ids:description" : [ {
"@value" : "IDS Connector A with static example resources",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:title" : [ {
"@value" : "Dataspace Connector",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:hasEndpoint" : [ ],
"ids:hasDefaultEndpoint" : {
"@type" : "ids:ConnectorEndpoint",
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"ids:accessURL" : {
"@id" : "https://connectora:8080/api/ids/data"
},
"ids:endpointDocumentation" : [ ],
"ids:endpointInformation" : [ ]
},
"ids:resourceCatalog" : [ {
"@type" : "ids:ResourceCatalog",
"@id" : "https://connectora:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f",
"ids:offeredResource" : [ ],
"ids:requestedResource" : [ ]
} ],
"ids:hasAgent" : [ ],
"ids:securityProfile" : {
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE"
},
"ids:extendedGuarantee" : [ ],
"ids:maintainer" : {
"@id" : "https://www.isst.fraunhofer.de/"
},
"ids:curator" : {
"@id" : "https://www.isst.fraunhofer.de/"
},
"ids:inboundModelVersion" : [ "4.2.0", "4.1.2", "4.0.0", "4.1.0" ],
"ids:outboundModelVersion" : "4.2.0",
"ids:publicKey" : {
"@type" : "ids:PublicKey",
"@id" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"ids:keyType" : {
"@id" : "https://w3id.org/idsa/code/RSA"
},
"ids:keyValue" : "VFVsSlFrbHFRVTVDWjJ0eGFHdHBSemwzTUVKQlVVVkdRVUZQUTBGUk9FRk5TVWxDUTJkTFEwRlJSVUYxZHpadFJuSmtabXhZV2xSS1owWlBRVFZ6YlVSWVF6QTVVMjF3U2xkdlIzQjVSVkphVGtWNU16RndTMlJ6VWtkb1ZHbHdVakkzYWpscGNtMXRjV2xvZGpkblNXZDZRMjU0Tm10SlVrNUhTVEoxTUc5R1VUVkdaM1pQTVhoNFozcGphV2hrY0VZd1EyaGxUMlk1U1U1bmFYTlFhM0UxYUdvNFFXVXZSRmxZYTNacWFGRTJZelpoYXk5YVdXWnFNRTV3Y1hsRlVHTktOVTFNVW0xWlIyVjRUV0ZOV20xVVluRkVTblpLYkRWS1J6TXJZa1V6V1dFeU1XaFVXbGxQZUdsVGFXTndaa1puU2pNd2EyNDFZVlZKUVhSa01EVkpXbmszZWpGelJHbFdUSFJVV0d4TVptVXZXbEZETkhCdWFrWjBjeXQwWXpFeWMxZzVhV2hKYlc1RGEyUXdWM1o2TTBOVVdtOTVRbE56WXpGVVpFSnJZamx0TUVNMWRIWm5NR1pSVURSUlowWXZla2d5VVc5YWJtNXlTVFV5ZFVGYU9FMXZiVmQwV1RKc2RETkVNR3RyY0ZJMk9YQm1Wa1JLTjNremRrNHZaWGRKUkVGUlFVST0="
}
}
}
From this Response body obtain the resource catalog @id
https://connectora:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f
Request the specific resource catalog of Connector A using POST /api/ids/description
Insert the recipient url of Connector A (recipient)
Insert the id of the requested resource (elementId)
https://connectora:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f
The response body should give code 200 and should have this structure:
{
"@context" : {
"ids" : "https://w3id.org/idsa/core/",
"idsc" : "https://w3id.org/idsa/code/"
},
"@type" : "ids:ResourceCatalog",
"@id" : "https://connectora:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f",
"ids:offeredResource" : [ {
"@type" : "ids:Resource",
"@id" : "https://connectora:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991",
"ids:description" : [ {
"@value" : "DWD weather warnings for Germany.",
"@language" : "DE"
} ],
"ids:version" : "1",
"ids:language" : [ {
"@id" : "https://w3id.org/idsa/code/DE"
} ],
"ids:title" : [ {
"@value" : "DWD Weather Warnings",
"@language" : "DE"
} ],
"ids:publisher" : {
"@id" : "https://dwd.com"
},
"ids:sovereign" : {
"@id" : "https://dwd.com"
},
"ids:resourceEndpoint" : [ {
"@type" : "ids:ConnectorEndpoint",
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e3e0fb5a-f0bd-4c29-8200-f6c8e138d04c",
"ids:accessURL" : {
"@id" : "https://connectora:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991"
},
"ids:endpointDocumentation" : [ {
"@id" : ""
} ],
"ids:endpointInformation" : [ ]
} ],
"ids:contractOffer" : [ {
"@type" : "ids:ContractOffer",
"@id" : "https://connectora:8080/api/contracts/122355bd-f49a-423e-9a3d-15bd55b639ea",
"ids:permission" : [ {
"@type" : "ids:Permission",
"@id" : "https://connectora:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802",
"ids:description" : [ {
"@value" : "provide-access",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:title" : [ {
"@value" : "Example Usage Policy",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:postDuty" : [ ],
"ids:assignee" : [ ],
"ids:assigner" : [ ],
"ids:preDuty" : [ ],
"ids:action" : [ {
"@id" : "https://w3id.org/idsa/code/USE"
} ],
"ids:constraint" : [ ]
} ],
"ids:provider" : {
"@id" : "https://connectora:8080/"
},
"ids:consumer" : {
"@id" : ""
},
"ids:contractEnd" : {
"@value" : "2023-10-22T07:48:37.068Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:contractStart" : {
"@value" : "2021-12-16T10:24:10.230Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:contractDate" : {
"@value" : "2021-12-16T13:20:30.521Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:prohibition" : [ ],
"ids:obligation" : [ ]
} ],
"ids:sample" : [ ],
"ids:contentPart" : [ ],
"ids:representation" : [ {
"@type" : "ids:Representation",
"@id" : "https://connectora:8080/api/representations/b734b25b-042f-462e-8203-6c8f2ba6852d",
"ids:description" : [ ],
"ids:language" : {
"@id" : "https://w3id.org/idsa/code/EN"
},
"ids:mediaType" : {
"@type" : "ids:IANAMediaType",
"@id" : "https://w3id.org/idsa/autogen/iANAMediaType/bbd0d6d4-0fb2-4d68-a941-6bef561a334f",
"ids:filenameExtension" : "json"
},
"ids:title" : [ ],
"ids:instance" : [ {
"@type" : "ids:Artifact",
"@id" : "https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6",
"ids:fileName" : "Artifact",
"ids:creationDate" : {
"@value" : "2021-12-16T10:35:37.850Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:byteSize" : 24,
"ids:checkSum" : "2302133775"
} ],
"ids:representationStandard" : {
"@id" : ""
},
"ids:modified" : {
"@value" : "2021-12-16T10:37:10.751Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:created" : {
"@value" : "2021-12-16T10:37:10.751Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
}
} ],
"ids:defaultRepresentation" : [ ],
"ids:resourcePart" : [ ],
"ids:standardLicense" : {
"@id" : ""
},
"ids:theme" : [ ],
"ids:modified" : {
"@value" : "2021-12-15T15:50:58.703Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
},
"ids:keyword" : [ {
"@value" : "DWD",
"@language" : "DE"
} ],
"ids:temporalCoverage" : [ ],
"ids:spatialCoverage" : [ ],
"ids:created" : {
"@value" : "2021-12-15T15:50:58.703Z",
"@type" : "http://www.w3.org/2001/XMLSchema#dateTimeStamp"
}
} ],
"ids:requestedResource" : [ ]
}
From this response body it is obtained the necessary information in order to negotiate the contract (Connector A: offer id, artifact id, rule id)
https://connectora:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991
https://connectora:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802
https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6
Send IDS contract request message POST /api/ids/contract.
Insert the recipient url of Connector A (recipient)
Insert the ids resource that should be requested (resourceIds)
https://connectora:8080/api/offers/03735877-0111-49a4-b20d-51734c81a991
Insert the artifact that should be requested (artifactIds)
https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6
Put the connector automatically download data of an artifact to False (download)
false
The request body must contain a contract offer, this contract must match the one the resource was created with. Therefore, it is a policy with a USE permission. The rule list will be automatically turned into a contract request to then send it to the provider. This will read this contract request, compare it to the artifact’s (respectively the corresponding resource’s) contract offers, and return either a ContractRejectionMessage or a ContractAgreementMessage.
Include in it the id of the Connector A rule and as ids:target the artifact.
[ {
"@type" : "ids:Permission",
"@id" : "https://connectora:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802",
"ids:description" : [ {
"@value" : "provide-access",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:title" : [ {
"@value" : "Example Usage Policy",
"@type" : "http://www.w3.org/2001/XMLSchema#string"
} ],
"ids:action" : [ {
"@id" : "https://w3id.org/idsa/code/USE"
}],
"ids:target" : "https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6"
} ]
The response body should give code 201 and should have this structure:
{
"creationDate": "2021-12-16T13:27:38.959+0000",
"modificationDate": "2021-12-16T13:27:38.959+0000",
"remoteId": "https://connectora:8080/api/agreements/01c29b32-b202-46d3-ade1-e9401b43ed0f",
"confirmed": true,
"value": "{\n \"@context\" : {\n \"ids\" : \"https://w3id.org/idsa/core/\",\n \"idsc\" : \"https://w3id.org/idsa/code/\"\n },\n \"@type\" : \"ids:ContractAgreement\",\n \"@id\" : \"https://connectora:8080/api/agreements/01c29b32-b202-46d3-ade1-e9401b43ed0f\",\n \"ids:permission\" : [ {\n \"@type\" : \"ids:Permission\",\n \"@id\" : \"https://connectora:8080/api/rules/fac53177-3e4c-45cf-bdfc-181c3f3e3802\",\n \"ids:description\" : [ {\n \"@value\" : \"provide-access\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:title\" : [ {\n \"@value\" : \"Example Usage Policy\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#string\"\n } ],\n \"ids:action\" : [ {\n \"@id\" : \"https://w3id.org/idsa/code/USE\"\n } ],\n \"ids:postDuty\" : [ ],\n \"ids:assignee\" : [ {\n \"@id\" : \"https://connector_B\"\n } ],\n \"ids:assigner\" : [ {\n \"@id\" : \"https://connector_A\"\n } ],\n \"ids:constraint\" : [ ],\n \"ids:preDuty\" : [ ],\n \"ids:target\" : {\n \"@id\" : \"https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6\"\n }\n } ],\n \"ids:provider\" : {\n \"@id\" : \"https://connector_A\"\n },\n \"ids:consumer\" : {\n \"@id\" : \"https://connector_B\"\n },\n \"ids:contractStart\" : {\n \"@value\" : \"2021-12-16T13:27:37.868Z\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#dateTimeStamp\"\n },\n \"ids:contractDate\" : {\n \"@value\" : \"2021-12-16T13:27:37.868Z\",\n \"@type\" : \"http://www.w3.org/2001/XMLSchema#dateTimeStamp\"\n },\n \"ids:prohibition\" : [ ],\n \"ids:obligation\" : [ ]\n}",
"_links": {
"self": {
"href": "https://localhost:8081/api/agreements/3a638d21-07fb-40a0-be14-bea6d353825e"
},
"artifacts": {
"href": "https://localhost:8081/api/agreements/3a638d21-07fb-40a0-be14-bea6d353825e/artifacts{?page,size}",
"templated": true
}
}
}
From this response body it is obtained the Connector B agreement
https://localhost:8081/api/agreements/3a638d21-07fb-40a0-be14-bea6d353825e
To get the artifact and their data link, make the following request: POST /api/agreements/{id}/artifacts
Insert the agreement id
3a638d21-07fb-40a0-be14-bea6d353825e
The response body should give code 200 and should have this structure:
{
"_embedded": {
"artifacts": [
{
"creationDate": "2021-12-16T13:27:40.183+0000",
"modificationDate": "2021-12-16T15:32:57.815+0000",
"remoteId": "https://connectora:8080/api/artifacts/d5eb7f14-b99b-4bbf-94e7-4e612a4ccac6",
"title": "Artifact",
"description": "",
"numAccessed": 1,
"byteSize": 2347,
"checkSum": 0,
"additional": {
"ids:byteSize": "0",
"ids:creationDate": "2021-12-16T10:35:37.850Z",
"ids:checkSum": "0"
},
"_links": {
"self": {
"href": "https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d"
},
"data": {
"href": "https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d/data"
},
"representations": {
"href": "https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d/representations{?page,size}",
"templated": true
},
"agreements": {
"href": "https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d/agreements{?page,size}",
"templated": true
},
"subscriptions": {
"href": "https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d/subscriptions{?page,size}",
"templated": true
}
}
}
]
},
"_links": {
"self": {
"href": "https://localhost:8081/api/agreements/3a638d21-07fb-40a0-be14-bea6d353825e/artifacts?page=0&size=30"
}
},
"page": {
"size": 30,
"totalElements": 1,
"totalPages": 1,
"number": 0
}
}
From this response body it is obtained the url to obtain the data
https://localhost:8081/api/artifacts/1d06f1c0-8b64-465a-b5f0-3e185914a67d/data
If you paste it in a browser and download it is obtained the corresponding DWD weather data.
This section will explain the necessary steps to validate correct setup of the Broker with information regarding Connector A and B and to obtain information about the dataset offered by Connector A. With the Reference Testbed setup, follow the next steps on Connector B to obtain information from the Broker concerning Connector A. Access in a browser https://localhost:8081 and conduct the following steps in the Swagger UI of connector B.
Obtain broker self-description using POST /api/ids/description.
Insert the recipient url
https://broker-localhost_broker-reverseproxy_1/infrastructure
The response body should give code 200 and should have this structure:
{
"@context" : {
"ids" : "https://w3id.org/idsa/core/",
"idsc" : "https://w3id.org/idsa/code/"
},
"@type" : "ids:Broker",
"@id" : "https://localhost/",
"ids:description" : [ {
"@value" : "A Broker with a graph persistence layer",
"@language" : "en"
} ],
"ids:title" : [ {
"@value" : "IDS Metadata Broker",
"@language" : "en"
} ],
"ids:maintainer" : {
"@id" : "https://www.iais.fraunhofer.de"
},
"ids:curator" : {
"@id" : "https://www.iais.fraunhofer.de"
},
"ids:inboundModelVersion" : [ "4.0.3" ],
"ids:outboundModelVersion" : "4.0.3",
"ids:resourceCatalog" : [ {
"@type" : "ids:ResourceCatalog",
"@id" : "https://w3id.org/idsa/autogen/resourceCatalog/b76c559b-359d-4e2f-bb2e-cd2692ed985e",
"ids:offeredResource" : [ {
"@type" : "ids:DataResource",
"@id" : "https://w3id.org/idsa/autogen/dataResource/41ea3278-89ed-4e5a-800c-836f01731dbd",
"ids:description" : [ ],
"ids:language" : [ ],
"ids:title" : [ ],
"ids:resourceEndpoint" : [ ],
"ids:contractOffer" : [ ],
"ids:sample" : [ ],
"ids:contentPart" : [ ],
"ids:representation" : [ {
"@type" : "ids:DataRepresentation",
"@id" : "https://w3id.org/idsa/autogen/dataRepresentation/44c079d3-0e53-40d3-8634-0a15f424e459",
"ids:description" : [ ],
"ids:title" : [ ],
"ids:instance" : [ {
"@type" : "ids:Artifact",
"@id" : "https://localhost/connectors/"
} ]
} ],
"ids:defaultRepresentation" : [ ],
"ids:resourcePart" : [ ],
"ids:theme" : [ ],
"ids:keyword" : [ ],
"ids:temporalCoverage" : [ ],
"ids:spatialCoverage" : [ ]
} ],
"ids:requestedResource" : [ ]
} ],
"ids:hasAgent" : [ ],
"ids:securityProfile" : {
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE"
},
"ids:extendedGuarantee" : [ ],
"ids:hasEndpoint" : [ {
"@type" : "ids:ConnectorEndpoint",
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/2d4cf2c8-2023-4e5e-8f3e-0906ba278295",
"ids:path" : "/infrastructure",
"ids:accessURL" : {
"@id" : "https://localhost/infrastructure"
},
"ids:endpointDocumentation" : [ {
"@id" : "https://app.swaggerhub.com/apis/idsa/IDS-Broker/1.3.1#/Multipart%20Interactions/post_infrastructure"
} ],
"ids:endpointInformation" : [ {
"@value" : "This endpoint provides IDS Connector and IDS Resource registration and search capabilities at the IDS Metadata Broker.",
"@language" : "en"
}, {
"@value" : "Dieser Endpunkt ermöglicht die Registrierung von und das Suchen nach IDS Connectoren und IDS Ressourcen am IDS Metadata Broker.",
"@language" : "de"
} ]
} ],
"ids:hasDefaultEndpoint" : {
"@type" : "ids:ConnectorEndpoint",
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/ac1ce4c6-6e8a-490d-bf7d-2ae560fd7ba5",
"ids:path" : "/",
"ids:accessURL" : {
"@id" : "https://localhost/"
},
"ids:endpointDocumentation" : [ ],
"ids:endpointInformation" : [ {
"@value" : "Dieser Endpunkt liefert eine Selbstbeschreibung dieses IDS Connectors",
"@language" : "de"
}, {
"@value" : "Endpoint providing a self-description of this connector",
"@language" : "en"
} ]
},
"ids:connectorCatalog" : [ ]
}
Query the MetaData Broker for available connectors in the Testbed using message POST /api/ids/description.
Insert the recipient url
https://broker-localhost_broker-reverseproxy_1/infrastructure
Insert the element id of the requested resource
The response body should give code 200 and contain both connectors (A and B) in the list of connector as follows:
{
"@graph" : [ {
"@id" : "https://localhost/connectors/",
"@type" : "ids:ConnectorCatalog",
"listedConnector" : [ "https://localhost/connectors/2129657531", "https://localhost/connectors/2129657530" ]
}, {
"@id" : "https://localhost/connectors/2129657530",
"@type" : "ids:BaseConnector",
"sameAs" : "https://connector_A",
"curator" : "https://www.isst.fraunhofer.de/",
"description" : "IDS Connector A with static example resources",
"hasDefaultEndpoint" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"inboundModelVersion" : [ "4.2.0", "4.0.0", "4.1.0", "4.1.2" ],
"maintainer" : "https://www.isst.fraunhofer.de/",
"outboundModelVersion" : "4.2.0",
"publicKey" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"resourceCatalog" : "https://localhost/connectors/2129657530/-733289566",
"securityProfile" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE",
"title" : "Dataspace Connector",
"version" : "6.2.0"
}, {
"@id" : "https://localhost/connectors/2129657530/-733289566",
"@type" : "ids:ResourceCatalog",
"sameAs" : "https://localhost:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f"
}, {
"@id" : "https://localhost/connectors/2129657531",
"@type" : "ids:BaseConnector",
"sameAs" : "https://connector_B",
"curator" : "https://www.isst.fraunhofer.de/",
"description" : "IDS Connector B with static example resources",
"hasDefaultEndpoint" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"inboundModelVersion" : [ "4.2.0", "4.1.0", "4.1.2", "4.0.0" ],
"maintainer" : "https://www.isst.fraunhofer.de/",
"outboundModelVersion" : "4.2.0",
"publicKey" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"securityProfile" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE",
"title" : "Dataspace Connector",
"version" : "6.2.0"
}, {
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"@type" : "ids:ConnectorEndpoint",
"accessURL" : [ "https://connectorb:8081/api/ids/data", "https://connectora:8080/api/ids/data" ]
}, {
"@id" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"@type" : "ids:PublicKey",
"keyType" : "https://w3id.org/idsa/code/RSA",
"keyValue" : "VkZWc1NsRnJiSEZSVlRWRFdqSjBlR0ZIZEhCU2Vtd3pUVVZLUWxWVlZrZFJWVVpRVVRCR1VrOUZSazVUVld4RFVUSmtURkV3UmxKU1ZVWXhaSHBhZEZKdVNtdGFiWGhaVjJ4U1Mxb3dXbEJSVkZaNllsVlNXVkY2UVRWVk1qRjNVMnhrZGxJelFqVlNWa3BoVkd0V05VMTZSbmRUTWxKNlZXdGtiMVpIYkhkVmFra3pZV3BzY0dOdE1YUmpWMnh2Wkdwa2JsTlhaRFpSTWpVMFRtMTBTbFZyTlVoVFZFb3hUVWM1UjFWVVZrZGFNMXBRVFZob05Gb3pjR3BoVjJoclkwVlpkMUV5YUd4VU1sazFVMVUxYm1GWVRsRmhNMFV4WVVkdk5GRlhWWFpTUm14WllUTmFjV0ZHUlRKWmVscG9ZWGs1WVZkWFduRk5SVFYzWTFoc1JsVkhUa3RPVlRGTlZXMHhXbEl5VmpSVVYwWk9WMjB4VlZsdVJrVlRibHBMWWtSV1MxSjZUWEpaYTFWNlYxZEZlVTFYYUZWWGJHeFFaVWRzVkdGWFRuZGFhMXB1VTJwTmQyRXlOREZaVmxaS1VWaFNhMDFFVmtwWGJtc3paV3BHZWxKSGJGZFVTRkpWVjBkNFRWcHRWWFpYYkVaRVRraENkV0ZyV2pCamVYUXdXWHBGZVdNeFp6VmhWMmhLWWxjMVJHRXlVWGRXTTFvMlRUQk9WVmR0T1RWUmJFNTZXWHBHVlZwRlNuSlphbXgwVFVWTk1XUklXbTVOUjFwU1ZVUlNVbG93V1habGEyZDVWVmM1WVdKdE5YbFRWRlY1WkZWR1lVOUZNWFppVm1Rd1YxUktjMlJFVGtWTlIzUnlZMFpKTWs5WVFtMVdhMUpMVGpOcmVtUnJOSFphV0dSS1VrVkdVbEZWU1QwPQ=="
} ],
"@context" : {
"accessURL" : {
"@id" : "https://w3id.org/idsa/core/accessURL",
"@type" : "@id"
},
"sameAs" : {
"@id" : "http://www.w3.org/2002/07/owl#sameAs",
"@type" : "@id"
},
"description" : {
"@id" : "https://w3id.org/idsa/core/description"
},
"hasDefaultEndpoint" : {
"@id" : "https://w3id.org/idsa/core/hasDefaultEndpoint",
"@type" : "@id"
},
"publicKey" : {
"@id" : "https://w3id.org/idsa/core/publicKey",
"@type" : "@id"
},
"curator" : {
"@id" : "https://w3id.org/idsa/core/curator",
"@type" : "@id"
},
"inboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/inboundModelVersion"
},
"title" : {
"@id" : "https://w3id.org/idsa/core/title"
},
"outboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/outboundModelVersion"
},
"securityProfile" : {
"@id" : "https://w3id.org/idsa/core/securityProfile",
"@type" : "@id"
},
"maintainer" : {
"@id" : "https://w3id.org/idsa/core/maintainer",
"@type" : "@id"
},
"resourceCatalog" : {
"@id" : "https://w3id.org/idsa/core/resourceCatalog",
"@type" : "@id"
},
"version" : {
"@id" : "https://w3id.org/idsa/core/version"
},
"listedConnector" : {
"@id" : "https://w3id.org/idsa/core/listedConnector",
"@type" : "@id"
},
"keyValue" : {
"@id" : "https://w3id.org/idsa/core/keyValue"
},
"keyType" : {
"@id" : "https://w3id.org/idsa/core/keyType",
"@type" : "@id"
},
"owl" : "http://www.w3.org/2002/07/owl#",
"ids" : "https://w3id.org/idsa/core/"
}
}
From this list of connectors we now know the connector A element id:
With the connector A element id, more details on Connector A can be requested from the broker using POST /api/ids/description.
Insert the recipient url
https://broker-localhost_broker-reverseproxy_1/infrastructure
Insert the element id of the requested connector A
The response body should give code 200 and should have this structure
{
"@graph" : [ {
"@id" : "https://localhost/connectors/2129657530",
"@type" : "ids:BaseConnector",
"sameAs" : "https://connector_A",
"curator" : "https://www.isst.fraunhofer.de/",
"description" : "IDS Connector A with static example resources",
"hasDefaultEndpoint" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"inboundModelVersion" : [ "4.2.0", "4.0.0", "4.1.0", "4.1.2" ],
"maintainer" : "https://www.isst.fraunhofer.de/",
"outboundModelVersion" : "4.2.0",
"publicKey" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"resourceCatalog" : "https://localhost/connectors/2129657530/-733289566",
"securityProfile" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE",
"title" : "Dataspace Connector",
"version" : "6.2.0"
}, {
"@id" : "https://localhost/connectors/2129657530/-733289566",
"@type" : "ids:ResourceCatalog",
"sameAs" : "https://localhost:8080/api/catalogs/2cd59c94-54e4-4979-9842-36ee45dd354f"
}, {
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"@type" : "ids:ConnectorEndpoint",
"accessURL" : "https://connectora:8080/api/ids/data"
}, {
"@id" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9",
"@type" : "ids:PublicKey",
"keyType" : "https://w3id.org/idsa/code/RSA",
"keyValue" : "VkZWc1NsRnJiSEZSVlRWRFdqSjBlR0ZIZEhCU2Vtd3pUVVZLUWxWVlZrZFJWVVpRVVRCR1VrOUZSazVUVld4RFVUSmtURkV3UmxKU1ZVWXhaSHBhZEZKdVNtdGFiWGhaVjJ4U1Mxb3dXbEJSVkZaNllsVlNXVkY2UVRWVk1qRjNVMnhrZGxJelFqVlNWa3BoVkd0V05VMTZSbmRUTWxKNlZXdGtiMVpIYkhkVmFra3pZV3BzY0dOdE1YUmpWMnh2Wkdwa2JsTlhaRFpSTWpVMFRtMTBTbFZyTlVoVFZFb3hUVWM1UjFWVVZrZGFNMXBRVFZob05Gb3pjR3BoVjJoclkwVlpkMUV5YUd4VU1sazFVMVUxYm1GWVRsRmhNMFV4WVVkdk5GRlhWWFpTUm14WllUTmFjV0ZHUlRKWmVscG9ZWGs1WVZkWFduRk5SVFYzWTFoc1JsVkhUa3RPVlRGTlZXMHhXbEl5VmpSVVYwWk9WMjB4VlZsdVJrVlRibHBMWWtSV1MxSjZUWEpaYTFWNlYxZEZlVTFYYUZWWGJHeFFaVWRzVkdGWFRuZGFhMXB1VTJwTmQyRXlOREZaVmxaS1VWaFNhMDFFVmtwWGJtc3paV3BHZWxKSGJGZFVTRkpWVjBkNFRWcHRWWFpYYkVaRVRraENkV0ZyV2pCamVYUXdXWHBGZVdNeFp6VmhWMmhLWWxjMVJHRXlVWGRXTTFvMlRUQk9WVmR0T1RWUmJFNTZXWHBHVlZwRlNuSlphbXgwVFVWTk1XUklXbTVOUjFwU1ZVUlNVbG93V1habGEyZDVWVmM1WVdKdE5YbFRWRlY1WkZWR1lVOUZNWFppVm1Rd1YxUktjMlJFVGtWTlIzUnlZMFpKTWs5WVFtMVdhMUpMVGpOcmVtUnJOSFphV0dSS1VrVkdVbEZWU1QwPQ=="
} ],
"@context" : {
"accessURL" : {
"@id" : "https://w3id.org/idsa/core/accessURL",
"@type" : "@id"
},
"description" : {
"@id" : "https://w3id.org/idsa/core/description"
},
"hasDefaultEndpoint" : {
"@id" : "https://w3id.org/idsa/core/hasDefaultEndpoint",
"@type" : "@id"
},
"publicKey" : {
"@id" : "https://w3id.org/idsa/core/publicKey",
"@type" : "@id"
},
"sameAs" : {
"@id" : "http://www.w3.org/2002/07/owl#sameAs",
"@type" : "@id"
},
"curator" : {
"@id" : "https://w3id.org/idsa/core/curator",
"@type" : "@id"
},
"inboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/inboundModelVersion"
},
"title" : {
"@id" : "https://w3id.org/idsa/core/title"
},
"outboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/outboundModelVersion"
},
"securityProfile" : {
"@id" : "https://w3id.org/idsa/core/securityProfile",
"@type" : "@id"
},
"maintainer" : {
"@id" : "https://w3id.org/idsa/core/maintainer",
"@type" : "@id"
},
"resourceCatalog" : {
"@id" : "https://w3id.org/idsa/core/resourceCatalog",
"@type" : "@id"
},
"version" : {
"@id" : "https://w3id.org/idsa/core/version"
},
"keyValue" : {
"@id" : "https://w3id.org/idsa/core/keyValue"
},
"keyType" : {
"@id" : "https://w3id.org/idsa/core/keyType",
"@type" : "@id"
},
"owl" : "http://www.w3.org/2002/07/owl#",
"ids" : "https://w3id.org/idsa/core/"
}
}
From here we can obtain the accessURL of Connector A
"accessURL" : "https://connectora:8080/api/ids/data"
This accessURL can be utilized to request the data set from Connector A as described in "Validating Preconfigured Setup: Interaction between Connectors".