Skip to main content

tengu_api/state/
dojo.rs

1use super::DojosAccount;
2use solana_program::program_error::ProgramError;
3use steel::*;
4
5#[repr(C)]
6#[derive(Clone, Copy, Debug, PartialEq, bytemuck::Pod, bytemuck::Zeroable)]
7pub struct Dojo {
8    pub owner: Pubkey,
9    pub barracks_level: u64,
10    pub forge_level: u64,
11    pub ore_balance: u64,
12    pub shard_balance: u64, // In-game shards (raw $DOJO when claimed). Refine: Ore → shards.
13    pub last_ore_claim_slot: u64,
14    pub referrer: Pubkey, // Referrer's Dojo PDA (who referred this player)
15    pub recruitment_ticket_balance: u64,
16    pub recruited_count: u64,
17    pub dine_count: u64,
18    /// Pity counter: pulls since last SR+. At 10, next pull is forced SR+. Resets on SR+.
19    pub pity_counter: u64,
20    /// Last daily reset slot (Solana slot). Used for flash_sale reset.
21    pub last_daily_reset_slot: u64,
22    pub flash_sale_count_today: u64,
23    pub last_flash_sale_reset_slot: u64,
24    pub amethyst_balance: u64,
25    pub active_scene_id: u64,
26    /// Fodder counts by element×5+rarity (0–24). Recruit adds; seat/merge/prestige consume.
27    pub fodder_counts: [u64; 25],
28}
29
30account!(DojosAccount, Dojo);
31
32impl Dojo {
33    pub fn assert_owner(&self, signer: &Pubkey) -> Result<(), ProgramError> {
34        if self.owner != *signer {
35            return Err(ProgramError::IllegalOwner);
36        }
37        Ok(())
38    }
39
40    pub fn barracks_upgrade_cost_shards(&self) -> u64 {
41        match self.barracks_level {
42            1 => crate::consts::BARRACKS_COST_1_2_SHARDS,
43            2 => crate::consts::BARRACKS_COST_2_3_SHARDS,
44            3 => crate::consts::BARRACKS_COST_3_4,
45            _ => u64::MAX,
46        }
47    }
48    pub fn barracks_upgrade_cost_sol(&self) -> u64 {
49        match self.barracks_level {
50            1 => crate::consts::BARRACKS_COST_1_2_SOL,
51            2 => crate::consts::BARRACKS_COST_2_3_SOL,
52            3 => u64::MAX, // 3→4 shards only
53            _ => u64::MAX,
54        }
55    }
56
57    pub fn add_amethyst(&mut self, amount: u64) {
58        self.amethyst_balance = self.amethyst_balance.saturating_add(amount);
59    }
60
61    pub fn sub_amethyst(&mut self, amount: u64) -> Result<(), ProgramError> {
62        if self.amethyst_balance < amount {
63            return Err(ProgramError::InsufficientFunds);
64        }
65        self.amethyst_balance -= amount;
66        Ok(())
67    }
68}