mirror of
https://github.com/d0zingcat/ore.git
synced 2026-05-14 07:26:51 +00:00
46 lines
1.5 KiB
Rust
46 lines
1.5 KiB
Rust
use ore_api::{consts::*, instruction::StakeArgs, loaders::*, state::Proof};
|
|
use ore_utils::spl::transfer;
|
|
use solana_program::{
|
|
account_info::AccountInfo, clock::Clock, entrypoint::ProgramResult,
|
|
program_error::ProgramError, sysvar::Sysvar,
|
|
};
|
|
|
|
use crate::utils::AccountDeserialize;
|
|
|
|
/// Stake deposits ORE into a proof account to earn multiplier.
|
|
pub fn process_stake<'a, 'info>(accounts: &'a [AccountInfo<'info>], data: &[u8]) -> ProgramResult {
|
|
// Parse args.
|
|
let args = StakeArgs::try_from_bytes(data)?;
|
|
let amount = u64::from_le_bytes(args.amount);
|
|
|
|
// Load accounts.
|
|
let [signer, proof_info, sender_info, treasury_tokens_info, token_program] = accounts else {
|
|
return Err(ProgramError::NotEnoughAccountKeys);
|
|
};
|
|
load_signer(signer)?;
|
|
load_proof(proof_info, signer.key, true)?;
|
|
load_token_account(sender_info, Some(signer.key), &MINT_ADDRESS, true)?;
|
|
load_treasury_tokens(treasury_tokens_info, true)?;
|
|
load_program(token_program, spl_token::id())?;
|
|
|
|
// Update the proof balance.
|
|
let mut proof_data = proof_info.data.borrow_mut();
|
|
let proof = Proof::try_from_bytes_mut(&mut proof_data)?;
|
|
proof.balance = proof.balance.checked_add(amount).unwrap();
|
|
|
|
// Update deposit timestamp.
|
|
let clock = Clock::get().or(Err(ProgramError::InvalidAccountData))?;
|
|
proof.last_stake_at = clock.unix_timestamp;
|
|
|
|
// Transfer tokens from signer to treasury.
|
|
transfer(
|
|
signer,
|
|
sender_info,
|
|
treasury_tokens_info,
|
|
token_program,
|
|
amount,
|
|
)?;
|
|
|
|
Ok(())
|
|
}
|