23 unstable releases (3 breaking)

Uses new Rust 2024

0.4.9 Apr 16, 2025
0.4.8 Apr 12, 2025
0.4.5 Mar 13, 2025
0.4.0 Feb 27, 2025
0.1.4 Jan 24, 2025

#357 in Magic Beans

Download history 338/week @ 2025-01-18 70/week @ 2025-01-25 337/week @ 2025-02-01 275/week @ 2025-02-08 351/week @ 2025-02-15 288/week @ 2025-02-22 543/week @ 2025-03-01 261/week @ 2025-03-08 56/week @ 2025-03-15 31/week @ 2025-03-22 89/week @ 2025-03-29 221/week @ 2025-04-05 309/week @ 2025-04-12 115/week @ 2025-04-19

735 downloads per month

MIT license

95KB
2K SLoC

Paradex

A simple, yet high performance client library for paradex

Both websocket and rest connectivity are supported. Currently a sub-set of the most important APIs are supported.

The benchmark uses mimalloc as I notice a 10-20% speedup using a mimalloc vs default allocator. Suggest benchmarking on your system / environment.

Support Me

If you appreciate this crate, use my paradex referral link for a 5% fee discount. Click Here

Examples

See here for full examples.

Simple example for receiving public market Data Over WebSocket

#[tokio::main]
async fn main() {
    let symbol: String = "BTC-USD-PERP".into();
    let manager = paradex::ws::WebsocketManager::new(paradex::url::URL::Testnet, None).await;
    let summary_id = manager
        .subscribe(
            paradex::ws::Channel::MarketSummary,
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();
    let bbo_id = manager
        .subscribe(
            paradex::ws::Channel::BBO {
                market_symbol: symbol.clone(),
            },
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();
    let trades_id = manager
        .subscribe(
            paradex::ws::Channel::Trades {
                market_symbol: symbol.clone(),
            },
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();
    let orderbook_id = manager
        .subscribe(
            paradex::ws::Channel::OrderBook {
                market_symbol: symbol.clone(),
                refresh_rate: "50ms".into(),
                price_tick: None,
            },
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();
    let orderbook_deltas_id = manager
        .subscribe(
            paradex::ws::Channel::OrderBookDeltas {
                market_symbol: symbol.clone(),
            },
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();
    let funding_id = manager
        .subscribe(
            paradex::ws::Channel::FundingData {
                market_symbol: None,
            },
            Box::new(|message| info!("Received message {message:?}")),
        )
        .await
        .unwrap();

    tokio::time::sleep(Duration::from_secs(120)).await;

    for id in [
        summary_id,
        bbo_id,
        trades_id,
        orderbook_id,
        orderbook_deltas_id,
        funding_id,
    ] {
        manager.unsubscribe(id).await.unwrap();
    }

    tokio::time::sleep(Duration::from_secs(5)).await;
    manager.stop().await.unwrap();
}

Dependencies

~20–35MB
~552K SLoC