mango-v4/programs/mango-v4/src/state/mint_info.rs

77 lines
2.0 KiB
Rust

use anchor_lang::prelude::*;
use static_assertions::const_assert_eq;
use std::mem::size_of;
use crate::error::*;
use super::TokenIndex;
pub const MAX_BANKS: usize = 6;
// This struct describes which address lookup table can be used to pass
// the accounts that are relevant for this mint. The idea is that clients
// can load this account to figure out which address maps to use when calling
// instructions that need banks/oracles for all active positions.
#[account(zero_copy)]
#[derive(Debug)]
pub struct MintInfo {
// ABI: Clients rely on this being at offset 8
pub group: Pubkey,
// ABI: Clients rely on this being at offset 40
pub token_index: TokenIndex,
pub group_insurance_fund: u8,
pub padding1: [u8; 5],
pub mint: Pubkey,
pub banks: [Pubkey; MAX_BANKS],
pub vaults: [Pubkey; MAX_BANKS],
pub oracle: Pubkey,
pub registration_time: u64,
pub reserved: [u8; 2560],
}
const_assert_eq!(
size_of::<MintInfo>(),
32 + 2 + 1 + 5 + 32 + MAX_BANKS * 2 * 32 + 32 + 8 + 2560
);
const_assert_eq!(size_of::<MintInfo>(), 3056);
const_assert_eq!(size_of::<MintInfo>() % 8, 0);
impl MintInfo {
// used for health purposes
pub fn first_bank(&self) -> Pubkey {
self.banks[0]
}
pub fn first_vault(&self) -> Pubkey {
self.vaults[0]
}
pub fn num_banks(&self) -> usize {
self.banks
.iter()
.position(|&b| b == Pubkey::default())
.unwrap_or(MAX_BANKS)
}
pub fn banks(&self) -> &[Pubkey] {
&self.banks[..self.num_banks()]
}
pub fn verify_banks_ais(&self, all_bank_ais: &[AccountInfo]) -> Result<()> {
require_msg!(
all_bank_ais.iter().map(|ai| ai.key).eq(self.banks().iter()),
"the passed banks {:?} don't match banks in mint_info {:?}",
all_bank_ais.iter().map(|ai| ai.key).collect::<Vec<_>>(),
self.banks()
);
Ok(())
}
pub fn elligible_for_group_insurance_fund(&self) -> bool {
self.group_insurance_fund == 1
}
}