nft-burn?
Burning a non-fungible token (NFT) in Clarity smart contracts.
Function Signature
(nft-burn? asset-class asset-identifier sender)
- Input: AssetName, A, principal
- Output: (response bool uint)
Why it matters
The nft-burn? function is crucial for:
- 1Reducing the circulating supply of a non-fungible token (NFT).
- 2Managing the lifecycle of NFTs by allowing their destruction.
- 3Ensuring data integrity by removing ownership records of burned NFTs.
- 4Simplifying the process of handling NFT burn operations in smart contracts.
When to use it
Use nft-burn? when you need to:
- Reduce the circulating supply of an NFT.
- Manage the lifecycle of NFTs by allowing their destruction.
- Remove ownership records of burned NFTs.
- Handle NFT burn operations in your smart contract.
Best Practices
- Ensure the senderprincipal owns the NFT before attempting to burn it.
- Use meaningful variable names for better readability.
- Combine with other NFT functions for comprehensive NFT management.
- Handle the possible error cases to ensure robust contract behavior.
Practical Example: Burning an NFT
Let's implement a function that burns an NFT owned by the sender:
(define-non-fungible-token Stackaroo (string-ascii 40))(define-public (burn-nft (id (string-ascii 40)))(nft-burn? Stackaroo id tx-sender));; Usage(nft-mint? Stackaroo "Roo" tx-sender) ;; Returns (ok true)(burn-nft "Roo") ;; Returns (ok true)(nft-burn? Stackaroo "Roo" tx-sender) ;; Returns (err u3) because the asset no longer exists
This example demonstrates:
- 1Using nft-burn?to burn an NFT owned by the sender.
- 2Implementing a public function to handle the burn operation.
- 3Handling both the successful burn and the case where the asset no longer exists.
Common Pitfalls
- 1Using nft-burn?without ensuring thesenderowns the NFT, causing the operation to fail.
- 2Assuming the NFT will always exist, leading to unhandled error cases.
- 3Not handling all possible conditions, resulting in incomplete NFT management.
- 4Overlooking the need for proper error handling and validation.
Related Functions
- nft-mint?: Mints a new non-fungible token.
- nft-transfer?: Transfers ownership of a non-fungible token.
- nft-get-owner?: Retrieves the owner of a non-fungible token.
Conclusion
The nft-burn? function is a fundamental tool for managing the lifecycle of non-fungible tokens in Clarity smart contracts. It allows developers to reduce the circulating supply of NFTs, manage their destruction, and ensure data integrity. When used effectively, nft-burn? enhances the reliability and maintainability of your smart contract code by providing a clear and concise way to handle NFT burn operations.