-
Notifications
You must be signed in to change notification settings - Fork 1
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
mcip-1 Cross-player On-chain NFT Attributes #3
Comments
Great concept, thanks for the work! I am a big fan of more on-chain data for NFTs. Here are two suggestions:
|
@tckpwr Thanks for the comment.
I will make some change asap. |
My primary doubt is if we should allow generic fields or if it would be better to refer to standard agreements. One way to solve it would be to deploy read-only contracts that provide information about a specific set of attributes and their rules. Take the role-playing attributes as defined in https://en.wikipedia.org/wiki/Attribute_(role-playing_games) |
I updated the issue and the proposal at https://github.com/ndujaLabs/MCIPs/blob/main/MCIPs/mcip-1.md The change makes the NFT totally agnostic about the game where it is playing. |
I was wondering if it is better to not extend ERC-165, since marketplace can have difficulty to manage the token. |
A proposal for a standard to handle cross-player on-chain NFT attributes
Abstract
The following standard allows for the implementation of a standard protocol for gaming NFTs and other NFTs that must be managed on pure decentralized application, i.e., at a smart contract level.
Motivation
The standard ERC721 works very well for collectibles, despite being introduced by a game. Games on chain may need attributes and other information on chain to be able to play with it. For example, the original EverDragons factory was implementing the following
to manage mutable and immutable properties of the single dragon. The limit of this model is that the properties were predefined and a different game could not reuse the same approach.
We need a generic solution that establish basic rules and is flexible enough to manage most scenarios and make NFT really movable among games.
Specification
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119.
Rationale
The reason why ERC721 metadata are off-chain makes perfect sense in general, in particular for immutable collectibles, but it does not allow pure on-chain games to interact with the NFT because they cannot access the metadata. This proposal adds a relatively inexpensive solution to it.
Imagine that there are two Bored Ape with the same rarity, but the two apes are used in a game. If one of the two gets very good attributes, whoever will by the ape will also buy levels in the game where the ape played. So, the value on the market of the good ape will be higher that the value of the ape who is a bad player.
Of course, to work as expected, OpenSea and other marketplace should have a list of games and be able to retrieve the attributes on game of any NFT.
NFT Owner inits and Player updates
If NFT owners are allowed to update the attributes of their tokens, they could set whichever value the want, so the only the Player must be able to update the attributes. It is important that the owner cannot revoke the approval because if not, owners could play a game and, when they realized they are decreasing their score, before that the game updates the attributes, they revoke the approval.
On the other hand, if the Player initializes the token, spam will florish. For example, a bad game could initialize tokens pretending that their owner played the game. Think of a porn game that sets your NFT and pretends that you have high scores. That can be a problem, right? The solution is that the Owner only can initialize the attribute for a specific game.
Recommendation
The on-chain Metadata must be used only for important informations, like, for example, level ups. If used for frequent changing values, too many changes will congestionate the blockchain.
Backwards Compatibility
This is totally compatible with the ERC721 standard, except for the interfaceId.
Implementations
https://github.com/ndujaLabs/erc721playable
The text was updated successfully, but these errors were encountered: