ft-burn?
Burning fungible tokens in Clarity smart contracts.
Function signature
- Input:
token-name
: The name of the fungible tokenamount
: The amount of tokens to burn (uint)sender
: The principal from whose balance the tokens will be burned
- Output:
(response bool uint)
Why it matters
The ft-burn?
function is crucial for:
- Decreasing the total supply of a fungible token.
- Implementing token burning mechanisms in tokenomics models.
- Allowing users to destroy their own tokens.
- Managing token supply in deflationary token systems.
When to use it
Use ft-burn?
when you need to:
- Implement a token burning feature in your contract.
- Reduce the circulating supply of a token.
- Allow users to voluntarily destroy their tokens.
- Execute deflationary mechanisms in your token economy.
Best practices
- Ensure that the
sender
has sufficient balance before attempting to burn. - Use
ft-burn?
in conjunction with proper access controls. - Consider emitting events or logging burns for transparency.
- Be cautious when burning tokens from a different principal than
tx-sender
.
Practical example: Token burning mechanism
Let's implement a simple token burning function:
This example demonstrates:
- Using
ft-burn?
to burn tokens from the transaction sender. - Implementing an admin function to burn tokens from any account.
- Using assertions to ensure only the admin can burn tokens from other accounts.
Common pitfalls
- Attempting to burn more tokens than the
sender
has in their balance. - Not checking the return value of
ft-burn?
to handle potential errors. - Allowing unauthorized burning of tokens from other accounts.
- Forgetting that burned tokens are permanently destroyed and cannot be recovered.
Related functions
ft-mint?
: Used to create new tokens, increasing the total supply.ft-transfer?
: Used to transfer tokens between principals.ft-get-balance
: Used to check the token balance of a principal.ft-get-supply
: Used to get the current total supply of tokens.
Conclusion
The ft-burn?
function is a powerful tool for managing the supply of fungible tokens in Clarity smart contracts. It allows for the implementation of deflationary mechanisms and gives users the ability to destroy their own tokens. When used correctly, it can be a key component in sophisticated tokenomics models. However, it should be used with caution and with proper checks to ensure the integrity of your token system.