#[repr(packed(1))]pub struct OracleAccountData {
pub name: [u8; 32],
pub metadata: [u8; 128],
pub oracle_authority: Pubkey,
pub last_heartbeat: i64,
pub num_in_use: u32,
pub token_account: Pubkey,
pub queue_pubkey: Pubkey,
pub metrics: OracleMetrics,
pub bump: u8,
pub _ebuf: [u8; 255],
}
Fields§
§name: [u8; 32]
Name of the oracle to store on-chain.
metadata: [u8; 128]
Metadata of the oracle to store on-chain.
The account delegated as the authority for making account changes or withdrawing funds from a staking wallet.
last_heartbeat: i64
Unix timestamp when the oracle last heartbeated
num_in_use: u32
Flag dictating if an oracle is active and has heartbeated before the queue’s oracle timeout parameter.
token_account: Pubkey
Stake account and reward/slashing wallet.
queue_pubkey: Pubkey
Public key of the oracle queue who has granted it permission to use its resources.
metrics: OracleMetrics
Oracle track record.
bump: u8
The PDA bump to derive the pubkey.
_ebuf: [u8; 255]
Reserved for future info.
Implementations§
source§impl OracleAccountData
impl OracleAccountData
pub fn size() -> usize
sourcepub fn new<'info>(
account_info: &'info AccountInfo<'info>
) -> Result<Ref<'info, Self>>
pub fn new<'info>( account_info: &'info AccountInfo<'info> ) -> Result<Ref<'info, Self>>
sourcepub fn new_from_bytes(data: &[u8]) -> Result<&OracleAccountData>
pub fn new_from_bytes(data: &[u8]) -> Result<&OracleAccountData>
pub fn fetch(client: &RpcClient, pubkey: Pubkey) -> Result<Self, SbError>
pub async fn fetch_async( client: &RpcClient, pubkey: Pubkey ) -> Result<Self, SbError>
pub fn fetch_sync<T: SyncClient>( client: &T, pubkey: Pubkey ) -> Result<Self, SbError>
Trait Implementations§
source§impl AccountDeserialize for OracleAccountData
impl AccountDeserialize for OracleAccountData
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 OracleAccountData
impl Clone for OracleAccountData
source§fn clone(&self) -> OracleAccountData
fn clone(&self) -> OracleAccountData
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 Discriminator for OracleAccountData
impl Discriminator for OracleAccountData
const DISCRIMINATOR: [u8; 8] = _
fn discriminator() -> [u8; 8]
impl Copy for OracleAccountData
impl Pod for OracleAccountData
impl ZeroCopy for OracleAccountData
Auto Trait Implementations§
impl RefUnwindSafe for OracleAccountData
impl Send for OracleAccountData
impl Sync for OracleAccountData
impl Unpin for OracleAccountData
impl UnwindSafe for OracleAccountData
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
.