Crates.io | ink_metadata |
lib.rs | ink_metadata |
version | 5.1.1 |
source | src |
created_at | 2020-10-09 19:16:02.896908 |
updated_at | 2024-12-04 11:33:05.290635 |
description | [ink!] Metadata definitions for ink! smart contracts. |
homepage | https://use.ink |
repository | https://github.com/use-ink/ink |
max_upload_size | |
id | 297788 |
size | 153,719 |
The ink! metadata is used to describe a contracts properties in a platform independent way. To learn more about it see the section in the ink! docs.
Note: The metadata version is independent of the ink! version! The version 4 of the metadata which is described here is used in ink! v5.
The ink! metadata is broken down into two main parts. The outer metadata and the ink!
metadata (MetadataVersioned
).
We won't go into details about the differences between the two here, but if you're curious you can read about it in the ink! documentation portal.
In order to validate that a contract's metadata conforms to the format expected by external tooling we have created a set of JSON Schemas. These schemas describe the properties of the metadata and allows us to validate a contract's metadata for correctness.
In order to validate the metadata we will be using
jsonschema
,
but an online validator like https://www.jsonschemavalidator.net/
will also work.
First, let's install jsonschema
:
cargo install jsonschema
Next, we'll build our contract's metadata:
# At the top level of the ink! repo
cargo contract build --manifest-path ./integration-tests/flipper/Cargo.toml
The generated metadata will be in: $PATH_TO_INK_REPO/integration-tests/flipper/target/ink/flipper.json
.
Now, to validate our metadata we'll need the schemas. These schemas can be found in this
folder: outer-schema.json
and ink-v3-schema.json
.
We can then use it to validate our metadata against our schema:
jsonschema outer-schema.json --instance $PATH_TO_INK_REPO/integration-tests/flipper/target/ink/flipper.json
If flipper.json
is respects our schema we should see the following:
flipper.json - VALID
Otherwise, we will see:
flipper.json - INVALID. Errors: ...
alongside a list of the errors.
We can do a similar thing for the ink! versioned metadata.
jq '. | {V3}' $PATH_TO_INK_REPO/integration-tests/flipper/target/ink/flipper.json > ink-v3-metadata.json
jsonschema ink-v3-schema.json --instance ink-v3-metadata.json
Right now the schemas are generated using a set of cobbled branches across scale-info
,
ink
, and cargo-contract
.
hc-derive-jsonschema
branch across all of themscale-info
and ink
to match your local folder structureNow, in your patched version of cargo-contract
run the following:
cargo run -- contract build --manifest-path $PATH_TO_INK_REPO/integration-tests/flipper/Cargo.toml > schema.json
In src/cmd/metadata.rs
you can change the schema being printed depending on what struct
you pass into the schemars::schema_for
macro (this is called in the execute
function).
let schema = schemars::schema_for!(ContractMetadata);
println!("{}", serde_json::to_string_pretty(&schema).unwrap());
OR
let schema = schemars::schema_for!(ink_metadata::MetadataVersioned);
println!("{}", serde_json::to_string_pretty(&schema).unwrap());