Struct switchboard_solana::oracle_program::accounts::lease::LeaseAccountData
source · #[repr(packed(1))]pub struct LeaseAccountData {
pub escrow: Pubkey,
pub queue: Pubkey,
pub aggregator: Pubkey,
pub token_program: Pubkey,
pub is_active: bool,
pub crank_row_count: u32,
pub created_at: i64,
pub update_count: u128,
pub withdraw_authority: Pubkey,
pub bump: u8,
pub _ebuf: [u8; 255],
}
Fields§
§escrow: Pubkey
Public key of the token account holding the lease contract funds until rewarded to oracles for successfully processing updates
queue: Pubkey
Public key of the oracle queue that the lease contract is applicable for.
aggregator: Pubkey
Public key of the aggregator that the lease contract is applicable for
token_program: Pubkey
Public key of the Solana token program ID.
is_active: bool
Whether the lease contract is still active.
crank_row_count: u32
Index of an aggregators position on a crank.
created_at: i64
Timestamp when the lease contract was created.
update_count: u128
Counter keeping track of the number of updates for the given aggregator.
Public key of keypair that may withdraw funds from the lease at any time
bump: u8
The PDA bump to derive the pubkey.
_ebuf: [u8; 255]
Implementations§
Trait Implementations§
source§impl AccountDeserialize for LeaseAccountData
impl AccountDeserialize for LeaseAccountData
source§fn try_deserialize(buf: &mut &[u8]) -> Result<Self>
fn try_deserialize(buf: &mut &[u8]) -> Result<Self>
Deserializes previously initialized account data. Should fail for all
uninitialized accounts, where the bytes are zeroed. Implementations
should be unique to a particular account type so that one can never
successfully deserialize the data of one account type into another.
For example, if the SPL token program were to implement this trait,
it should be impossible to deserialize a
Mint
account into a token
Account
.source§fn try_deserialize_unchecked(buf: &mut &[u8]) -> Result<Self>
fn try_deserialize_unchecked(buf: &mut &[u8]) -> Result<Self>
Deserializes account data without checking the account discriminator.
This should only be used on account initialization, when the bytes of
the account are zeroed.
source§impl Clone for LeaseAccountData
impl Clone for LeaseAccountData
source§fn clone(&self) -> LeaseAccountData
fn clone(&self) -> LeaseAccountData
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Default for LeaseAccountData
impl Default for LeaseAccountData
source§impl Discriminator for LeaseAccountData
impl Discriminator for LeaseAccountData
const DISCRIMINATOR: [u8; 8] = _
fn discriminator() -> [u8; 8]
source§impl TryInto<LeaseAccountData> for Option<Vec<u8>>
impl TryInto<LeaseAccountData> for Option<Vec<u8>>
§type Error = SwitchboardError
type Error = SwitchboardError
The type returned in the event of a conversion error.
impl Copy for LeaseAccountData
impl Pod for LeaseAccountData
impl ZeroCopy for LeaseAccountData
Auto Trait Implementations§
impl Freeze for LeaseAccountData
impl RefUnwindSafe for LeaseAccountData
impl Send for LeaseAccountData
impl Sync for LeaseAccountData
impl Unpin for LeaseAccountData
impl UnwindSafe for LeaseAccountData
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
§type Bits = T
type Bits = T
Self
must have the same layout as the specified Bits
except for
the possible invalid bit patterns being checked during
is_valid_bit_pattern
.§fn is_valid_bit_pattern(_bits: &T) -> bool
fn is_valid_bit_pattern(_bits: &T) -> bool
If this function returns true, then it must be valid to reinterpret
bits
as &Self
.source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more