jlib 0.3.7

A lightweight blockchain lib.
Documentation
#![allow(unused)]

use serde_json::json;
use serde::{Deserialize, Serialize};
use serde_json::Result;
use std::any::Any;

use crate::message::common::command_trait::CommandConversion;
use std::error::Error;
use std::fmt;

/*
@4.14获得挂单佣金设置信息
RequestBrokerageCommand 请求格式
command: String, //(固定值): Fee_Info
account: String, //Account
ledger_index: String //(固定值): 'validated'
*/
#[derive(Serialize, Deserialize, Debug)]
pub struct RequestBrokerageCommand {
    #[serde(rename="id")]
    id: u64,

    #[serde(rename="command")]
    command: String,

    #[serde(rename="account")]
    account: String,

    #[serde(rename="ledger_index")]
    ledger_index: String,
}

impl RequestBrokerageCommand {
    pub fn with_params(account: String) -> Box<Self> {
        Box::new(
            RequestBrokerageCommand {
                id: 1,
                command: "Fee_Info".to_string(),
                account: account,
                ledger_index: "validated".to_string(),
            }
        )
    }
}

impl CommandConversion for RequestBrokerageCommand {
    type T = RequestBrokerageCommand;
    fn to_string(&self) -> Result<String> {
        // let json = json!({ "id": "0", "command": "subscribe" , "streams" : ["ledger","server","transactions"]});
        // let compact = format!("{}", json);

        //https://crates.io/crates/serde_json
        // Serialize it to a JSON string.
        let j = serde_json::to_string(&self)?;

        // Print, write to a file, or send to an HTTP server.
        Ok(j)
    }

    fn box_to_raw(&self) -> &dyn Any {
        self
    }

    // fn to_concrete<T>(&self) -> T {
    //     let def: Box<dyn CommandConversion> = self;
    //     let b: &SubscribeCommand = match def.box_to_raw().downcast_ref::<SubscribeCommand>() {
    //         Some(b) => b,
    //         None => panic!("&a isn't a B!"),
    //     };

    //     b
    // }
}

//实现default方法, 此command不提供default方法~
// impl Default for RequestLedgerCommand {
//     fn default() -> Self {
//         RequestLedgerCommand {
//             id: 1,
//             command: "ledger".to_string(),
//         }
//     }
// }

/////////////////////////
#[derive(Serialize, Deserialize, Debug)]
pub struct Brokerages {
    #[serde(rename="FeeCurrency")]
    pub fee_currency: String,

    #[serde(rename="FeeCurrencyIssuer")]
    pub fee_currency_issuer: String,

    #[serde(rename="OfferFeeRateDen")]
    pub den: String,

    #[serde(rename="OfferFeeRateNum")]
    pub num: String,

    #[serde(rename="Platform")]
    pub platform: String,

    #[serde(rename="fee_account")]
    pub fee_account: String,
}
/*
RequestBrokerageResponse 数据返回格式
*/
#[derive(Serialize, Deserialize, Debug)]
pub struct RequestBrokerageResponse {
    #[serde(rename="account")]
    pub account: String,

    #[serde(rename="brokerages")]
    pub brokerages: Vec<Brokerages>,

    #[serde(rename="ledger_hash")]
    pub ledger_hash: String,

    #[serde(rename="ledger_index")]
    pub ledger_index: u64,

    #[serde(rename="validated")]
    pub validated: bool,
}

#[derive(Debug, Serialize, Deserialize)]
pub struct BrokerageSideKick {
    pub error           : String,
    pub error_code      : i32,
    pub error_message   : String,
    pub id              : u32,
    pub request         : RequestBrokerageCommand,
    pub status          : String,

    #[serde(rename="type")]
    pub rtype            : String,
}

impl fmt::Display for BrokerageSideKick {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "BrokerageSideKick is here!")
    }
}

impl Error for BrokerageSideKick  {
    fn description(&self) -> &str {
        "I'm BrokerageSideKick side kick"
    }
}