From 84eef2a95dbb318a51c5b4c9b1fa1fe9e9467fc6 Mon Sep 17 00:00:00 2001 From: "remy.baranx@gmail.com" Date: Sun, 17 Nov 2024 20:33:11 +0100 Subject: [PATCH] feat: update metadata page Update the Metadata page according to https://github.com/dojoengine/dojo/pull/2691. --- docs/pages/framework/world/metadata.md | 43 +++++++++++++++---- .../sozo/project-commands/migrate.mdx | 24 +++++++++++ 2 files changed, 58 insertions(+), 9 deletions(-) diff --git a/docs/pages/framework/world/metadata.md b/docs/pages/framework/world/metadata.md index f81bdd88..08a6dcbd 100644 --- a/docs/pages/framework/world/metadata.md +++ b/docs/pages/framework/world/metadata.md @@ -1,16 +1,17 @@ # Metadata -Dojo supports associating offchain metadata with the world contract and other deployed contracts. This can provide additional context about the world, such as it's name, description, social links and other media. Enabling external services to easily index and distribute worlds and experiences built on them. +Dojo supports associating offchain metadata with the world and its resources. This can provide additional context about the world and their resources, such as their name, description, icon URI, ... Enabling external services to easily index and distribute worlds and experiences built on them. -## World Metadata +During migration, `sozo` will automatically manage metadata for you, uploading them to IPFS in `JSON` format and registering them in the world contract through the `ResourceMetadata` Dojo model. `sozo` does so by parsing the metadata defined in the Dojo profile configuration `dojo_.toml`. -During migration, `sozo` will automatically manage the worlds metadata for you, uploading it to IPFS and setting it in the world contract. It does so by parsing the metadata defined in the projects `Scarb.toml`. +## World Metadata -To set a world metadata, create the following section in your `Scarb.toml`: +To set world metadata, create the following section in your `dojo_.toml`: ```toml -[tool.dojo.world] +[world] name = "example" +seed = "dojo_examples" description = "example world" icon_uri = "file://assets/icon.png" cover_uri = "file://assets/cover.png" @@ -18,10 +19,34 @@ website = "https://dojoengine.org" socials.x = "https://twitter.com/dojostarknet" ``` -The toolchain supports the `name`, `description`, `icon_uri`, `cover_uri`, `website` and `socials` attributes by default. `*_uri` attributes can point to an asset in the repo using the `file://` schema or to remote resouces using either `ipfs://` or `https://`. Arbitrary social links can be set by setting a key value on the `socials` attribute. For example, we could add a `socials.github = "..."`. +The toolchain supports the `name`, `description`, `icon_uri`, `cover_uri`, `website` and `socials` attributes by default. + +`*_uri` attributes can point to an asset in the repo using the `file://` schema or to remote resouces using either `ipfs://` or `https://`. For local assets, `sozo` wil upload them to IPFS and replace the corresponding URIs by a IPFS URI. + +Arbitrary social links can be set by setting a key value on the `socials` attribute. For example, we could add a `socials.github = "..."`. + +## Resource Metadata + +To set resource metadata, create the following section in your `dojo_.toml`, using `[[models]]`, `[[contracts]]` or `[[events]]` depending on the type of the resource: + +```toml +[[models]] +tag = "ns-Position" +description = "Position of the player in the world" +icon_uri = "file://assets/position_icon.png" + +[[events]] +tag = "ns-Moved" +description = "emit when a player has moved" +icon_uri = "file://assets/moved_icon.png" + +[[contracts]] +tag = "ns-actions" +description = "Available actions for a player in the world" +icon_uri = "file://assets/actions_icon.png" +``` -During migration, `sozo` will upload any local assets to IPFS, replace the corresponding URIs, upload the metadata JSON to IPFS, and set the `metadata_uri` for the world (resource `0`). +For each type of resource, the toolchain supports the `description` and `icon_uri` attributes by default. The `name` of the resource, retrieved from its `tag`, is also stored in the resource metadata. -## Contract and Model Metadata +`*_uri` attributes can point to an asset in the repo using the `file://` schema or to remote resouces using either `ipfs://` or `https://`. For local assets, `sozo` wil upload them to IPFS and replace the corresponding URIs by a IPFS URI. -It is possible for contract/model owners to set a `metadata_uri` for any contract. However, this specification has not yet been defined and it is not supported by the toolchain at this time. diff --git a/docs/pages/toolchain/sozo/project-commands/migrate.mdx b/docs/pages/toolchain/sozo/project-commands/migrate.mdx index be6255d7..353dcffb 100644 --- a/docs/pages/toolchain/sozo/project-commands/migrate.mdx +++ b/docs/pages/toolchain/sozo/project-commands/migrate.mdx @@ -47,6 +47,30 @@ Commands: +#### IPFS Options + +If you provide your IPFS credentials, `sozo` can automatically upload metadata +of the world and its resources to IPFS, and register IPFS URIs to the `ResourceMetadata` +model of the world. + +You can either provide these credentials through command-line arguments, through environment variables +or through your `dojo_.toml`. + +`--ipfs-url` URL +    The URL of the IPFS client to use. + +    _or `DOJO_IPFS_URL` environment variable, or `ipfs_url` in your profile configuration file._ + +`--ipfs-username` USERNAME +    The username to use for the IPFS client. + +    _or `DOJO_IPFS_USERNAME` environment variable, or `ipfs_username` in your profile configuration file._ + +`--ipfs-password` PASSWORD +    The password to use for the IPFS client. + +    _or `DOJO_IPFS_PASSWORD` environment variable, or `ipfs_password` in your profile configuration file._ + #### Signer Options - Raw