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
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
use indexmap::map::IndexMap;
use serde::{Deserialize, Serialize};
use std::collections::HashMap;

use crate::auth::KrakenAuth;
// Structs/Enums
use super::{EndpointInfo, KrakenInput, MethodType, TradeHistoryType};

// Traits
use super::{Input, MutateInput, Output, UpdateInput};

pub use super::KOTradeData;

/// Request builder for the Get Trades History endpoint
pub struct KITradeHistory {
    params: IndexMap<String, String>,
}

impl KITradeHistory {
    /// Constructor returning a [KrakenInput] builder for the get trades history endpoint.
    pub fn build() -> Self {
        KITradeHistory {
            params: IndexMap::new(),
        }
    }

    /// Filter by type of trade
    pub fn with_trade_type(self, tradetype: TradeHistoryType) -> Self {
        self.update_input("type", tradetype.to_string())
    }

    /// Should trades be included in returned output?
    pub fn with_trade_info(self, include_trades: bool) -> Self {
        if include_trades {
            self.update_input("trades", include_trades.to_string())
        } else {
            self.update_input("trades", String::from(""))
        }
    }

    /// Starting Unix timestamp to filter output by. Exclusive
    pub fn starting_timestamp(self, timestamp: u64) -> Self {
        self.update_input("start", timestamp.to_string())
    }

    /// Ending Unix timestamp to filter output by. Inclusive
    pub fn ending_timestamp(self, timestamp: u64) -> Self {
        self.update_input("end", timestamp.to_string())
    }

    /// Starting transaction ID to filter output by. Exclusive
    pub fn starting_txid(self, txid: String) -> Self {
        self.update_input("start", txid)
    }

    /// Ending transaction ID to filter output by. Inclusive
    pub fn ending_txid(self, txid: String) -> Self {
        self.update_input("end", txid)
    }

    /// Result offset. Not clear what this does
    pub fn with_offset(self, offset: u64) -> Self {
        self.update_input("ofs", offset.to_string())
    }

    fn with_nonce(self) -> Self {
        self.update_input("nonce", KrakenAuth::nonce())
    }
}

impl Input for KITradeHistory {
    fn finish(self) -> KrakenInput {
        KrakenInput {
            info: EndpointInfo {
                methodtype: MethodType::Private,
                endpoint: String::from("TradesHistory"),
            },
            params: Some(self.with_nonce().params),
        }
    }

    fn finish_clone(self) -> (KrakenInput, Self) {
        let newself = self.with_nonce();
        (
            KrakenInput {
                info: EndpointInfo {
                    methodtype: MethodType::Private,
                    endpoint: String::from("TradesHistory"),
                },
                params: Some(newself.params.clone()),
            },
            newself,
        )
    }
}

impl MutateInput for KITradeHistory {
    fn list_mut(&mut self) -> &mut IndexMap<String, String> {
        &mut self.params
    }
}

impl UpdateInput for KITradeHistory {}

/// Response from the Get Trades History endpoint
#[derive(Deserialize, Serialize, Debug)]
pub struct KOTradeHistory {
    pub closed: HashMap<String, KOTradeData>,
    pub count: u32,
}

impl Output for KOTradeHistory {}