PoolSwap

Struct PoolSwap 

Source
pub struct PoolSwap {
Show 18 fields pub chain: SharedChain, pub dex: SharedDex, pub instrument_id: InstrumentId, pub pool_identifier: PoolIdentifier, pub block: u64, pub transaction_hash: String, pub transaction_index: u32, pub log_index: u32, pub sender: Address, pub recipient: Address, pub sqrt_price_x96: U160, pub amount0: I256, pub amount1: I256, pub liquidity: u128, pub tick: i32, pub timestamp: Option<UnixNanos>, pub ts_init: Option<UnixNanos>, pub trade_info: Option<SwapTradeInfo>,
}
Expand description

Represents a token swap transaction on a decentralized exchange (DEX).

This structure captures both the raw blockchain data from a swap event and optionally includes computed market-oriented trade information. It serves as the primary data structure for tracking and analyzing DEX swap activity.

Fields§

§chain: SharedChain

The blockchain network where the swap occurred.

§dex: SharedDex

The decentralized exchange where the swap was executed.

§instrument_id: InstrumentId

The instrument ID for this pool’s trading pair.

§pool_identifier: PoolIdentifier

The unique identifier for this pool (could be an address or other protocol-specific hex string).

§block: u64

The blockchain block number at which the swap was executed.

§transaction_hash: String

The unique hash identifier of the blockchain transaction containing the swap.

§transaction_index: u32

The index position of the transaction within the block.

§log_index: u32

The index position of the swap event log within the transaction.

§sender: Address

The blockchain address of the user or contract that initiated the swap.

§recipient: Address

The blockchain address that received the swapped tokens.

§sqrt_price_x96: U160

The sqrt price after the swap (Q64.96 format).

§amount0: I256

The amount of token0 involved in the swap.

§amount1: I256

The amount of token1 involved in the swap.

§liquidity: u128

The liquidity of the pool after the swap occurred.

§tick: i32

The current tick of the pool after the swap occurred.

§timestamp: Option<UnixNanos>

UNIX timestamp (nanoseconds) when the swap occurred.

§ts_init: Option<UnixNanos>

UNIX timestamp (nanoseconds) when the instance was initialized.

§trade_info: Option<SwapTradeInfo>

Optional computed trade information in market-oriented format. This translates raw blockchain data into standard trading terminology.

Implementations§

Source§

impl PoolSwap

Source

pub fn new( chain: SharedChain, dex: SharedDex, instrument_id: InstrumentId, pool_identifier: PoolIdentifier, block: u64, transaction_hash: String, transaction_index: u32, log_index: u32, timestamp: Option<UnixNanos>, sender: Address, recipient: Address, amount0: I256, amount1: I256, sqrt_price_x96: U160, liquidity: u128, tick: i32, ) -> Self

Creates a new PoolSwap instance with the specified properties.

Source

pub fn calculate_trade_info( &mut self, token0: &Token, token1: &Token, sqrt_price_x96: Option<U160>, ) -> Result<()>

Calculates and populates the trade_info field with market-oriented trade data.

This method transforms the raw blockchain swap data (token0/token1 amounts) into standard trading terminology (base/quote, buy/sell, execution price). The computation determines token roles based on priority and handles decimal adjustments.

§Arguments
  • token0 - Reference to token0 in the pool
  • token1 - Reference to token1 in the pool
  • sqrt_price_x96 - Optional square root price before the swap (Q96 format) for calculating price impact and slippage
§Errors

Returns an error if the trade info computation or price calculations fail.

Trait Implementations§

Source§

impl Clone for PoolSwap

Source§

fn clone(&self) -> PoolSwap

Returns a duplicate of the value. Read more
1.0.0§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for PoolSwap

Source§

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

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

impl Display for PoolSwap

Source§

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

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

impl From<PoolSwap> for DefiData

Source§

fn from(value: PoolSwap) -> Self

Converts to this type from the input type.
Source§

impl<'py> IntoPyObject<'py> for PoolSwap

Source§

type Target = PoolSwap

The Python output type
Source§

type Output = Bound<'py, <PoolSwap as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
Source§

type Error = PyErr

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

fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>

Performs the conversion.
Source§

impl PartialEq for PoolSwap

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PyClass for PoolSwap

Source§

type Frozen = False

Whether the pyclass is frozen. Read more
Source§

impl PyClassImpl for PoolSwap

Source§

const IS_BASETYPE: bool = false

#[pyclass(subclass)]
Source§

const IS_SUBCLASS: bool = false

#[pyclass(extends=…)]
Source§

const IS_MAPPING: bool = false

#[pyclass(mapping)]
Source§

const IS_SEQUENCE: bool = false

#[pyclass(sequence)]
Source§

const IS_IMMUTABLE_TYPE: bool = false

#[pyclass(immutable_type)]
Source§

