A Extensão Mint Close Authority
A extensão MintCloseAuthority é uma extensão de Mint que permite à autoridade fechar e recuperar o rent de uma conta Mint que possui um supply atual de 0.
Essa extensão é útil para limpar mints não utilizadas e recuperar o SOL que foi usado para pagar a isenção de rent da conta. A mint só pode ser fechada quando não há tokens em circulação.
Inicializando a Conta Mint
Para inicializar a extensão MintCloseAuthority em uma conta Mint, podemos simplesmente usar a macro que o Anchor criou para nós.
Veja como criar uma mint com a extensão Mint Close:
rust
#[derive(Accounts)]
pub struct CreateMint<'info> {
#[account(mut)]
pub signer: Signer<'info>,
#[account(
init,
payer = signer,
mint::decimals = 6,
mint::authority = signer.key(),
mint::token_program = token_program,
extensions::close_authority::authority = signer,
)]
pub mint: InterfaceAccount<'info, Mint>,
pub system_program: Program<'info, System>,
pub token_program: Interface<'info, TokenInterface>,
}Fechando a Conta Mint
Se uma conta Mint tem um supply de zero, a CloseMint Authority pode recuperar o rent dessa conta usando a instrução close_account() assim:
rust
use anchor_lang::prelude::*;
use anchor_lang::system_program::{create_account, CreateAccount};
use anchor_spl::{
token_2022::{close_account, CloseAccount},
token_interface::{
spl_token_2022::{
extension::{
mint_close_authority::MintCloseAuthority
},
},
Mint, Token2022,
},
};
#[derive(Accounts)]
pub struct Close<'info> {
#[account(mut)]
pub authority: Signer<'info>,
#[account(
mut,
extensions::close_authority::authority = authority,
)]
pub mint_account: InterfaceAccount<'info, Mint>,
pub token_program: Program<'info, Token2022>,
}
pub fn close(ctx: Context<Close>) -> Result<()> {
// CPI para os programas de extensões de token para fechar a conta mint
// alternativamente, isso também pode ser feito no client
close_account(CpiContext::new(
ctx.accounts.token_program.to_account_info(),
CloseAccount {
account: ctx.accounts.mint_account.to_account_info(),
destination: ctx.accounts.authority.to_account_info(),
authority: ctx.accounts.authority.to_account_info(),
},
))?;
Ok(())
}