#trading #quant #tradestation

tradestation-rs

High level, fully featured, and ergonomic Rust client for the TradeStation API

3 releases

0.1.2 Dec 29, 2024
0.1.1 Sep 28, 2024
0.1.0 Sep 27, 2024

#54 in Finance

Download history 289/week @ 2024-09-25 34/week @ 2024-10-02 1/week @ 2024-10-09 1/week @ 2024-11-13 1/week @ 2024-11-20 5/week @ 2024-12-04 13/week @ 2024-12-11 118/week @ 2024-12-25 8/week @ 2025-01-01 4/week @ 2025-01-08

130 downloads per month

MIT license

350KB
4K SLoC

TradeStation Rust Client

An ergonomic Rust client for the TradeStation API.

This is a fork of the tradestation crate, but more opinionated and providing higher level abstractions.

Install

Use cargo CLI:

cargo install tradestation-rs

Or manually add it into your Cargo.toml:

[dependencies]
tradestation-rs = "0.1.2"

Usage

For more thorough information, read the docs.

Simple example for streaming bars of trading activity:

use tradestation_rs::{
    responses::MarketData::StreamBarsResp,
    ClientBuilder, Error,
    MarketData::{self, BarUnit},
};

#[tokio::main]
async fn main() -> Result<(), Error> {
    let mut client = ClientBuilder::new()?
        .set_credentials("YOUR_CLIENT_ID", "YOUR_CLIENT_SECRET")?
        .authorize("YOUR_AUTHORIZATION_CODE")
        .await?
        .build()
        .await?;
    println!("Your TradeStation API Bearer Token: {:?}", client.token);

    let stream_bars_query = MarketData::StreamBarsQueryBuilder::new()
        .set_symbol("CLX24")
        .set_unit(BarUnit::Minute)
        .set_interval("240")
        .build()?;

    let streamed_bars = client
        .stream_bars(&stream_bars_query, |stream_data| {
            match stream_data {
                StreamBarsResp::Bar(bar) => {
                    // Do something with the bars like making a chart
                    println!("{bar:?}")
                }
                StreamBarsResp::Heartbeat(heartbeat) => {
                    if heartbeat.heartbeat > 10 {
                        return Err(Error::StopStream);
                    }
                }
                StreamBarsResp::Status(status) => {
                    println!("{status:?}");
                }
                StreamBarsResp::Error(err) => {
                    println!("{err:?}");
                }
            }

            Ok(())
        })
        .await?;

    // All the bars collected during the stream
    println!("{streamed_bars:?}");

    Ok(())
}

Dependencies

~7–18MB
~236K SLoC