The ERC-721 standard introduces a non-fungible token (NFT) in which each issued token is unique and distinct from others. This standard defines functions and events that enable the creation, ownership, and transfer of non-fungible assets.
Note:ERC-721 Token addresses refer to full Hedera Token Service (HTS) fungible token entities. These tokens can be fully managed by HTS API calls. Additionally, by utilizing IERC721 interfaces or system contract functions, these tokens can also be managed by smart contracts on Hedera.
Gives the spender permission to transfer a token (_tokenId) to another account from the owner. The approval is cleared when the token is transferred. The _tokenId is the Hedera serial number of the NFT.
This works by creating a synthetic CryptoApproveAllowanceTransaction with payer - the account that called the precompile (the message sender property of the message frame in the EVM).
If the spender address is 0, this creates a CryptoDeleteAllowanceTransaction instead and removes any allowances previously approved on the token.
Fires an approval event with the following signature when executed:
function setApprovalForAll(address _operator, bool _approved) external
Approve or remove an operator as an operator for the caller. Operators can call transferFrom for any token owned by the caller.
This works by creating a synthetic CryptoApproveAllowanceTransaction with payer - the account that called the precompile (the message sender property of the message frame in the EVM).
getApproved
function getApproved(uint256 _tokenId) external view returns (address)
Returns the account approved for the specified _tokenId. The _tokenId is the Hedera serial number of the NFT.
This works by loading the SPENDER property of the token from the NFTs ledger.
isApprovedForAll
function isApprovedForAll(address _owner, address _operator) external view returns (bool)
Returns if the operator is allowed to manage all of the assets of owner.
This works by loading the APPROVE_FOR_ALL_NFTS_ALLOWANCES property of the owner account and verifying if the list of approved for all accounts contains the account id of the operator.
Transfers a token (_tokenId) from a Hedera account (from) to another Hedera account (to) in Solidity format. The _tokenId is the Hedera serial number of the NFT.
This works by creating a synthetic CryptoTransferTransaction with nft token transfers with the is_approval property set to true.
Returns the token metadata of the HTS non-fungible token. This corresponds to the NFT metadata field when minting an NFT using HTS. The _tokenId is the Hedera serial number of the NFT.
Returns the total supply of the HTS non-fungible token.
Unsupported Functions
The following ERC-721 operations will not be natively supported on Hedera and will return a failure if they're called. Advanced functionality is achievable only through custom implementations within smart contracts.