use crate::{
exchange::{
bitmex::{
channel::BitmexChannel, market::BitmexMarket, subscription::BitmexSubResponse,
trade::BitmexTrade,
},
subscription::ExchangeSub,
Connector, ExchangeId, StreamSelector,
},
subscriber::{validator::WebSocketSubValidator, WebSocketSubscriber},
subscription::{trade::PublicTrades, Map},
transformer::stateless::StatelessTransformer,
ExchangeWsStream,
};
use barter_integration::{
error::SocketError, model::instrument::Instrument, protocol::websocket::WsMessage,
};
use serde::de::{Error, Unexpected};
use std::fmt::Debug;
use url::Url;
pub mod channel;
pub mod market;
pub mod message;
pub mod subscription;
pub mod trade;
pub const BASE_URL_BITMEX: &str = "wss://ws.bitmex.com/realtime";
#[derive(Copy, Clone, Eq, PartialEq, Ord, PartialOrd, Hash, Debug, Default)]
pub struct Bitmex;
impl Connector for Bitmex {
const ID: ExchangeId = ExchangeId::Bitmex;
type Channel = BitmexChannel;
type Market = BitmexMarket;
type Subscriber = WebSocketSubscriber;
type SubValidator = WebSocketSubValidator;
type SubResponse = BitmexSubResponse;
fn url() -> Result<Url, SocketError> {
Url::parse(BASE_URL_BITMEX).map_err(SocketError::UrlParse)
}
fn requests(exchange_subs: Vec<ExchangeSub<Self::Channel, Self::Market>>) -> Vec<WsMessage> {
let stream_names = exchange_subs
.into_iter()
.map(|sub| format!("{}:{}", sub.channel.as_ref(), sub.market.as_ref(),))
.collect::<Vec<String>>();
vec![WsMessage::Text(
serde_json::json!({
"op": "subscribe",
"args": stream_names
})
.to_string(),
)]
}
fn expected_responses(_: &Map<Instrument>) -> usize {
1
}
}
impl StreamSelector<PublicTrades> for Bitmex {
type Stream = ExchangeWsStream<StatelessTransformer<Self, PublicTrades, BitmexTrade>>;
}
impl<'de> serde::Deserialize<'de> for Bitmex {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::de::Deserializer<'de>,
{
let input = <&str as serde::Deserialize>::deserialize(deserializer)?;
let expected = Self::ID.as_str();
if input == Self::ID.as_str() {
Ok(Self::default())
} else {
Err(Error::invalid_value(Unexpected::Str(input), &expected))
}
}
}
impl serde::Serialize for Bitmex {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::ser::Serializer,
{
let exchange_id = Self::ID.as_str();
serializer.serialize_str(exchange_id)
}
}