Struct MeteoraDbc

Source
pub struct MeteoraDbc {
Show 14 fields pub pool: Pool, pub config: Pubkey, pub sqrt_price: u128, pub base_reserve: u64, pub quote_reserve: u64, pub cliff_fee_numerator: u64, pub base_fee_mode: BaseFeeMode, pub activation_point: u64, pub volatility_accumulator: u128, pub variable_fee_control: u32, pub activation_type: ActivationType, pub base_fee_reduction_factor: u64, pub base_fee_period_frequency: u64, pub base_fee_number_of_periods: u16,
}
Expand description

Struct to hold data and PoolTrait implementation for Meteora Dynamic Bonding Curve pools.

Fields§

§pool: Pool§config: Pubkey§sqrt_price: u128§base_reserve: u64

The actual amount of base token (token A) in the pool

§quote_reserve: u64

The actual amount of quote token (token B) in the pool

§cliff_fee_numerator: u64

The initial fee numerator at the start of the curve.

§base_fee_mode: BaseFeeMode

The mode for calculating the base fee (Linear or Exponential).

§activation_point: u64

The slot or timestamp when the pool becomes active and fees start decaying.

§volatility_accumulator: u128

Accumulator for price volatility, used in dynamic fee calculation.

§variable_fee_control: u32

A control factor for adjusting the impact of volatility on the dynamic fee.

§activation_type: ActivationType

The method of time kept to track

§base_fee_reduction_factor: u64§base_fee_period_frequency: u64§base_fee_number_of_periods: u16

Implementations§

Source§

impl MeteoraDbc

Source

pub fn from_account_info( pubkey: Pubkey, account_buffer: &[u8], dbc_pool_config: &DbcPoolConfig, config_address: Pubkey, ) -> Self

Trait Implementations§

Source§

impl PoolTrait for MeteoraDbc

Source§

fn total_swap_fee_lp(&self, central_context: &Arc<CentralContext>) -> u64

Calculates the total trading fee numerator. This combines the base fee (scheduled) and the dynamic fee (volatility-based). Returns just the numerator as the denomiator is 10^9 whcih is lamports.

Source§

fn price_a_over_b_lp(&self) -> u128

The reciprocal of the price_b_over_a_lp.

Source§

fn price_b_over_a_lp(&self) -> u128

The sqrt price of the protocol will be in terms of quote over base which for us is b over a.

Source§

fn pool_address(&self) -> &Pubkey

Get the pool’s on-chain address
Source§

fn token_a_address(&self) -> &Pubkey

Get the address of token A
Source§

fn token_b_address(&self) -> &Pubkey

Get the address of token B
Source§

fn token_a_vault_address(&self) -> &Pubkey

Get the vault address for token A
Source§

fn token_b_vault_address(&self) -> &Pubkey

Get the vault address for token B
Source§

fn pool_type(&self) -> &Pools

Get the pool type enum variant
Source§

fn as_any(&self) -> &dyn Any

Get a reference to the pool as Any for type downcasting
Source§

fn as_any_mut(&mut self) -> &mut dyn Any

Get a mutable reference to the pool as Any for type downcasting
Source§

fn fetch_market_state_from_rpc(&mut self, central_context: &Arc<CentralContext>)

Fetch and update pool state from JSON RPC and immediately overrides the in-memory pool state. Should not be used in production in favor of using gRPC streams.
Source§

fn token_a_amount_units(&self) -> u64

Get the actual amount of token A in the pool, in token units. This is calculated dynamically because some protocols (like Meteora) derive real token balances from LP token balances rather than storing them directly in the pool account, and other protocols require excluding collected fees from raw reserves.
Source§

fn token_b_amount_units(&self) -> u64

Get the actual amount of token B in the pool, in token units. See token_a_amount_units for details on why this is calculated dynamically.
Source§

fn directional_fees( &self, _: SwapDirection, __: &Arc<CentralContext>, ) -> (f64, f64)

Get directional swap fees as fractions for a given swap direction Read more

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<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more