Skip to content

sbepstein/neo-nft-template

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 

Repository files navigation

Neo Non-Fungible Token Template

What is a non-fungible token?

A non-fungible token (NFT) can be thought of like a property deed - each one is unique and carries some non-mutable information (e.g. the physical address of the property) although other information, such as the owner of the property can be changed. An NFT smart contract is useful to track ownership of real-world items, as well as in online gaming, allowing users to posess unique characters or items of a limited supply, that can be transferred between users without requiring the permission of the game owner.

The NFT proposal standard for the Neo Smart Economy is currently in development. This is a draft template example in Python showing how such a smart contract might be written. There is some overlap between NEP-5 (fungible) token functionality to make adoption easier by API writers.

Smart Contract Operations

The operations of the NFT template contract are:

  • allowance(tokenid): returns approved third-party spender of a token
  • approve(owner, spender, tokenid, revoke): approve third party to spend a token
  • balanceOf(owner): returns owner's current total tokens owned
  • circulation(): returns current number of tokens in circulation
  • decimals(): returns number of decimals of token
  • mintToken(owner, ROData, RWData, URI): create a new NFT token
  • modifyRWData(tokenid, RWData): modify a token's read/write data
  • modifyURI(tokenid, URI): modify a token's URI
  • name(): returns name of token
  • ownerOf(tokenid): returns owner of a token
  • symbol(): returns token symbol
  • tokenOfOwnerByIndex(owner, idx): returns one token from owner's collection
  • tokenROData(tokenid): returns a token's read-only data
  • tokenRWData(tokenid): returns a token's read/write data
  • tokenURI(tokenid): returns a token's URI
  • transfer(from, to, tokenid): transfers a token
  • transferFrom(from, to, tokenid): transfers a token by authorized spender

About

Example code for non-fungible token smart contract

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%