Struct PriceUpdateV2

Source
pub struct PriceUpdateV2 {
    pub write_authority: Pubkey,
    pub verification_level: VerificationLevel,
    pub price_message: PriceFeedMessage,
    pub posted_slot: u64,
}
Expand description

A price update account. This account is used by the Pyth Receiver program to store a verified price update from a Pyth price feed. It contains:

  • write_authority: The write authority for this account. This authority can close this account to reclaim rent or update the account to contain a different price update.
  • verification_level: The VerificationLevel of this price update. This represents how many Wormhole guardian signatures have been verified for this price update.
  • price_message: The actual price update.
  • posted_slot: The slot at which this price update was posted.

Fields§

§write_authority: Pubkey§verification_level: VerificationLevel§price_message: PriceFeedMessage§posted_slot: u64

Implementations§

Source§

impl PriceUpdateV2

Source

pub const LEN: usize = 134usize

Source§

impl PriceUpdateV2

Source

pub fn get_price_unchecked( &self, feed_id: &FeedId, ) -> Result<Price, GetPriceError>

Get a Price from a PriceUpdateV2 account for a given FeedId.

§Warning

This function does not check :

  • How recent the price is
  • Whether the price update has been verified

It is therefore unsafe to use this function without any extra checks, as it allows for the possibility of using unverified or outdated price updates.

Source

pub fn get_price_no_older_than_with_custom_verification_level( &self, clock: &Clock, maximum_age: u64, feed_id: &FeedId, verification_level: VerificationLevel, ) -> Result<Price, GetPriceError>

Get a Price from a PriceUpdateV2 account for a given FeedId no older than maximum_age with customizable verification level.

§Warning

Lowering the verification level from Full to Partial increases the risk of using a malicious price update. Please read the documentation for VerificationLevel for more information.

§Example
use pyth_solana_receiver_sdk::price_update::{get_feed_id_from_hex, VerificationLevel, PriceUpdateV2};
use anchor_lang::prelude::*;

const MAXIMUM_AGE : u64 = 30;
const FEED_ID: &str = "0xef0d8b6fda2ceba41da15d4095d1da392a0d2f8ed0c6c7bc0f4cfac8c280b56d"; // SOL/USD

#[derive(Accounts)]
#[instruction(amount_in_usd : u64)]
pub struct ReadPriceAccount<'info> {
    pub price_update: Account<'info, PriceUpdateV2>,
}

pub fn read_price_account(ctx : Context<ReadPriceAccount>) -> Result<()> {
    let price_update = &mut ctx.accounts.price_update;
    let price = price_update.get_price_no_older_than_with_custom_verification_level(&Clock::get()?, MAXIMUM_AGE, &get_feed_id_from_hex(FEED_ID)?, VerificationLevel::Partial{num_signatures: 5})?;
    Ok(())
}
Source

pub fn get_price_no_older_than( &self, clock: &Clock, maximum_age: u64, feed_id: &FeedId, ) -> Result<Price, GetPriceError>

Get a Price from a PriceUpdateV2 account for a given FeedId no older than maximum_age with Full verification.

§Example
use pyth_solana_receiver_sdk::price_update::{get_feed_id_from_hex, PriceUpdateV2};
use anchor_lang::prelude::*;

const MAXIMUM_AGE : u64 = 30;
const FEED_ID: &str = "0xef0d8b6fda2ceba41da15d4095d1da392a0d2f8ed0c6c7bc0f4cfac8c280b56d"; // SOL/USD

#[derive(Accounts)]
#[instruction(amount_in_usd : u64)]
pub struct ReadPriceAccount<'info> {
    pub price_update: Account<'info, PriceUpdateV2>,
}

pub fn read_price_account(ctx : Context<ReadPriceAccount>) -> Result<()> {
    let price_update = &mut ctx.accounts.price_update;
    let price = price_update.get_price_no_older_than(&Clock::get()?, MAXIMUM_AGE, &get_feed_id_from_hex(FEED_ID)?)?;
    Ok(())
}

Trait Implementations§

Source§

impl AccountDeserialize for PriceUpdateV2

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 AccountSerialize for PriceUpdateV2

Source§

fn try_serialize<W: Write>(&self, writer: &mut W) -> Result<()>

Serializes the account data into writer.
Source§

impl BorshDeserialize for PriceUpdateV2

Source§

fn deserialize_reader<R: Read>(reader: &mut R) -> Result<Self, Error>

Source§

fn deserialize(buf: &mut &[u8]) -> Result<Self, Error>

Deserializes this instance from a given slice of bytes. Updates the buffer to point at the remaining bytes.
Source§

fn try_from_slice(v: &[u8]) -> Result<Self, Error>

Deserialize this instance from a slice of bytes.
Source§

fn try_from_reader<R>(reader: &mut R) -> Result<Self, Error>
where R: Read,

Source§

impl BorshSerialize for PriceUpdateV2

Source§

fn serialize<W: Write>(&self, writer: &mut W) -> Result<(), Error>

Source§

fn try_to_vec(&self) -> Result<Vec<u8>, Error>

Serialize this instance into a vector of bytes.
Source§

impl BorshSchema for PriceUpdateV2

Source§

fn declaration() -> Declaration

Get the name of the type without brackets.
Source§

fn add_definitions_recursively( definitions: &mut HashMap<Declaration, Definition>, )

Recursively, using DFS, add type definitions required for this type. For primitive types this is an empty map. Type definition explains how to serialize/deserialize a type.
Source§

fn add_definition( declaration: String, definition: Definition, definitions: &mut HashMap<String, Definition>, )

Helper method to add a single type definition to the map.
Source§

fn schema_container() -> BorshSchemaContainer

Source§

impl Clone for PriceUpdateV2

Source§

fn clone(&self) -> PriceUpdateV2

Returns a duplicate 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 PriceUpdateV2

Source§

const DISCRIMINATOR: &'static [u8]

Discriminator slice. Read more
Source§

impl Owner for PriceUpdateV2

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

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
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> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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>,

Source§

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>,

Source§

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.
Source§

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

Source§

fn vzip(self) -> V