diff --git a/README.md b/README.md index 1833c8b1..25e67fdb 100644 --- a/README.md +++ b/README.md @@ -1,117 +1,65 @@ # tests-untp -UNTP mock implementation is a mock app that presents how the decentralized app works. There are three main packages in this repository: components, core, and services. The components package contains the UI components, the core package plays the role of the render page by using the components package and interacting with the services package and the services package contains the business logic. +The UNTP Test Suite is a comprehensive set of tools designed to ensure conformance to the UN Transparency Protocol (UNTP). This repository contains the following key components: + +1. Mock Apps: Demonstrating how decentralized applications work within the UNTP ecosystem. +2. Test Suites: Covering three tiers of testing - technical interoperability, semantic interoperability, and graph validation. +3. Documentation Site: Providing detailed information on setup, configuration, and usage. + +The Mock Apps are structured into three main packages: +- Components: Contains the UI components. +- Core: Handles rendering and interaction between components and services. +- Services: Contains the business logic. + +These tools allow implementers to model value chains, test UNTP functionality in real-world scenarios, and ensure their implementations align with the UNTP specification across various aspects of interoperability and validation. ## Prerequisites - [Node.js](https://nodejs.org/en/) version 20.12.2 - [yarn](https://yarnpkg.com/) version 1.22.22 +- [Docker](https://www.docker.com/get-started) and [Docker Compose](https://docs.docker.com/compose/install/) (for running services) -### Install dependencies +## Setup -```bash -yarn install -``` - -### Copy the .app-config.example file to .env for the demo explorer +To set up and run the mock app: -```bash -cp packages/mock-app/src/constants/app-config.example.json packages/mock-app/src/constants/app-config.json -``` +1. Install dependencies: + ```bash + yarn install + ``` -### Update the app-config.json file with the correct values, for example: - -```json -{ - "services": [ - { - "name": "processDPP", // Service name - "parameters": [ - { - "vckit": { - "vckitAPIUrl": "https://vckit.example.com", // URL of the VC API - "issuer": "did:web:vckit.example.com" // Issuer DID - }, - "dpp": { - "context": ["https://dpp.example.com/dppld.json"], // DPP context, please refer to the DPP documentation, if it is not provided, the error message will be displayed - "renderTemplate": [{ "template": "

Render dpp template

", "@type": "WebRenderingTemplate2022" }], - "type": ["DigitalProductPassport"], - "dlrLinkTitle": "Livestock Passport", - "dlrIdentificationKeyType": "gtin", - "dlrVerificationPage": "http://dlr.example.com/verify" // DLR verification page - }, - - "dlr": { - "dlrAPIUrl": "http://dlr.example.com", // DLR API URL - "dlrAPIKey": "5555555555555" - }, - "storage": { - "url": "https://storage.example.com", // Storage API URL - "params": { - "resultPath": "" // Path to access the credential or the link to the credential within the API response - }, - // Optional parameters - "options": { - "method": "POST", - "headers": { - "Content-Type": "application/json" - } - } - } - } - ] - } - ] -} -``` +2. Build the package: + ```bash + yarn build + ``` -### Build the package +3. Start the project: + ```bash + yarn start + ``` -```bash -yarn build -``` +## Docker Compose Configuration -### Start the project +We provide a Docker Compose configuration to easily set up the required services (Verifiable Credential Service, Storage Service, a database for the VC service) and the documentation site. To start these services: ```bash -yarn start -``` - -## Documentation - -``` -$ cd documentation +docker-compose up -d ``` -### Installation +This will start pre-configured instances of the necessary services and the documentation site. The `app-config.json` mock app config file is pre-configured to work with these Docker services. -``` -$ yarn -``` +## Documentation -### Local Development +For detailed information about the configuration, services, and how to use the mock app, please refer to the documentation site. -``` -$ yarn start -``` - -## Docker +The documentation site is available at [`http://localhost:3002`](http://localhost:3002) after starting the services with Docker Compose. -- Dockerfile - Build image +If you need to run the documentation site manually: ```bash -docker build --build-arg CONFIG_FILE=./app-config.json -t mock-app:latest . -``` - -Run image - -```bash -docker run -p 3000:80 mock-app:latest +cd documentation +yarn install +yarn start ``` -- Docker compose - -```bash -docker-compose up -d -``` +Please consult the documentation for comprehensive instructions on setting up and using the mock app, regardless of whether you're using Docker Compose or setting up services manually. \ No newline at end of file diff --git a/app-config.json b/app-config.json index e6994ad8..31b0c812 100644 --- a/app-config.json +++ b/app-config.json @@ -1,5 +1,5 @@ { - "name": "ACRS", + "name": "Truffle Value Chain", "styles": { "primaryColor": "rgb(35, 138, 186)", "secondaryColor": "black", @@ -19,16 +19,14 @@ ], "apps": [ { - "name": "Top Line Steel", + "name": "Truffle Farm", "type": "producer", "assets": { - "logo": "https://storage.googleapis.com/acrs-assets/logos/Top-Line-Steel-Logo.jpg", - "brandTitle": "Top Line Steel", - "passportVC": "", - "transactionEventVC": "" + "logo": "truffle-farm-logo.webp", + "brandTitle": "Truffle Farm" }, "styles": { - "primaryColor": "#b22166", + "primaryColor": "#b5651d", "secondaryColor": "#391561", "tertiaryColor": "#ffffff" }, @@ -560,1278 +558,78 @@ } }, "data": { + "image": "", "productIdentifier": [ { - "scheme": "https://identifier.example.org/steel", - "identifierValue": "0109359502000010", + "scheme": "https://id.gs1.org/gtin", + "identifierValue": "0105012345678900", "binding": { "type": "document", "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/steel/12345/binding" + "reference": "https://id.gs1.org/gtin/05012345678900/binding" } } ], "batchIdentifier": [ { - "scheme": "https://batch.example.org", - "identifierValue": "BATCH-67890", + "scheme": "https://trufflefarm.example.org/batch", + "identifierValue": "BATCH-2024-001", "binding": { "type": "document", "assuranceLevel": "3rdParty", - "reference": "https://batch.example.org/67890/binding" + "reference": "https://trufflefarm.example.org/batch/2024-001/binding" } } ], "itemIdentifier": [ { - "scheme": "https://item.example.org", - "identifierValue": "ITEM-112233", + "scheme": "https://trufflefarm.example.org/item", + "identifierValue": "TRF-24-0001", "binding": { "type": "document", "assuranceLevel": "3rdParty", - "reference": "https://item.example.org/112233/binding" + "reference": "https://trufflefarm.example.org/item/TRF-24-0001/binding" } } ], "classification": [ { - "scheme": "https://unstats.un.org/unsd/classifications/Econ/cpc", - "classifierValue": "41231", - "classifierName": "Steel Rods", - "classifierURL": "https://vocabulary.uncefact.org/unlocode#AUSYD" + "scheme": "https://www.unspsc.org", + "classifierValue": "50383710", + "classifierName": "Truffles", + "classifierURL": "https://www.unspsc.org/search-code/50383710" } ], - "modelName": "Steel Model X", - "image": "", - "description": "High-quality steel rods for construction.", - "furtherInformation": "https://example.org/products/steel_model_x", - "manufacturedDate": "2024-05-20", + "modelName": "Black Truffle", + "description": "Premium Black Truffles harvested from our sustainable truffle orchards.", + "furtherInformation": "https://trufflefarm.example.org/products/black_perigord", + "manufacturedDate": "2024-01-15", "dimension": { - "weight": { "value": 1500, "unit": "KG" }, - "length": { "value": 6, "unit": "MTR" }, - "width": { "value": 0.1, "unit": "MTR" }, - "height": { "value": 0.1, "unit": "MTR" }, - "volume": { "value": 0.6, "unit": "CMT" } + "weight": { "value": 50, "unit": "GRM" } }, - "characteristic": {}, - "manufacturer": { - "id": "did:example:123456789abcdefghi", - "name": "Steel Manufacturer Inc.", - "identifiers": [ - { - "scheme": "https://identifier.example.org/company", - "identifierValue": "COMP-56789", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/company/56789/binding" - } - } - ] - }, - "manufacturedAt": { - "identifier": [ - { - "scheme": "https://identifier.example.org/facility", - "identifierValue": "FAC-1234", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/facility/1234/binding" - } - } - ], - "name": "Main Steel Plant", - "location": "https://example.org/locations/main_steel_plant", - "operatedBy": { - "id": "did:example:567890abcdefghi", - "name": "Steel Manufacturer Inc.", - "identifiers": [ - { - "scheme": "https://identifier.example.org/company", - "identifierValue": "COMP-56789", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/company/56789/binding" - } - } - ] - } - }, - "materialsProvenance": [ - { - "originCountry": "CN", - "materialType": { - "scheme": "https://textileexchange.org/materials", - "classifierValue": "STEEL", - "classifierName": "Carbon Steel" - }, - "massFraction": 100, - "recycled": false, - "hazardous": false - } - ], - "conformityClaim": [ - { - "topic": "environment.emissions", - "standardOrRegulation": "https://example.org/standards/environment", - "criteriaReference": "https://example.org/standards/environment/criteria", - "claimedValues": [ - { "name": "GHG Emissions", "value": { "value": 50, "unit": "KG_CO2E" }, "accuracy": 0.98 } - ], - "benchmarkValue": { "name": "Industry Benchmark", "value": { "value": 60, "unit": "KG_CO2E" } }, - "benchmarkReference": "https://example.org/benchmarks/environment", - "conformance": true, - "conformityEvidence": { - "type": "w3c_vc", - "assuranceLevel": "3rdParty", - "reference": "https://acrs.pyx.io/verify?q=%7B%22payload%22%3A%7B%22uri%22%3A%22https%3A%2F%2Fstorage.googleapis.com%2Fverifiable-credentials%2Fconformity-credentials%2Facrs-conformity-credential.json%22%7D%7D" - } - } - ], - "recyclingInstruction": "https://example.org/recycling/steel_model_x" - }, - "className": "json-form", - "style": { - "margin": "40px auto", - "paddingTop": "40px", - "width": "80%" - } - } - }, - { - "name": "CustomButton", - "type": "Submit", - "props": {} - } - ], - "services": [ - { - "name": "processDPP", - "parameters": [ - { - "vckit": { - "vckitAPIUrl": "http://localhost:3332/v1", - "issuer": "did:web:example.com" - }, - "dpp": { - "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"], - "renderTemplate": [ - { - "template": "Digital Product Passport

