BitmexExecClientConfig

Struct BitmexExecClientConfig 

Source
pub struct BitmexExecClientConfig {
Show 15 fields pub api_key: Option<String>, pub api_secret: Option<String>, pub base_url_http: Option<String>, pub base_url_ws: Option<String>, pub http_timeout_secs: Option<u64>, pub max_retries: Option<u32>, pub retry_delay_initial_ms: Option<u64>, pub retry_delay_max_ms: Option<u64>, pub heartbeat_interval_secs: Option<u64>, pub recv_window_ms: Option<u64>, pub active_only: bool, pub use_testnet: bool, pub account_id: Option<AccountId>, pub max_requests_per_second: Option<u32>, pub max_requests_per_minute: Option<u32>,
}
Expand description

Configuration for the BitMEX live execution client.

Fields§

§api_key: Option<String>

API key used for authenticated requests.

§api_secret: Option<String>

API secret used for authenticated requests.

§base_url_http: Option<String>

Optional override for the REST base URL.

§base_url_ws: Option<String>

Optional override for the WebSocket URL.

§http_timeout_secs: Option<u64>

Optional REST timeout in seconds.

§max_retries: Option<u32>

Optional maximum retry attempts for REST requests.

§retry_delay_initial_ms: Option<u64>

Optional initial retry backoff in milliseconds.

§retry_delay_max_ms: Option<u64>

Optional maximum retry backoff in milliseconds.

§heartbeat_interval_secs: Option<u64>

Optional heartbeat interval (seconds) for the WebSocket client.

§recv_window_ms: Option<u64>

Optional receive window in milliseconds for signed requests (default 10000).

This value determines how far in the future the api-expires timestamp will be set for signed REST requests. BitMEX uses seconds-granularity Unix timestamps in the api-expires header, calculated as: current_timestamp + (recv_window_ms / 1000).

Note: This parameter is specified in milliseconds for consistency with other adapter configurations (e.g., Bybit’s recv_window_ms), but BitMEX only supports seconds-granularity timestamps. The value is converted via integer division, so 10000ms becomes 10 seconds, 15500ms becomes 15 seconds, etc.

A larger window provides more tolerance for clock skew and network latency, but increases the replay attack window. The default of 10 seconds should be sufficient for most deployments. Consider increasing this value (e.g., to 30000ms = 30s) if you experience request expiration errors due to clock drift or high network latency.

§active_only: bool

When true, only active instruments are requested during bootstrap.

§use_testnet: bool

When true, use BitMEX testnet endpoints by default.

§account_id: Option<AccountId>

Optional account identifier to associate with the execution client.

§max_requests_per_second: Option<u32>

Maximum number of requests per second (burst limit).

§max_requests_per_minute: Option<u32>

Maximum number of requests per minute (rolling window).

Implementations§

Source§

impl BitmexExecClientConfig

Source

pub fn new() -> Self

Creates a configuration with default values.

Source

pub fn has_api_credentials(&self) -> bool

Returns true if both API key and secret are available.

Source

pub fn http_base_url(&self) -> String

Returns the REST base URL, considering overrides and the testnet flag.

Source

pub fn ws_url(&self) -> String

Returns the WebSocket URL, considering overrides and the testnet flag.

Trait Implementations§

Source§

impl Clone for BitmexExecClientConfig

Source§

fn clone(&self) -> BitmexExecClientConfig

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

Source§

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

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

impl Default for BitmexExecClientConfig

Source§

fn default() -> Self

Returns the “default value” for a type. 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<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.

§

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

impl<T> Pointable for T

§

const ALIGN: usize

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
§

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

§

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
§

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

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<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,

§

impl<T> ErasedDestructor for T
where T: 'static,

§

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