forked from uncefact/tests-untp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp-config.json
2853 lines (2852 loc) · 361 KB
/
app-config.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
{
"name": "ACRS",
"styles": {
"primaryColor": "rgb(255, 207, 7)",
"secondaryColor": "black",
"tertiaryColor": "black"
},
"generalFeatures": [
{
"name": "General features",
"type": "",
"styles": {
"primaryColor": "rgb(255, 207, 7)",
"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": "STEEL-12345",
"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://example.org/locations/main_steel_plant",
"operatedBy": {
"id": "did:example:567890abcdefghi",
"name": "Steel Manufacturer Inc.",
"identifiers": [
{
"scheme": "https://identifier.example.org/company",
"identifierValue": "COMP-56789",
"binding": {
"type": "document",
"assuranceLevel": "3rdParty",
"reference": "https://identifier.example.org/company/56789/binding"
}
}
]
}
},
"materialsProvenance": [
{
"originCountry": "CN",
"materialType": {
"scheme": "https://textileexchange.org/materials",
"classifierValue": "STEEL",
"classifierName": "Carbon Steel"
},
"massFraction": 100,
"recycled": false,
"hazardous": false
}
],
"conformityClaim": [
{
"topic": "environment.emissions",
"standardOrRegulation": "https://example.org/standards/environment",
"criteriaReference": "https://example.org/standards/environment/criteria",
"claimedValues": [
{ "name": "GHG Emissions", "value": { "value": 50, "unit": "KG_CO2E" }, "accuracy": 0.98 }
],
"benchmarkValue": { "name": "Industry Benchmark", "value": { "value": 60, "unit": "KG_CO2E" } },
"benchmarkReference": "https://example.org/benchmarks/environment",
"conformance": true,
"conformityEvidence": {
"type": "w3c_vc",
"assuranceLevel": "3rdParty",
"reference": "https://acrs.pyx.io/verify?q=%7B%22payload%22%3A%7B%22uri%22%3A%22https%3A%2F%2Fstorage.googleapis.com%2Fverifiable-credentials%2Fconformity-credentials%2Facrs-conformity-credential.json%22%7D%7D"
}
}
],
"recyclingInstruction": "https://example.org/recycling/steel_model_x"
},
"className": "json-form",
"style": {
"margin": "40px auto",
"paddingTop": "40px",
"width": "80%"
}
}
},
{
"name": "CustomButton",
"type": "Submit",
"props": {}
}
],
"services": [
{
"name": "processDPP",
"parameters": [
{
"vckit": {
"vckitAPIUrl": "http://localhost:3332/v1",
"issuer": "did:web:example.com"
},
"dpp": {
"context": ["https://dpp-json-ld.s3.ap-southeast-2.amazonaws.com/dppld.json"],
"renderTemplate": [
{
"template": "<!DOCTYPE html><html lang=\"en\"><head><meta charset=\"UTF-8\"><meta name=\"viewport\" content=\"width=device-width,initial-scale=1\"><link href=\"https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,200..900;1,200..900&display=swap\" rel=\"stylesheet\"><title>Digital Product Passport</title><style>*{margin:0;padding:0;box-sizing:border-box}body{font-family:\"Source Sans 3\",sans-serif}.container{text-align:initial;min-width:290px;max-width:390px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.header{background:#edeff0}.header-image{position:relative;background-image:linear-gradient(to right bottom,rgba(0,0,0,.15),rgba(0,0,0,.5)),url({{{credentialSubject.image}}});background-size:cover;background-position:center;min-height:215px}.header-image-top-left{position:absolute;top:25px;left:15px;font-weight:500;font-size:16px;line-height:22px;color:#fff}.header-image-bottom-left{position:absolute;bottom:18px;left:15px;color:#fff}.header-image-bottom-left h1{font-size:28px;font-weight:700;line-height:32.5px;word-break:break-word}.header-batch{padding:12px 16px 16px 16px;word-break:break-word;display:flex;padding:12px 16px 16px 16px;align-items:flex-start;align-content:flex-start;gap:12px;align-self:stretch;flex-wrap:wrap}.header-batch-item{display:flex;align-items:center;gap:6px}.header-batch a{padding:0 2px;font-size:14px;font-weight:600;line-height:15.25px;color:#232e3d}.passport{display:flex;flex-direction:column;gap:24px}.passport-header{display:flex;justify-content:space-between;align-items:center}.passport-box{display:grid;grid-template-columns:1fr 1fr;justify-items:center;column-gap:10px}.passport-box-item{padding:12px 16px 12px 16px;border-radius:8px;min-height:90px;background-color:#006eb5;color:#fff}.passport-box-item h3{font-size:16px;font-weight:300;line-height:18.29px}.passport-box-item p{margin-top:8px;font-size:40px;font-weight:800;line-height:43.33px;word-break:break-word}.passport-issued-by{display:flex;flex-direction:column;gap:16px}.passport-issued-by-header p{font-size:14px;font-weight:400;line-height:15.26px;color:#55606e}.passport-issued-by-header h3{margin-top:2px;font-size:20px;font-weight:600;line-height:21.8px}.passport-info{display:flex;flex-direction:column}.passport-info-item{padding:10px 0 12px 0;min-height:39px;border-bottom:1px solid #d4d6d8;word-break:break-word;display:grid;grid-template-columns:130px 1fr;column-gap:8px}.passport-info-item:first-child>a{text-decoration:none}.passport-info-item-title{font-size:16px;font-weight:400;line-height:17.44px;color:#55606e}.passport-info-item a{font-size:16px;font-weight:500;line-height:17.44px;color:#232e3d;text-decoration-color:#4f95dd;text-decoration-thickness:2px;text-underline-offset:2px}.passport-info-item-vc a{display:block;margin-bottom:8px}section{padding:0 16px 0 16px}.section-title{font-size:18px;font-weight:700;line-height:19.62px;color:#000}.section-description{margin-top:12px;font-size:16px;line-height:18.88px;color:#000;font-weight:400}.esg-claims-box{margin-top:16px}.conformity-box{border:1px solid #d4d6d8;border-radius:4px;padding:16px 18px 16px 18px}.conformity-box-title{font-size:16px;font-weight:600;line-height:17.44px;color:#000}.conformity-box-description{font-size:14px;font-weight:400;line-height:19.25px;color:#55606e;margin-top:4px}.conformity-claimed-benchmark{margin-top:8px;display:grid;grid-template-columns:1fr 1fr;column-gap:4px}.conformity-claimed-title{font-size:16px;font-weight:600;line-height:17.44px;color:#000;word-break:break-word}.conformity-claimed-description{font-size:14px;font-weight:500;line-height:19.25px;color:#55606e}.conformity-vc-details{margin-top:8px;display:grid;grid-template-columns:1.5fr 1fr}.conformity-vc-details a{grid-column:2}.conformity-vc{border-radius:8px;background-color:#b8ecb6;width:auto;display:flex;justify-content:space-between;align-items:center}.conformity-text{font-size:13px;font-weight:600;line-height:15.26px;color:#000;margin-left:8px}.conformity-vc .icon{margin-right:4px}.conformity-view-details,.conformity-view-details:link{justify-self:end;font-size:14px;font-weight:600;line-height:19.25px;cursor:pointer;color:#000;text-decoration:none;display:flex;align-items:center;gap:10px}.composition-box{display:flex;flex-direction:column;gap:8px;margin-top:12px}.composition-box-item{border:1px solid #d4d6d8;border-radius:4px;min-height:103px;padding:16px 18px 16px 16px;display:flex;justify-content:space-between}.composition-percent{font-size:16px;font-weight:500;line-height:21.92px;color:#000}.composition-id{font-size:14px;font-weight:400;line-height:19.25px;color:#55606e}.composition-title{font-size:16px;font-weight:600;line-height:17.44px;color:#000}.composition-tag{display:flex}.composition-tag-item{font-size:14px;font-weight:400;line-height:19.25px;color:#000;background-color:#edeff0;padding:2px 4px 2px 4px;margin-right:4px}.composition-box-first-column{display:flex;gap:20px;word-break:break-word}.composition-box-second-column{word-break:break-word;display:flex;flex-direction:column;gap:6px}.composition-box-third-column{cursor:pointer;text-decoration:none;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.traceability{display:flex;flex-direction:column;gap:12px}.traceability-event-item{height:39px;border-bottom:1px solid #d4d6d8;padding:10px 0 12px 0;display:flex;justify-content:space-between}.traceability-event-item span{font-size:16px;font-weight:400;line-height:17.44px;color:#000}.traceability-event-item a{font-size:16px;font-weight:500;line-height:17.44px;color:#232e3d;text-decoration-color:#4f95dd;text-decoration-thickness:2px}.product-info{margin-top:15px;display:flex;flex-direction:column;gap:10px}.product-info-item{display:grid;grid-template-columns:1fr 2.5fr;column-gap:16px;padding:3px 0 5px 0;min-height:39px;border-bottom:1px solid #d4d6d8}.product-info-item span{font-size:16px;font-weight:400;line-height:17.44px;color:#55606e}.product-info-item p{font-size:16px;font-weight:500;line-height:17.44px;color:#232e3d;margin-bottom:12px;word-break:break-word}.tag{border-radius:8px;max-width:100%;width:fit-content;display:flex;align-items:center}.vc-tag-text{font-size:13px;font-weight:600;line-height:15.26px;color:#000;margin:4px 10px 4px 8px}.vc-tag{background-color:#b8ecb6}.other-evidence-tag{background-color:#b5d5f5}.icon{margin:4px 8px 4px 0;width:22px;height:22px;display:inline-block}.country-code{font-size:16px;font-weight:400;line-height:19.25px;color:#55606e}.blue-bottom-line,.blue-bottom-line:link,.blue-bottom-line:link:visited{text-decoration-color:#4f95dd;text-decoration-thickness:2px;text-underline-offset:3px}footer{height:60px}</style></head><body><div class=\"container\"><header><div class=\"header\"><div class=\"header-image\"><p class=\"header-image-top-left\">PRODUCT PASSPORT</p><div class=\"header-image-bottom-left\"><h1>{{credentialSubject.modelName}}</h1></div></div><div class=\"header-batch\">{{#each credentialSubject.batchIdentifier}}<div class=\"header-batch-item\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.45 3.5C2.17152 3.5 1.90445 3.38938 1.70754 3.19246C1.51062 2.99555 1.4 2.72848 1.4 2.45C1.4 2.17152 1.51062 1.90445 1.70754 1.70754C1.90445 1.51062 2.17152 1.4 2.45 1.4C2.72848 1.4 2.99555 1.51062 3.19246 1.70754C3.38938 1.90445 3.5 2.17152 3.5 2.45C3.5 2.72848 3.38938 2.99555 3.19246 3.19246C2.99555 3.38938 2.72848 3.5 2.45 3.5ZM13.587 6.706L7.287 0.406C7.035 0.154 6.685 0 6.3 0H1.4C0.623 0 0 0.623 0 1.4V6.3C0 6.685 0.154 7.035 0.413 7.287L6.706 13.587C6.965 13.839 7.315 14 7.7 14C8.085 14 8.435 13.839 8.687 13.587L13.587 8.687C13.846 8.435 14 8.085 14 7.7C14 7.308 13.839 6.958 13.587 6.706Z\" fill=\"#1F5A95\"/></svg><a href=\"{{binding.reference}}\" class=\"blue-bottom-line\">Batch: {{identifierValue}}</a></div>{{/each}} {{#each credentialSubject.productIdentifier}}<div class=\"header-batch-item\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.45 3.5C2.17152 3.5 1.90445 3.38938 1.70754 3.19246C1.51062 2.99555 1.4 2.72848 1.4 2.45C1.4 2.17152 1.51062 1.90445 1.70754 1.70754C1.90445 1.51062 2.17152 1.4 2.45 1.4C2.72848 1.4 2.99555 1.51062 3.19246 1.70754C3.38938 1.90445 3.5 2.17152 3.5 2.45C3.5 2.72848 3.38938 2.99555 3.19246 3.19246C2.99555 3.38938 2.72848 3.5 2.45 3.5ZM13.587 6.706L7.287 0.406C7.035 0.154 6.685 0 6.3 0H1.4C0.623 0 0 0.623 0 1.4V6.3C0 6.685 0.154 7.035 0.413 7.287L6.706 13.587C6.965 13.839 7.315 14 7.7 14C8.085 14 8.435 13.839 8.687 13.587L13.587 8.687C13.846 8.435 14 8.085 14 7.7C14 7.308 13.839 6.958 13.587 6.706Z\" fill=\"#1F5A95\"/></svg><a href=\"{{binding.reference}}\" class=\"blue-bottom-line\">SKU: {{identifierValue}}</a></div>{{/each}} {{#each credentialSubject.itemIdentifier}}<div class=\"header-batch-item\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.45 3.5C2.17152 3.5 1.90445 3.38938 1.70754 3.19246C1.51062 2.99555 1.4 2.72848 1.4 2.45C1.4 2.17152 1.51062 1.90445 1.70754 1.70754C1.90445 1.51062 2.17152 1.4 2.45 1.4C2.72848 1.4 2.99555 1.51062 3.19246 1.70754C3.38938 1.90445 3.5 2.17152 3.5 2.45C3.5 2.72848 3.38938 2.99555 3.19246 3.19246C2.99555 3.38938 2.72848 3.5 2.45 3.5ZM13.587 6.706L7.287 0.406C7.035 0.154 6.685 0 6.3 0H1.4C0.623 0 0 0.623 0 1.4V6.3C0 6.685 0.154 7.035 0.413 7.287L6.706 13.587C6.965 13.839 7.315 14 7.7 14C8.085 14 8.435 13.839 8.687 13.587L13.587 8.687C13.846 8.435 14 8.085 14 7.7C14 7.308 13.839 6.958 13.587 6.706Z\" fill=\"#1F5A95\"/></svg><a href=\"{{binding.reference}}\" class=\"blue-bottom-line\">GTIN: {{identifierValue}}</a></div>{{/each}}</div></div></header><section class=\"passport\"><div class=\"passport-box\"><div class=\"passport-box-item\"><h3>Sustainability</h3><p>100%</p></div><div class=\"passport-box-item\"><h3>Confidence</h3><p>100%</p></div></div><div class=\"passport-issued-by\"><div class=\"passport-issued-by-header\"><p>PASSPORT ISSUED BY</p><h3>{{issuer.name}}</h3></div><div class=\"passport-info\"><div class=\"passport-info-item\"><div class=\"passport-info-item-title\">Industry</div><a href=\"#\">Unknown</a></div><div class=\"passport-info-item\"><div class=\"passport-info-item-title\">Business identifier</div><a href=\"{{issuer.identifiers.0.scheme}}\">{{issuer.identifiers.0.identifierValue}}</a></div><div class=\"passport-info-item\"><div class=\"passport-info-item-title\">Location</div><a href=\"{{credentialSubject.manufacturedAt.location}}\">Unknown</a></div><div class=\"passport-info-item\"><div class=\"passport-info-item-title\">Identity verification</div><div class=\"passport-info-item-vc\"><a href=\"{{issuer.identifiers.0.binding.reference}}\">Unknown</a>{{!-- {{#if (eq issuer.identifiers.0.binding.type \"w3c_vc\")}} --}}<div class=\"tag vc-tag\"><div class=\"vc-tag-text\">Verifiable credential</div><div class=\"icon\"><svg width=\"22\" height=\"22\" viewBox=\"0 0 22 22\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><g clip-path=\"url(#clip0_134_619)\"><path d=\"M4.23077 22C3.2906 22 2.49145 21.6792 1.83333 21.0375C1.17521 20.3958 0.846153 19.6167 0.846153 18.7V15.4H4.23077V0L5.92308 1.65L7.61538 0L9.30769 1.65L11 0L12.6923 1.65L14.3846 0L16.0769 1.65L17.7692 0L19.4615 1.65L21.1538 0V18.7C21.1538 19.6167 20.8248 20.3958 20.1667 21.0375C19.5085 21.6792 18.7094 22 17.7692 22H4.23077ZM17.7692 19.8C18.0889 19.8 18.357 19.6944 18.5736 19.4832C18.7903 19.272 18.8982 19.0109 18.8974 18.7V3.3H6.48718V15.4H16.641V18.7C16.641 19.0117 16.7493 19.2731 16.9659 19.4843C17.1826 19.6955 17.4503 19.8007 17.7692 19.8ZM7.61538 7.7V5.5H14.3846V7.7H7.61538ZM7.61538 11V8.8H14.3846V11H7.61538ZM16.641 7.7C16.3214 7.7 16.0536 7.5944 15.8377 7.3832C15.6219 7.172 15.5136 6.91093 15.5128 6.6C15.5121 6.28907 15.6204 6.028 15.8377 5.8168C16.0551 5.6056 16.3229 5.5 16.641 5.5C16.9592 5.5 17.2273 5.6056 17.4454 5.8168C17.6636 6.028 17.7715 6.28907 17.7692 6.6C17.767 6.91093 17.6587 7.17237 17.4443 7.3843C17.2299 7.59623 16.9622 7.70147 16.641 7.7ZM16.641 11C16.3214 11 16.0536 10.8944 15.8377 10.6832C15.6219 10.472 15.5136 10.2109 15.5128 9.9C15.5121 9.58907 15.6204 9.328 15.8377 9.1168C16.0551 8.9056 16.3229 8.8 16.641 8.8C16.9592 8.8 17.2273 8.9056 17.4454 9.1168C17.6636 9.328 17.7715 9.58907 17.7692 9.9C17.767 10.2109 17.6587 10.4724 17.4443 10.6843C17.2299 10.8962 16.9622 11.0015 16.641 11ZM4.23077 19.8H14.3846V17.6H3.10256V18.7C3.10256 19.0117 3.21087 19.2731 3.42749 19.4843C3.6441 19.6955 3.91186 19.8007 4.23077 19.8Z\" fill=\"#232E3D\"/></g><defs><clipPath id=\"clip0_134_619\"><rect width=\"22\" height=\"22\" fill=\"white\"/></clipPath></defs></svg></div></div>{{!-- {{/if}} --}}</div></div></div></div></section><section class=\"conformity\"><div><p class=\"section-title\">ESG Claims</p><p class=\"section-description\">Conformity credentials are usually issued by independent third parties and provide a trusted assessment of product ESG performance against credible standards or regulations</p></div>{{#each credentialSubject.conformityClaim}}<div class=\"esg-claims-box\"><div class=\"conformity-box\"><p class=\"conformity-box-title\">{{topic}}</p><div class=\"conformity-claimed-benchmark\"><div><div class=\"conformity-claimed-title\">{{claimedValues.0.value.value}}% per {{claimedValues.0.value.unit}}</div><div class=\"conformity-claimed-description\">Claimed</div></div><div><div class=\"conformity-claimed-title\">{{benchmarkValue.value.value}}% per {{benchmarkValue.value.unit}}</div><div class=\"conformity-claimed-description\">Benchmark</div></div></div><div class=\"conformity-vc-details\">{{!-- {{#if (eq conformityEvidence.type \"w3c_vc\")}} --}}<div class=\"tag vc-tag\"><div class=\"vc-tag-text\">Verifiable credential</div><div class=\"icon\"><svg width=\"22\" height=\"22\" viewBox=\"0 0 22 22\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><g clip-path=\"url(#clip0_134_619)\"><path d=\"M4.23077 22C3.2906 22 2.49145 21.6792 1.83333 21.0375C1.17521 20.3958 0.846153 19.6167 0.846153 18.7V15.4H4.23077V0L5.92308 1.65L7.61538 0L9.30769 1.65L11 0L12.6923 1.65L14.3846 0L16.0769 1.65L17.7692 0L19.4615 1.65L21.1538 0V18.7C21.1538 19.6167 20.8248 20.3958 20.1667 21.0375C19.5085 21.6792 18.7094 22 17.7692 22H4.23077ZM17.7692 19.8C18.0889 19.8 18.357 19.6944 18.5736 19.4832C18.7903 19.272 18.8982 19.0109 18.8974 18.7V3.3H6.48718V15.4H16.641V18.7C16.641 19.0117 16.7493 19.2731 16.9659 19.4843C17.1826 19.6955 17.4503 19.8007 17.7692 19.8ZM7.61538 7.7V5.5H14.3846V7.7H7.61538ZM7.61538 11V8.8H14.3846V11H7.61538ZM16.641 7.7C16.3214 7.7 16.0536 7.5944 15.8377 7.3832C15.6219 7.172 15.5136 6.91093 15.5128 6.6C15.5121 6.28907 15.6204 6.028 15.8377 5.8168C16.0551 5.6056 16.3229 5.5 16.641 5.5C16.9592 5.5 17.2273 5.6056 17.4454 5.8168C17.6636 6.028 17.7715 6.28907 17.7692 6.6C17.767 6.91093 17.6587 7.17237 17.4443 7.3843C17.2299 7.59623 16.9622 7.70147 16.641 7.7ZM16.641 11C16.3214 11 16.0536 10.8944 15.8377 10.6832C15.6219 10.472 15.5136 10.2109 15.5128 9.9C15.5121 9.58907 15.6204 9.328 15.8377 9.1168C16.0551 8.9056 16.3229 8.8 16.641 8.8C16.9592 8.8 17.2273 8.9056 17.4454 9.1168C17.6636 9.328 17.7715 9.58907 17.7692 9.9C17.767 10.2109 17.6587 10.4724 17.4443 10.6843C17.2299 10.8962 16.9622 11.0015 16.641 11ZM4.23077 19.8H14.3846V17.6H3.10256V18.7C3.10256 19.0117 3.21087 19.2731 3.42749 19.4843C3.6441 19.6955 3.91186 19.8007 4.23077 19.8Z\" fill=\"#232E3D\"/></g><defs><clipPath id=\"clip0_134_619\"><rect width=\"22\" height=\"22\" fill=\"white\"/></clipPath></defs></svg></div></div>{{!-- {{/if}} --}}<a href=\"{{conformityEvidence.reference}}\" class=\"conformity-view-details\"><p>View details</p><svg width=\"10\" height=\"15\" viewBox=\"0 0 10 15\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1.5L7.66667 7.99842M7.66667 7.99842L1 14.5M7.66667 7.99842H7\" stroke=\"#4F95DD\" stroke-width=\"2\"/></svg></a></div></div></div>{{/each}}</section><section class=\"composition\"><div><p class=\"section-title\">Product composition</p><p class=\"section-description\">A complete list of materials that make up the composition of this product.</p></div><div class=\"composition-box\">{{#each credentialSubject.materialsProvenance}}<div class=\"composition-box-item\"><div class=\"composition-box-first-column\"><p class=\"composition-percent\">{{massFraction}}%</p><div class=\"composition-box-second-column\"><p class=\"composition-id\">ID {{materialType.classifierValue}}</p><p class=\"composition-title\">{{materialType.classifierName}}</p><div class=\"composition-tag\">{{#if recycled}}<p class=\"composition-tag-item\">Recycled</p>{{/if}} {{#if hazardous}}<p class=\"composition-tag-item\">Hazard</p>{{/if}}</div></div></div><a href=\"{{materialType.classifierURL}}\" class=\"composition-box-third-column\"><div class=\"country-code\">{{originCountry}}</div><svg width=\"10\" height=\"15\" viewBox=\"0 0 10 15\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1.5L7.66667 7.99842M7.66667 7.99842L1 14.5M7.66667 7.99842H7\" stroke=\"#4F95DD\" stroke-width=\"2\"/></svg></a></div>{{/each}}</div></section><section class=\"traceability\"><div><p class=\"section-title\">Traceability</p><p class=\"section-description\">Traceability events specify the “what, when, where, why and how” of the products and facilities that constitute a value chain.</p></div><div class=\"traceability-event\">{{#each credentialSubject.traceabilityInformation}}<div class=\"traceability-event-item\"><span>{{eventType}}</span><a href=\"{{eventReference}}\">View</a></div>{{/each}}</div></section><section class=\"product\"><div><h2 class=\"section-title\">Product information</h2></div><div class=\"product-info\"><div class=\"product-info-item\"><span>Manuf. Date</span><p>{{credentialSubject.manufacturedDate}}</p></div><div class=\"product-info-item\"><span>Batch No.</span><p>{{credentialSubject.batchIdentifier.0.identifierValue}}</p></div><div class=\"product-info-item\"><span>Weight</span><p>{{credentialSubject.dimension.weight.value}}{{credentialSubject.dimension.weight.unit}}</p></div><div class=\"product-info-item\"><span>Length</span><p>{{credentialSubject.dimension.length.value}}{{credentialSubject.dimension.weight.unit}}</p></div><div class=\"product-info-item\"><span>Width</span><p>{{credentialSubject.dimension.width.value}}{{credentialSubject.dimension.weight.unit}}</p></div><div class=\"product-info-item\"><span>Height</span><p>{{credentialSubject.dimension.height.value}}{{credentialSubject.dimension.weight.unit}}</p></div><div class=\"product-info-item\"><span>Description</span><p>{{credentialSubject.description}}</p></div></div></section></div><footer></footer></body></html>",
"@type": "WebRenderingTemplate2022"
}
],
"type": ["VerifiableCredential", " DigitalProductPassport"],
"dlrLinkTitle": "Steel Passport",
"dlrIdentificationKeyType": "gtin",
"dlrVerificationPage": "http://localhost:3000/verify"
},
"dlr": {
"dlrAPIUrl": "http://localhost:8080",
"dlrAPIKey": "5555555555555"
},
"storage": {
"url": "http://localhost:3001/upload",
"params": {
"resultPath": "/url"
},
"options": {
"method": "POST",
"headers": {
"Content-Type": "application/json"
}
}
},
"identifierKeyPath": "/productIdentifier/0/identifierValue"
}
]
},
{
"name": "mergeToLocalStorage",
"parameters": [
{
"storageKey": "topLineSteel_dpps",
"objectKeyPath": "/vc/credentialSubject/productIdentifier/0/identifierValue"
}
]
}
]
},
{
"name": "Sale Steel",
"id": "transaction_product",
"components": [
{
"name": "LocalStorageLoader",
"type": "EntryData",
"props": {
"storageKey": "topLineSteel_dpps",
"nestedComponents": [
{
"name": "JsonForm",
"type": "EntryData",
"props": {
"schema": {
"type": "object",
"additionalProperties": false,
"properties": {
"sourceParty": {
"$ref": "#/$defs/Party",
"description": "The source party for this supply chain transaction - typically the seller party"
},
"destinationParty": {
"$ref": "#/$defs/Party",
"description": "The destination party for this supply chain transaction - typically the buyer party."
},
"epcList": {
"type": "array",
"items": { "$ref": "#/$defs/Item" },
"description": "The list of uniquely identified trade items included in this supply chain transaction."
},
"quantityList": {
"type": "array",
"items": { "$ref": "#/$defs/QuantityElement" },
"description": "List of quantified product classes that are included in this transaction. Used when the trade items do not have unique identifiers (eg 100 reels of yarn)"
},
"referenceDocument": {
"$ref": "#/$defs/TradeDocument",
"description": "The supply chain document reference for this transaction event - eg the invoice, order, or dispatch advice"
},
"eventID": {
"x-jargon-isKey": true,
"readOnly": true,
"type": "string",
"description": "The unique identifier of this event - SHOULD be a UUID"
},
"eventTime": {
"type": "string",
"format": "date-time",
"description": "The ISO-8601 date time when the event occurred."
},
"action": {
"type": "string",
"enum": ["observe", "add", "delete"],
"example": "observe",
"description": "Code describing how an event relates to the lifecycle of the entity impacted by the event."
},
"disposition": {
"type": "string",
"x-external-enumeration": "https://ref.gs1.org/cbv/Disp",
"description": "Disposition code describing the state of the item after the event. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/Disp\n "
},
"bizStep": {
"type": "string",
"x-external-enumeration": "https://ref.gs1.org/cbv/BizStep",
"description": "A business step code drawn from a controlled vocabulary. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/BizStep\n "
},
"bizLocation": {
"type": "string",
"format": "uri",
"description": "A Business Location is a uniquely identified and discretely recorded geospatial location that is meant to designate the specific place where an object is assumed to be following an EPCIS event until it is reported to be at a different Business Location by a subsequent EPCIS event. The bizLocation must be a resolvable URI that links to facility information and geolocation data."
},
"sensorElementList": {
"type": "array",
"items": { "$ref": "#/$defs/SensorElement" },
"description": "An array (one for each sensor) of sensor device data sets associated with the event. "
}
},
"description": "Transaction represents an event in which one or more objects become associated or disassociated with one or more identified business transactions - such as the purchase / shipment of goods between buyer and seller.",
"$schema": "https://json-schema.org/draft/2020-12/schema",
"$defs": {
"TransactionEvent": {
"type": "object",
"additionalProperties": false,
"properties": {
"sourceParty": {
"$ref": "#/$defs/Party",
"description": "The source party for this supply chain transaction - typically the seller party"
},
"destinationParty": {
"$ref": "#/$defs/Party",
"description": "The destination party for this supply chain transaction - typically the buyer party."
},
"epcList": {
"type": "array",
"items": { "$ref": "#/$defs/Item" },
"description": "The list of uniquely identified trade items included in this supply chain transaction."
},
"quantityList": {
"type": "array",
"items": { "$ref": "#/$defs/QuantityElement" },
"description": "List of quantified product classes that are included in this transaction. Used when the trade items do not have unique identifiers (eg 100 reels of yarn)"
},
"referenceDocument": {
"$ref": "#/$defs/TradeDocument",
"description": "The supply chain document reference for this transaction event - eg the invoice, order, or dispatch advice"
},
"eventID": {
"x-jargon-isKey": true,
"readOnly": true,
"type": "string",
"description": "The unique identifier of this event - SHOULD be a UUID"
},
"eventTime": {
"type": "string",
"format": "date-time",
"description": "The ISO-8601 date time when the event occurred."
},
"action": {
"type": "string",
"enum": ["observe", "add", "delete"],
"example": "observe",
"description": "Code describing how an event relates to the lifecycle of the entity impacted by the event."
},
"disposition": {
"type": "string",
"x-external-enumeration": "https://ref.gs1.org/cbv/Disp",
"description": "Disposition code describing the state of the item after the event. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/Disp\n "
},
"bizStep": {
"type": "string",
"x-external-enumeration": "https://ref.gs1.org/cbv/BizStep",
"description": "A business step code drawn from a controlled vocabulary. \n\n This is an enumerated value, but the list of valid values are too big, or change too often to include here. You can access the list of allowable values at this URL: https://ref.gs1.org/cbv/BizStep\n "
},
"bizLocation": {
"type": "string",
"format": "uri",
"description": "A Business Location is a uniquely identified and discretely recorded geospatial location that is meant to designate the specific place where an object is assumed to be following an EPCIS event until it is reported to be at a different Business Location by a subsequent EPCIS event. The bizLocation must be a resolvable URI that links to facility information and geolocation data."
},
"sensorElementList": {
"type": "array",
"items": { "$ref": "#/$defs/SensorElement" },
"description": "An array (one for each sensor) of sensor device data sets associated with the event. "
}
},
"description": "Transaction represents an event in which one or more objects become associated or disassociated with one or more identified business transactions - such as the purchase / shipment of goods between buyer and seller."
},
"Party": {
"type": "object",
"additionalProperties": false,
"properties": {
"id": {
"type": "string",
"description": "The decentralised identifier of the party - must be a W3C DID."
},
"name": {
"type": "string",
"description": "The name of the organization or company, represented as a text string."
},
"identifiers": {
"type": "array",
"items": { "$ref": "#/$defs/Identifier" },
"description": "A list of unique business identifiers assigned to the party - such as tax registration numbers."
}
},
"description": "The Party class represents an entity such as an organization, or a company that manufactured the product."
},
"Identifier": {
"type": "object",
"additionalProperties": false,
"properties": {
"scheme": {
"type": "string",
"format": "uri",
"description": "the identifier scheme as defined by the registrar that manages the identifier registry. If the identifier scheme is registered with UNTP then this URI can use used to dicsover the resolution method (to get more data) and the verification method (to prove ownership)."
},
"identifierValue": {
"type": "string",
"description": "The value of the identifier within the scheme"
},
"binding": {
"$ref": "#/$defs/Evidence",
"description": "Link to evidence that attests to the validity and ownership of the identifer. "
}
},
"description": "An identifier of a party, product, or facility that is defined by an identifier scheme and idenfier value and, optinally, verification evidence "
},
"Evidence": {
"type": "object",
"additionalProperties": false,
"properties": {
"type": {
"type": "string",
"enum": ["w3c_vc", "iso_mdl", "document", "website", "other"],
"example": "w3c_vc",
"description": "Format of the evidence (verifiable credential, document, website, etc)"
},
"assuranceLevel": {
"type": "string",
"enum": ["Self", "Commercial", "Buyer", "Membership", "Unspecified", "3rdParty"],
"example": "Self",
"description": "The assurance level of the evidence (self declaration, 2nd party, 3rd party, accredited auditor)"
},
"reference": {
"type": "string",
"format": "uri",
"description": "The URL at which the evidence data can be found. "
}
},
"description": "Evidence to support a conformity or identity claim. "
},
"Item": {
"type": "object",
"additionalProperties": false,
"properties": {
"itemID": {
"x-jargon-isKey": true,
"type": "string",
"format": "uri",
"description": "The globally unique identifier (eg GS1 GTIN or digital link) of the product item. "
},
"name": {
"type": "string",
"description": "The name of the product class to which the product item belongs. "
}
},
"description": "A specific trade item /product code which could be either a product serial number or a consignment identifier "
},
"QuantityElement": {
"type": "object",
"additionalProperties": false,
"properties": {
"epcClass": {
"type": "string",
"format": "uri",
"description": "THe identifier of a product class (as opposed to a product instance) such as a GTIN code for a manufactured product."
},
"quantity": {
"type": "number",