#[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.

§oracle_authority: Pubkey

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

source

pub fn size() -> usize

source

pub fn new<'info>( account_info: &'info AccountInfo<'info> ) -> Result<Ref<'info, Self>>

Returns the deserialized Switchboard Oracle account

§Arguments
  • account_info - A Solana AccountInfo referencing an existing Switchboard Oracle
§Examples
use switchboard_solana::OracleAccountData;

let oracle = OracleAccountData::new(oracle_account_info)?;
source

pub fn new_from_bytes(data: &[u8]) -> Result<&OracleAccountData>

Returns the deserialized Switchboard Oracle account

§Arguments
  • data - A Solana AccountInfo’s data buffer
§Examples
use switchboard_solana::OracleAccountData;

let oracle = OracleAccountData::new(oracle_account_info.try_borrow_data()?)?;

Trait Implementations§

source§

impl AccountDeserialize for OracleAccountData

source§

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>

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

source§

fn clone(&self) -> OracleAccountData

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Discriminator for OracleAccountData

source§

const DISCRIMINATOR: [u8; 8] = _

§

fn discriminator() -> [u8; 8]

source§

impl Owner for OracleAccountData

source§

impl Zeroable for OracleAccountData

§

fn zeroed() -> Self

source§

impl Copy for OracleAccountData

source§

impl Pod for OracleAccountData

source§

impl ZeroCopy for OracleAccountData

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CheckedBitPattern for T
where T: AnyBitPattern,

§

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

If this function returns true, then it must be valid to reinterpret bits as &Self.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> AnyBitPattern for T
where T: Pod,

§

impl<T> NoUninit for T
where T: Pod,