# dukascopy-rs [![github]](https://github.com/eEQK/dukascopy_rs) [![crates-io]](https://crates.io/crates/dukascopy_rs) [![docs-rs]](https://docs.rs/dukascopy_rs) [github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github [crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= Stream historical tick data straight from Dukascopy ```rust use dukascopy_rs::DukascopyService; use futures::TryStreamExt; use time::macros::datetime; #[tokio::main] async fn main() { DukascopyService::default() .download_ticks( String::from("EURGBP"), // only full hours are supported for now datetime!(2020-03-12 13:00), datetime!(2020-03-12 15:00), ) .try_for_each(|e| async move { println!("{}", e); Ok(()) }) .await .unwrap_or(()); } ``` _source: example/main.rs_ For details on what are the possible inputs/outputs, please have a look on `download_ticks` method documentation. ### Optional cargo features * serde - enables serialization support for `Tick` struct ### TODO * support for any date and time (not only full hours) * `DataSupplier` that retries requests upon failure