pub struct BinanceFuturesWebSocketClient { /* private fields */ }Expand description
Binance Futures WebSocket client for JSON market data streams.
Implementations§
Source§impl BinanceFuturesWebSocketClient
impl BinanceFuturesWebSocketClient
Sourcepub fn new(
product_type: BinanceProductType,
environment: BinanceEnvironment,
api_key: Option<String>,
api_secret: Option<String>,
url_override: Option<String>,
heartbeat: Option<u64>,
) -> Result<Self>
pub fn new( product_type: BinanceProductType, environment: BinanceEnvironment, api_key: Option<String>, api_secret: Option<String>, url_override: Option<String>, heartbeat: Option<u64>, ) -> Result<Self>
Creates a new BinanceFuturesWebSocketClient instance.
§Errors
Returns an error if:
product_typeis not a futures type (UsdM or CoinM).- Credential creation fails.
Sourcepub const fn product_type(&self) -> BinanceProductType
pub const fn product_type(&self) -> BinanceProductType
Returns the product type (UsdM or CoinM).
Sourcepub fn subscription_count(&self) -> usize
pub fn subscription_count(&self) -> usize
Returns the number of confirmed subscriptions.
Sourcepub async fn connect(&mut self) -> BinanceWsResult<()>
pub async fn connect(&mut self) -> BinanceWsResult<()>
Sourcepub async fn close(&mut self) -> BinanceWsResult<()>
pub async fn close(&mut self) -> BinanceWsResult<()>
Sourcepub async fn subscribe(&self, streams: Vec<String>) -> BinanceWsResult<()>
pub async fn subscribe(&self, streams: Vec<String>) -> BinanceWsResult<()>
Subscribes to the specified streams.
§Errors
Returns an error if subscription fails or would exceed stream limit.
Sourcepub async fn unsubscribe(&self, streams: Vec<String>) -> BinanceWsResult<()>
pub async fn unsubscribe(&self, streams: Vec<String>) -> BinanceWsResult<()>
Sourcepub fn stream(&self) -> impl Stream<Item = NautilusFuturesWsMessage> + 'static
pub fn stream(&self) -> impl Stream<Item = NautilusFuturesWsMessage> + 'static
Returns a stream of messages from the WebSocket.
This method can only be called once per connection. Subsequent calls will return an empty stream. If you need to consume messages from multiple tasks, clone the client before connecting.
§Panics
Panics if the internal output receiver mutex is poisoned.
Sourcepub fn cache_instruments(&self, instruments: Vec<InstrumentAny>)
pub fn cache_instruments(&self, instruments: Vec<InstrumentAny>)
Bulk initialize the instrument cache.
Instruments are cached by their raw symbol (e.g., “BTCUSDT”) to match the symbol format sent in WebSocket messages.
Sourcepub fn cache_instrument(&self, instrument: InstrumentAny)
pub fn cache_instrument(&self, instrument: InstrumentAny)
Update a single instrument in the cache.
Instruments are cached by their raw symbol (e.g., “BTCUSDT”) to match the symbol format sent in WebSocket messages.
Sourcepub fn get_instrument(&self, symbol: &str) -> Option<InstrumentAny>
pub fn get_instrument(&self, symbol: &str) -> Option<InstrumentAny>
Get an instrument from the cache.
Trait Implementations§
Source§impl Clone for BinanceFuturesWebSocketClient
impl Clone for BinanceFuturesWebSocketClient
Source§fn clone(&self) -> BinanceFuturesWebSocketClient
fn clone(&self) -> BinanceFuturesWebSocketClient
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<'py> IntoPyObject<'py> for BinanceFuturesWebSocketClient
impl<'py> IntoPyObject<'py> for BinanceFuturesWebSocketClient
Source§type Target = BinanceFuturesWebSocketClient
type Target = BinanceFuturesWebSocketClient
Source§type Output = Bound<'py, <BinanceFuturesWebSocketClient as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <BinanceFuturesWebSocketClient as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PyClass for BinanceFuturesWebSocketClient
impl PyClass for BinanceFuturesWebSocketClient
Source§impl PyClassImpl for BinanceFuturesWebSocketClient
impl PyClassImpl for BinanceFuturesWebSocketClient
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// Binance Futures WebSocket client for JSON market data streams.
const RAW_DOC: &'static CStr = /// Binance Futures WebSocket client for JSON market data streams.
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<BinanceFuturesWebSocketClient>
type ThreadChecker = SendablePyClass<BinanceFuturesWebSocketClient>
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature for BinanceFuturesWebSocketClient
impl PyClassNewTextSignature for BinanceFuturesWebSocketClient
const TEXT_SIGNATURE: &'static str = "(product_type, environment, api_key=None, api_secret=None, url_override=None, heartbeat=None)"
Source§impl PyMethods<BinanceFuturesWebSocketClient> for PyClassImplCollector<BinanceFuturesWebSocketClient>
impl PyMethods<BinanceFuturesWebSocketClient> for PyClassImplCollector<BinanceFuturesWebSocketClient>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for BinanceFuturesWebSocketClient
impl PyTypeInfo for BinanceFuturesWebSocketClient
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.impl DerefToPyAny for BinanceFuturesWebSocketClient
impl ExtractPyClassWithClone for BinanceFuturesWebSocketClient
Auto Trait Implementations§
impl Freeze for BinanceFuturesWebSocketClient
impl !RefUnwindSafe for BinanceFuturesWebSocketClient
impl Send for BinanceFuturesWebSocketClient
impl Sync for BinanceFuturesWebSocketClient
impl Unpin for BinanceFuturesWebSocketClient
impl !UnwindSafe for BinanceFuturesWebSocketClient
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
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>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
§fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more