-
Notifications
You must be signed in to change notification settings - Fork 142
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Consider simplifying MT Metadata structure #367
Comments
Not sure if details just got lost with time. You could probably rework somethings there's a PR near/near-sdk-rs#776 already floating, but noone has had time to review it from standards team. I'd figure out what the process should be that Jay setup. The way to think about mt is in tiers. A multi token contract has many tokens vs just one. You need a way to represent these tokens in the same contract (MTBaseTokenMetadata). ContractMetadata as a field only can relay information about the protocol in use and the title for this particular MultiTokenContract. Furthermore with multi token contracts, there has to be a way of grouping token ids. In the 1155 standard this was done by suggesting a hexadecimal format for cross associating tokens. I.e. your contract has a golden flame nft and 5 editions of it or you want to link metadata for your token across a set of tokens , the Why separate data structures still. Well people(wallet team initially etc...) want to be able to enumerate over the set of nfts/fts/other in the contract, and retrieving back every instances full metadata could become somewhat infeasible. So having a way to retrieve a subset of the information is important . This was decided after meeting with the stakeholders at the time.
Does this clarify a bit why the methods and the data structure ? It's verbose but covers the cases. MTBaseTokenMetadata - Is essentially the high level data that describes a ft/nft collection ( a class) Feel free to drop new thoughts here or alternatives, perhaps you have some weight to start the standards review process for the existing PR(near/near-sdk-rs#776) ? |
I haven't found any details here #245
We have 5 different functions for MT metadata 🤯 https://github.com/near/NEPs/blob/master/specs/Standards/Tokens/MultiToken/Metadata.md
As the smart contract developer, I'd expect 2 structures: contract-wide and token-wide.
As the web developer, trying to show the tokens to the users, I feel absolutely lost. Do I need to call all the 5 methods? Where do I need to show each piece of the info?
Why do we decided to split the data to MTBaseTokenMetadata and MTTokenMetadata? It looks like it's actually should be one object.
Why doesn't MTContractMetadata contain icon and other important fields? See NFT Contract Metadata as the reference.
Are we still allowed to rework this part of the standard, adding breaking changes, dropping some methods and reworking things?
cc @zcstarr @frol @MaximusHaximus @jberrytech @BenKurrek
The text was updated successfully, but these errors were encountered: