mirror of
https://github.com/d0zingcat/ore.git
synced 2026-05-14 07:26:51 +00:00
40 lines
1.1 KiB
Rust
40 lines
1.1 KiB
Rust
use bytemuck::{Pod, Zeroable};
|
|
use shank::ShankAccount;
|
|
use solana_program::pubkey::Pubkey;
|
|
|
|
use crate::{
|
|
impl_account_from_bytes, impl_to_bytes,
|
|
state::Hash,
|
|
utils::{AccountDiscriminator, Discriminator},
|
|
};
|
|
|
|
/// Proof accounts track a miner's current hash, claimable rewards, and lifetime stats.
|
|
/// Every miner is allowed one proof account which is required by the program to mine or claim rewards.
|
|
#[repr(C)]
|
|
#[derive(Clone, Copy, Debug, PartialEq, Pod, ShankAccount, Zeroable)]
|
|
pub struct Proof {
|
|
/// The account (i.e. miner) authorized to use this proof.
|
|
pub authority: Pubkey,
|
|
|
|
/// The quantity of tokens this miner may claim from the treasury.
|
|
pub claimable_rewards: u64,
|
|
|
|
/// The proof's current hash.
|
|
pub hash: Hash,
|
|
|
|
/// The total lifetime hashes provided by this miner.
|
|
pub total_hashes: u64,
|
|
|
|
/// The total lifetime rewards distributed to this miner.
|
|
pub total_rewards: u64,
|
|
}
|
|
|
|
impl Discriminator for Proof {
|
|
fn discriminator() -> AccountDiscriminator {
|
|
AccountDiscriminator::Proof
|
|
}
|
|
}
|
|
|
|
impl_to_bytes!(Proof);
|
|
impl_account_from_bytes!(Proof);
|