|
|
@@ -1,28 +1,27 @@
|
|
|
use std::collections::{BTreeMap};
|
|
|
-// use std::{env};
|
|
|
use std::io::{Error};
|
|
|
-// use std::sync::Arc;
|
|
|
-// use std::sync::atomic::AtomicBool;
|
|
|
-// use std::time::Duration;
|
|
|
-// use rust_decimal_macros::dec;
|
|
|
+use std::sync::Arc;
|
|
|
+use std::sync::atomic::AtomicBool;
|
|
|
+use futures::StreamExt;
|
|
|
+use rust_decimal_macros::dec;
|
|
|
use tokio::sync::mpsc::{channel, Receiver, Sender};
|
|
|
-// use tokio::try_join;
|
|
|
-// use tracing::{error, trace};
|
|
|
-use tracing::{error};
|
|
|
-use exchanges::kucoin_spot_ws::KucoinSpotSubscribeType;
|
|
|
-// use exchanges::bitget_spot_ws::{BitgetSpotWs, BitgetSubscribeType, BitgetWsType};
|
|
|
-// use exchanges::kucoin_spot_ws::{KucoinSpotWs, KucoinSpotSubscribeType, KucoinSpotWsType};
|
|
|
-// use exchanges::binance_spot_ws::{BinanceSpotSubscribeType, BinanceSpotWs, BinanceSpotWsType};
|
|
|
+use tokio::sync::Mutex;
|
|
|
+use tokio::try_join;
|
|
|
+use tracing::{error, trace};
|
|
|
+// use exchanges::binance_spot_ws::{BinanceSpotLogin, BinanceSpotSubscribeType, BinanceSpotWs, BinanceSpotWsType};
|
|
|
+// use exchanges::binance_swap_ws::{BinanceSwapLogin, BinanceSwapSubscribeType, BinanceSwapWs, BinanceSwapWsType};
|
|
|
+// use exchanges::kucoin_swap_ws::{KucoinSwapLogin, KucoinSwapSubscribeType, KucoinSwapWs, KucoinSwapWsType};
|
|
|
+use exchanges::kucoin_spot_ws::{KucoinSpotLogin, KucoinSpotSubscribeType, KucoinSpotWs, KucoinSpotWsType};
|
|
|
+// use exchanges::bitget_spot_ws::{BitgetSpotWs, BitgetSpotSubscribeType, BitgetSpotWsType, BitgetSpotLogin};
|
|
|
// use exchanges::okx_swap_ws::{OkxSubscribeType, OkxSwapWs, OkxWsType};
|
|
|
-// use exchanges::kucoin_swap_ws::{KucoinSubscribeType, KucoinSwapWs, KucoinWsType};
|
|
|
-// use exchanges::response_base::ResponseData;
|
|
|
+use exchanges::response_base::ResponseData;
|
|
|
use standard::exchange::{Exchange, ExchangeEnum};
|
|
|
+// use standard::{binance_spot_handle, Order, Platform, utils};
|
|
|
// use standard::{binance_handle, Order, Platform, utils};
|
|
|
-// use standard::{okx_handle, Order, Platform, utils};
|
|
|
// use standard::{kucoin_handle, Order, Platform, utils};
|
|
|
-// use standard::{kucoin_spot_handle, Order, Platform, utils};
|
|
|
+use standard::{kucoin_spot_handle, Order, Platform, utils};
|
|
|
// use standard::{bitget_spot_handle, Order, Platform, utils};
|
|
|
-use standard::{Order, Platform, utils};
|
|
|
+// use standard::{okx_handle, Order, Platform, utils};
|
|
|
|
|
|
// 创建实体
|
|
|
#[allow(dead_code)]
|
|
|
@@ -109,45 +108,46 @@ pub async fn test_new_exchange(exchange: ExchangeEnum, symbol: &str) -> Box<dyn
|
|
|
}
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
-pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, _symbol: &str, _subscriber_type: T, _mold: &str) where Vec<KucoinSpotSubscribeType>: From<T> {
|
|
|
+pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, symbol: &str, subscriber_type: T, mold: &str) where Vec<KucoinSpotSubscribeType>: From<T> {
|
|
|
utils::proxy_handle();
|
|
|
-
|
|
|
+ let account_info = global::account_info::get_account_info("../test_account.toml");
|
|
|
match exchange {
|
|
|
ExchangeEnum::BinanceSpot => {
|
|
|
// let symbol_format = utils::format_symbol(symbol.to_string(), "").to_uppercase();
|
|
|
// trace!(symbol_format);
|
|
|
- // let name = format!("binance_usdt_swap@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let name = format!("binance_spot@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
|
|
|
+ // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
|
|
|
+ // let write_tx_am = Arc::new(Mutex::new(write_tx));
|
|
|
// let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
//
|
|
|
- // let (res_sender, mut res_receiver): (Sender<ResponseData>, Receiver<ResponseData>) = channel(1024);
|
|
|
- // let mut params: BTreeMap<String, String> = BTreeMap::new();
|
|
|
- // let access_key = env::var("binance_access_key").unwrap_or("".to_string());
|
|
|
- // let secret_key = env::var("binance_secret_key").unwrap_or("".to_string());
|
|
|
- // params.insert("access_key".to_string(), access_key);
|
|
|
- // params.insert("secret_key".to_string(), secret_key);
|
|
|
+ // let params = BinanceSpotLogin {
|
|
|
+ // api_key: account_info.binance_access_key,
|
|
|
+ // api_secret: account_info.binance_secret_key,
|
|
|
+ // };
|
|
|
// let mut exchange_wss;
|
|
|
- // exchange_wss = BinanceSpotWs::new_label(name, false, params, BinanceSpotWsType::PublicAndPrivate, res_sender);
|
|
|
+ // exchange_wss = BinanceSpotWs::new_label(name, false, Option::from(params), BinanceSpotWsType::PublicAndPrivate);
|
|
|
+ // exchange_wss.set_symbols(vec![symbol_format]);
|
|
|
// exchange_wss.set_subscribe(subscriber_type.into());
|
|
|
//
|
|
|
- // let t1 = tokio::spawn(async move {
|
|
|
- // exchange_wss.custom_subscribe(bool_v1, vec![symbol_format]).await;
|
|
|
- // });
|
|
|
+ //
|
|
|
// let mold_arc = Arc::new(mold.to_string());
|
|
|
- // let t2 = tokio::spawn(async move {
|
|
|
+ // //读取
|
|
|
+ // tokio::spawn(async move {
|
|
|
// let mold_clone = Arc::clone(&mold_arc);
|
|
|
// loop {
|
|
|
- // tokio::time::sleep(Duration::from_millis(1)).await;
|
|
|
- // if let Ok(received) = res_receiver.try_recv() {
|
|
|
+ // if let Some(data) = read_rx.next().await {
|
|
|
+ // trace!("原始数据 data:{:?}",data);
|
|
|
// match mold_clone.as_str() {
|
|
|
// "depth" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = binance_handle::handle_special_depth(received);
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = binance_spot_handle::handle_special_depth(data);
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
// "ticker" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = binance_handle::handle_special_ticker(received);
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = binance_spot_handle::handle_special_ticker(data);
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
@@ -157,74 +157,56 @@ pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, _symbol: &str, _su
|
|
|
// }
|
|
|
// }
|
|
|
// }
|
|
|
- // }
|
|
|
+ // };
|
|
|
// });
|
|
|
- // try_join!(t1, t2).unwrap();
|
|
|
- error!("该交易所不支持!test_new_exchange_wss:{:?}",exchange);
|
|
|
- panic!("该交易所不支持!test_new_exchange_wss:{:?}", exchange)
|
|
|
+ //
|
|
|
+ // let t1 = tokio::spawn(async move {
|
|
|
+ // //链接
|
|
|
+ // let bool_v3_clone = Arc::clone(&bool_v1);
|
|
|
+ // exchange_wss.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
|
|
|
+ // });
|
|
|
+ // try_join!(t1).unwrap();
|
|
|
}
|
|
|
ExchangeEnum::BinanceSwap => {
|
|
|
- error!("该交易所不支持!test_new_exchange_wss:{:?}",exchange);
|
|
|
- panic!("该交易所不支持!test_new_exchange_wss:{:?}", exchange)
|
|
|
- }
|
|
|
- ExchangeEnum::GateSwap => {
|
|
|
- error!("该交易所不支持!test_new_exchange_wss:{:?}",exchange);
|
|
|
- panic!("该交易所不支持!test_new_exchange_wss:{:?}", exchange)
|
|
|
- }
|
|
|
- ExchangeEnum::KucoinSwap => {
|
|
|
- // let symbol_format = format!("{}M", utils::format_symbol(symbol.to_string(), ""));
|
|
|
- // let symbol_back = utils::format_symbol(symbol.to_string(), "_");
|
|
|
- // let name = format!("kucoin_usdt_swap@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let symbol_format = utils::format_symbol(symbol.to_string(), "").to_uppercase();
|
|
|
+ // trace!(symbol_format);
|
|
|
+ // let name = format!("binance_swap@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
|
|
|
+ // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
|
|
|
+ // let write_tx_am = Arc::new(Mutex::new(write_tx));
|
|
|
// let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
//
|
|
|
- // let (res_sender, mut res_receiver): (Sender<ResponseData>, Receiver<ResponseData>) = channel(1024);
|
|
|
- // let mut params: BTreeMap<String, String> = BTreeMap::new();
|
|
|
- // let access_key = env::var("kucoin_access_key").unwrap_or("".to_string());
|
|
|
- // let secret_key = env::var("kucoin_secret_key").unwrap_or("".to_string());
|
|
|
- // let pass_key = env::var("kucoin_pass_key").unwrap_or("".to_string());
|
|
|
- // params.insert("access_key".to_string(), access_key);
|
|
|
- // params.insert("secret_key".to_string(), secret_key);
|
|
|
- // params.insert("pass_key".to_string(), pass_key);
|
|
|
+ // let api_key = env::var("binance_access_key").unwrap_or("".to_string());
|
|
|
+ // let api_secret = env::var("binance_secret_key").unwrap_or("".to_string());
|
|
|
+ // let params = BinanceSwapLogin {
|
|
|
+ // api_key: account_info.binance_access_key,
|
|
|
+ // api_secret: account_info.binance_secret_key,
|
|
|
+ // };
|
|
|
// let mut exchange_wss;
|
|
|
- // if ["depth", "ticker"].contains(&mold) {
|
|
|
- // exchange_wss = KucoinSwapWs::new_label(name, false, params, KucoinWsType::Public, res_sender).await
|
|
|
- // } else {
|
|
|
- // exchange_wss = KucoinSwapWs::new_label(name, false, params, KucoinWsType::Private, res_sender).await
|
|
|
- // }
|
|
|
+ // exchange_wss = BinanceSwapWs::new_label(name, false, Option::from(params), BinanceSwapWsType::PublicAndPrivate);
|
|
|
+ // exchange_wss.set_symbols(vec![symbol_format]);
|
|
|
// exchange_wss.set_subscribe(subscriber_type.into());
|
|
|
//
|
|
|
- // let t1 = tokio::spawn(async move {
|
|
|
- // exchange_wss.custom_subscribe(bool_v1, vec![symbol_format]).await;
|
|
|
- // });
|
|
|
+ //
|
|
|
// let mold_arc = Arc::new(mold.to_string());
|
|
|
- // let t2 = tokio::spawn(async move {
|
|
|
+ // //读取
|
|
|
+ // tokio::spawn(async move {
|
|
|
// let mold_clone = Arc::clone(&mold_arc);
|
|
|
// loop {
|
|
|
- // tokio::time::sleep(Duration::from_millis(1)).await;
|
|
|
- // if let Ok(received) = res_receiver.try_recv() {
|
|
|
+ // if let Some(data) = read_rx.next().await {
|
|
|
+ // trace!("原始数据 data:{:?}",data);
|
|
|
// match mold_clone.as_str() {
|
|
|
// "depth" => {
|
|
|
- // let result = kucoin_handle::handle_special_depth(received);
|
|
|
- // trace!(?result)
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = binance_handle::handle_special_depth(data);
|
|
|
+ // trace!(?result)
|
|
|
+ // }
|
|
|
// }
|
|
|
// "ticker" => {
|
|
|
- // let result = kucoin_handle::handle_special_ticker(received);
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
- // "account" => {
|
|
|
- // trace!(?received);
|
|
|
- // let result = kucoin_handle::handle_account_info(received, symbol_back.clone());
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
- // "position" => {
|
|
|
- // trace!(?received);
|
|
|
- // let result = kucoin_handle::handle_position(received, dec!(1));
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
- // "orders" => {
|
|
|
- // trace!(?received);
|
|
|
- // let result = kucoin_handle::handle_order(received, dec!(0.001));
|
|
|
- // trace!(?result)
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = binance_handle::handle_special_ticker(data);
|
|
|
+ // trace!(?result)
|
|
|
+ // }
|
|
|
// }
|
|
|
// _ => {
|
|
|
// error!("没有该命令!mode={}", mold_clone);
|
|
|
@@ -232,68 +214,66 @@ pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, _symbol: &str, _su
|
|
|
// }
|
|
|
// }
|
|
|
// }
|
|
|
- // }
|
|
|
+ // };
|
|
|
// });
|
|
|
- // try_join!(t1, t2).unwrap();
|
|
|
+ //
|
|
|
+ // let t1 = tokio::spawn(async move {
|
|
|
+ // //链接
|
|
|
+ // let bool_v3_clone = Arc::clone(&bool_v1);
|
|
|
+ // exchange_wss.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
|
|
|
+ // });
|
|
|
+ // try_join!(t1).unwrap();
|
|
|
}
|
|
|
- ExchangeEnum::KucoinSpot => {
|
|
|
- // let symbol_format = utils::format_symbol(symbol.to_string(), "-").to_uppercase();
|
|
|
+ ExchangeEnum::KucoinSwap => {
|
|
|
+ // let symbol_format = format!("{}M", utils::format_symbol(symbol.to_string(), ""));
|
|
|
// let symbol_back = utils::format_symbol(symbol.to_string(), "_");
|
|
|
- // trace!(symbol_format);
|
|
|
- // let name = format!("kucoin_usdt_spot@{}", symbol.to_string().to_lowercase());
|
|
|
- // let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
//
|
|
|
- // let (res_sender, mut res_receiver): (Sender<ResponseData>, Receiver<ResponseData>) = channel(1024);
|
|
|
- // let mut params: BTreeMap<String, String> = BTreeMap::new();
|
|
|
- // let access_key = env::var("kucoin_access_key").unwrap_or("".to_string());
|
|
|
- // let secret_key = env::var("kucoin_secret_key").unwrap_or("".to_string());
|
|
|
- // let pass_key = env::var("kucoin_pass_key").unwrap_or("".to_string());
|
|
|
- // params.insert("access_key".to_string(), access_key);
|
|
|
- // params.insert("secret_key".to_string(), secret_key);
|
|
|
- // params.insert("pass_key".to_string(), pass_key);
|
|
|
+ // let name = format!("kucoin_swap@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
|
|
|
+ // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
|
|
|
+ // let write_tx_am = Arc::new(Mutex::new(write_tx));
|
|
|
+ // let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
//
|
|
|
- // let mut exchange_wss = if ["depth", "ticker"].contains(&mold) {
|
|
|
- // KucoinSpotWs::new_label(name, false, params, KucoinSpotWsType::Public).await
|
|
|
- // } else {
|
|
|
- // KucoinSpotWs::new_label(name, false, params, KucoinSpotWsType::Private).await
|
|
|
+ // let params = KucoinSwapLogin {
|
|
|
+ // access_key: account_info.kucoin_access_key,
|
|
|
+ // secret_key: account_info.kucoin_secret_key,
|
|
|
+ // pass_key: account_info.kucoin_pass,
|
|
|
// };
|
|
|
- //
|
|
|
+ // let mut exchange_wss;
|
|
|
+ // if ["depth", "ticker"].contains(&mold) {
|
|
|
+ // exchange_wss = KucoinSwapWs::new_label(name, false, Option::from(params), KucoinSwapWsType::Public).await;
|
|
|
+ // } else {
|
|
|
+ // exchange_wss = KucoinSwapWs::new_label(name, false, Option::from(params), KucoinSwapWsType::Private).await;
|
|
|
+ // }
|
|
|
+ // exchange_wss.set_symbols(vec![symbol_format]);
|
|
|
// exchange_wss.set_subscribe(subscriber_type.into());
|
|
|
//
|
|
|
- // let t1 = tokio::spawn(async move {
|
|
|
- // exchange_wss.custom_subscribe(bool_v1, vec![symbol_format]).await;
|
|
|
- // });
|
|
|
// let mold_arc = Arc::new(mold.to_string());
|
|
|
- // let t2 = tokio::spawn(async move {
|
|
|
+ // tokio::spawn(async move {
|
|
|
// let mold_clone = Arc::clone(&mold_arc);
|
|
|
// loop {
|
|
|
- // tokio::time::sleep(Duration::from_millis(1)).await;
|
|
|
- // if let Ok(received) = res_receiver.try_recv() {
|
|
|
- // trace!(?received);
|
|
|
+ // if let Some(data) = read_rx.next().await {
|
|
|
+ // trace!("原始数据 data:{:?}",data);
|
|
|
// match mold_clone.as_str() {
|
|
|
// "depth" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = kucoin_spot_handle::handle_special_depth(received);
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
+ // let result = kucoin_handle::handle_special_depth(data);
|
|
|
+ // trace!(?result)
|
|
|
// }
|
|
|
// "ticker" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = kucoin_spot_handle::handle_special_ticker(received);
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
+ // let result = kucoin_handle::handle_special_ticker(data);
|
|
|
+ // trace!(?result)
|
|
|
// }
|
|
|
// "account" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = kucoin_spot_handle::handle_account_info(received, symbol_back.clone());
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
+ // let result = kucoin_handle::handle_account_info(data, symbol_back.clone());
|
|
|
+ // trace!(?result)
|
|
|
+ // }
|
|
|
+ // "position" => {
|
|
|
+ // let result = kucoin_handle::handle_position(data, dec!(1));
|
|
|
+ // trace!(?result)
|
|
|
// }
|
|
|
// "orders" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = kucoin_spot_handle::handle_order(received, dec!(1));
|
|
|
- // trace!(?result)
|
|
|
- // }
|
|
|
+ // let result = kucoin_handle::handle_order(data, dec!(0.001));
|
|
|
+ // trace!(?result)
|
|
|
// }
|
|
|
// _ => {
|
|
|
// error!("没有该命令!mode={}", mold_clone);
|
|
|
@@ -303,63 +283,143 @@ pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, _symbol: &str, _su
|
|
|
// }
|
|
|
// }
|
|
|
// });
|
|
|
- // try_join!(t1, t2).unwrap();
|
|
|
+ //
|
|
|
+ // let t1 = tokio::spawn(async move {
|
|
|
+ // //链接
|
|
|
+ // let bool_v3_clone = Arc::clone(&bool_v1);
|
|
|
+ // exchange_wss.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
|
|
|
+ // });
|
|
|
+ // try_join!(t1).unwrap();
|
|
|
+ }
|
|
|
+ ExchangeEnum::KucoinSpot => {
|
|
|
+ let symbol_format = utils::format_symbol(symbol.to_string(), "-").to_uppercase();
|
|
|
+ let symbol_back = utils::format_symbol(symbol.to_string(), "_");
|
|
|
+ trace!(symbol_format);
|
|
|
+ let name = format!("kucoin_spot@{}", symbol.to_string().to_lowercase());
|
|
|
+ let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
|
|
|
+ let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
|
|
|
+ let write_tx_am = Arc::new(Mutex::new(write_tx));
|
|
|
+ let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
+
|
|
|
+ let params = KucoinSpotLogin {
|
|
|
+ access_key: account_info.kucoin_access_key,
|
|
|
+ secret_key: account_info.kucoin_secret_key,
|
|
|
+ pass_key: account_info.kucoin_pass,
|
|
|
+ };
|
|
|
+ let mut exchange_wss = if ["depth", "ticker"].contains(&mold) {
|
|
|
+ KucoinSpotWs::new_label(name, false, Option::from(params), KucoinSpotWsType::Public).await
|
|
|
+ } else {
|
|
|
+ KucoinSpotWs::new_label(name, false, Option::from(params), KucoinSpotWsType::Private).await
|
|
|
+ };
|
|
|
+ exchange_wss.set_symbols(vec![symbol_format]);
|
|
|
+ exchange_wss.set_subscribe(subscriber_type.into());
|
|
|
+
|
|
|
+ let mold_arc = Arc::new(mold.to_string());
|
|
|
+ tokio::spawn(async move {
|
|
|
+ let mold_clone = Arc::clone(&mold_arc);
|
|
|
+ loop {
|
|
|
+ if let Some(data) = read_rx.next().await {
|
|
|
+ trace!("原始数据 data:{:?}",data);
|
|
|
+ match mold_clone.as_str() {
|
|
|
+ "depth" => {
|
|
|
+ if data.data != "" {
|
|
|
+ let result = kucoin_spot_handle::handle_special_depth(data);
|
|
|
+ trace!(?result)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ "ticker" => {
|
|
|
+ if data.data != "" {
|
|
|
+ let result = kucoin_spot_handle::handle_special_ticker(data);
|
|
|
+ trace!(?result)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ "account" => {
|
|
|
+ if data.data != "" {
|
|
|
+ let result = kucoin_spot_handle::handle_account_info(data, symbol_back.clone());
|
|
|
+ trace!(?result)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ "orders" => {
|
|
|
+ if data.data != "" {
|
|
|
+ let result = kucoin_spot_handle::handle_order(data, dec!(1));
|
|
|
+ trace!(?result)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ _ => {
|
|
|
+ error!("没有该命令!mode={}", mold_clone);
|
|
|
+ panic!("没有该命令!mode={}", mold_clone)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ });
|
|
|
+ let t1 = tokio::spawn(async move {
|
|
|
+ //链接
|
|
|
+ let bool_v3_clone = Arc::clone(&bool_v1);
|
|
|
+ exchange_wss.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
|
|
|
+ });
|
|
|
+ try_join!(t1).unwrap();
|
|
|
+ }
|
|
|
+ ExchangeEnum::GateSwap => {
|
|
|
+ error!("该交易所不支持!test_new_exchange_wss:{:?}",exchange);
|
|
|
+ panic!("该交易所不支持!test_new_exchange_wss:{:?}", exchange)
|
|
|
}
|
|
|
ExchangeEnum::BitgetSpot => {
|
|
|
// let symbol_format = utils::format_symbol(symbol.to_string(), "-").to_uppercase();
|
|
|
// let symbol_back = utils::format_symbol(symbol.to_string(), "_");
|
|
|
// trace!(symbol_format);
|
|
|
- // let name = format!("bitget_usdt_spot@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let name = format!("bitget_spot@{}", symbol.to_string().to_lowercase());
|
|
|
+ // let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
|
|
|
+ // let (read_tx, mut read_rx) = futures_channel::mpsc::unbounded::<ResponseData>();
|
|
|
+ // let write_tx_am = Arc::new(Mutex::new(write_tx));
|
|
|
// let bool_v1 = Arc::new(AtomicBool::new(true));
|
|
|
//
|
|
|
- // let (res_sender, mut res_receiver): (Sender<ResponseData>, Receiver<ResponseData>) = channel(1024);
|
|
|
- // let mut params: BTreeMap<String, String> = BTreeMap::new();
|
|
|
- // let access_key = env::var("bitget_access_key").unwrap_or("".to_string());
|
|
|
+ // let api_key = env::var("bitget_access_key").unwrap_or("".to_string());
|
|
|
// let secret_key = env::var("bitget_secret_key").unwrap_or("".to_string());
|
|
|
- // let pass_key = env::var("bitget_pass_key").unwrap_or("".to_string());
|
|
|
- // params.insert("access_key".to_string(), access_key);
|
|
|
- // params.insert("secret_key".to_string(), secret_key);
|
|
|
- // params.insert("pass_key".to_string(), pass_key);
|
|
|
+ // let passphrase_key = env::var("bitget_pass_key").unwrap_or("".to_string());
|
|
|
+ // let params = BitgetSpotLogin {
|
|
|
+ // api_key,
|
|
|
+ // secret_key,
|
|
|
+ // passphrase_key,
|
|
|
+ // };
|
|
|
//
|
|
|
// let mut exchange_wss = if ["depth", "ticker"].contains(&mold) {
|
|
|
- // BitgetSpotWs::new_label(name, false, params, BitgetWsType::Public, res_sender)
|
|
|
+ // BitgetSpotWs::new_label(name, false, Option::from(params), BitgetSpotWsType::Public)
|
|
|
// } else {
|
|
|
- // BitgetSpotWs::new_label(name, false, params, BitgetWsType::Private, res_sender)
|
|
|
+ // BitgetSpotWs::new_label(name, false, Option::from(params), BitgetSpotWsType::Private)
|
|
|
// };
|
|
|
- //
|
|
|
+ // exchange_wss.set_symbols(vec![symbol_format]);
|
|
|
// exchange_wss.set_subscribe(subscriber_type.into());
|
|
|
//
|
|
|
- // let t1 = tokio::spawn(async move {
|
|
|
- // exchange_wss.custom_subscribe(bool_v1, vec![symbol_format]).await;
|
|
|
- // });
|
|
|
// let mold_arc = Arc::new(mold.to_string());
|
|
|
- // let t2 = tokio::spawn(async move {
|
|
|
- // let mold_clone = Arc::clone(&mold_arc);
|
|
|
+ // //读取
|
|
|
+ // tokio::spawn(async move {
|
|
|
// loop {
|
|
|
- // tokio::time::sleep(Duration::from_millis(1)).await;
|
|
|
- // if let Ok(received) = res_receiver.try_recv() {
|
|
|
+ // let mold_clone = Arc::clone(&mold_arc);
|
|
|
+ // if let Some(data) = read_rx.next().await {
|
|
|
+ // trace!("原始数据 data:{:?}",data);
|
|
|
// match mold_clone.as_str() {
|
|
|
// "depth" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = bitget_spot_handle::handle_special_depth(received);
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = bitget_spot_handle::handle_special_depth(data);
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
// "ticker" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = bitget_spot_handle::handle_special_ticker(received);
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = bitget_spot_handle::handle_special_ticker(data);
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
// "account" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = bitget_spot_handle::handle_account_info(received, symbol_back.clone());
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = bitget_spot_handle::handle_account_info(data, symbol_back.clone());
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
// "orders" => {
|
|
|
- // if received.data != "" {
|
|
|
- // let result = bitget_spot_handle::handle_order(received, dec!(1));
|
|
|
+ // if data.data != "" {
|
|
|
+ // let result = bitget_spot_handle::handle_order(data, dec!(1));
|
|
|
// trace!(?result)
|
|
|
// }
|
|
|
// }
|
|
|
@@ -371,7 +431,12 @@ pub async fn test_new_exchange_wss<T>(exchange: ExchangeEnum, _symbol: &str, _su
|
|
|
// }
|
|
|
// }
|
|
|
// });
|
|
|
- // try_join!(t1, t2).unwrap();
|
|
|
+ // let t1 = tokio::spawn(async move {
|
|
|
+ // //链接
|
|
|
+ // let bool_v3_clone = Arc::clone(&bool_v1);
|
|
|
+ // exchange_wss.ws_connect_async(bool_v3_clone, &write_tx_am, write_rx, read_tx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
|
|
|
+ // });
|
|
|
+ // try_join!(t1).unwrap();
|
|
|
}
|
|
|
ExchangeEnum::OkxSwap => {
|
|
|
// let symbol_format = utils::format_symbol(symbol.to_string(), "-").to_uppercase();
|