const RAW_DOC: &'static CStr = /// Represents a token swap transaction on a decentralized exchange (DEX). /// /// This structure captures both the raw blockchain data from a swap event and /// optionally includes computed market-oriented trade information. It serves as /// the primary data structure for tracking and analyzing DEX swap activity.

Docstring for the class provided on the struct or enum. Read more
Source§

const DOC: &'static CStr

Fully rendered class doc, including the text_signature if a constructor is defined. Read more
Source§

type BaseType = PyAny

Base class
Source§

type ThreadChecker = SendablePyClass<PoolSwap>

This handles following two situations: Read more
Source§

type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild

Immutable or mutable
Source§

type Dict = PyClassDummySlot

Specify this class has #[pyclass(dict)] or not.
Source§

type WeakRef = PyClassDummySlot

Specify this class has #[pyclass(weakref)] or not.
Source§

type BaseNativeType = PyAny

The closest native ancestor. This is PyAny by default, and when you declare #[pyclass(extends=PyDict)], it’s PyDict.
Source§

fn items_iter() -> PyClassItemsIter

Source§

fn lazy_type_object() -> &'static LazyTypeObject<Self>

§

fn dict_offset() -> Option<isize>

§

fn weaklist_offset() -> Option<isize>

Source§

impl PyClassNewTextSignature for PoolSwap

Source§

const TEXT_SIGNATURE: &'static str = "(chain, dex, instrument_id, pool_identifier, block, transaction_hash, transaction_index, log_index, timestamp, sender, receiver, amount0, amount1, sqrt_price_x96, liquidity, tick)"

Source§

impl PyMethods<PoolSwap> for PyClassImplCollector<PoolSwap>

Source§

fn py_methods(self) -> &'static PyClassItems

Source§

impl PyTypeInfo for PoolSwap

Source§

const NAME: &'static str = "PoolSwap"

Class name.
Source§

const MODULE: Option<&'static str>

Module name, if any.
Source§

fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject

Returns the PyTypeObject instance for this type.
§

fn type_object(py: Python<'_>) -> Bound<'_, PyType>

Returns the safe abstraction over the type object.
§

fn is_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type or a subclass of this type.
§

fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type.
Source§

impl DerefToPyAny for PoolSwap

Source§

impl ExtractPyClassWithClone for PoolSwap

Source§

impl StructuralPartialEq for PoolSwap

Auto Trait Implementations§

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

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

§

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
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<'a, 'py, T> FromPyObject<'a, 'py> for T
where T: PyClass + Clone + ExtractPyClassWithClone,

§

type Error = PyClassGuardError<'a, 'py>

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

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<T, <T as FromPyObject<'a, 'py>>::Error>

Extracts Self from the bound smart pointer obj. Read more
§

impl<T> Instrument for T

§

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

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

fn in_current_span(self) -> Instrumented<Self>

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

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

§

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
§

impl<'py, T> IntoPyObjectExt<'py> for T
where T: IntoPyObject<'py>,

§

fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>

Converts self into an owned Python object, dropping type information.
§

fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>

Converts self into an owned Python object, dropping type information and unbinding it from the 'py lifetime.
§

fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>

Converts self into a Python object. Read more
Source§

impl<'py, T> IntoPyObjectNautilusExt<'py> for T
where T: IntoPyObjectExt<'py>,

Source§

fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>

Convert self into a [Py<PyAny>] while panicking if the conversion fails. Read more
§

impl<T> PyErrArguments for T
where T: for<'py> IntoPyObject<'py> + Send + Sync,

§

fn arguments(self, py: Python<'_>) -> Py<PyAny>

Arguments for exception
§

impl<T> PyTypeCheck for T
where T: PyTypeInfo,

§

const NAME: &'static str = T::NAME

👎Deprecated since 0.27.0: Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Name of self. This is used in error messages, for example.
§

fn type_check(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of Self, which may include a subtype. Read more
§

fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>

Returns the expected type as a possible argument for the isinstance and issubclass function. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Separable for T
where T: Display,

Source§

fn separate_by_policy(&self, policy: SeparatorPolicy<'_>) -> String

Adds separators according to the given SeparatorPolicy. Read more
Source§

fn separate_with_commas(&self) -> String

Inserts a comma every three digits from the right. Read more
Source§

fn separate_with_spaces(&self) -> String

Inserts a space every three digits from the right. Read more
Source§

fn separate_with_dots(&self) -> String

Inserts a period every three digits from the right. Read more
Source§

fn separate_with_underscores(&self) -> String

Inserts an underscore every three digits from the right. Read more
§

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

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

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

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

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

impl<T> ToString for T
where T: Display + ?Sized,

§

fn to_string(&self) -> String

Converts the given value to a String. Read more
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

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

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<'py, T> FromPyObjectOwned<'py> for T
where T: for<'a> FromPyObject<'a, 'py>,

§

impl<T> Ungil for T
where T: Send,