use super::error::UtilError;
use solana_program::{
account_info::AccountInfo,
entrypoint::ProgramResult,
program_error::ProgramError,
program_pack::{IsInitialized, Pack},
pubkey::Pubkey,
};
use spl_associated_token_account::get_associated_token_address;
use spl_token;
use spl_token::state::Account;
pub fn assert_is_ata(ata: &AccountInfo, wallet: &Pubkey, mint: &Pubkey) -> ProgramResult {
assert_owned_by(ata, &spl_token::id())?;
let ata_account: Account = assert_initialized(ata)?;
assert_keys_equal(ata_account.owner, *wallet)?;
assert_keys_equal(get_associated_token_address(wallet, mint), *ata.key)?;
Ok(())
}
pub fn assert_keys_equal(key1: Pubkey, key2: Pubkey) -> ProgramResult {
if key1 != key2 {
Err(UtilError::PublicKeyMismatch.into())
} else {
Ok(())
}
}
pub fn assert_initialized<T: Pack + IsInitialized>(
account_info: &AccountInfo,
) -> Result<T, ProgramError> {
let account: T = T::unpack_unchecked(&account_info.data.borrow())?;
if !account.is_initialized() {
Err(UtilError::UninitializedAccount.into())
} else {
Ok(account)
}
}
pub fn assert_owned_by(account: &AccountInfo, owner: &Pubkey) -> ProgramResult {
if account.owner != owner {
Err(UtilError::IncorrectOwner.into())
} else {
Ok(())
}
}