Here we give some supporting files, give an example and explain how the example.json was created.
The context fields which could be added to CIP-100 compliant jsonld metadata. See cip-0100.common.jsonld.
A json schema for the common context fields. See cip-0100.common.schema.json.
CIP-100 off-chain metadata json example: example.json
Blake2b-256 hash of the canonicalize example (to go on-chain): cf704961a066ba770afdd810cc98e0834206df7c0febe70405e0a5f79dece3ec
Files produced to articulate process, these are not necessary in implementations.
Body files, used to correctly generate author's witness:
Blake2b-256 hash digest of canonicalized body: cc4ab8ead604ddb498ed4b2916af7b454c65ac783b5d836fddf388e72a40eccb
Whole document canonical representation, used to generate final hash:
This tutorial creates additional intermediate files, these are not required in implementations but are shown here to articulate the process.
Private extended signing key (hex):
105d2ef2192150655a926bca9cccf5e2f6e496efa9580508192e1f4a790e6f53de06529129511d1cacb0664bcf04853fdc0055a47cc6d2c6d205127020760652
Public verification key (hex):
7ea09a34aebb13c9841c71397b1cabfec5ddf950405293dee496cac2f437480a
Create the example.json
file adding in all available values.
Then remove from this document any top-level field that is not @context
or body
.
This creates a intermediate file of example.body.json.
Using a tool which complies with the RDF Dataset Canonicalization, create a canonicalized representation of example.body.json. One such tool is the JSON-LD Playground. Ensure the result ends in a newline.
This creates a intermediate file of example.body.nq.
Using a tool create a Blake2b-256 hash of the canonicalized example.body.nq. One such tool is the ToolKit Bay.
For our example this will result in: cc4ab8ead604ddb498ed4b2916af7b454c65ac783b5d836fddf388e72a40eccb
.
Use the hash produced in 3. as the payload for the witness as described in Hashing and Signatures for the chosen witnessAlgorithm
.
For the provided example.json, we use the keys described in Author resulting in a signature
of: 340c2ef8d6abda96769844ab9dca2634ae21ef97ddbfad1f8843bea1058e40d656455a2962143adc603d063bbbe27b54b88d002d23d1dff1cd0e05017cd4f506
We can go back to our example.body.json and now add in properties from outside of body
.
- Adding the
hashAlgorithm
ofblake2b-256
. - Adding the
authors
, including information of ourwitness
produced via 4..
By adding this information we create our example.json.
To be able to create a final metadata hash which can be attached on-chain we must first canonicalize the example.json. Ensure the results ends in a newline.
This creates example.nq.
We then use the specified hashAlgorithm
on example.nq.
This results in: cf704961a066ba770afdd810cc98e0834206df7c0febe70405e0a5f79dece3ec
.
We can then host example.json somewhere easily accessible following Best Practices.
Then at submission time of the governance metadata anchor we can provide the on-chain transaction both the URI to the hosted example.json but also the hash generated via 7..