mirror of
https://github.com/d0zingcat/ore.git
synced 2026-05-14 07:26:51 +00:00
27 lines
779 B
Rust
27 lines
779 B
Rust
use bytemuck::{Pod, Zeroable};
|
|
use shank::ShankAccount;
|
|
|
|
use crate::{
|
|
impl_account_from_bytes, impl_to_bytes,
|
|
utils::{AccountDiscriminator, Discriminator},
|
|
};
|
|
|
|
/// Treasury is a singleton account which manages all program wide variables.
|
|
/// It is the mint authority for the Ore token and also the authority of the program-owned token account.
|
|
#[repr(C)]
|
|
#[derive(Clone, Copy, Debug, PartialEq, Pod, ShankAccount, Zeroable)]
|
|
pub struct Treasury {
|
|
/// The bump of the treasury account PDA, for signing CPIs.
|
|
// TODO Is this needed if bump is const?
|
|
pub bump: u64,
|
|
}
|
|
|
|
impl Discriminator for Treasury {
|
|
fn discriminator() -> AccountDiscriminator {
|
|
AccountDiscriminator::Treasury
|
|
}
|
|
}
|
|
|
|
impl_to_bytes!(Treasury);
|
|
impl_account_from_bytes!(Treasury);
|