1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//! 
//! This is a minimal interface for the [Kraken exchange Websockets API](https://docs.kraken.com/websockets/) using the [async-std](https://async.rs/) runtime.
//! 
//! This crate will handle the auth token adquisition and automatically add it to all private messages send to Kraken.
//! 
//! # Prerequisites
//! To use the **```private```** connection you will need to generate an **```API-Key```** and an **```API-Secret```** to authenticate to the desired Kraken account.  
//! [How to generate an API key pair?](https://support.kraken.com/hc/en-us/articles/360000919966-How-to-generate-an-API-key-pair-)
//! 
//! # Usage
//! Private and public channels can't be mixed, so you will need to create a ``KrakenWSHandler`` for each type.  
//! 
//! To create a handler for the public channels use ``KrakenWS::run_public``, and for a private handler use ``KrakenWS::run_private``.  
//! 
//! Apart from the ``key`` and ``secret`` parameters for the private handler, both methods require a callback having a [Value](https://docs.serde.rs/serde_json/value/enum.Value.html) JSON object as input. This **callback** will be used when receiving messages from Kraken for the data to be handled. 
//! 
//! The base subscribable channels have their own methods, but they can be bypassed using ``send_private`` or ``send_public`` plus a [Value](https://docs.serde.rs/serde_json/value/enum.Value.html) payload. Remember that the auth token is added automatically to all private messages.
//! 
//! Read the [Kraken documentation](https://docs.kraken.com/websockets/) to understand the messages.
//! 
//! # Example
//! ```rust
//! use async_kraken_ws::client::KrakenWS;
//! 
//! fn get_keys() -> (String, String) {
//!     let content = std::fs::read_to_string("key").expect("File not found");
//!     let lines: Vec<&str> = content.lines().collect();
//! 
//!     let key = String::from(lines[0]);
//!     let secret = String::from(lines[1]);
//! 
//!     (key, secret)
//! }
//! 
//! #[async_std::main]
//! async fn main() {
//!     let (api_key, api_secret) = get_keys();
//!     let kpr = KrakenWS::run_private(|x| println!("{}", x.to_string()), api_key, api_secret).await;
//!     let _ = kpr.subscribe_open_orders().await;
//!     let _ = kpr.subscribe_own_trades().await;
//! 
//!     let kpu = KrakenWS::run_public(|x| println!("{}", x.to_string())).await;
//!     let _ = kpu.subscribe_ticker(vec!["XBT/EUR"]).await;
//!     let _ = kpu.subscribe_ohlc(vec!["XBT/EUR"], 1).await;
//!     let _ = kpu.subscribe_book(vec!["XBT/EUR"], 100).await;
//!     let _ = kpu.subscribe_spread(vec!["XBT/EUR"]).await;
//!     let _ = kpu.subscribe_trade(vec!["XBT/EUR"]).await;
//! 
//!     loop {
//!         std::thread::sleep(std::time::Duration::from_secs(30));
//!         let _ = kpu.ping().await;
//!         let _ = kpr.ping().await;
//!     }
//! }
//! 
//! ```
//! 
//! # Disclaimer
//! This software comes without any kind of warranties.  
//! You are the sole responsible of your gains or loses.
//! 

pub mod client;
mod config;