Skip to content

An EDC compatible python implementation of the IDS protocol - for learning purposes - NOT production ready

License

Notifications You must be signed in to change notification settings

boschresearch/py-cx-ids

Repository files navigation

Introduction

This project is for research and development of Catena-X and the Dataspace Protocol.

This repository contains work that has been funded by Catena-X:

Catena-X funded project

Project structure

edc-dev-env

A easy developpment environment that spawns up a Consumer and Provider EDC with official 'product-edc' images.

pycxids

edc

To call EDC data management endpoints

registry

To call AAS Registry

models

Contains generated models from openapi specs or self defined models.

core

Some core components to e.g. get a DAPS token or negotiate (without the EDC), but purely on an IDS protocol level.

CLI - command line interface

The cli uses the pycxids core module, meaning the one without EDC connection, but purely on the IDS protocol level.

The cli needs a webhook-service up and running with a public endpoint. The cli uses this to receive async responses from the provider. This is required because of the IDS multipart async protocol design.

setup of the webhook-service

pip install --no-cache-dir --upgrade git+https://github.com/boschresearch/py-cx-ids.git@dev

export CONSUMER_CONNECTOR_URN=urn:uuid:yourconnectorname
export CONSUMER_WEBHOOK=http://yourservernamehere:8000/webhook
export PRIVATE_KEY_FN=./your_private.key

python -m pycxids.core.ids_multipart.webhook_fastapi

Or have a look into ./edc-dev-env/docker-compose-helpers.yaml and ./edc-dev-env/docker/webhook-service/Dockerfile

Using the CLI - some useful commands

# Setup the cli
./cli.py init

# print the catalog
./cli.py catalog

# find all assets from a catalog
./cli.py catalog | ./cli.py assets

# fetch each asset from the catalog. Confirm each with 'y'
./cli.py catalog | ./cli.py assets | xargs --interactive -L 1 ./cli.py fetch

# fetch each asset from the catalog and save results in given output directory
./cli.py catalog | ./cli.py assets | xargs -L 1 ./cli.py fetch --out-dir ./my-out-dir

Development

Test execution examples

Various ways to run the tests

# with pytest (which reads pytest.ini)
pytest tests/test_assets.py

# from file - with PYTHONPATH set
PYTHONPATH=./ python tests/test_assets.py

# as a module
python -m pytest tests/test_assets.py
python -m pytest pycxids/demo/assetstructure/test_with_registry.py

About

An EDC compatible python implementation of the IDS protocol - for learning purposes - NOT production ready

Resources

License

Stars

Watchers

Forks

Packages

No packages published