mirror of
https://github.com/d0zingcat/ore.git
synced 2026-05-14 15:10:13 +00:00
190 lines
6.2 KiB
Rust
190 lines
6.2 KiB
Rust
use drillx::Solution;
|
|
use steel::*;
|
|
|
|
use crate::{
|
|
consts::*,
|
|
instruction::*,
|
|
state::{bus_pda, config_pda, proof_pda, treasury_pda},
|
|
};
|
|
|
|
/// Builds an auth instruction.
|
|
pub fn auth(proof: Pubkey) -> Instruction {
|
|
Instruction {
|
|
program_id: NOOP_PROGRAM_ID,
|
|
accounts: vec![],
|
|
data: proof.to_bytes().to_vec(),
|
|
}
|
|
}
|
|
|
|
/// Builds a claim instruction.
|
|
pub fn claim(signer: Pubkey, beneficiary: Pubkey, amount: u64) -> Instruction {
|
|
let proof = proof_pda(signer).0;
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new(beneficiary, false),
|
|
AccountMeta::new(proof, false),
|
|
AccountMeta::new_readonly(TREASURY_ADDRESS, false),
|
|
AccountMeta::new(TREASURY_TOKENS_ADDRESS, false),
|
|
AccountMeta::new_readonly(spl_token::ID, false),
|
|
],
|
|
data: Claim {
|
|
amount: amount.to_le_bytes(),
|
|
}
|
|
.to_bytes(),
|
|
}
|
|
}
|
|
|
|
/// Builds a close instruction.
|
|
pub fn close(signer: Pubkey) -> Instruction {
|
|
let proof = proof_pda(signer).0;
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new(proof, false),
|
|
AccountMeta::new_readonly(solana_program::system_program::ID, false),
|
|
],
|
|
data: Close {}.to_bytes(),
|
|
}
|
|
}
|
|
|
|
/// Builds a mine instruction.
|
|
pub fn mine(
|
|
signer: Pubkey,
|
|
authority: Pubkey,
|
|
bus: Pubkey,
|
|
solution: Solution,
|
|
boost_keys: Option<[Pubkey; 2]>,
|
|
) -> Instruction {
|
|
let proof = proof_pda(authority).0;
|
|
let mut accounts = vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new(bus, false),
|
|
AccountMeta::new_readonly(CONFIG_ADDRESS, false),
|
|
AccountMeta::new(proof, false),
|
|
AccountMeta::new_readonly(sysvar::instructions::ID, false),
|
|
AccountMeta::new_readonly(sysvar::slot_hashes::ID, false),
|
|
];
|
|
if let Some([boost_address, boost_config_address]) = boost_keys {
|
|
accounts.push(AccountMeta::new_readonly(boost_address, false));
|
|
accounts.push(AccountMeta::new(proof_pda(boost_address).0, false));
|
|
accounts.push(AccountMeta::new_readonly(boost_config_address, false));
|
|
}
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts,
|
|
data: Mine {
|
|
digest: solution.d,
|
|
nonce: solution.n,
|
|
}
|
|
.to_bytes(),
|
|
}
|
|
}
|
|
|
|
/// Builds an open instruction.
|
|
pub fn open(signer: Pubkey, miner: Pubkey, payer: Pubkey) -> Instruction {
|
|
let proof_pda = proof_pda(signer);
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new_readonly(miner, false),
|
|
AccountMeta::new(payer, true),
|
|
AccountMeta::new(proof_pda.0, false),
|
|
AccountMeta::new_readonly(solana_program::system_program::ID, false),
|
|
AccountMeta::new_readonly(sysvar::slot_hashes::ID, false),
|
|
],
|
|
data: Open {}.to_bytes(),
|
|
}
|
|
}
|
|
|
|
/// Builds a reset instruction.
|
|
pub fn reset(signer: Pubkey) -> Instruction {
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new(BUS_ADDRESSES[0], false),
|
|
AccountMeta::new(BUS_ADDRESSES[1], false),
|
|
AccountMeta::new(BUS_ADDRESSES[2], false),
|
|
AccountMeta::new(BUS_ADDRESSES[3], false),
|
|
AccountMeta::new(BUS_ADDRESSES[4], false),
|
|
AccountMeta::new(BUS_ADDRESSES[5], false),
|
|
AccountMeta::new(BUS_ADDRESSES[6], false),
|
|
AccountMeta::new(BUS_ADDRESSES[7], false),
|
|
AccountMeta::new(CONFIG_ADDRESS, false),
|
|
AccountMeta::new(MINT_ADDRESS, false),
|
|
AccountMeta::new(TREASURY_ADDRESS, false),
|
|
AccountMeta::new(TREASURY_TOKENS_ADDRESS, false),
|
|
AccountMeta::new_readonly(spl_token::ID, false),
|
|
],
|
|
data: Reset {}.to_bytes(),
|
|
}
|
|
}
|
|
|
|
// Build an update instruction.
|
|
pub fn update(signer: Pubkey, miner: Pubkey) -> Instruction {
|
|
let proof = proof_pda(signer).0;
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new_readonly(miner, false),
|
|
AccountMeta::new(proof, false),
|
|
],
|
|
data: Update {}.to_bytes(),
|
|
}
|
|
}
|
|
|
|
/// Builds an initialize instruction.
|
|
pub fn initialize(signer: Pubkey) -> Instruction {
|
|
let bus_pdas = [
|
|
bus_pda(0),
|
|
bus_pda(1),
|
|
bus_pda(2),
|
|
bus_pda(3),
|
|
bus_pda(4),
|
|
bus_pda(5),
|
|
bus_pda(6),
|
|
bus_pda(7),
|
|
];
|
|
let config_pda = config_pda();
|
|
let mint_pda = Pubkey::find_program_address(&[MINT, MINT_NOISE.as_slice()], &crate::ID);
|
|
let treasury_pda = treasury_pda();
|
|
let metadata_pda = Pubkey::find_program_address(
|
|
&[
|
|
METADATA,
|
|
mpl_token_metadata::ID.as_ref(),
|
|
mint_pda.0.as_ref(),
|
|
],
|
|
&mpl_token_metadata::ID,
|
|
);
|
|
Instruction {
|
|
program_id: crate::ID,
|
|
accounts: vec![
|
|
AccountMeta::new(signer, true),
|
|
AccountMeta::new(bus_pdas[0].0, false),
|
|
AccountMeta::new(bus_pdas[1].0, false),
|
|
AccountMeta::new(bus_pdas[2].0, false),
|
|
AccountMeta::new(bus_pdas[3].0, false),
|
|
AccountMeta::new(bus_pdas[4].0, false),
|
|
AccountMeta::new(bus_pdas[5].0, false),
|
|
AccountMeta::new(bus_pdas[6].0, false),
|
|
AccountMeta::new(bus_pdas[7].0, false),
|
|
AccountMeta::new(config_pda.0, false),
|
|
AccountMeta::new(metadata_pda.0, false),
|
|
AccountMeta::new(mint_pda.0, false),
|
|
AccountMeta::new(treasury_pda.0, false),
|
|
AccountMeta::new(TREASURY_TOKENS_ADDRESS, false),
|
|
AccountMeta::new_readonly(system_program::ID, false),
|
|
AccountMeta::new_readonly(spl_token::ID, false),
|
|
AccountMeta::new_readonly(spl_associated_token_account::ID, false),
|
|
AccountMeta::new_readonly(mpl_token_metadata::ID, false),
|
|
AccountMeta::new_readonly(sysvar::rent::ID, false),
|
|
],
|
|
data: Initialize {}.to_bytes(),
|
|
}
|
|
}
|