Skip to content

Engineering-Research-and-Development/market4.0-clearing_house

Repository files navigation

IDS clearing house

The IDS clearing house is an intermediary role in the IDS architecture, it is based on the IDSA Clearing House Specifications and his main aim is to provide a broad set of supporting clearing and settlement functions in alignment with the IDS service architecture approach.

In the IDSA Scenario through the clearing house the connector brokers could register and log transactions in order to prove the correct information transfer across them.

Our implementation is based on a Blockchain Network in order to distribute the clearing functionalities on multiple nodes. Each node keeps a global state of the transactions.

The Blockchain implementation is based on Hyperledger Fabric a permissioned DLT, mainly used in Enterprise software scenarios.

The IDS clearing house software release is composed by two components:

API Documentation

The API is composed by three Operations:

Endpoint Input Output Description
GET /data Parameter Id (String) of the class de.fraunhofer.iais.eis.LogNotification *NotificationContent Object Retrieve all transaction by a specific Id
POST /data Parameter notificationContent of class NotificationContent Success or Failure Record a new transaction
GET /data/all
List of NotificationContent Objects Retrieve all transactions

*The it.eng.idsa.clearinghouse.model.NotificationContent is a new Model composed by an header within a LogNotification and a Body composed by a Message object and a string payload.

The size of the payload is limited to 64 characters.

Under an example of the Model in JSON format and a diagram showing the NotificationContent components.

{

"header": {

"@type": "ids:LogNotification",

"issuerConnector": "auto-generated",

"securityToken": null,

"issued": "2020-07-02T07:11:55.825Z",

"modelVersion": null,

"recipientConnector": null,

"recipientAgent": null,

"correlationMessage": null,

"senderAgent": null,

"authorizationToken": null,

"transferContract": null,

"contentVersion": null,

"@id":

" https://w3id.org/idsa/autogen/logNotification/ce5d4853-80c7-4f65-b800-31bcc64d7bce"

},

"body": {

"header": {

"@type": "ids:Message",

"issuerConnector": "http://iais.fraunhofer.de/ids/mdm-connector",

"securityToken": null,

"issued": "2019-05-27T13:09:42.306Z",

"modelVersion": "1.0.2-SNAPSHOT",

"recipientConnector": null,

"recipientAgent": null,

"correlationMessage": "http://industrialdataspace.org/connectorUnavailableMessage/1a421b8c-3407-44a8-aeb9-253f145c869a",

"senderAgent": null,

"authorizationToken": null,

"transferContract":

"https://mdm-connector.ids.isst.fraunhofer.de/examplecontract/bab-bayern-sample/",

"contentVersion": null,

"@id":

"https://w3id.org/idsa/autogen/artifactResponseMessage/eb3ab487-dfb0-4d18-b39a-585514dd044f"

},

"payload": " dafd135e0c9e7d80b615de88effb15233a68026361bdf4cad0fba26d82040be2"

}

}

* The LogMessage and Message are part of the IDSA Information Model.

How to Configure and Run

Prerequisites

  • Linux Environment.
  • Administrative access to the machine.
  • Access to Internet.
  • Install Hyperledger Fabric version 1.4 following this installation guide available here.

Chaincode Installation

Service Installation

  • Clone the repository: git clone https://github.com/Engineering-Research-and-Development/ market4.0-clearing_house.git
  • Go to the clearing-house-apifolder and edit the docker-compose.yaml, using your own user , volumes containing the wallet with the identities and the crypto-config folder with the digital certificates to access the Blockchain.

version: '2.2'

services:

clearing-house:

image: market4.0/clearing-house

ports:

  • 8080:8080

environment:

  • SPRING_PROFILES_ACTIVE=container

  • PORT=8080

  • LOG_LEVEL=info

  • WALLET_PATH=/wallet

  • USER_NAME= user1

  • CHAINCODE_NAME=clearing-house-chaincode

  • CERT_FILENAME=/crypto-config/peerOrganizations/org1.example.com/users/ User1@org1.example.com/msp/signcerts/User1@org1.example.com-cert.pem

  • KEYSTORE_FILENAME=/crypto-config/peerOrganizations/org1.example.com/users/ User1@org1.example.com/msp/keystore/keystore_sk

  • NETWORK_FILENAME=connection_container.json

volumes:

  • ./wallet:/ wallet

  • /crypto-config:/ crypto-config

external_links:

  • ca.example.com

  • orderer.example.com

  • peer0.org1.example.com

  • peer1.org1.example.com

  • peer2.org1.example.com

  • peer3.org1.example.com

command: --spring.profiles.active=container

network_mode: configurationservice_byfn

  • Execute in a terminal the command: bash dockerize.sh in order to start the service.

The Clearing House Service is now reachable at: http://<your_host>:8080/swagger-ui.html#

How to Test

All the APIs are documented and testable via Swagger using the Service URL:

http://<your_host>:8080/swagger-ui.html#