1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
use anchor_client::{solana_sdk::pubkey::Pubkey, Client, ClientError};
use anyhow::{anyhow, Result};
pub use mpl_candy_machine::ID as CANDY_MACHINE_ID;
use mpl_candy_machine::{CandyMachine, CandyMachineData, WhitelistMintMode, WhitelistMintSettings};
use spl_token::id as token_program_id;
use crate::{
config::{data::SugarConfig, price_as_lamports, ConfigData},
setup::setup_client,
utils::check_spl_token,
};
#[derive(Debug)]
pub struct ConfigStatus {
pub index: u32,
pub on_chain: bool,
}
pub fn parse_config_price(client: &Client, config: &ConfigData) -> Result<u64> {
let parsed_price = if let Some(spl_token) = config.spl_token {
let token_program = client.program(token_program_id());
let token_mint = check_spl_token(&token_program, &spl_token.to_string())?;
match (config.price as u64).checked_mul(10u64.pow(token_mint.decimals.into())) {
Some(price) => price,
None => return Err(anyhow!("Price math overflow")),
}
} else {
price_as_lamports(config.price)
};
Ok(parsed_price)
}
pub fn get_candy_machine_state(
sugar_config: &SugarConfig,
candy_machine_id: &Pubkey,
) -> Result<CandyMachine> {
let client = setup_client(sugar_config)?;
let program = client.program(CANDY_MACHINE_ID);
program.account(*candy_machine_id).map_err(|e| match e {
ClientError::AccountNotFound => anyhow!("Candy Machine does not exist!"),
_ => anyhow!(
"Failed to deserialize Candy Machine account {}: {}",
candy_machine_id.to_string(),
e
),
})
}
pub fn get_candy_machine_data(
sugar_config: &SugarConfig,
candy_machine_id: &Pubkey,
) -> Result<CandyMachineData> {
let candy_machine = get_candy_machine_state(sugar_config, candy_machine_id)?;
Ok(candy_machine.data)
}
pub fn print_candy_machine_state(state: CandyMachine) {
println!("Authority {:?}", state.authority);
println!("Wallet {:?}", state.wallet);
println!("Token mint: {:?}", state.token_mint);
println!("Items redeemed: {:?}", state.items_redeemed);
print_candy_machine_data(&state.data);
}
pub fn print_candy_machine_data(data: &CandyMachineData) {
println!("Uuid: {:?}", data.uuid);
println!("Price: {:?}", data.price);
println!("Symbol: {:?}", data.symbol);
println!(
"Seller fee basis points: {:?}",
data.seller_fee_basis_points
);
println!("Max supply: {:?}", data.max_supply);
println!("Is mutable: {:?}", data.is_mutable);
println!("Retain Authority: {:?}", data.retain_authority);
println!("Go live date: {:?}", data.go_live_date);
println!("Items available: {:?}", data.items_available);
print_whitelist_mint_settings(&data.whitelist_mint_settings);
}
fn print_whitelist_mint_settings(settings: &Option<WhitelistMintSettings>) {
if let Some(settings) = settings {
match settings.mode {
WhitelistMintMode::BurnEveryTime => println!("Mode: Burn every time"),
WhitelistMintMode::NeverBurn => println!("Mode: Never burn"),
}
println!("Mint: {:?}", settings.mint);
println!("Presale: {:?}", settings.presale);
println!("Discount price: {:?}", settings.discount_price);
} else {
println!("No whitelist mint settings");
}
}