This user guide is meant to explain to each testbed user what they should do with the testbed in order to assess the compatibility of their own developed component.
1. Download and Install the Testbed
Follow the instructions in the installation and configuration guide to install and configure the testbed as required. Utilize the preconfigured setup described as basis for this user guide.
2. Integrating your Connector into the Ecosystem
2.1. Generate a Certificate for your Connector
Generate a private-public key pair for your connector. Issue a certificate for the public key in this key pair signed by the private key of the utilized testbed CA:
Copy ./pki.py cert sign --key-file [path to public key file] --subCA [Sub CA name] --common-name [common name] --client
For the preconfigured setup, the name of the subCA is "ReferenceTestbedSubCA" and the respective files are found in CertificateAuthority/data/subca/ .
Ensure that your connector always utilizes this IDS certificate to prove their identity with respect to the other components.
2.2. Configure your Connector
Configure your connector to use the DAPS available under https://localhost:443 (endpoints: /token, /.well-known/jwks.json)
Provide a self-description for your connector
3. Interacting with the DAPS
3.1. Register your connector at the DAPS
Register your connector following the instructions provided here .
Or use the manual steps described below:
Convert your connector certificate {common name}.crt from step 2.1 into the format required by the DAPS:
Copy ## .crt + .key -> .p12
openssl pkcs12 -export -out {common name}.p12 -inkey {common name}.key -in {common name}.crt -passout pass:password
## .p12 -> .cert
openssl pkcs12 -in {common name}.p12 -out {common name}.cert -nokeys -nodes -passin pass:password
Add the certificate {common name}.cert to the DAPS/keys directory
Add your client information identified by the unique identifier (client_id) in the DAPS/config/clients.yml file following the given examples in this file. The provided script DAPS/register_connector.sh can extract the unique identifier from the certificate to help the users who are not familiar with AKI/SKI extensions. This script adds the specified certificate to the DAPS's list of clients.
3.2. Request your DAT
Use your connector to request a DAT from the DAPS
Validate that you received a valid DAT corresponding to the specification: https://github.com/International-Data-Spaces-Association/IDS-G/blob/main/Components/IdentityProvider/DAPS/README.md#dynamic-attribute-token-dat
4. Interacting with Connectors
4.1. Request Self-descriptions from Available Connectors
Connector A
Connector A is available at the following URL: https://localhost:8080
Request the Self-Description from Connector A using those of the following protocols you support:
Multipart: currently supported by connector A
IDSCP2: currently supported by connector A - still work in progress
IDS-REST: not yet supported by connector A
Validate that you receive the following self-description:
Copy {
"@context" : {
"ids" : "https://w3id.org/idsa/core/" ,
"idsc" : "https://w3id.org/idsa/code/"
} ,
"@type" : "ids:BaseConnector" ,
"@id" : "https://connector_A" ,
"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="
} ,
"ids:version" : "7.1.0" ,
"ids:description" : [
{
"@value" : "IDS Connector A with static example resources" ,
"@type" : "http://www.w3.org/2001/XMLSchema#string"
}
] ,
"ids:resourceCatalog" : [
{
"@type" : "ids:ResourceCatalog" ,
"@id" : "https://connectora:8080/api/catalogs/eb72752d-23ed-4ff8-b679-bd4c4b950b97"
}
] ,
"ids:securityProfile" : {
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE"
} ,
"ids:maintainer" : {
"@id" : "https://sovity.de/"
} ,
"ids:curator" : {
"@id" : "https://sovity.de/"
} ,
"ids:inboundModelVersion" : [
"4.2.6" ,
"4.2.7" ,
"4.2.0" ,
"4.1.2" ,
"4.2.1" ,
"4.0.0" ,
"4.1.0" ,
"4.2.4" ,
"4.2.5" ,
"4.2.2" ,
"4.2.3"
] ,
"ids:outboundModelVersion" : "4.2.7" ,
"ids:title" : [
{
"@value" : "Dataspace Connector" ,
"@type" : "http://www.w3.org/2001/XMLSchema#string"
}
] ,
"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"
}
}
}
Connector B
Connector B is available at the following URL: https://localhost:8081
Request the Self-Description from Connector B using those of the following protocols that you support:
Multipart: currently supported by connector B
IDSCP2: currently supported by connector B - still work in progress
IDS-REST: not yet supported by connector B
Validate that you receive the following self-description:
Copy {
"@context" : {
"ids" : "https://w3id.org/idsa/core/" ,
"idsc" : "https://w3id.org/idsa/code/"
} ,
"@type" : "ids:BaseConnector" ,
"@id" : "https://connector_B" ,
"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="
} ,
"ids:version" : "7.1.0" ,
"ids:description" : [
{
"@value" : "IDS Connector B with static example resources" ,
"@type" : "http://www.w3.org/2001/XMLSchema#string"
}
] ,
"ids:securityProfile" : {
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE"
} ,
"ids:maintainer" : {
"@id" : "https://sovity.de/"
} ,
"ids:curator" : {
"@id" : "https://sovity.de/"
} ,
"ids:inboundModelVersion" : [
"4.2.6" ,
"4.2.7" ,
"4.2.0" ,
"4.2.1" ,
"4.1.2" ,
"4.0.0" ,
"4.1.0" ,
"4.2.4" ,
"4.2.5" ,
"4.2.2" ,
"4.2.3"
] ,
"ids:outboundModelVersion" : "4.2.7" ,
"ids:title" : [
{
"@value" : "Dataspace Connector" ,
"@type" : "http://www.w3.org/2001/XMLSchema#string"
}
] ,
"ids:hasDefaultEndpoint" : {
"@type" : "ids:ConnectorEndpoint" ,
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf" ,
"ids:accessURL" : {
"@id" : "https://connectorb:8081/api/ids/data"
}
}
}
4.2. Request Data from Available Connectors
Connector A
Connector A offers an exemplary data artifact with weather warnings from the DWD. Obtain the resource catalog @id from the Self-Description requested in 4.1
https://connectora:8080/api/catalogs/eb72752d-23ed-4ff8-b679-bd4c4b950b97
Request the data sets from connector A using those of the following protocols you support:
Multipart: currently supported by connector A
IDSCP2: currently supported by connector A - still work in progress
IDS-REST: not yet supported by connector A
Follow the provided Postman collection Guide for Preparing and Validating the Preconfigured Setup/Validating Preconfigured Setup: Interaction between Connectors
to validate that you are able to receive the data offered by the Dataspace Connector acting as providert:
Connector B Connector B is currently not offering any data sets but only helping with validating the correct testbed setup as described in the Guide for Preparing and Validating the Preconfigured Setup .
5. Interacting with the MetaData Broker
5.1. Query the Self-description of the MetaData Broker
Request the self-description of the Broker.
The response body should give code 200 and should be comparable to the following:
Copy {
"@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:resourceCatalog" : [
{
"@type" : "ids:ResourceCatalog" ,
"@id" : "https://w3id.org/idsa/autogen/resourceCatalog/fce5bdd4-cf42-44ff-8c67-dbef3fb138e0" ,
"ids:offeredResource" : [
{
"@type" : "ids:DataResource" ,
"@id" : "https://w3id.org/idsa/autogen/dataResource/2864e71b-f5da-4d19-bd67-72748370302a" ,
"ids:representation" : [
{
"@type" : "ids:DataRepresentation" ,
"@id": "https://w3id.org/idsa/autogen/dataRepresentation/bfe7fd72-e393-4e77-8106-8c0dcef686de",
"ids:instance" : [
{
"@type" : "ids:Artifact" ,
"@id" : "https://localhost/connectors/"
}
]
}
]
}
]
}
] ,
"ids:securityProfile" : {
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE"
} ,
"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:title" : [
{
"@value" : "IDS Metadata Broker" ,
"@language" : "en"
}
] ,
"ids:hasDefaultEndpoint" : {
"@type" : "ids:ConnectorEndpoint" ,
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/e12ab294-8f14-41e9-be1d-2958db4e5263" ,
"ids:path" : "/" ,
"ids:accessURL" : {
"@id" : "https://localhost/"
} ,
"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:hasEndpoint" : [
{
"@type" : "ids:ConnectorEndpoint" ,
"@id" : "https://w3id.org/idsa/autogen/connectorEndpoint/0e2dc9c3-2a06-4318-bcb8-f83613eb4800" ,
"ids:path" : "/infrastructure" ,
"ids:endpointDocumentation" : [
{
"@id": "https://app.swaggerhub.com/apis/idsa/IDS-Broker/1.3.1#/Multipart%20Interactions/post_infrastructure"
}
] ,
"ids:accessURL" : {
"@id" : "https://localhost/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"
}
]
}
]
}
5.2. Query the MetaData Broker for Available Connectors in the Testbed
The MetaData Broker can be reached at https://localhost[:444] and is aware of the self-descriptions of connector A and B.
Query the MetaData Broker for all available datasets using those of the following protocols you support:
Multipart: currently supported by the MetaData Broker
IDSCP2: not yet supported by the MetaData Broker
IDS-REST: not yet supported by the MetaData Broker
Validate that you received the following list of connectors:
Copy {
"@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://sovity.de/" ,
"description" : "IDS Connector A with static example resources" ,
"hasDefaultEndpoint": "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"inboundModelVersion" : [
"4.2.4" ,
"4.2.6" ,
"4.2.0" ,
"4.2.3" ,
"4.0.0" ,
"4.2.2" ,
"4.1.0" ,
"4.2.5" ,
"4.2.7" ,
"4.1.2" ,
"4.2.1"
] ,
"maintainer" : "https://sovity.de/" ,
"outboundModelVersion" : "4.2.7" ,
"publicKey" : "https://w3id.org/idsa/autogen/publicKey/78eb73a3-3a2a-4626-a0ff-631ab50a00f9" ,
"resourceCatalog" : "https://localhost/connectors/2129657530/277846396" ,
"securityProfile" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE" ,
"title" : "Dataspace Connector" ,
"version" : "7.1.0"
} ,
{
"@id" : "https://localhost/connectors/2129657530/277846396" ,
"@type" : "ids:ResourceCatalog" ,
"sameAs" : "https://localhost:8080/api/catalogs/eb72752d-23ed-4ff8-b679-bd4c4b950b97"
} ,
{
"@id" : "https://localhost/connectors/2129657531" ,
"@type" : "ids:BaseConnector" ,
"sameAs" : "https://connector_B" ,
"curator" : "https://sovity.de/" ,
"description" : "IDS Connector B with static example resources" ,
"hasDefaultEndpoint": "https://w3id.org/idsa/autogen/connectorEndpoint/e5e2ab04-633a-44b9-87d9-a097ae6da3cf",
"inboundModelVersion" : [
"4.2.4" ,
"4.2.7" ,
"4.2.6" ,
"4.2.0" ,
"4.2.3" ,
"4.2.2" ,
"4.1.0" ,
"4.2.5" ,
"4.1.2" ,
"4.0.0" ,
"4.2.1"
] ,
"maintainer" : "https://sovity.de/" ,
"outboundModelVersion" : "4.2.7" ,
"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" : "7.1.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=="
} ,
{
"@id" : "https://w3id.org/idsa/code/BASE_SECURITY_PROFILE" ,
"@type" : "ids:SecurityProfile"
} ,
{
"@id" : "https://w3id.org/idsa/code/RSA" ,
"@type" : "ids:KeyType"
}
] ,
"@context" : {
"accessURL" : {
"@id" : "https://w3id.org/idsa/core/accessURL" ,
"@type" : "@id"
} ,
"maintainer" : {
"@id" : "https://w3id.org/idsa/core/maintainer" ,
"@type" : "@id"
} ,
"inboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/inboundModelVersion"
} ,
"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"
} ,
"outboundModelVersion" : {
"@id" : "https://w3id.org/idsa/core/outboundModelVersion"
} ,
"version" : {
"@id" : "https://w3id.org/idsa/core/version"
} ,
"title" : {
"@id" : "https://w3id.org/idsa/core/title"
} ,
"curator" : {
"@id" : "https://w3id.org/idsa/core/curator" ,
"@type" : "@id"
} ,
"securityProfile" : {
"@id" : "https://w3id.org/idsa/core/securityProfile" ,
"@type" : "@id"
} ,
"resourceCatalog" : {
"@id" : "https://w3id.org/idsa/core/resourceCatalog" ,
"@type" : "@id"
} ,
"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/"
}
}
5.3. Register your connector at the IDS MetaDataBroker with an exemplary data set
Register your connector at the MetaData Broker using those of the following protocols you support:
Multipart: currently supported by the MetaData Broker
IDSCP2: not yet supported by the MetaData Broker
IDS-REST: not yet supported by the MetaData Broker
Query the MetaData Broker for all available datasets using those of the following protocols you support:
Multipart: currently supported by the MetaData Broker
IDSCP2: not yet supported by the MetaData Broker
IDS-REST: not yet supported by the MetaData Broker
Validate that the received list of connectors represents the list retreived in 5.2, but extended for your own provided information.
In Addition: Execute Automated Test Suite
Please execute the automated (interoperability) test suite provided at the Testsuite folder by following the installation and execution instructions .