Skip to content

eclipse-tractusx/item-relationship-service

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Item Relationship Service (IRS)

Apache 2 License
Build Coverage CodeQL
Kics Trivy VeraCode OWASP Dependency Check Spotbugs Eclipse-dash Tavern IRS API test

What is the IRS?

Within the Catena-X network, the so-called Item Relationship Service (IRS) forms an essential foundation for various services and products. Within the Catena-X use cases, the IRS serves to increase business value. For example, the IRS provides functionalities to serve requirements, such as occasion-based Traceability, from the Supply Chain Act. In doing so, IDSA and Gaia-X principles, such as data interoperability and sovereignty, are maintained on the Catena-X network and access to dispersed data is enabled. Data chains are established as a common asset.

With the help of the IRS, data chains are to be provided ad-hoc across n-tiers within the Catena-X network. To realize these data chains, the IRS relies on data models of the Traceability use case and provides the federated data chains to customers or applications. Furthermore, the target picture of the IRS includes the enablement of new business areas by means of data chains along the value chain in the automotive industry.

Usage

Local deployment

The following subsection provides instructions for running the infrastructure on docker-compose and the application in the IDE.

Docker-compose + IDE

  • Start the necessary infrastructure by running docker-compose up

  • Start the application from your favorite IDE. For IntelliJ, a run configuration is available in the .run folder.

Local IRS API

Local Helm deployment

Prerequisites

  • install rancher desktop
  • install kubectl
  • Credentials for external environments in helm charts can be found in IRS-KeePass
    • registry.registry.dockerSecret
    • edc.vault.hashicorp.token (for provider and consumer data- and control-plane)
    • irs-helm.keycloak.oauth2.clientId
    • irs-helm.keycloak.oauth2.clientSecret
    • irs-helm.keycloak.oauth2.clientTokenUri
    • irs-helm.keycloak.oauth2.jwkSetUri

How to run

  • Windows
    In CMD or PowerShell execute from project root: .\charts\irs-environments\local\start.bat
    A new window will open to forward the ports to your local machine. Do not close this window until you want to stop the local deployment

  • Linux
    Run the following commands from project root
    ./charts/irs-environments/local/start.sh
    ./charts/irs-environments/local/forward-ports.sh(in a separate terminal tab or window, this needs to stay open)
    ./charts/irs-environments/local/upload-testdata.sh

IRS will be available at http://localhost:10165

How to stop

helm uninstall irs-local -n product-traceability-irs

Accessing the secured API

A valid access token is required to access every IRS endpoint and must be included in the Authorization header - otherwise HTTP 401 Unauthorized status is returned to the client.

The IRS uses the configured Keycloak server to validate access tokens. By default, this is the Catena-X INT Keycloak instance. Get in contact with them to receive your client credentials.

To obtain an access token, you can use the prepared Postman collection.

Sample calls

Start a job for a globalAssetId:

curl -X 'POST' \
  'http://localhost:8080/irs/jobs' \
  -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -H 'Authorization: Bearer <token_value>' \
  -d '{
  "aspects": [
    "SerialPartTypization"
  ],
  "bomLifecycle": "asBuilt",
  "depth": 1,
  "direction": "downward",
  "globalAssetId": "urn:uuid:8a61c8db-561e-4db0-84ec-a693fc5ffdf6"
}'

Retrieve the job results by using the jobId returned by the previous call:

curl -X 'GET' 'http://localhost:8080/irs/jobs/<jobID>' -H 'accept: application/json' -H 'Authorization: Bearer <token_value>'

Documentation

Licenses

Apache 2.0 (https://www.apache.org/licenses/LICENSE-2.0) - see LICENSE