use anchor_spl::token::TokenAccount;
use cardinal_token_manager::state::{TokenManager, TokenManagerState};
use {
crate::{errors::ErrorCode, state::*},
anchor_lang::prelude::*,
};
#[derive(Accounts)]
pub struct SetGlobalReverseEntryCtx<'info> {
namespace: Box<Account<'info, Namespace>>,
#[account(
mut,
seeds = [ENTRY_SEED.as_bytes(), namespace.key().as_ref(), name_entry.name.as_bytes()],
bump = name_entry.bump,
)]
name_entry: Box<Account<'info, Entry>>,
#[account(
init_if_needed,
payer = payer,
space = REVERSE_ENTRY_SIZE,
seeds = [REVERSE_ENTRY_SEED.as_bytes(), user.key().as_ref()],
bump,
)]
reverse_name_entry: Box<Account<'info, ReverseEntry>>,
#[account(constraint =
user_name_entry_mint_token_account.mint == name_entry.mint
&& user_name_entry_mint_token_account.owner == user.key()
&& user_name_entry_mint_token_account.amount > 0
@ ErrorCode::InvalidOwnerMint
)]
user_name_entry_mint_token_account: Box<Account<'info, TokenAccount>>,
#[account(mut)]
token_manager: UncheckedAccount<'info>,
#[account(mut)]
user: Signer<'info>,
#[account(mut)]
payer: Signer<'info>,
system_program: Program<'info, System>,
}
pub fn handler(ctx: Context<SetGlobalReverseEntryCtx>) -> Result<()> {
let namespace = &mut ctx.accounts.namespace;
let entry = &mut ctx.accounts.name_entry;
entry.reverse_entry = Some(ctx.accounts.reverse_name_entry.key());
let token_manager = Account::<TokenManager>::try_from(&&ctx.accounts.token_manager)?;
if token_manager.mint != entry.mint || token_manager.issuer != namespace.key() || token_manager.state == TokenManagerState::Invalidated as u8 {
return Err(error!(ErrorCode::InvalidTokenManager));
}
let reverse_entry = &mut ctx.accounts.reverse_name_entry;
reverse_entry.bump = *ctx.bumps.get("reverse_name_entry").unwrap();
reverse_entry.namespace_name = ctx.accounts.namespace.name.clone();
reverse_entry.entry_name = entry.name.clone();
Ok(())
}