pub struct PriceFeed {
    pub id: Identifier,
    /* private fields */
}
Expand description

Represents a current aggregation price from pyth publisher feeds.

Fields§

§id: Identifier

Unique identifier for this price.

Implementations§

source§

impl PriceFeed

source

pub fn new(id: Identifier, price: Price, ema_price: Price) -> PriceFeed

Constructs a new Price Feed

source

pub fn get_price_unchecked(&self) -> Price

Get the “unchecked” price and confidence interval as fixed-point numbers of the form a * 10^e along with its publish time.

Returns a Price struct containing the current price, confidence interval, and the exponent for both numbers, and publish time. This method returns the latest price which may be from arbitrarily far in the past, and the caller should probably check the timestamp before using it.

Please consider using get_price_no_older_than when possible.

source

pub fn get_ema_price_unchecked(&self) -> Price

Get the “unchecked” exponentially-weighted moving average (EMA) price and a confidence interval on the result along with its publish time.

Returns the latest EMA price value which may be from arbitrarily far in the past, and the caller should probably check the timestamp before using it.

At the moment, the confidence interval returned by this method is computed in a somewhat questionable way, so we do not recommend using it for high-value applications.

Please consider using get_ema_price_no_older_than when possible.

source

pub fn get_price_no_older_than(
&self,
current_time: i64,
age: u64
) -> Option<Price>

Get the price as long as it was updated within age seconds of the current_time.

This function is a sanity-checked version of get_price_unchecked which is useful in applications that require a sufficiently-recent price. Returns None if the price wasn’t updated sufficiently recently.

Returns a struct containing the latest available price, confidence interval and the exponent for both numbers, or None if no price update occurred within age seconds of the current_time.

source

pub fn get_ema_price_no_older_than(
&self,
current_time: i64,
age: u64
) -> Option<Price>

Get the exponentially-weighted moving average (EMA) price as long as it was updated within age seconds of the current_time.

This function is a sanity-checked version of get_ema_price_unchecked which is useful in applications that require a sufficiently-recent price. Returns None if the price wasn’t updated sufficiently recently.

Returns a struct containing the EMA price, confidence interval and the exponent for both numbers, or None if no price update occurred within age seconds of the current_time.

Trait Implementations§

source§

impl BorshDeserialize for PriceFeedwhere
Identifier: BorshDeserialize,
Price: BorshDeserialize,

source§

fn deserialize(buf: &mut &[u8]) -> Result<PriceFeed, 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§

impl BorshSerialize for PriceFeedwhere
Identifier: BorshSerialize,
Price: BorshSerialize,

source§

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

source§

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

Serialize this instance into a vector of bytes.
source§

impl Clone for PriceFeed

source§

fn clone(&self) -> PriceFeed

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 Debug for PriceFeed

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl Default for PriceFeed

source§

fn default() -> PriceFeed

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for PriceFeed

source§

fn deserialize<__D>(
__deserializer: __D
) -> Result<PriceFeed, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl JsonSchema for PriceFeed

source§

fn schema_name() -> String

The name of the generated JSON Schema. Read more
source§

fn json_schema(gen: &mut SchemaGenerator) -> Schema

Generates a JSON Schema for this type. Read more
§

fn is_referenceable() -> bool

Whether JSON Schemas generated for this type should be re-used where possible using the $ref keyword. Read more
source§

impl PartialEq<PriceFeed> for PriceFeed

source§

fn eq(&self, other: &PriceFeed) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for PriceFeed

source§

fn serialize<__S>(
&self,
__serializer: __S
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Copy for PriceFeed

source§

impl Eq for PriceFeed

source§

impl StructuralEq for PriceFeed

source§

impl StructuralPartialEq for PriceFeed

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiEnumVisitor for Twhere
T: Serialize + ?Sized,

§

default fn visit_for_abi(
&self,
_digester: &mut AbiDigester
) -> Result<AbiDigester, DigestError>

§

impl<T> AbiEnumVisitor for Twhere
T: Serialize + AbiExample + ?Sized,

§

default fn visit_for_abi(
&self,
digester: &mut AbiDigester
) -> Result<AbiDigester, DigestError>

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> DynClone for Twhere
T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = mem::align_of::<T>()

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere
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 Twhere
U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
§

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

§

fn vzip(self) -> V

source§

impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,