PRODUCT PASSPORT

{{credentialSubject.modelName}}

{{#each credentialSubject.batchIdentifier}}{{/each}} {{#each credentialSubject.productIdentifier}}{{/each}} {{#each credentialSubject.itemIdentifier}}{{/each}}

Sustainability

100%

Confidence

100%

PASSPORT ISSUED BY

{{issuer.name}}

Industry
Unknown
Location
Unknown
Identity verification
Unknown{{!-- {{#if (eq issuer.identifiers.0.binding.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

ESG Claims

Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations

{{#each credentialSubject.conformityClaim}}

{{topic}}

{{claimedValues.0.value.value}}% per {{claimedValues.0.value.unit}}
Claimed
{{benchmarkValue.value.value}}% per {{benchmarkValue.value.unit}}
Benchmark
{{!-- {{#if (eq conformityEvidence.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

View details

{{/each}}

Product composition

A complete list of materials that make up the composition of this product.

{{#each credentialSubject.materialsProvenance}}

{{massFraction}}%

ID {{materialType.classifierValue}}

{{materialType.classifierName}}

{{#if recycled}}

Recycled

{{/if}} {{#if hazardous}}

Hazard

{{/if}}
{{originCountry}}
{{/each}}

Traceability

Traceability events specify the “what, when, where, why and how” of the products and facilities that constitute a value chain.

{{#each credentialSubject.traceabilityInformation}}
{{eventType}}View
{{/each}}

Product information

Manuf. Date

{{credentialSubject.manufacturedDate}}

Batch No.

{{credentialSubject.batchIdentifier.0.identifierValue}}

Weight

{{credentialSubject.dimension.weight.value}}{{credentialSubject.dimension.weight.unit}}

Length

{{credentialSubject.dimension.length.value}}{{credentialSubject.dimension.weight.unit}}

Width

{{credentialSubject.dimension.width.value}}{{credentialSubject.dimension.weight.unit}}

Height

{{credentialSubject.dimension.height.value}}{{credentialSubject.dimension.weight.unit}}

Description

{{credentialSubject.description}}

", - "@type": "WebRenderingTemplate2022" - } - ], - "type": ["VerifiableCredential", " DigitalProductPassport"], - "dlrLinkTitle": "Steel Passport", - "dlrIdentificationKeyType": "gtin", - "dlrVerificationPage": "http://localhost:3000/verify" - }, - "dlr": { - "dlrAPIUrl": "http://localhost:8080", - "dlrAPIKey": "5555555555555" - }, - "storage": { - "url": "http://localhost:3001/upload", - "params": { - "resultPath": "/url" - }, - "options": { - "method": "POST", - "headers": { - "Content-Type": "application/json" - } - } - }, - "identifierKeyPath": "/productIdentifier/0/identifierValue" - } - ] - }, - { - "name": "mergeToLocalStorage", - "parameters": [ - { - "storageKey": "topLineSteel_dpps", - "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue" - } - ] - } - ] - }, - { - "name": "Sale Steel", - "id": "transaction_product", - "components": [ - { - "name": "LocalStorageLoader", - "type": "EntryData", - "props": { - "storageKey": "topLineSteel_dpps", - "nestedComponents": [ - { - "name": "JsonForm", - "type": "EntryData", - "props": { - "schema": { - "type": "object", - "additionalProperties": false, - "properties": { - "sourceParty": { - "$ref": "#/$defs/Party", - "description": "The source party for this supply chain transaction - typically the seller party" - }, - "destinationParty": { - "$ref": "#/$defs/Party", - "description": "The destination party for this supply chain transaction - typically the buyer party." - }, - "epcList": { - "type": "array", - "items": { "$ref": "#/$defs/Item" }, - "description": "The list of uniquely identified trade items included in this supply chain transaction." - }, - "quantityList": { - "type": "array", - "items": { "$ref": "#/$defs/QuantityElement" }, - "description": "List of quantified product classes that are included in this transaction. Used when the trade items do not have unique identifiers (eg 100 reels of yarn)" - }, - "referenceDocument": { - "$ref": "#/$defs/TradeDocument", - "description": "The supply chain document reference for this transaction event - eg the invoice, order, or dispatch advice" - }, - "eventID": { - "x-jargon-isKey": true, - "readOnly": true, - "type": "string", - "description": "The unique identifier of this event - SHOULD be a UUID" - }, - "eventTime": { - "type": "string", - "format": "date-time", - "description": "The ISO-8601 date time when the event occurred." - }, - "action": { - "type": "string", - "enum": ["observe", "add", "delete"], - "example": "observe", - "description": "Code describing how an event relates to the lifecycle of the entity impacted by the event." - }, - "disposition": { - "type": "string", - "x-external-enumeration": "https://ref.gs1.org/cbv/Disp", - "description": "Disposition code describing the state of the item after the event. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/Disp\n " - }, - "bizStep": { - "type": "string", - "x-external-enumeration": "https://ref.gs1.org/cbv/BizStep", - "description": "A business step code drawn from a controlled vocabulary. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/BizStep\n " - }, - "bizLocation": { - "type": "string", - "format": "uri", - "description": "A Business Location is a uniquely identified and discretely recorded geospatial location that is meant to designate the specific place where an object is assumed to be following an EPCIS event until it is reported to be at a different Business Location by a subsequent EPCIS event. The bizLocation must be a resolvable URI that links to facility information and geolocation data." - }, - "sensorElementList": { - "type": "array", - "items": { "$ref": "#/$defs/SensorElement" }, - "description": "An array (one for each sensor) of sensor device data sets associated with the event. " - } - }, - "description": "Transaction represents an event in which one or more objects become associated or disassociated with one or more identified business transactions - such as the purchase / shipment of goods between buyer and seller.", - "$schema": "https://json-schema.org/draft/2020-12/schema", - "$defs": { - "TransactionEvent": { - "type": "object", - "additionalProperties": false, - "properties": { - "sourceParty": { - "$ref": "#/$defs/Party", - "description": "The source party for this supply chain transaction - typically the seller party" - }, - "destinationParty": { - "$ref": "#/$defs/Party", - "description": "The destination party for this supply chain transaction - typically the buyer party." - }, - "epcList": { - "type": "array", - "items": { "$ref": "#/$defs/Item" }, - "description": "The list of uniquely identified trade items included in this supply chain transaction." - }, - "quantityList": { - "type": "array", - "items": { "$ref": "#/$defs/QuantityElement" }, - "description": "List of quantified product classes that are included in this transaction. Used when the trade items do not have unique identifiers (eg 100 reels of yarn)" - }, - "referenceDocument": { - "$ref": "#/$defs/TradeDocument", - "description": "The supply chain document reference for this transaction event - eg the invoice, order, or dispatch advice" - }, - "eventID": { - "x-jargon-isKey": true, - "readOnly": true, - "type": "string", - "description": "The unique identifier of this event - SHOULD be a UUID" - }, - "eventTime": { - "type": "string", - "format": "date-time", - "description": "The ISO-8601 date time when the event occurred." - }, - "action": { - "type": "string", - "enum": ["observe", "add", "delete"], - "example": "observe", - "description": "Code describing how an event relates to the lifecycle of the entity impacted by the event." - }, - "disposition": { - "type": "string", - "x-external-enumeration": "https://ref.gs1.org/cbv/Disp", - "description": "Disposition code describing the state of the item after the event. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/Disp\n " - }, - "bizStep": { - "type": "string", - "x-external-enumeration": "https://ref.gs1.org/cbv/BizStep", - "description": "A business step code drawn from a controlled vocabulary. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/BizStep\n " - }, - "bizLocation": { - "type": "string", - "format": "uri", - "description": "A Business Location is a uniquely identified and discretely recorded geospatial location that is meant to designate the specific place where an object is assumed to be following an EPCIS event until it is reported to be at a different Business Location by a subsequent EPCIS event. The bizLocation must be a resolvable URI that links to facility information and geolocation data." - }, - "sensorElementList": { - "type": "array", - "items": { "$ref": "#/$defs/SensorElement" }, - "description": "An array (one for each sensor) of sensor device data sets associated with the event. " - } - }, - "description": "Transaction represents an event in which one or more objects become associated or disassociated with one or more identified business transactions - such as the purchase / shipment of goods between buyer and seller." - }, - "Party": { - "type": "object", - "additionalProperties": false, - "properties": { - "id": { - "type": "string", - "description": "The decentralised identifier of the party - must be a W3C DID." - }, - "name": { - "type": "string", - "description": "The name of the organization or company, represented as a text string." - }, - "identifiers": { - "type": "array", - "items": { "$ref": "#/$defs/Identifier" }, - "description": "A list of unique business identifiers assigned to the party - such as tax registration numbers." - } - }, - "description": "The Party class represents an entity such as an organization, or a company that manufactured the product." - }, - "Identifier": { - "type": "object", - "additionalProperties": false, - "properties": { - "scheme": { - "type": "string", - "format": "uri", - "description": "the identifier scheme as defined by the registrar that manages the identifier registry. If the identifier scheme is registered with UNTP then this URI can use used to dicsover the resolution method (to get more data) and the verification method (to prove ownership)." - }, - "identifierValue": { - "type": "string", - "description": "The value of the identifier within the scheme" - }, - "binding": { - "$ref": "#/$defs/Evidence", - "description": "Link to evidence that attests to the validity and ownership of the identifer. " - } - }, - "description": "An identifier of a party, product, or facility that is defined by an identifier scheme and idenfier value and, optinally, verification evidence " - }, - "Evidence": { - "type": "object", - "additionalProperties": false, - "properties": { - "type": { - "type": "string", - "enum": ["w3c_vc", "iso_mdl", "document", "website", "other"], - "example": "w3c_vc", - "description": "Format of the evidence (verifiable credential, document, website, etc)" - }, - "assuranceLevel": { - "type": "string", - "enum": ["Self", "Commercial", "Buyer", "Membership", "Unspecified", "3rdParty"], - "example": "Self", - "description": "The assurance level of the evidence (self declaration, 2nd party, 3rd party, accredited auditor)" - }, - "reference": { - "type": "string", - "format": "uri", - "description": "The URL at which the evidence data can be found. " - } - }, - "description": "Evidence to support a conformity or identity claim. " - }, - "Item": { - "type": "object", - "additionalProperties": false, - "properties": { - "itemID": { - "x-jargon-isKey": true, - "type": "string", - "format": "uri", - "description": "The globally unique identifier (eg GS1 GTIN or digital link) of the product item. " - }, - "name": { - "type": "string", - "description": "The name of the product class to which the product item belongs. " - } - }, - "description": "A specific trade item /product code which could be either a product serial number or a consignment identifier " - }, - "QuantityElement": { - "type": "object", - "additionalProperties": false, - "properties": { - "epcClass": { - "type": "string", - "format": "uri", - "description": "THe identifier of a product class (as opposed to a product instance) such as a GTIN code for a manufactured product." - }, - "quantity": { - "type": "number", - "description": "The numeric quantity of the product class (eg 100 kg of cotton)" - }, - "uom": { - "type": "string", - "x-external-enumeration": "https://vocabulary.uncefact.org/UnitMeasureCode", - "description": "The unit of measure for the quantity value (eg Kg or meters etc) using the UNECE Rec 20 unit of measure codelist.\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://vocabulary.uncefact.org/UnitMeasureCode\n " - } - }, - "description": "The quantity element is used to define the quantities (eg 100), units of measure (eg Kg) and product class (eg GTIN or other class identifier) of products that are inputs or outputs or the subject of supply chain events. ", - "required": ["quantity"] - }, - "TradeDocument": { - "type": "object", - "additionalProperties": false, - "properties": { - "type": { - "type": "string", - "x-external-enumeration": "https://ref.gs1.org/cbv/BTT", - "description": "The document type representing the trade transaction drawn from the business transaction type vocabulary.\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/BTT\n " - }, - "identifier": { - "type": "string", - "description": "The identifier of the trade transaction document - eg an invoice number or bill of lading number. Must be unique for a given source party" - }, - "documentURL": { - "type": "string", - "format": "uri", - "description": "The URL of the referenced trade document. For integrity reasons, it is recommended (but not required) that the documentURL is a hashlink (https://w3c-ccg.github.io/hashlink/) so that if the document the URL is changed then the hash verification will fail." - } - }, - "description": "A trade transaction between two parties such as an invoice, purchase order, or shipping notification." - }, - "SensorElement": { - "type": "object", - "additionalProperties": false, - "properties": { - "sensorMetadata": { - "$ref": "#/$defs/Sensor", - "description": "Data that describes the physical sensor that recorded the sensor data set." - }, - "sensorReport": { - "type": "array", - "items": { "$ref": "#/$defs/SensorData" }, - "description": "A list of sensor readings from the given sensor relevant to the traceability event context." - }, - "sensorIntegrityProof": { - "type": "string", - "format": "uri", - "description": "An optional reference to a verifiable credential signed by the sensor device or device manufacturer that contains the digitally signed raw data associated with this sensor report." - } - }, - "description": "A SensorElement is used to carry data related to an event that is captured one sensor such as an IoT device. Include one sensor property and an array of sensor data values." - }, - "Sensor": { - "type": "object", - "additionalProperties": false, - "properties": { - "device": { - "$ref": "#/$defs/Item", - "description": "The device Identifier for the sensor as a URI (typically an EPC)" - }, - "dataProcessingMethod": { - "type": "string", - "format": "uri", - "description": "The data processing method used by the sensor - should reference a documented standard criteria as a URI" - } - }, - "description": "A physical sensor that records a sensor data set." - }, - "SensorData": { - "type": "object", - "additionalProperties": false, - "properties": { - "time": { - "type": "string", - "format": "date-time", - "description": "the timestamp at which the sensor reading was made." - }, - "type": { - "type": "string", - "format": "uri", - "description": "the measurement type of the sensor reading, as a URI reference to a measurement method specification." - }, - "value": { "type": "number", "description": "the sensor reading" }, - "uom": { - "type": "string", - "x-external-enumeration": "https://vocabulary.uncefact.org/UnitMeasureCode", - "description": "the unit of measure for the sensor reading\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://vocabulary.uncefact.org/UnitMeasureCode\n " - } - }, - "description": "A data point read by a sensor." - } - } - } - }, - "constructData": { - "mappingFields": [ - { - "sourcePath": "/vc/credentialSubject/productIdentifier/0/identifierValue", - "destinationPath": "/eventID" - }, - { - "sourcePath": "/vc/credentialSubject/productIdentifier/0/identifierValue", - "destinationPath": "/epcList/index/name" - }, - { - "sourcePath": "/linkResolver", - "destinationPath": "/epcList/index/itemID" - } - ], - "dummyFields": [ - { - "path": "/action", - "data": "observe" - }, - { - "path": "/disposition", - "data": "https://ref.gs1.org/cbv/Disp/in_transit" - }, - { - "path": "/bizStep", - "data": "https://ref.gs1.org/cbv/BizStep/receiving" - }, - { - "path": "/bizLocation", - "data": "https://example.com/warehouse" - }, - { - "path": "/sourceParty", - "data": { - "id": "did:web:api.acrs.pyx.io:top-line-steel", - "name": "Top Line Steel", - "identifiers": [ - { - "scheme": "https://example.com/scheme/source", - "identifierValue": "SRC123456", - "binding": { - "type": "w3c_vc", - "assuranceLevel": "3rdParty", - "reference": "https://example.com/source_evidence" - } - } - ] - } - }, - { - "path": "/destinationParty", - "data": { - "id": "did:web:api.acrs.pyx.io:steel-processor", - "name": "Steel Processor", - "identifiers": [ - { - "scheme": "https://example.com/scheme/destination", - "identifierValue": "DST7891011", - "binding": { - "type": "w3c_vc", - "assuranceLevel": "3rdParty", - "reference": "https://example.com/destination_evidence" - } - } - ] - } - } - ], - "generationFields": [ - { - "path": "/eventID", - "handler": "generateIdWithSerialNumber" - }, - { - "path": "/eventTime", - "handler": "generateCurrentDatetime" - } - ] - } - } - ] - } - }, - { - "name": "CustomButton", - "type": "Submit", - "props": { - "includeDownload": true, - "downloadFileName": "transaction" - } - } - ], - "services": [ - { - "name": "processTransactionEvent", - "parameters": [ - { - "vckit": { - "vckitAPIUrl": "http://localhost:3332/v1", - "issuer": "did:web:example.com" - }, - "epcisTransactionEvent": { - "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"], - "renderTemplate": [ - { - "template": "Transaction Event

TRACEABILITY EVENT

Transaction

EVENT ISSUED BY

{{issuer.name}}

{{#each issuer.identifiers}}
Industry
Needs to be replaced...
Business identifier
Needs to be replaced...
Identity verification
{{identiferValue}}
Verifiable credential
{{/each}}

Event description

Event ID
{{credentialSubject.eventID}}
Event type
Needs to be replaced...
Description
Needs to be replaced...
Time and date
{{credentialSubject.eventTime}}
Lifecycle action
{{credentialSubject.action}}
Product disposition
{{credentialSubject.disposition}}
Business step
{{credentialSubject.bizStep}}

Transaction

{{credentialSubject.sourceParty.name}}

SOURCE

{{credentialSubject.sourceParty.identifiers.0.identifierValue}}

Transferred

{{credentialSubject.destinationParty.name}}

DESTINATION

{{credentialSubject.destinationParty.partyID}}

Object list

{{#each credentialSubject.epcList}}

{{name}}

{{itemID}}

Product class name

Sustainability 0%
Confidence 0%
View
{{/each}}

Sensor

{{#each credentialSubject.sensorElementList}}
{{sensorMetadata.device.name}}
{{#each sensorReport}}

{{time}}

Data type

{{value}} {{uom}}

{{/each}}{{sensorIntegrityProof}}
Other evidence
{{/each}}
", - "@type": "WebRenderingTemplate2022" - } - ], - "type": ["TransactionEventCredential"], - "dlrLinkTitle": "Transaction Event", - "dlrIdentificationKeyType": "gtin", - "dlrVerificationPage": "http://localhost:3000/verify" - }, - "dlr": { - "dlrAPIUrl": "http://localhost:8080", - "dlrAPIKey": "5555555555555" - }, - "storage": { - "url": "http://localhost:3001/upload", - "params": { - "resultPath": "/url" - }, - "options": { - "method": "POST", - "headers": { - "Content-Type": "application/json" - } - } - }, - "identifierKeyPath": "/eventID", - "localStorageParams": { "storageKey": "topLineSteel_dpps", "keyPath": "/epcList/index/name" } - } - ] - } - ] - } - ] - }, - { - "name": "Quality Steel", - "type": "producer", - "assets": { - "logo": "https://storage.googleapis.com/acrs-assets/logos/Quality-Steel-Logo.png", - "brandTitle": "Quality Steel", - "passportVC": "", - "transactionEventVC": "" - }, - "styles": { - "primaryColor": "#000000", - "secondaryColor": "#391561", - "tertiaryColor": "#ffffff" - }, - "features": [ - { - "name": "Issue DPP", - "id": "produce_product", - "components": [ - { - "name": "JsonForm", - "type": "EntryData", - "props": { - "schema": { - "type": "object", - "additionalProperties": false, - "properties": { - "productIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "An array of unique identifiers assigned to the product or model. " - }, - "batchIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "Information regarding the specific production batch of the product." - }, - "itemIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "An array of identifiers representing a specific serialised item of the product." - }, - "classification": { - "type": "array", - "items": { - "$ref": "#/$defs/Classification" - }, - "description": "A code representing the product's class, typically using the UN CPC (United Nations Central Product Classification) https://unstats.un.org/unsd/classifications/Econ/cpc" - }, - "modelName": { - "type": "string", - "description": "The model name or number of the product, represented as text." - }, - "image": { - "$ref": "#/$defs/BinaryFile", - "description": "A unique identifier (URI) pointing to an image of the product." - }, - "description": { - "type": "string", - "description": "A textual description providing details about the product." - }, - "furtherInformation": { - "type": "string", - "format": "uri", - "description": "A URL pointing to further human readable information about the product." - }, - "manufacturedDate": { - "type": "string", - "format": "date", - "description": "The ISO 8601 date on which the product batch was manufactured." - }, - "dimension": { - "$ref": "#/$defs/Dimension", - "description": "The physical dimensions of the product. Not every dimension is relevant to every products. For example bulk materials may have wieght and volume but not length, with, or height." - }, - "characteristic": { - "$ref": "#/$defs/Characteristic", - "description": "" - }, - "manufacturer": { - "$ref": "#/$defs/Party", - "description": "The Party entity that manufactured the product." - }, - "manufacturedAt": { - "$ref": "#/$defs/Facility", - "description": "The Facility where the product batch was manufactured." - }, - "materialsProvenance": { - "type": "array", - "items": { - "$ref": "#/$defs/Material" - }, - "description": "An array of Provenance objects providing details on the origin and mass fraction of components or ingredients of the product batch." - }, - "conformityClaim": { - "type": "array", - "items": { - "$ref": "#/$defs/Claim" - }, - "description": "An array of claim objects representing various product conformity claims about the product / batch. These can be sustainability claims, circularity claims, or any other claim type within the conformity topic list." - }, - "recyclingInstruction": { - "type": "string", - "format": "uri", - "description": "A URI pointing to information regarding the recycling aspects of the product." - }, - "traceabilityInformation": { - "type": "array", - "items": { - "$ref": "#/$defs/TraceabilityEvent" - }, - "description": "An array of TraceabilityEvent objects detailing EPCIS events related to the traceability of the product batch." - } - }, - "description": "The ProductInformation class encapsulates detailed information regarding a specific product, including its identification details, manufacturer, and other pertinent details.", - "$schema": "https://json-schema.org/draft/2020-12/schema", - "$defs": { - "Product": { - "type": "object", - "additionalProperties": false, - "properties": { - "productIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "An array of unique identifiers assigned to the product or model. " - }, - "batchIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "Information regarding the specific production batch of the product." - }, - "itemIdentifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "An array of identifiers representing a specific serialised item of the product." - }, - "classification": { - "type": "array", - "items": { - "$ref": "#/$defs/Classification" - }, - "description": "A code representing the product's class, typically using the UN CPC (United Nations Central Product Classification) https://unstats.un.org/unsd/classifications/Econ/cpc" - }, - "modelName": { - "type": "string", - "description": "The model name or number of the product, represented as text." - }, - "image": { - "$ref": "#/$defs/BinaryFile", - "description": "A unique identifier (URI) pointing to an image of the product." - }, - "description": { - "type": "string", - "description": "A textual description providing details about the product." - }, - "furtherInformation": { - "type": "string", - "format": "uri", - "description": "A URL pointing to further human readable information about the product." - }, - "manufacturedDate": { - "type": "string", - "format": "date", - "description": "The ISO 8601 date on which the product batch was manufactured." - }, - "dimension": { - "$ref": "#/$defs/Dimension", - "description": "The physical dimensions of the product. Not every dimension is relevant to every products. For example bulk materials may have wieght and volume but not length, with, or height." - }, - "characteristic": { - "$ref": "#/$defs/Characteristic", - "description": "" - }, - "manufacturer": { - "$ref": "#/$defs/Party", - "description": "The Party entity that manufactured the product." - }, - "manufacturedAt": { - "$ref": "#/$defs/Facility", - "description": "The Facility where the product batch was manufactured." - }, - "materialsProvenance": { - "type": "array", - "items": { - "$ref": "#/$defs/Material" - }, - "description": "An array of Provenance objects providing details on the origin and mass fraction of components or ingredients of the product batch." - }, - "conformityClaim": { - "type": "array", - "items": { - "$ref": "#/$defs/Claim" - }, - "description": "An array of claim objects representing various product conformity claims about the product / batch. These can be sustainability claims, circularity claims, or any other claim type within the conformity topic list." - }, - "recyclingInstruction": { - "type": "string", - "format": "uri", - "description": "A URI pointing to information regarding the recycling aspects of the product." - }, - "traceabilityInformation": { - "type": "array", - "items": { - "$ref": "#/$defs/TraceabilityEvent" - }, - "description": "An array of TraceabilityEvent objects detailing EPCIS events related to the traceability of the product batch." - } - }, - "description": "The ProductInformation class encapsulates detailed information regarding a specific product, including its identification details, manufacturer, and other pertinent details." - }, - "Identifier": { - "type": "object", - "additionalProperties": false, - "properties": { - "scheme": { - "type": "string", - "format": "uri", - "description": "the identifier scheme as defined by the registrar that manages the identifier registry. If the identifier scheme is registered with UNTP then this URI can use used to dicsover the resolution method (to get more data) and the verification method (to prove ownership)." - }, - "identifierValue": { - "type": "string", - "description": "The value of the identifier within the scheme" - }, - "binding": { - "$ref": "#/$defs/Evidence", - "description": "Link to evidence that attests to the validity and ownership of the identifer. " - } - }, - "description": "An identifier of a party, product, or facility that is defined by an identifier scheme and idenfier value and, optinally, verification evidence " - }, - "Evidence": { - "type": "object", - "additionalProperties": false, - "properties": { - "type": { - "type": "string", - "enum": ["w3c_vc", "iso_mdl", "document", "website", "other"], - "example": "w3c_vc", - "description": "Format of the evidence (verifiable credential, document, website, etc)" - }, - "assuranceLevel": { - "type": "string", - "enum": ["Self", "Commercial", "Buyer", "Membership", "Unspecified", "3rdParty"], - "example": "Self", - "description": "The assurance level of the evidence (self declaration, 2nd party, 3rd party, accredited auditor)" - }, - "reference": { - "type": "string", - "format": "uri", - "description": "The URL at which the evidence data can be found. " - } - }, - "description": "Evidence to support a conformity or identity claim. " - }, - "Classification": { - "type": "object", - "additionalProperties": false, - "properties": { - "scheme": { - "type": "string", - "format": "uri", - "description": "Classification scheme - eg https://unstats.un.org/unsd/classifications/Econ/cpc " - }, - "classifierValue": { - "type": "string", - "description": "classifier value within the scheme - eg \"01211\" in UN CPC" - }, - "classifierName": { - "type": "string", - "description": "Name of the classifier - eg \"Asparagus\" for code \"01211\" in UNCPC" - }, - "classifierURL": { - "type": "string", - "format": "uri", - "description": "Linked data URL to a web vocabulary entery for this classificaiton code. When this property is provided, the scheme, value, and name properties of the classifer are not required. eg https://vocabulary.uncefact.org/unlocode#AUBNE represensign the port of Brisbane in the UN/LOCODE classification scheme." - } - }, - "description": "A classification scheme and code / name representing a category value for a product, entity, or facility." - }, - "BinaryFile": { - "type": "object", - "additionalProperties": false, - "properties": { - "fileHash": { - "x-jargon-isKey": true, - "type": "string", - "description": "The MD5 hash of the file." - }, - "fileLocation": { - "type": "string", - "format": "uri", - "description": "The location of the evidence file." - }, - "fileType": { - "type": "string", - "x-external-enumeration": "https://mimetype.io/all-types", - "description": "The type of file, represented as a MIME type.\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://mimetype.io/all-types\n " - } - }, - "description": "A file representing a data snapshot that is used to infomr the conformity assessment." - }, - "Dimension": { - "type": "object", - "additionalProperties": false, - "properties": { - "weight": { - "$ref": "#/$defs/Measure", - "description": "the weight of the product" - }, - "length": { - "$ref": "#/$defs/Measure", - "description": "The length of the product or packaging" - }, - "width": { - "$ref": "#/$defs/Measure", - "description": "The width of the product or packaging" - }, - "height": { - "$ref": "#/$defs/Measure", - "description": "The height of the product or packaging" - }, - "volume": { - "$ref": "#/$defs/Measure", - "description": "The displacement volume of the product." - } - }, - "description": "Overall (length, width, height) dimensions and weight/volume of an item." - }, - "Measure": { - "type": "object", - "additionalProperties": false, - "properties": { - "value": { - "type": "number", - "description": "The numeric value of the measure" - }, - "unit": { - "type": "string", - "x-external-enumeration": "https://vocabulary.uncefact.org/UnitMeasureCode", - "description": "Unit of measure drawn from the UNECE rec20 measure code list.\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://vocabulary.uncefact.org/UnitMeasureCode\n " - } - }, - "description": "The measure class defines a numeric measured value (eg 10) and a coded unit of measure (eg KG)." - }, - "Characteristic": { - "type": "object", - "additionalProperties": false, - "properties": {}, - "description": "Product specific characteristics. This class is an extension point for industry specific product characteristics or performance information such as clothing size or battery capacity." - }, - "Party": { - "type": "object", - "additionalProperties": false, - "properties": { - "id": { - "type": "string", - "description": "The decentralised identifier of the party - must be a W3C DID." - }, - "name": { - "type": "string", - "description": "The name of the organization or company, represented as a text string." - }, - "identifiers": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "A list of unique business identifiers assigned to the party - such as tax registration numbers." - } - }, - "description": "The Party class represents an entity such as an organization, or a company that manufactured the product." - }, - "Facility": { - "type": "object", - "additionalProperties": false, - "properties": { - "identifier": { - "type": "array", - "items": { - "$ref": "#/$defs/Identifier" - }, - "description": "A unique identifier (URI) assigned to the facility. (Link Resolver - GS1 GLN?)" - }, - "name": { - "type": "string", - "description": "The name of the facility, represented as a text string." - }, - "location": { - "type": "string", - "format": "uri", - "description": "" - }, - "operatedBy": { - "$ref": "#/$defs/Party", - "description": "The Party entity responsible for operating the facility." - } - }, - "description": "The physical site (eg farm or factory) where the product or materials was produced." - }, - "Material": { - "type": "object", - "additionalProperties": false, - "properties": { - "originCountry": { - "type": "string", - "x-external-enumeration": "https://vocabulary.uncefact.org/CountryId", - "description": "A ISO 3166-1 code representing the country of origin of the component or ingredient.\n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://vocabulary.uncefact.org/CountryId\n " - }, - "materialType": { - "$ref": "#/$defs/Classification", - "description": "The type of this material - as a value drawn from a controlled vocabulary eg textileexchange.org/materials/rm01014 - representing organic cotton." - }, - "massFraction": { - "type": "number", - "description": "A numeric value representing the mass fraction of the product represented by this material. The sum of all mass fraction values for a given passport should be 100." - }, - "recycled": { - "type": "boolean", - "description": "Indicator is true if this material input is from a recycled source." - }, - "hazardous": { - "type": "boolean", - "description": "Indicates whether this material is hazardous. If true then " - } - }, - "description": "The material class encapsulates details about the origin or source of raw materials in a product, including the country of origin and the mass fraction." - }, - "Claim": { - "type": "object", - "additionalProperties": false, - "properties": { - "topic": { - "type": "string", - "enum": [ - "environment.energy", - "environment.emissions", - "environment.water", - "environment.waste", - "environment.deforestation", - "environment.biodiversity", - "circularity.content", - "circularity.design", - "social.labour", - "social.rights", - "social.community", - "social.safety", - "governance.ethics", - "governance.compliance", - "governance.transparency" - ], - "example": "environment.energy", - "description": "A code representing the topic of the sustainability claim. E.g. environment.deforestation, environment.ghg-emission-intensity, etc.. Drawn from a standard code list. " - }, - "standardOrRegulation": { - "type": "string", - "format": "uri", - "description": "The standard or regulation against which this conformity claim is made. Expressed as a URI and should match a value in the UN catalogue of reference vocabularies. " - }, - "criteriaReference": { - "type": "string", - "format": "uri", - "description": "A URI pointing to the specific criteria within the standard or regulation against which this claim is made." - }, - "claimedValues": { - "type": "array", - "items": { - "$ref": "#/$defs/Metric" - }, - "description": "One or more actual measures supporting the claim. For example for GHG emissions there may be a metric for total emissions intensity and also a metric for amount of offsets included." - }, - "benchmarkValue": { - "$ref": "#/$defs/Metric", - "description": "A benchmark value against which the claimed value can be assessed. THis could be a value specified by a standard or regulation or could be an industry benchmark." - }, - "benchmarkReference": { - "type": "string", - "format": "uri", - "description": "A refernce to evidence to support the benchmark value." - }, - "conformance": { - "type": "boolean", - "description": "and indicator (boolean) that expresses whether or not this product has achieved compliance against the criteria. for example, if the topic is environment.deforstation and the criteria is EU.2023.1115 then the product is conformant if it has not touched any facility throughout it's lifecycle that is not deforestation free since dec 2020." - }, - "conformityEvidence": { - "$ref": "#/$defs/Evidence", - "description": "A URI pointing to the evidence supporting the claim. Most likely in the form of a verifiable credential." - } - }, - "description": "The SustainabilityClaim class represents specific claims regarding the sustainability of a product, providing details about the metrics, thresholds, and evidences supporting the claim." - }, - "Metric": { - "type": "object", - "additionalProperties": false, - "properties": { - "name": { - "type": "string", - "description": "A human readable name for this metric" - }, - "value": { - "$ref": "#/$defs/Measure", - "description": "A numeric value representing the measurement or evaluation outcome for the claim." - }, - "accuracy": { - "type": "number", - "description": "A percentage represented as a numeric between 0 and 1 indicating the rage of accuracy of the claimed value (eg 0.05 means that the actual value is within 5% of the claimed value.)" - } - }, - "description": "A specific measure of performance against the criteria that governs the claim. Expressed as an array of metric (ie unit of emasure) / value (ie the actual numeric value) pairs. " - }, - "TraceabilityEvent": { - "type": "object", - "additionalProperties": false, - "properties": { - "eventReference": { - "type": "string", - "format": "uri", - "description": "A URI pointing to the detailed information about the EPCIS event. Most likely in the form of a verifiable credential." - }, - "eventType": { - "type": "string", - "enum": ["aggregation", "transformation", "object", "transaction", "association"], - "example": "aggregation", - "description": "A code representing the type of EPCIS event. ObjectEvent, AggregationEvent, TransactionEvent, TransformationEvent, ObjectEvent." - } - }, - "description": "The TraceabilityEvent class represents a specific EPCIS event in the traceability chain of a product, including details about the event type and reference." - } - } - }, - "data": { - "productIdentifier": [ - { - "scheme": "https://identifier.example.org/steel", - "identifierValue": "0109359502000041", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/steel/67890/binding" - } - } - ], - "batchIdentifier": [ - { - "scheme": "https://batch.example.org", - "identifierValue": "BATCH-54321", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://batch.example.org/54321/binding" - } - } - ], - "itemIdentifier": [ - { - "scheme": "https://item.example.org", - "identifierValue": "ITEM-445566", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://item.example.org/445566/binding" - } - } - ], - "classification": [ + "materialsProvenance": [ { - "scheme": "https://unstats.un.org/unsd/classifications/Econ/cpc", - "classifierValue": "41232", - "classifierName": "Steel Beams", - "classifierURL": "https://vocabulary.uncefact.org/unlocode#GBLON" + "originCountry": "AU", + "materialType": { + "scheme": "https://www.gs1.org/gpc", + "classifierValue": "10005953", + "classifierName": "Truffles (Fresh)", + "classifierURL": "https://www.gs1.org/gpc/10005953" + }, + "massFraction": 100, + "recycled": false, + "hazardous": false } ], - "modelName": "Steel Model Y", - "image": "", - "description": "Durable steel beams for construction and infrastructure projects.", - "furtherInformation": "https://example.org/products/steel_model_y", - "manufacturedDate": "2024-06-01", - "dimension": { - "weight": { "value": 2500, "unit": "KG" }, - "length": { "value": 8, "unit": "MTR" }, - "width": { "value": 0.15, "unit": "MTR" }, - "height": { "value": 0.15, "unit": "MTR" }, - "volume": { "value": 1.8, "unit": "CMT" } + "characteristic": { + "variety": "Tuber melanosporum", + "grade": "Extra", + "aroma": "Intense, earthy", + "flavor": "Rich, complex" }, - "characteristic": {}, "manufacturer": { - "id": "did:example:abcdef1234567890", - "name": "Global Steel Co.", + "id": "did:example:123456789abcdefghi", + "name": "Gourmet Truffle Farm", "identifiers": [ { "scheme": "https://identifier.example.org/company", @@ -1848,19 +646,19 @@ "identifier": [ { "scheme": "https://identifier.example.org/facility", - "identifierValue": "FAC-6789", + "identifierValue": "FAC-5678", "binding": { "type": "document", "assuranceLevel": "3rdParty", - "reference": "https://identifier.example.org/facility/6789/binding" + "reference": "https://identifier.example.org/facility/5678/binding" } } ], - "name": "Advanced Steel Plant", - "location": "https://example.org/locations/advanced_steel_plant", + "name": "Truffle Orchard", + "location": "https://trufflefarm.example.org/locations/perigord_orchard", "operatedBy": { - "id": "did:example:0987654321abcdef", - "name": "Global Steel Co.", + "id": "did:example:123456789abcdefghi", + "name": "Gourmet Truffle Farm", "identifiers": [ { "scheme": "https://identifier.example.org/company", @@ -1873,39 +671,7 @@ } ] } - }, - "materialsProvenance": [ - { - "originCountry": "US", - "materialType": { - "scheme": "https://textileexchange.org/materials", - "classifierValue": "STEEL", - "classifierName": "Alloy Steel" - }, - "massFraction": 100, - "recycled": false, - "hazardous": false - } - ], - "conformityClaim": [ - { - "topic": "environment.emissions", - "standardOrRegulation": "https://example.org/standards/environment", - "criteriaReference": "https://example.org/standards/environment/criteria", - "claimedValues": [ - { "name": "GHG Emissions", "value": { "value": 40, "unit": "KG_CO2E" }, "accuracy": 0.99 } - ], - "benchmarkValue": { "name": "Industry Benchmark", "value": { "value": 50, "unit": "KG_CO2E" } }, - "benchmarkReference": "https://example.org/benchmarks/environment", - "conformance": true, - "conformityEvidence": { - "type": "w3c_vc", - "assuranceLevel": "3rdParty", - "reference": "https://acrs.pyx.io/verify?q=%7B%22payload%22%3A%7B%22uri%22%3A%22https%3A%2F%2Fstorage.googleapis.com%2Fverifiable-credentials%2Fconformity-credentials%2Facrs-conformity-credential.json%22%7D%7D" - } - } - ], - "recyclingInstruction": "https://example.org/recycling/steel_model_y" + } }, "className": "json-form", "style": { @@ -1928,30 +694,30 @@ { "vckit": { "vckitAPIUrl": "http://localhost:3332/v1", - "issuer": "did:web:example.com" + "issuer": "did:web:0e37-27-32-93-137.ngrok-free.app" }, "dpp": { "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"], "renderTemplate": [ { - "template": "Digital Product Passport

PRODUCT PASSPORT

{{credentialSubject.modelName}}

{{#each credentialSubject.batchIdentifier}}{{/each}} {{#each credentialSubject.productIdentifier}}{{/each}} {{#each credentialSubject.itemIdentifier}}{{/each}}

Sustainability

100%

Confidence

100%

PASSPORT ISSUED BY

{{issuer.name}}

Industry
Unknown
Location
Unknown
Identity verification
Unknown{{!-- {{#if (eq issuer.identifiers.0.binding.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

ESG Claims

Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations

{{#each credentialSubject.conformityClaim}}

{{topic}}

{{claimedValues.0.value.value}}% per {{claimedValues.0.value.unit}}
Claimed
{{benchmarkValue.value.value}}% per {{benchmarkValue.value.unit}}
Benchmark
{{!-- {{#if (eq conformityEvidence.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

View details

{{/each}}

Product composition

A complete list of materials that make up the composition of this product.

{{#each credentialSubject.materialsProvenance}}

{{massFraction}}%

ID {{materialType.classifierValue}}

{{materialType.classifierName}}

{{#if recycled}}

Recycled

{{/if}} {{#if hazardous}}

Hazard

{{/if}}
{{originCountry}}
{{/each}}

Traceability

Traceability events specify the “what, when, where, why and how” of the products and facilities that constitute a value chain.

{{#each credentialSubject.traceabilityInformation}}
{{eventType}}View
{{/each}}

Product information

Manuf. Date

{{credentialSubject.manufacturedDate}}

Batch No.

{{credentialSubject.batchIdentifier.0.identifierValue}}

Weight

{{credentialSubject.dimension.weight.value}}{{credentialSubject.dimension.weight.unit}}

Length

{{credentialSubject.dimension.length.value}}{{credentialSubject.dimension.weight.unit}}

Width

{{credentialSubject.dimension.width.value}}{{credentialSubject.dimension.weight.unit}}

Height

{{credentialSubject.dimension.height.value}}{{credentialSubject.dimension.weight.unit}}

Description

{{credentialSubject.description}}

", + "template": " Digital Product Passport

PRODUCT PASSPORT

{{credentialSubject.modelName}}

{{#each credentialSubject.batchIdentifier}} {{/each}} {{#each credentialSubject.productIdentifier}} {{/each}}

Sustainability

100%

Confidence

100%

PASSPORT ISSUED BY

{{issuer.name}}

Industry

Agriculture

Business identifier
75 859 224 235
Location
Rooty Hill, NSW
Identity verification
75 859 224 235
Other evidence

Conformity credentials

Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations

{{#each credentialSubject.conformityClaim}}

{{topic}}

{{!-- {{#if (eq conformityEvidence.type 'w3c_vc')}} --}}
Verifiable credential
{{!-- {{/if}} --}}

View details

{{/each}}

Product composition

A complete list of materials that make up the composition of this product.

{{#each credentialSubject.materialsProvenance}}

{{massFraction}}%

ID {{materialType.classifierValue}}

{{materialType.classifierName}}

{{#if recycled}}

Recycled

{{/if}} {{#if hazardous}}

Hazard

{{/if}}
{{originCountry}}
{{/each}}

Product information

Harvest Date

{{credentialSubject.manufacturedDate}}

Batch No.

{{credentialSubject.batchIdentifier.0.identifierValue}}

Weight

{{credentialSubject.dimension.weight.value}}{{credentialSubject.dimension.weight.unit}}

Description

{{credentialSubject.description}}

", "@type": "WebRenderingTemplate2022" } ], - "type": ["VerifiableCredential", " DigitalProductPassport"], - "dlrLinkTitle": "Steel Passport", + "type": ["VerifiableCredential", "DigitalProductPassport"], + "dlrLinkTitle": "Truffle Product Passport", "dlrIdentificationKeyType": "gtin", - "dlrVerificationPage": "http://localhost:3000/verify" + "dlrVerificationPage": "http://localhost:3001/verify" }, - "dlr": { "dlrAPIUrl": "http://localhost:8080", "dlrAPIKey": "5555555555555" }, "storage": { - "url": "http://localhost:3001/upload", + "url": "http://localhost:3334/v1/documents", "params": { - "resultPath": "/url" + "resultPath": "/uri", + "bucket": "verifiable-credentials" }, "options": { "method": "POST", @@ -1968,7 +734,7 @@ "name": "mergeToLocalStorage", "parameters": [ { - "storageKey": "qualitySteel_dpps", + "storageKey": "truffleFarm_dpps", "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue" } ] @@ -1976,14 +742,14 @@ ] }, { - "name": "Sale Steel", + "name": "Sell Truffle", "id": "transaction_product", "components": [ { "name": "LocalStorageLoader", "type": "EntryData", "props": { - "storageKey": "qualitySteel_dpps", + "storageKey": "truffleFarm_dpps", "nestedComponents": [ { "name": "JsonForm", @@ -2344,8 +1110,8 @@ { "path": "/sourceParty", "data": { - "id": "did:web:api.acrs.pyx.io:quality-steel", - "name": "Quality Steel", + "id": "did:web:0e37-27-32-93-137.ngrok-free.app", + "name": "Truffle Farm", "identifiers": [ { "scheme": "https://example.com/scheme/source", @@ -2362,8 +1128,8 @@ { "path": "/destinationParty", "data": { - "id": "did:web:api.acrs.pyx.io:steel-processor", - "name": "Steel Processor", + "id": "did:web:0e37-27-32-93-137.ngrok-free.app", + "name": "Truffle Processor", "identifiers": [ { "scheme": "https://example.com/scheme/destination", @@ -2409,7 +1175,7 @@ { "vckit": { "vckitAPIUrl": "http://localhost:3332/v1", - "issuer": "did:web:example.com" + "issuer": "did:web:0e37-27-32-93-137.ngrok-free.app" }, "epcisTransactionEvent": { "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"], @@ -2422,16 +1188,17 @@ "type": ["TransactionEventCredential"], "dlrLinkTitle": "Transaction Event", "dlrIdentificationKeyType": "gtin", - "dlrVerificationPage": "http://localhost:3000/verify" + "dlrVerificationPage": "http://localhost:3001/verify" }, "dlr": { "dlrAPIUrl": "http://localhost:8080", "dlrAPIKey": "5555555555555" }, "storage": { - "url": "http://localhost:3001/upload", + "url": "http://localhost:3334/v1/documents", "params": { - "resultPath": "/url" + "resultPath": "/uri", + "bucket": "verifiable-credentials" }, "options": { "method": "POST", @@ -2441,410 +1208,7 @@ } }, "identifierKeyPath": "/eventID", - "localStorageParams": { "storageKey": "qualitySteel_dpps", "keyPath": "/epcList/index/name" } - } - ] - } - ] - } - ] - }, - { - "name": "Steel Processor", - "type": "processor", - "assets": { - "logo": "https://storage.googleapis.com/acrs-assets/logos/Steel-Processor-LogoV1.png", - "brandTitle": "Steel Processor", - "passportVC": "", - "transactionEventVC": "" - }, - "styles": { - "primaryColor": "#8f2629", - "secondaryColor": "#391561", - "tertiaryColor": "#ffffff" - }, - "features": [ - { - "name": "Process Steel", - "id": "process_product", - "components": [ - { - "name": "RenderCheckList", - "type": "EntryData", - "props": { - "requiredFieldPath": "/vc/credentialSubject/eventID", - "checkBoxLabel": "Imported valid json:", - "nestedComponents": [ - { - "name": "ImportButton", - "type": "EntryData", - "props": { - "label": "Import JSON", - "style": { "margin": "40px auto", "paddingTop": "40px", "width": "80%" } - } - } - ], - "style": { "margin": "40px auto", "paddingTop": "40px", "width": "80%" } - } - }, - { - "name": "CustomButton", - "type": "Submit", - "props": {} - }, - { - "name": "BarcodeGenerator", - "type": "Result", - "props": { - "dataPath": "/credentialSubject/outputEPCList/index/name" - } - } - ], - "services": [ - { - "name": "processTransformationEvent", - "parameters": [ - { - "epcisTransformationEvent": { - "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transformation-event-ld.json"], - "renderTemplate": [ - { - "template": "Transformation Event

TRACEABILITY EVENT

Transformation

EVENT ISSUED BY

{{issuer.name}}

Industry
Hardcoded value...
Identity verification

Event description

Event ID
{{credentialSubject.eventID}}
Event type
{{credentialSubject.action}}
Description
Hardcoded value...
Time and date
{{credentialSubject.eventTime}}
Lifecycle action
{{credentialSubject.action}}
Product disposition
{{credentialSubject.disposition}}
Business step
{{credentialSubject.bizStep}}
Process type

Transformation

{{#each credentialSubject.outputEPCList}}

{{name}}

OUTPUT

Hardcoded value...

Hardcoded value...

Sustainability Hardcoded value...
Confidence Hardcoded value...
View
{{/each}}

Transformed

{{#each credentialSubject.inputEPCList}}

{{name}}

INPUT

Hardcoded value...

Hardcoded value...

Sustainability Hardcoded value...
Confidence Hardcoded value...
View
{{/each}}

Sensor

{{#each credentialSubject.sensorElementList}}
{{sensorMetadata.device.name}}
{{#each sensorReport}}

{{time}}

Hardcoded value...

{{value}} {{uom}}

{{/each}}Integrity Proof
Other evidence
{{/each}}
", - "@type": "WebRenderingTemplate2022" - } - ], - "type": ["TransformationEventCredential"], - "dlrIdentificationKeyType": "gtin", - "dlrLinkTitle": "EPCIS transformation event VC", - "dlrVerificationPage": "http://localhost:3000/verify", - "dlrQualifierPath": "" - }, - "dpp": { - "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"], - "renderTemplate": [ - { - "template": "Digital Product Passport

PRODUCT PASSPORT

{{credentialSubject.modelName}}

{{#each credentialSubject.batchIdentifier}}{{/each}} {{#each credentialSubject.productIdentifier}}{{/each}} {{#each credentialSubject.itemIdentifier}}{{/each}}

Sustainability

100%

Confidence

100%

PASSPORT ISSUED BY

{{issuer.name}}

Industry
Unknown
Location
Unknown
Identity verification
Unknown{{!-- {{#if (eq issuer.identifiers.0.binding.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

ESG Claims

Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations

{{#each credentialSubject.conformityClaim}}

{{topic}}

{{claimedValues.0.value.value}}% per {{claimedValues.0.value.unit}}
Claimed
{{benchmarkValue.value.value}}% per {{benchmarkValue.value.unit}}
Benchmark
{{!-- {{#if (eq conformityEvidence.type \"w3c_vc\")}} --}}
Verifiable credential
{{!-- {{/if}} --}}

View details

{{/each}}

Product composition

A complete list of materials that make up the composition of this product.

{{#each credentialSubject.materialsProvenance}}

{{massFraction}}%

ID {{materialType.classifierValue}}

{{materialType.classifierName}}

{{#if recycled}}

Recycled

{{/if}} {{#if hazardous}}

Hazard

{{/if}}
{{originCountry}}
{{/each}}

Traceability

Traceability events specify the “what, when, where, why and how” of the products and facilities that constitute a value chain.

{{#each credentialSubject.traceabilityInformation}}
{{eventType}}View
{{/each}}

Product information

Manuf. Date

{{credentialSubject.manufacturedDate}}

Batch No.

{{credentialSubject.batchIdentifier.0.identifierValue}}

Weight

{{credentialSubject.dimension.weight.value}}{{credentialSubject.dimension.weight.unit}}

Length

{{credentialSubject.dimension.length.value}}{{credentialSubject.dimension.weight.unit}}

Width

{{credentialSubject.dimension.width.value}}{{credentialSubject.dimension.weight.unit}}

Height

{{credentialSubject.dimension.height.value}}{{credentialSubject.dimension.weight.unit}}

Description

{{credentialSubject.description}}

", - "@type": "WebRenderingTemplate2022" - } - ], - "type": ["DigitalProductPassport"], - "dlrIdentificationKeyType": "gtin", - "dlrLinkTitle": "Digital Product Passport", - "dlrVerificationPage": "http://localhost:3000/verify", - "dlrQualifierPath": "" - }, - "vckit": { - "vckitAPIUrl": "http://localhost:3332/v1", - "issuer": "did:web:example.com" - }, - "dlr": { - "dlrAPIUrl": "http://localhost:8080", - "dlrAPIKey": "5555555555555" - }, - "storage": { - "url": "http://localhost:3001/upload", - "params": { - "resultPath": "/url" - }, - "options": { - "method": "POST", - "headers": { - "Content-Type": "application/json" - } - } - }, - "transformationEventCredential": { - "mappingFields": [ - { - "sourcePath": "/vc/credentialSubject/epcList/index/name", - "destinationPath": "/inputEPCList/index/name" - }, - { - "sourcePath": "/vc/credentialSubject/epcList/index/itemID", - "destinationPath": "/inputEPCList/index/itemID" - } - ], - "dummyFields": [ - { - "path": "/inputQuantityList", - "data": [ - { - "epcClass": "urn:epc:class:lgtin:4012345.012345.1000", - "quantity": 500, - "uom": "KGM" - }, - { - "epcClass": "urn:epc:class:lgtin:4012345.012345.1001", - "quantity": 300, - "uom": "KGM" - } - ] - }, - { - "path": "/outputQuantityList", - "data": [ - { - "epcClass": "urn:epc:class:lgtin:4012345.012345.2000", - "quantity": 200, - "uom": "KGM" - } - ] - }, - { - "path": "/outputEPCList", - "data": [{ "name": "0109359502000034" }] - }, - { - "path": "/action", - "data": "observe" - }, - { - "path": "/bizStep", - "data": "https://ref.gs1.org/cbv/BizStep/receiving" - }, - { - "path": "/disposition", - "data": "https://ref.gs1.org/cbv/Disp/in_transit" - }, - { - "path": "/bizLocation", - "data": "https://example.com/location/warehouse" - } - ], - "generationFields": [ - { - "path": "/outputEPCList/index/name", - "handler": "generateIdWithBatchLot" - }, - { - "path": "/outputEPCList/index/itemID", - "handler": "generateLinkResolver", - "dependencies": ["/outputEPCList/index/name"] - }, - { - "path": "/eventID", - "handler": "generateUUID" - }, - { - "path": "/eventTime", - "handler": "generateCurrentDatetime" - } - ] - }, - "dppCredentials": [ - { - "mappingFields": [ - { - "sourcePath": "/linkResolver", - "destinationPath": "/traceabilityInformation/0/eventReference" - }, - { - "sourcePath": "/vc/credentialSubject/outputEPCList/0/name", - "destinationPath": "/productIdentifier/0/identifierValue" - }, - { - "sourcePath": "/vc/credentialSubject/outputEPCList/0/itemID", - "destinationPath": "/productIdentifier/0/binding/reference" - } - ], - "dummyFields": [ - { - "path": "/traceabilityInformation/0/eventType", - "data": "transformation" - }, - { - "path": "/batchIdentifier", - "data": [ - { - "scheme": "https://batch.example.org", - "identifierValue": "BATCH-77889", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://batch.example.org/77889/binding" - } - } - ] - }, - { - "path": "/itemIdentifier", - "data": [ - { - "scheme": "https://item.example.org", - "identifierValue": "ITEM-998877", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://item.example.org/998877/binding" - } - } - ] - }, - { - "path": "/classification", - "data": [ - { - "scheme": "https://unstats.un.org/unsd/classifications/Econ/cpc", - "classifierValue": "31254", - "classifierName": "Cold-rolled steel", - "classifierURL": "https://vocabulary.uncefact.org/unlocode#USNYC" - } - ] - }, - { - "path": "/modelName", - "data": "SteelBeam-X200" - }, - { - "path": "/image", - "data": "" - }, - { - "path": "/description", - "data": "High-strength cold-rolled steel beam suitable for construction and industrial applications." - }, - { - "path": "/furtherInformation", - "data": "https://example.com/products/steelbeam-x200" - }, - { - "path": "/manufacturedDate", - "data": "2024-05-15" - }, - { - "path": "/dimension", - "data": { - "weight": { - "value": 1500, - "unit": "KG" - }, - "length": { - "value": 2.44, - "unit": "MTR" - }, - "width": { - "value": 1.22, - "unit": "MTR" - }, - "height": { - "value": 0.018, - "unit": "MTR" - }, - "volume": { - "value": 0.053, - "unit": "CMT" - } - } - }, - { - "path": "/manufacturer", - "data": { - "id": "did:example:123456789abcdefghi", - "name": "SteelWorks Ltd.", - "identifiers": [ - { - "scheme": "https://example.com/company-scheme", - "identifierValue": "SW-001", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://example.com/company/001/binding" - } - } - ] - } - }, - { - "path": "/manufacturedAt", - "data": { - "identifier": [ - { - "scheme": "https://example.com/facility-scheme", - "identifierValue": "FAC-002", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://example.com/facility/002/binding" - } - } - ], - "name": "SteelWorks Manufacturing Plant 2", - "location": "https://maps.example.com/location/steelworks-plant-2", - "operatedBy": { - "id": "did:example:123456789abcdefghi", - "name": "SteelWorks Ltd.", - "identifiers": [ - { - "scheme": "https://example.com/company-scheme", - "identifierValue": "SW-001", - "binding": { - "type": "document", - "assuranceLevel": "3rdParty", - "reference": "https://example.com/company/001/binding" - } - } - ] - } - } - }, - { - "path": "/materialsProvenance", - "data": [ - { - "originCountry": "CN", - "materialType": { - "scheme": "https://example.com/material-scheme", - "classifierValue": "steel", - "classifierName": "Steel" - }, - "massFraction": 100, - "recycled": false, - "hazardous": false - } - ] - }, - { - "path": "/conformityClaim", - "data": [ - { - "topic": "sustainability.certification", - "standardOrRegulation": "https://steel-industry.org/standards/sustainability", - "criteriaReference": "https://steel-industry.org/standards/sustainability/criteria", - "claimedValues": [ - { - "name": "Green Steel Certification", - "value": { - "value": true, - "unit": "boolean" - }, - "accuracy": 1.0 - } - ], - "benchmarkValue": { - "name": "Industry Standard", - "value": { - "value": true, - "unit": "boolean" - } - }, - "benchmarkReference": "https://steel-industry.org/benchmarks/sustainability", - "conformance": true, - "conformityEvidence": { - "type": "w3c_vc", - "assuranceLevel": "3rdParty", - "reference": "https://acrs.pyx.io/verify?q=%7B%22payload%22%3A%7B%22uri%22%3A%22https%3A%2F%2Fstorage.googleapis.com%2Fverifiable-credentials%2Fconformity-credentials%2Facrs-conformity-credential.json%22%7D%7D" - } - } - ] - }, - { - "path": "/recyclingInstruction", - "data": "https://example.com/recycling/steelbeam-x200" - } - ] - } - ], - "identifierKeyPath": "/credentialSubject/outputEPCList/index/name" + "localStorageParams": { "storageKey": "truffleFarm_dpps", "keyPath": "/epcList/index/name" } } ] } diff --git a/documentation/docs/mock-apps/configuration/index.md b/documentation/docs/mock-apps/configuration/index.md index eefe8fe2..cffa5dfc 100644 --- a/documentation/docs/mock-apps/configuration/index.md +++ b/documentation/docs/mock-apps/configuration/index.md @@ -9,13 +9,36 @@ import Disclaimer from '../.././\_disclaimer.mdx'; The Mock Apps config file is used to define the system level config, the apps within the mock app system, the apps functions and the connection to the external services. +## Example Configuration + +The `app-config.json` file in the root directory contains an example configuration for a value chain called "Truffle". This configuration is pre-set to work with the services created by the Docker Compose setup. + +### Pre-configured Services + +Most of the service endpoints in the example configuration are already set to use the Docker Compose services. The only endpoint you might need to change is the Identity Resolver Service (IDR) endpoint. + +- By default, the IDR service endpoint is set to `http://localhost:8080`. +- If you've changed this endpoint, update the `dlr` values in the config file accordingly. + +### Updating the Issuer + +You will need to update the `issuer` property value (did:web) inside the `vckit` object. This should be set to the identifier you created using the Verifiable Credential Service. + +For example: + +```json +"vckit": { + "issuer": "did:web:your-created-identifier" +} +``` + ## Mock App Configuration File Lifecycle The Mock App system can be tailored to model different value chains using a configuration file. This section explains the lifecycle of this configuration file and how to apply changes. ### Location of the Configuration File -The configuration file is named `app-config.json` and is located in the root directory of the cloned Mock App repository. To navigate to this directory, use the following command: +The configuration file is named `app-config.json` and is located in the root directory of the cloned repository. To navigate to this directory, use the following command: ```bash cd tests-untp @@ -41,4 +64,5 @@ yarn start ### Important Notes - Changes to the configuration file will not be reflected in the mock apps until you restart the Mock App system. -- Always ensure you save the `app-config.json` file before restarting the Mock App system. \ No newline at end of file +- Always ensure you save the `app-config.json` file before restarting the Mock App system. +- If you're using the Docker Compose setup, most service endpoints are pre-configured. You only need to update the `issuer` property in the `vckit` object and potentially the IDR service endpoint if you've changed it from the default. \ No newline at end of file diff --git a/documentation/docs/mock-apps/dependent-services/identity-resolution-service.md b/documentation/docs/mock-apps/dependent-services/identity-resolution-service.md index a4b2c57b..d38cd963 100644 --- a/documentation/docs/mock-apps/dependent-services/identity-resolution-service.md +++ b/documentation/docs/mock-apps/dependent-services/identity-resolution-service.md @@ -15,11 +15,11 @@ Key functions of the Identity Resolver Service include: - Enabling downstream value chain actors to discover more information about products they have purchased or are considering purchasing. - Facilitating the connection between unique identifiers and more information about the product (e.g. [Digital Product Passports](https://uncefact.github.io/spec-untp/docs/specification/DigitalProductPassport), [Traceability Events](https://uncefact.github.io/spec-untp/docs/specification/DigitalTraceabilityEvents) and [Conformity Credentials](https://uncefact.github.io/spec-untp/docs/specification/ConformityCredential)). -For the Mock Apps, we currently recommend and will be using the [GS1 Digital Link Resolver](https://github.com/gs1/GS1_DigitalLink_Resolver_CE). +For the Mock Apps, we currently recommend and will be using the [GS1 Digital Link Resolver v2.6](https://github.com/gs1/GS1_DigitalLink_Resolver_CE/tree/v2.6). ### Identity Resolver Service Documentation -Please go through the GS1 Digital Link Resolve documentation available [here](https://github.com/gs1/GS1_DigitalLink_Resolver_CE#fast-start) to understand how to set up and use the Identity Resolver Service. +Please go through the GS1 Digital Link Resolve documentation available [here](https://github.com/gs1/GS1_DigitalLink_Resolver_CE/tree/v2.6#fast-start) to understand how to set up and use the Identity Resolver Service. ### Requirements diff --git a/documentation/docs/mock-apps/dependent-services/index.md b/documentation/docs/mock-apps/dependent-services/index.md index 4d9efe37..592ed560 100644 --- a/documentation/docs/mock-apps/dependent-services/index.md +++ b/documentation/docs/mock-apps/dependent-services/index.md @@ -14,3 +14,55 @@ Ensure all services are configured and running before proceeding with the Mock A - [Verifiable Credential Service](./verifiable-credential-service) - [Storage Service](./storage-service) - [Identity Resolver Service](./identity-resolution-service) + +## Docker Compose Setup + +We have created a Docker Compose file in the root directory to simplify the setup process. This Docker Compose file contains the necessary configurations to start pre-configured instances of the Verifiable Credential Service, Storage Service, a database for the VC service, and the documentation site. + +To use the Docker Compose setup: + +1. Ensure you have [Docker](https://www.docker.com/products/docker-desktop/) and [Docker Compose](https://docs.docker.com/compose/) installed on your system. + +2. Navigate to the root directory of the project where the Docker Compose file is located: + ``` + cd tests-untp + ``` + +3. Run the following command to start the services: + ``` + docker-compose up -d + ``` + + This command will start all the services in detached mode. + +4. To stop the services, use: + + ``` + docker-compose down + ``` + +Using this Docker Compose setup allows for a quick and easy deployment of the required services, ensuring they are properly configured and ready for use with the Mock App system. + +## Service Endpoints + +Once the services are up and running, you can access them at the following endpoints: + +- [Documentation Site](http://localhost:3002) +- [Verifiable Credential Service](http://localhost:3332) +- [Storage Service](http://localhost:3334) + +## Creating an Identifier (did:web) + +After setting up the services, you need to create an identifier (did:web) within the Verifiable Credential Service. This step is crucial for the proper functioning of the system. + +To learn how to create an identifier, please refer to the [Verifiable Credential Service](./verifiable-credential-service) page. + +## Additional Information + +For detailed information about each service, please refer to their respective sections: + +- [Verifiable Credential Service](./verifiable-credential-service) +- [Storage Service](./storage-service) +- [Identity Resolver Service](./identity-resolution-service) + +Note that the Identity Resolver Service is not currently included in the Docker Compose setup. Please refer to the [Identity Resolver Service](./identity-resolution-service) page for more details on its setup and configuration. \ No newline at end of file diff --git a/documentation/docs/mock-apps/dependent-services/storage-service.md b/documentation/docs/mock-apps/dependent-services/storage-service.md index 0929b814..3ee1cc5d 100644 --- a/documentation/docs/mock-apps/dependent-services/storage-service.md +++ b/documentation/docs/mock-apps/dependent-services/storage-service.md @@ -16,44 +16,30 @@ It offers the following capabilities: For the Mock Apps, we recommend and will be using the UN's reference implementation located within the [Identity Resolver Service repository](https://github.com/uncefact/project-identity-resolver). -### Storage Service Documentation +### Setup Options -Please go through the Storage Service documentation available [here](https://github.com/uncefact/project-identity-resolver#project-identity-resolver) to understand how to set up and use the Storage Service. +#### Option 1: Using Docker Compose (Recommended) -### Examples - -#### Store the credential +If you've chosen to use the Docker Compose setup as described in the [Dependent Services](/docs/mock-apps/dependent-services/) section, the Storage Service is already configured and ready to use. You don't need to perform any additional setup steps. -```bash -curl -X POST \ - http://localhost:3001/upload \ - -H 'Content-Type: application/json' \ - -d '{ - "filename": "conformity-credentials/steel-mill-1-emissions.json", - "data": { - "Your credential data here" - } - }' -``` -You would replace `"Your credential data here"` with the actual credential data you want to store (just the verifiable credential). +#### Option 2: Manual Setup -#### Fetch the credential +If you're setting up your own instance of the Storage Service, please follow these steps: -```bash -curl -X GET \ - http://localhost:3001/conformity-credentials/steel-mill-1-emissions.json \ - -H 'Accept: application/json' -``` +### Storage Service Documentation +Please go through the Storage Service documentation available [here](https://github.com/uncefact/project-identity-resolver#project-identity-resolver) to understand how to set up and use the Storage Service. ### Requirements To use the Storage Service with the mock apps, you will need: 1. The Storage Service API running. -2. The address of the Storage Service (e.g.http://localhost:3001/upload) +2. The address of the Storage Service (e.g., http://localhost:3334/v1/documents) 3. The API key of the Storage Service API (if applicable) -Make sure you have the Storage Service API set up and running, and note its address and API key (if applicable) before proceeding with the mock app configuration. +If you're using the Docker Compose setup, these requirements are already met, and the Storage Service is available at http://localhost:3334. + +If you're setting up your own instance, make sure you have the Storage Service API set up and running, and note its address and API key (if applicable) before proceeding with the mock app configuration. In the next section, we will explore the Identity Resolver Service and its role in the UNTP ecosystem. \ No newline at end of file diff --git a/documentation/docs/mock-apps/dependent-services/verifiable-credential-service.md b/documentation/docs/mock-apps/dependent-services/verifiable-credential-service.md index cb683c43..0df33273 100644 --- a/documentation/docs/mock-apps/dependent-services/verifiable-credential-service.md +++ b/documentation/docs/mock-apps/dependent-services/verifiable-credential-service.md @@ -20,6 +20,19 @@ To learn more about why UNTP leverages verifiable credentials, refer to the [Ver For the Mock Apps, we recommend and will be using the UN's Verifiable Credential reference implementation called [VCKit](https://github.com/uncefact/project-vckit). +### Setup Options + +#### Option 1: Using Docker Compose (Recommended) + +If you've chosen to use the Docker Compose setup as described in the [Dependent Services](/docs/mock-apps/dependent-services/) section, most of the configuration is already done for you. In this case, you only need to: + +1. Create an identifier (did:web) within the Verifiable Credential Service. +2. Record this identifier for use in the mock app configuration. + +#### Option 2: Manual Setup + +If you're setting up your own instance of the Verifiable Credential Service, please follow these steps: + ### VCKit Documentation Please go through the VCKit documentation available [here](https://github.com/uncefact/project-vckit#start-the-documentation-page) to understand how to set up and use VCKit. @@ -27,14 +40,17 @@ Please go through the VCKit documentation available [here](https://github.com/un ### Requirements To use the Verifiable Credential Service with the mock apps, you will need: - 1. The VCKit API running. -2. The VCKit Explorer app running. -3. An [Identifier](https://uncefact.github.io/spec-untp/docs/specification/VerifiableCredentials/#did-methods) (did:web) created and recorded for each actor in the value chain you would like to model. -4. The address of the VCKit API (e.g. http://localhost:3332/v2) -5. The API key of the VCkit API (if applicable) - +2. An [Identifier](https://uncefact.github.io/spec-untp/docs/specification/VerifiableCredentials/#did-methods) (did:web) created and recorded for each actor in the value chain you would like to model. +3. The address of the VCKit API (e.g. http://localhost:3332/v2) +4. The API key of the VCkit API (if applicable) Make sure you have these components set up and running, and note the API address, API key and Identifiers before proceeding with the mock app configuration. +### Creating an Identifier (did:web) + +Regardless of which setup option you chose, you'll need to create an identifier (did:web) within the Verifiable Credential Service. This identifier is crucial for the proper functioning of the system. + +To create an identifier, you'll need to use the VCKit API. Refer to the [VCKit documentation](https://github.com/uncefact/project-vckit#start-the-documentation-page) for specific instructions on how to create a did:web identifier using their API endpoints. + In the next section, we will discuss the Storage Service and its role in the UNTP ecosystem. \ No newline at end of file diff --git a/documentation/docs/mock-apps/installation.md b/documentation/docs/mock-apps/installation.md index 4cfb7457..8b3392e8 100644 --- a/documentation/docs/mock-apps/installation.md +++ b/documentation/docs/mock-apps/installation.md @@ -37,13 +37,6 @@ Once you have met the prerequisites, follow these steps to install the dependenc yarn install ``` -3. Copy the example configuration file: - ``` - cp packages/mock-app/src/constants/app-config.example.json packages/mock-app/src/constants/app-config.json - ``` - -This command copies the example configuration file `app-config.example.json` to create the actual configuration file `app-config.json` that will be used by the mock apps. - -After completing these steps, you will have all the necessary mock app dependencies installed and the configuration file ready for customisation. +After completing these steps, you will have all the necessary mock app dependencies installed. In the next section, we will explore the required services and their documentation to help you understand their role in the mock apps ecosystem. \ No newline at end of file diff --git a/package.json b/package.json index 93f19bc8..4bab678f 100644 --- a/package.json +++ b/package.json @@ -6,7 +6,7 @@ "packages/*" ], "scripts": { - "start": "cd packages/mock-app && yarn start", + "start": "cp app-config.json packages/mock-app/src/constants/app-config.json && cd packages/mock-app && yarn start", "build": "yarn build:services && yarn build:components && yarn build:untp-test-suite", "build:services": "cd packages/services && yarn run build", "build:components": "cd packages/components && yarn run build",