use bytemuck::{Pod, Zeroable};
use shank::ShankAccount;
use solana_program::pubkey::Pubkey;
use crate::utils::{impl_account_from_bytes, impl_to_bytes, Discriminator};
use super::AccountDiscriminator;
#[repr(C)]
#[derive(Clone, Copy, Debug, PartialEq, Pod, ShankAccount, Zeroable)]
pub struct Proof {
pub authority: Pubkey,
pub balance: u64,
pub challenge: [u8; 32],
pub last_hash: [u8; 32],
pub last_hash_at: i64,
pub last_stake_at: i64,
pub miner: Pubkey,
pub total_hashes: u64,
pub total_rewards: u64,
}
impl Discriminator for Proof {
fn discriminator() -> u8 {
AccountDiscriminator::Proof.into()
}
}
impl_to_bytes!(Proof);
impl_account_from_bytes!(Proof);