As we reach the end of a very long path to ICRC-7, it is time to start looking at the next set of work for the NFT Working group.
The WG originally decided to take on a ‘Simple’ NFT that provided the minimum amount of functionality that the community would expect for an NFT on the Internet Computer. Thus ICRC-7 was born(and will hopefully be approved in the next few weeks) and we split it into an ICRC-37 to handle some extra functionality that was not necessarily required, but expected(approve and transferFrom). We reserved and designated ICRC-8 for a full-fledged IC-enabled super NFT.
Over the course of working on ICRC-1,2,3,4, 7, and 37 we’ve learned a lot of things like ‘smaller is better’ and that getting broad agreement in two-week increments is difficult. Nevertheless, it is time to look forward! As part of the exercise, I’ve broken down what was originally ICRC-8 into 4 different ICRCs.
ICRC-8 - Ledger Markets - At Origyn, we put the marketplace inside the NFT to help enable us to provide creators and the community with more dependable guarantees about the behavior of an NFT. Since this makes sense for NFTs, why not for Fungible Ledgers as well? This ICRC defines a marketplace standard for the IC that can either be run on a Fungible or NFT Ledger directly(where fees can be less and atomicity faster) or on any marketplace canister. It defines the data structures and workflows necessary to achieve atomic trades with any number of ICRC 1,2,4,7,37 type tokens and any number of participants. It isn’t ‘simple’ and may be able to be broken into a number of ICRCs itself, but we need to start somewhere. ICRC/ICRCs/ICRC-8 at icrc8 · skilesare/ICRC · GitHub
ICRC-56 - Infinitely Scalable Multi-Canister File System - On the IC we have the ability to put our NFT files on-chain in a way that is computable. Why is this important? Imagine an NFT that secretly holds a very high-resolution image and will only let Canister-based Generative AIs that can’t steal the bits run transforms over it. There are many other reasons to have files in a place that smart contracts can compute over them. In addition, having your metadata, files, and logic all on one system is a nice assurance for users. As I was thinking about how to structure this for NFTs(we took a swing at it with the origyn_nft) it occurred to me that lots of applications on the IC need a standard file system. While this ICRC can be used for storing on-chain NFT media, it is a generic ICRC that follows the Asset Canister pattern, adds some sugar, and attempts to create a drop-in module for canisters that want to contain smart contract logic AND host files. ICRC/ICRCs/ICRC-56/readme.md at icrc56 · skilesare/ICRC · GitHub
ICRC-59 - Static NFT Metadata Interface Standard - Two camps arose as we discussed NFT metadata in the community. There are those that want their NFT to be hardcoded, hashed, and never change. And there are those that want an NFT that can store permissioned and constantly updating metadata. We split the baby with ICRC-59 and ICRC-60. ICRC-59 defines a static approach. It provides the minting and burning interface as well as methods to stage NFT metadata. If you are building a simple PFP NFT, you likely won’t have to go much farther than ICRC-59. ICRC/ICRCs/ICRC-59 at icrc59and60 · skilesare/ICRC · GitHub
ICRC-60 - Dynamic NFT Metadata Interface Standard - ICRC-60 builds on top of ICRC-59 but defines how and by what methods data can change. It also upgrades from the limited ‘Value’ type used in 7 and 59 form metadata and upgrades metadata to use ICRC-16 which allows for the Class data type. This data type allows a creator to mark some of their data as immutable and some of it as mutable. Further, the standard defines how creators can incorporate a rich community of data apps into their NFT and permission them such that you can trust that only those data providers updated the metadata(important for games and service-based NFTs). ICRC/ICRCs/ICRC-60 at icrc59and60 · skilesare/ICRC · GitHub
Please come join us during the NFT working groups and give your input as we begin to look at these and other important standards. Calendar: Internet Computer Events
Your feedback is invaluable and I’m really happy to have these out of my head an on ‘paper’ so we can begin discussing them.
So where do we start?
- ICRC-8 - Ledger Markets
- ICRC-56 - Multi-canister File System
- ICRC-59 - Static Metadata
- ICRC-60 - Dynamic Metadata