use crate::instructions::assert_derivation;
use {
crate::{errors::ErrorCode, state::*},
anchor_lang::prelude::*,
cardinal_token_manager::state::{TokenManager, TokenManagerState},
};
#[derive(Accounts)]
pub struct InvalidateTransferableReverseNameEntryCtx<'info> {
namespace: Account<'info, Namespace>,
#[account(
mut,
constraint = name_entry.namespace == namespace.key()
@ ErrorCode::InvalidEntry
)]
name_entry: Account<'info, Entry>,
#[account(
mut,
close = invalidator,
constraint = reverse_name_entry.entry_name == name_entry.name && reverse_name_entry.namespace_name == namespace.name @ ErrorCode::InvalidReverseEntry,
)]
reverse_name_entry: Account<'info, ReverseEntry>,
token_manager: UncheckedAccount<'info>,
#[account(mut)]
invalidator: UncheckedAccount<'info>,
}
pub fn handler(ctx: Context<InvalidateTransferableReverseNameEntryCtx>) -> Result<()> {
let name_entry = &mut ctx.accounts.name_entry;
name_entry.reverse_entry = None;
assert_derivation(
&cardinal_token_manager::id(),
&ctx.accounts.token_manager.to_account_info(),
&[cardinal_token_manager::state::TOKEN_MANAGER_SEED.as_bytes(), name_entry.mint.as_ref()],
)?;
if !ctx.accounts.token_manager.data_is_empty() {
let token_manager = Account::<TokenManager>::try_from(&ctx.accounts.token_manager)?;
if token_manager.state != TokenManagerState::Invalidated as u8 || token_manager.issuer != ctx.accounts.namespace.key() || token_manager.mint != name_entry.mint {
return Err(ErrorCode::InvalidTokenManager.into());
}
}
Ok(())
}