diff --git a/.gitignore b/.gitignore
index d72a9634..1992ebaa 100644
--- a/.gitignore
+++ b/.gitignore
@@ -35,6 +35,7 @@ yarn-error.log
testem.log
/typings
.env
+minio_data/*
# Yarn
.yarn/*
diff --git a/app-config.acrs.json b/app-config.acrs.json
new file mode 100644
index 00000000..7e5333a9
--- /dev/null
+++ b/app-config.acrs.json
@@ -0,0 +1,2865 @@
+{
+ "name": "ACRS",
+ "styles": {
+ "primaryColor": "rgb(35, 138, 186)",
+ "secondaryColor": "black",
+ "tertiaryColor": "black"
+ },
+ "generalFeatures": [
+ {
+ "name": "General features",
+ "type": "",
+ "styles": {
+ "primaryColor": "rgb(35, 138, 186)",
+ "secondaryColor": "black",
+ "tertiaryColor": "black"
+ },
+ "features": []
+ }
+ ],
+ "apps": [
+ {
+ "name": "Top Line Steel",
+ "type": "producer",
+ "assets": {
+ "logo": "https://storage.googleapis.com/acrs-assets/logos/Top-Line-Steel-Logo.jpg",
+ "brandTitle": "Top Line Steel",
+ "passportVC": "",
+ "transactionEventVC": ""
+ },
+ "styles": {
+ "primaryColor": "#b22166",
+ "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": "0109359502000010",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/steel/12345/binding"
+ }
+ }
+ ],
+ "batchIdentifier": [
+ {
+ "scheme": "https://batch.example.org",
+ "identifierValue": "BATCH-67890",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://batch.example.org/67890/binding"
+ }
+ }
+ ],
+ "itemIdentifier": [
+ {
+ "scheme": "https://item.example.org",
+ "identifierValue": "ITEM-112233",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://item.example.org/112233/binding"
+ }
+ }
+ ],
+ "classification": [
+ {
+ "scheme": "https://unstats.un.org/unsd/classifications/Econ/cpc",
+ "classifierValue": "41231",
+ "classifierName": "Steel Rods",
+ "classifierURL": "https://vocabulary.uncefact.org/unlocode#AUSYD"
+ }
+ ],
+ "modelName": "Steel Model X",
+ "image": "",
+ "description": "High-quality steel rods for construction.",
+ "furtherInformation": "https://example.org/products/steel_model_x",
+ "manufacturedDate": "2024-05-20",
+ "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" }
+ },
+ "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://plus.codes/4RRG6RJX+W3",
+ "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": "AU",
+ "materialType": {
+ "scheme": "https://textileexchange.org/materials",
+ "classifierValue": "STEEL",
+ "classifierName": "Carbon Steel"
+ },
+ "massFraction": 100,
+ "recycled": false,
+ "hazardous": false
+ }
+ ],
+ "conformityClaim": [
+ {
+ "topic": "Structural Steel Certification",
+ "standardOrRegulation": "https://example.org/standards/environment",
+ "criteriaReference": "https://example.org/standards/environment/criteria",
+ "claimedValues": [],
+ "benchmarkValue": {},
+ "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%2Ftop-line-steel-dcc.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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "dpp": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
+ "renderTemplate": [
+ {
+ "template": "
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Steel Passport",
+ "dlrIdentificationKeyNamespace": "gs1",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["TransactionEventCredential"],
+ "dlrLinkTitle": "Transaction Event",
+ "dlrIdentificationKeyNamespace": "gs1",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "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": [
+ {
+ "scheme": "https://unstats.un.org/unsd/classifications/Econ/cpc",
+ "classifierValue": "41232",
+ "classifierName": "Steel Coil",
+ "classifierURL": "https://vocabulary.uncefact.org/unlocode#GBLON"
+ }
+ ],
+ "modelName": "Steel Model Y",
+ "image": "",
+ "description": "Steel Coil 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": 100, "unit": "MTR" },
+ "width": { "value": 1, "unit": "MTR" },
+ "height": { "value": 0.005, "unit": "MTR" },
+ "volume": { "value": 1.8, "unit": "CMT" }
+ },
+ "characteristic": {},
+ "manufacturer": {
+ "id": "did:example:abcdef1234567890",
+ "name": "Global Steel Co.",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ },
+ "manufacturedAt": {
+ "identifier": [
+ {
+ "scheme": "https://identifier.example.org/facility",
+ "identifierValue": "FAC-6789",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/facility/6789/binding"
+ }
+ }
+ ],
+ "name": "Advanced Steel Plant",
+ "location": "https://plus.codes/4RRG4WWR+W5",
+ "operatedBy": {
+ "id": "did:example:0987654321abcdef",
+ "name": "Global Steel Co.",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ }
+ },
+ "materialsProvenance": [
+ {
+ "originCountry": "AU",
+ "materialType": {
+ "scheme": "https://textileexchange.org/materials",
+ "classifierValue": "STEEL",
+ "classifierName": "Alloy Steel"
+ },
+ "massFraction": 100,
+ "recycled": false,
+ "hazardous": false
+ }
+ ],
+ "conformityClaim": [
+ {
+ "topic": "Structural Steel Certification",
+ "standardOrRegulation": "https://example.org/standards/environment",
+ "criteriaReference": "https://example.org/standards/environment/criteria",
+ "claimedValues": [],
+ "benchmarkValue": {},
+ "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%2Fquality-steel-dcc.json%22%7D%7D"
+ }
+ }
+ ],
+ "recyclingInstruction": "https://example.org/recycling/steel_model_y"
+ },
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "dpp": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
+ "renderTemplate": [
+ {
+ "template": " Digital Product Passport
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Steel Passport",
+ "dlrIdentificationKeyNamespace": "gs1",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/productIdentifier/0/identifierValue"
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "qualitySteel_dpps",
+ "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Sale Steel",
+ "id": "transaction_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "qualitySteel_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:quality-steel",
+ "name": "Quality 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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Cherries Product Passport",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": {
+ "function": "concatService",
+ "args": [
+ { "type": "text", "value": "(01)" },
+ { "type": "path", "value": "/productIdentifier/0/identifierValue" },
+ { "type": "text", "value": "(10)" },
+ { "type": "path", "value": "/batchIdentifier/0/identifierValue" },
+ { "type": "text", "value": "(21)" },
+ { "type": "path", "value": "/itemIdentifier/0/identifierValue" }
+ ]
+ }
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "CherriesFarm_dpps",
+ "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Move to Next Facility",
+ "id": "transaction_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "CherriesFarm_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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries Farm",
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries 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:450e-103-69-79-17.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["TransactionEventCredential"],
+ "dlrLinkTitle": "Transaction Event",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/eventID",
+ "localStorageParams": { "storageKey": "CherriesFarm_dpps", "keyPath": "/epcList/index/name" }
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "orchard_facility_transaction_event",
+ "objectKeyPath": "/vc/credentialSubject/eventID"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Packhouse Facility",
+ "type": "producer",
+ "assets": {
+ "logo": "Cherries-farm-logo.webp",
+ "brandTitle": "Packhouse Facility"
+ },
+ "styles": {
+ "primaryColor": "#b5651d",
+ "secondaryColor": "#391561",
+ "tertiaryColor": "#ffffff"
+ },
+ "features": [
+ {
+ "name": "Issue DPP",
+ "id": "produce_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "orchard_facility_transaction_event",
+ "nestedComponents": [
+ {
+ "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": {
+ "image": "",
+ "productIdentifier": [
+ {
+ "scheme": "https://id.gs1.org/gtin",
+ "identifierValue": "0105012345678900",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://id.gs1.org/gtin/05012345678900/binding"
+ }
+ }
+ ],
+ "batchIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/batch",
+ "identifierValue": "BATCH-2024-001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/batch/2024-001/binding"
+ }
+ }
+ ],
+ "itemIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/item",
+ "identifierValue": "TRF-24-0001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/item/TRF-24-0001/binding"
+ }
+ }
+ ],
+ "classification": [
+ {
+ "scheme": "https://www.unspsc.org",
+ "classifierValue": "50383710",
+ "classifierName": "Cherriess",
+ "classifierURL": "https://www.unspsc.org/search-code/50383710"
+ }
+ ],
+ "modelName": "Black Cherries",
+ "description": "Premium Black Cherriess harvested from our sustainable Cherries orchards.",
+ "furtherInformation": "https://Cherriesfarm.example.org/products/black_perigord",
+ "manufacturedDate": "2024-01-15",
+ "dimension": {
+ "weight": { "value": 50, "unit": "GRM" }
+ },
+ "materialsProvenance": [
+ {
+ "originCountry": "AU",
+ "materialType": {
+ "scheme": "https://www.gs1.org/gpc",
+ "classifierValue": "10005953",
+ "classifierName": "Cherriess (Fresh)",
+ "classifierURL": "https://www.gs1.org/gpc/10005953"
+ },
+ "massFraction": 100,
+ "recycled": false,
+ "hazardous": false
+ }
+ ],
+ "characteristic": {
+ "variety": "Tuber melanosporum",
+ "grade": "Extra",
+ "aroma": "Intense, earthy",
+ "flavor": "Rich, complex"
+ },
+ "manufacturer": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ },
+ "manufacturedAt": {
+ "identifier": [
+ {
+ "scheme": "https://identifier.example.org/facility",
+ "identifierValue": "FAC-5678",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/facility/5678/binding"
+ }
+ }
+ ],
+ "name": "Cherries Orchard",
+ "location": "https://Cherriesfarm.example.org/locations/perigord_orchard",
+ "operatedBy": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ }
+ }
+ },
+ "className": "json-form",
+ "style": {
+ "margin": "40px auto",
+ "paddingTop": "40px",
+ "width": "80%"
+ }
+ },
+ "constructData": {
+ "mappingFields": [
+ {
+ "sourcePath": "/linkResolver",
+ "destinationPath": "/traceabilityInformation/0/eventReference"
+ }
+ ],
+ "dummyFields": [
+ {
+ "path": "/traceabilityInformation/0/eventType",
+ "data": "transaction"
+ }
+ ],
+ "generationFields": []
+ }
+ }
+ ]
+ }
+ },
+ {
+ "name": "CustomButton",
+ "type": "Submit",
+ "props": {}
+ }
+ ],
+ "services": [
+ {
+ "name": "processDPP",
+ "parameters": [
+ {
+ "vckit": {
+ "vckitAPIUrl": "http://localhost:3332/v1",
+ "issuer": "did:web:450e-103-69-79-17.ngrok-free.app"
+ },
+ "dpp": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
+ "renderTemplate": [
+ {
+ "template": " Digital Product Passport
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Cherries Product Passport",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/productIdentifier/0/identifierValue"
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "CherriesFarm_dpps",
+ "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Move to Next Facility",
+ "id": "transaction_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "CherriesFarm_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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries Farm",
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries 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:450e-103-69-79-17.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["TransactionEventCredential"],
+ "dlrLinkTitle": "Transaction Event",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/eventID",
+ "localStorageParams": { "storageKey": "CherriesFarm_dpps", "keyPath": "/epcList/index/name" }
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "packhouse_facility_transaction_event",
+ "objectKeyPath": "/vc/credentialSubject/eventID"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Fumigation and Freight Forwarding Facility",
+ "type": "producer",
+ "assets": {
+ "logo": "Cherries-farm-logo.webp",
+ "brandTitle": "Fumigation and Freight Forwarding Facility"
+ },
+ "styles": {
+ "primaryColor": "#b5651d",
+ "secondaryColor": "#391561",
+ "tertiaryColor": "#ffffff"
+ },
+ "features": [
+ {
+ "name": "Issue DPP",
+ "id": "produce_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "packhouse_facility_transaction_event",
+ "nestedComponents": [
+ {
+ "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": {
+ "image": "",
+ "productIdentifier": [
+ {
+ "scheme": "https://id.gs1.org/gtin",
+ "identifierValue": "0105012345678900",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://id.gs1.org/gtin/05012345678900/binding"
+ }
+ }
+ ],
+ "batchIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/batch",
+ "identifierValue": "BATCH-2024-001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/batch/2024-001/binding"
+ }
+ }
+ ],
+ "itemIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/item",
+ "identifierValue": "TRF-24-0001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/item/TRF-24-0001/binding"
+ }
+ }
+ ],
+ "classification": [
+ {
+ "scheme": "https://www.unspsc.org",
+ "classifierValue": "50383710",
+ "classifierName": "Cherriess",
+ "classifierURL": "https://www.unspsc.org/search-code/50383710"
+ }
+ ],
+ "modelName": "Black Cherries",
+ "description": "Premium Black Cherriess harvested from our sustainable Cherries orchards.",
+ "furtherInformation": "https://Cherriesfarm.example.org/products/black_perigord",
+ "manufacturedDate": "2024-01-15",
+ "dimension": {
+ "weight": { "value": 50, "unit": "GRM" }
+ },
+ "materialsProvenance": [
+ {
+ "originCountry": "AU",
+ "materialType": {
+ "scheme": "https://www.gs1.org/gpc",
+ "classifierValue": "10005953",
+ "classifierName": "Cherriess (Fresh)",
+ "classifierURL": "https://www.gs1.org/gpc/10005953"
+ },
+ "massFraction": 100,
+ "recycled": false,
+ "hazardous": false
+ }
+ ],
+ "characteristic": {
+ "variety": "Tuber melanosporum",
+ "grade": "Extra",
+ "aroma": "Intense, earthy",
+ "flavor": "Rich, complex"
+ },
+ "manufacturer": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ },
+ "manufacturedAt": {
+ "identifier": [
+ {
+ "scheme": "https://identifier.example.org/facility",
+ "identifierValue": "FAC-5678",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/facility/5678/binding"
+ }
+ }
+ ],
+ "name": "Cherries Orchard",
+ "location": "https://Cherriesfarm.example.org/locations/perigord_orchard",
+ "operatedBy": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ }
+ }
+ },
+ "className": "json-form",
+ "style": {
+ "margin": "40px auto",
+ "paddingTop": "40px",
+ "width": "80%"
+ }
+ },
+ "constructData": {
+ "mappingFields": [
+ {
+ "sourcePath": "/linkResolver",
+ "destinationPath": "/traceabilityInformation/0/eventReference"
+ }
+ ],
+ "dummyFields": [
+ {
+ "path": "/traceabilityInformation/0/eventType",
+ "data": "transaction"
+ }
+ ],
+ "generationFields": []
+ }
+ }
+ ]
+ }
+ },
+ {
+ "name": "CustomButton",
+ "type": "Submit",
+ "props": {}
+ }
+ ],
+ "services": [
+ {
+ "name": "processDPP",
+ "parameters": [
+ {
+ "vckit": {
+ "vckitAPIUrl": "http://localhost:3332/v1",
+ "issuer": "did:web:450e-103-69-79-17.ngrok-free.app"
+ },
+ "dpp": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
+ "renderTemplate": [
+ {
+ "template": " Digital Product Passport
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Cherries Product Passport",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/productIdentifier/0/identifierValue"
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "CherriesFarm_dpps",
+ "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Move to Next Facility",
+ "id": "transaction_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "CherriesFarm_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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries Farm",
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries 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:450e-103-69-79-17.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["TransactionEventCredential"],
+ "dlrLinkTitle": "Transaction Event",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/eventID",
+ "localStorageParams": { "storageKey": "CherriesFarm_dpps", "keyPath": "/epcList/index/name" }
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "fumigation_and_freight_forwarding_facility_transaction_event",
+ "objectKeyPath": "/vc/credentialSubject/eventID"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Airport Terminal Facility",
+ "type": "producer",
+ "assets": {
+ "logo": "Cherries-farm-logo.webp",
+ "brandTitle": "Airport Terminal"
+ },
+ "styles": {
+ "primaryColor": "#b5651d",
+ "secondaryColor": "#391561",
+ "tertiaryColor": "#ffffff"
+ },
+ "features": [
+ {
+ "name": "Issue DPP",
+ "id": "produce_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "fumigation_and_freight_forwarding_facility_transaction_event",
+ "nestedComponents": [
+ {
+ "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": {
+ "image": "",
+ "productIdentifier": [
+ {
+ "scheme": "https://id.gs1.org/gtin",
+ "identifierValue": "0105012345678900",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://id.gs1.org/gtin/05012345678900/binding"
+ }
+ }
+ ],
+ "batchIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/batch",
+ "identifierValue": "BATCH-2024-001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/batch/2024-001/binding"
+ }
+ }
+ ],
+ "itemIdentifier": [
+ {
+ "scheme": "https://Cherriesfarm.example.org/item",
+ "identifierValue": "TRF-24-0001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://Cherriesfarm.example.org/item/TRF-24-0001/binding"
+ }
+ }
+ ],
+ "classification": [
+ {
+ "scheme": "https://www.unspsc.org",
+ "classifierValue": "50383710",
+ "classifierName": "Cherriess",
+ "classifierURL": "https://www.unspsc.org/search-code/50383710"
+ }
+ ],
+ "modelName": "Black Cherries",
+ "description": "Premium Black Cherriess harvested from our sustainable Cherries orchards.",
+ "furtherInformation": "https://Cherriesfarm.example.org/products/black_perigord",
+ "manufacturedDate": "2024-01-15",
+ "dimension": {
+ "weight": { "value": 50, "unit": "GRM" }
+ },
+ "materialsProvenance": [
+ {
+ "originCountry": "AU",
+ "materialType": {
+ "scheme": "https://www.gs1.org/gpc",
+ "classifierValue": "10005953",
+ "classifierName": "Cherriess (Fresh)",
+ "classifierURL": "https://www.gs1.org/gpc/10005953"
+ },
+ "massFraction": 100,
+ "recycled": false,
+ "hazardous": false
+ }
+ ],
+ "characteristic": {
+ "variety": "Tuber melanosporum",
+ "grade": "Extra",
+ "aroma": "Intense, earthy",
+ "flavor": "Rich, complex"
+ },
+ "manufacturer": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ },
+ "manufacturedAt": {
+ "identifier": [
+ {
+ "scheme": "https://identifier.example.org/facility",
+ "identifierValue": "FAC-5678",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/facility/5678/binding"
+ }
+ }
+ ],
+ "name": "Cherries Orchard",
+ "location": "https://Cherriesfarm.example.org/locations/perigord_orchard",
+ "operatedBy": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Cherries Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ }
+ }
+ },
+ "className": "json-form",
+ "style": {
+ "margin": "40px auto",
+ "paddingTop": "40px",
+ "width": "80%"
+ }
+ },
+ "constructData": {
+ "mappingFields": [
+ {
+ "sourcePath": "/linkResolver",
+ "destinationPath": "/traceabilityInformation/0/eventReference"
+ }
+ ],
+ "dummyFields": [
+ {
+ "path": "/traceabilityInformation/0/eventType",
+ "data": "transaction"
+ }
+ ],
+ "generationFields": []
+ }
+ }
+ ]
+ }
+ },
+ {
+ "name": "CustomButton",
+ "type": "Submit",
+ "props": {}
+ }
+ ],
+ "services": [
+ {
+ "name": "processDPP",
+ "parameters": [
+ {
+ "vckit": {
+ "vckitAPIUrl": "http://localhost:3332/v1",
+ "issuer": "did:web:450e-103-69-79-17.ngrok-free.app"
},
"dpp": {
"context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
@@ -705,13 +4430,15 @@
}
],
"type": ["VerifiableCredential", "DigitalProductPassport"],
- "dlrLinkTitle": "Truffle Product Passport",
+ "dlrLinkTitle": "Cherries Product Passport",
"dlrIdentificationKeyType": "gtin",
- "dlrVerificationPage": "http://localhost:3001/verify"
+ "dlrVerificationPage": "http://localhost:3003/verify"
},
"dlr": {
- "dlrAPIUrl": "http://localhost:8080",
- "dlrAPIKey": "5555555555555"
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
},
"storage": {
"url": "http://localhost:3334/v1/documents",
@@ -734,7 +4461,7 @@
"name": "mergeToLocalStorage",
"parameters": [
{
- "storageKey": "truffleFarm_dpps",
+ "storageKey": "CherriesFarm_dpps",
"objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
}
]
@@ -742,14 +4469,14 @@
]
},
{
- "name": "Sell Truffle",
+ "name": "Move to Next Facility",
"id": "transaction_product",
"components": [
{
"name": "LocalStorageLoader",
"type": "EntryData",
"props": {
- "storageKey": "truffleFarm_dpps",
+ "storageKey": "CherriesFarm_dpps",
"nestedComponents": [
{
"name": "JsonForm",
@@ -1110,8 +4837,8 @@
{
"path": "/sourceParty",
"data": {
- "id": "did:web:0e37-27-32-93-137.ngrok-free.app",
- "name": "Truffle Farm",
+ "id": "did:web:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries Farm",
"identifiers": [
{
"scheme": "https://example.com/scheme/source",
@@ -1128,8 +4855,8 @@
{
"path": "/destinationParty",
"data": {
- "id": "did:web:0e37-27-32-93-137.ngrok-free.app",
- "name": "Truffle Processor",
+ "id": "did:web:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Cherries Processor",
"identifiers": [
{
"scheme": "https://example.com/scheme/destination",
@@ -1175,7 +4902,7 @@
{
"vckit": {
"vckitAPIUrl": "http://localhost:3332/v1",
- "issuer": "did:web:0e37-27-32-93-137.ngrok-free.app"
+ "issuer": "did:web:450e-103-69-79-17.ngrok-free.app"
},
"epcisTransactionEvent": {
"context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
@@ -1188,11 +4915,13 @@
"type": ["TransactionEventCredential"],
"dlrLinkTitle": "Transaction Event",
"dlrIdentificationKeyType": "gtin",
- "dlrVerificationPage": "http://localhost:3001/verify"
+ "dlrVerificationPage": "http://localhost:3003/verify"
},
"dlr": {
- "dlrAPIUrl": "http://localhost:8080",
- "dlrAPIKey": "5555555555555"
+ "dlrAPIUrl": "http://localhost:3000",
+ "dlrAPIKey": "test123",
+ "namespace": "gs1",
+ "linkRegisterPath": "/api/resolver"
},
"storage": {
"url": "http://localhost:3334/v1/documents",
@@ -1208,7 +4937,7 @@
}
},
"identifierKeyPath": "/eventID",
- "localStorageParams": { "storageKey": "truffleFarm_dpps", "keyPath": "/epcList/index/name" }
+ "localStorageParams": { "storageKey": "CherriesFarm_dpps", "keyPath": "/epcList/index/name" }
}
]
}
@@ -1219,7 +4948,8 @@
],
"identifyProvider": {
"type": "gs1",
- "url": "http://localhost:3333/products"
+ "url": "http://localhost:3001",
+ "namespace": "gs1"
},
"defaultVerificationServiceLink": {
"title": "Default Verification Service",
diff --git a/app-config.truff.json b/app-config.truff.json
new file mode 100644
index 00000000..bab932cc
--- /dev/null
+++ b/app-config.truff.json
@@ -0,0 +1,1232 @@
+{
+ "name": "Truffle Value Chain",
+ "styles": {
+ "primaryColor": "rgb(35, 138, 186)",
+ "secondaryColor": "black",
+ "tertiaryColor": "black"
+ },
+ "generalFeatures": [
+ {
+ "name": "General features",
+ "type": "",
+ "styles": {
+ "primaryColor": "rgb(35, 138, 186)",
+ "secondaryColor": "black",
+ "tertiaryColor": "black"
+ },
+ "features": []
+ }
+ ],
+ "apps": [
+ {
+ "name": "Truffle Farm",
+ "type": "producer",
+ "assets": {
+ "logo": "truffle-farm-logo.webp",
+ "brandTitle": "Truffle Farm"
+ },
+ "styles": {
+ "primaryColor": "#b5651d",
+ "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": {
+ "image": "",
+ "productIdentifier": [
+ {
+ "scheme": "https://id.gs1.org/gtin",
+ "identifierValue": "0105012345678900",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://id.gs1.org/gtin/05012345678900/binding"
+ }
+ }
+ ],
+ "batchIdentifier": [
+ {
+ "scheme": "https://trufflefarm.example.org/batch",
+ "identifierValue": "BATCH-2024-001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://trufflefarm.example.org/batch/2024-001/binding"
+ }
+ }
+ ],
+ "itemIdentifier": [
+ {
+ "scheme": "https://trufflefarm.example.org/item",
+ "identifierValue": "TRF-24-0001",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://trufflefarm.example.org/item/TRF-24-0001/binding"
+ }
+ }
+ ],
+ "classification": [
+ {
+ "scheme": "https://www.unspsc.org",
+ "classifierValue": "50383710",
+ "classifierName": "Truffles",
+ "classifierURL": "https://www.unspsc.org/search-code/50383710"
+ }
+ ],
+ "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": 50, "unit": "GRM" }
+ },
+ "materialsProvenance": [
+ {
+ "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
+ }
+ ],
+ "characteristic": {
+ "variety": "Tuber melanosporum",
+ "grade": "Extra",
+ "aroma": "Intense, earthy",
+ "flavor": "Rich, complex"
+ },
+ "manufacturer": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Truffle Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ },
+ "manufacturedAt": {
+ "identifier": [
+ {
+ "scheme": "https://identifier.example.org/facility",
+ "identifierValue": "FAC-5678",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/facility/5678/binding"
+ }
+ }
+ ],
+ "name": "Truffle Orchard",
+ "location": "https://trufflefarm.example.org/locations/perigord_orchard",
+ "operatedBy": {
+ "id": "did:example:123456789abcdefghi",
+ "name": "Gourmet Truffle Farm",
+ "identifiers": [
+ {
+ "scheme": "https://identifier.example.org/company",
+ "identifierValue": "COMP-12345",
+ "binding": {
+ "type": "document",
+ "assuranceLevel": "3rdParty",
+ "reference": "https://identifier.example.org/company/12345/binding"
+ }
+ }
+ ]
+ }
+ }
+ },
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "dpp": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
+ "renderTemplate": [
+ {
+ "template": " Digital Product Passport
Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations
",
+ "@type": "WebRenderingTemplate2022"
+ }
+ ],
+ "type": ["VerifiableCredential", "DigitalProductPassport"],
+ "dlrLinkTitle": "Truffle Product Passport",
+ "dlrIdentificationKeyType": "gtin",
+ "dlrVerificationPage": "http://localhost:3003/verify"
+ },
+ "dlr": {
+ "dlrAPIUrl": "http://localhost:3000/api",
+ "dlrAPIKey": "test123"
+ },
+ "storage": {
+ "url": "http://localhost:3334/v1/documents",
+ "params": {
+ "resultPath": "/uri",
+ "bucket": "verifiable-credentials"
+ },
+ "options": {
+ "method": "POST",
+ "headers": {
+ "Content-Type": "application/json"
+ }
+ }
+ },
+ "identifierKeyPath": "/productIdentifier/0/identifierValue"
+ }
+ ]
+ },
+ {
+ "name": "mergeToLocalStorage",
+ "parameters": [
+ {
+ "storageKey": "truffleFarm_dpps",
+ "objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "Sell Truffle",
+ "id": "transaction_product",
+ "components": [
+ {
+ "name": "LocalStorageLoader",
+ "type": "EntryData",
+ "props": {
+ "storageKey": "truffleFarm_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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Truffle Farm",
+ "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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app",
+ "name": "Truffle 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:143f-2406-2d40-4106-2b10-38c6-9732-f2d9-bb1c.ngrok-free.app"
+ },
+ "epcisTransactionEvent": {
+ "context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/transaction-event-ld.json"],
+ "renderTemplate": [
+ {
+ "template": "Transaction Event