Browse Source

注释cointr

DESKTOP-NE65RNK\Citrus_limon 1 năm trước cách đây
mục cha
commit
50ab02dcca
1 tập tin đã thay đổi với 122 bổ sung122 xóa
  1. 122 122
      src/cointr_usdt_swap_data_listener.rs

+ 122 - 122
src/cointr_usdt_swap_data_listener.rs

@@ -1,122 +1,122 @@
-use std::collections::{BTreeMap, HashMap};
-use std::str::FromStr;
-use std::sync::{Arc};
-use std::sync::atomic::AtomicBool;
-use lazy_static::lazy_static;
-use rust_decimal::Decimal;
-use rust_decimal_macros::dec;
-use tokio::sync::{Mutex};
-use exchanges::cointr_swap_rest::CointrSwapRest;
-use exchanges::cointr_swap_ws::{CointrSwapSubscribeType, CointrSwapWs, CointrSwapWsType};
-use exchanges::response_base::ResponseData;
-use serde_json::{json};
-use standard::exchange::ExchangeEnum;
-use standard::exchange_struct_handler::ExchangeStructHandler;
-use standard::utils::symbol_out_mapper;
-use crate::listener_tools::{RecordMap, TradeMap, update_record, update_trade};
-
-const EXCHANGE_NAME: &str = "cointr_usdt_swap";
-
-lazy_static! {
-    // static ref DEPTH_MAP: Mutex<DepthMap> = Mutex::new(HashMap::new());
-    static ref TRADES_MAP: Mutex<TradeMap> = Mutex::new(HashMap::new());
-    static ref RECORD_MAP: Mutex<RecordMap> = Mutex::new(HashMap::new());
-    static ref MUL_MAP: Mutex<HashMap<String, Decimal>> = Mutex::new(HashMap::new());
-}
-
-pub async fn run_listener(is_shutdown_arc: Arc<AtomicBool>) {
-    let name = "cointr_usdt_swap_listener";
-    // 订阅所有币种
-    let login = BTreeMap::new();
-    let mut cointr_rest = CointrSwapRest::new(false, login);
-    let params = json!({});
-    let response = cointr_rest.get_market(params).await;
-    let mut symbols = vec![];
-    if response.code == 200 {
-        let symbol_infos = response.data["data"].as_array().unwrap();
-        let mut mul_map = MUL_MAP.lock().await;
-        for symbol_info in symbol_infos {
-            if symbol_info["quoteCcy"].as_str().unwrap() != "USDT" { continue; }
-            // quanto_multiplier是ct_val
-            let symbol = symbol_info["instId"].as_str().unwrap().to_string();
-            let loc_symbol = format!("{}_{}", symbol_info["baseCcy"].as_str().unwrap(), symbol_info["quoteCcy"].as_str().unwrap());
-            let mul = Decimal::from_str(symbol_info["ctVal"].as_str().unwrap()).unwrap();
-            mul_map.insert(symbol_out_mapper(ExchangeEnum::CointrSwap, &loc_symbol), mul);
-
-            symbols.push(symbol)
-        }
-    }
-    for chunk in symbols.chunks(1) {
-        let ws_name = name.to_string();
-        let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
-        let write_tx_am = Arc::new(Mutex::new(write_tx));
-        let symbols_chunk = chunk.iter().cloned().collect::<Vec<String>>();
-        let is_shutdown_clone = Arc::clone(&is_shutdown_arc);
-
-        tokio::spawn(async move {
-            let mut ws = CointrSwapWs::new_with_tag(ws_name, false, None, CointrSwapWsType::PublicAndPrivate).clone();
-            ws.set_subscribe(vec![
-                CointrSwapSubscribeType::PuFuturesTrades,
-                CointrSwapSubscribeType::PuFuturesRecords,
-                // CointrSwapSubscribeType::PuFuturesDepth
-            ]);
-
-            // 建立链接
-            ws.set_symbols(symbols_chunk);
-            ws.ws_connect_async(is_shutdown_clone, data_listener, &write_tx_am, write_rx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
-        });
-    }
-}
-
-// 读取数据
-pub async fn data_listener(response: ResponseData) {
-    if response.code != 200 {
-        return;
-    }
-
-    match response.channel.as_str() {
-        // 深度数据
-        "futures.order_book" => {
-            // let depth = ExchangeStructHandler::order_book_handle(ExchangeEnum::CointrSwap, &response);
-            //
-            // update_depth(&depth).await;
-        }
-        // 订单流数据
-        "futures.trades" => {
-            let mut trades = ExchangeStructHandler::trades_handle(ExchangeEnum::CointrSwap, &response);
-            let mul_map = MUL_MAP.lock().await;
-
-            for trade in trades.iter_mut() {
-                // 真实交易量处理,因为cointr的量都是张数
-                let mul = mul_map[trade.symbol.as_str()];
-                let mut real_size = trade.size * mul * trade.price;
-                real_size.rescale(2);
-                trade.size = real_size;
-
-                // 更新到本地数据库
-                let trades_map = TRADES_MAP.lock().await;
-                update_trade(trade, trades_map, EXCHANGE_NAME).await;
-            }
-        }
-        // k线数据
-        "futures.candlesticks" => {
-            let mut records = ExchangeStructHandler::records_handle(ExchangeEnum::CointrSwap, &response);
-            let mul_map = MUL_MAP.lock().await;
-            for record in records.iter_mut() {
-                // 真实交易量处理,因为cointr的量都是张数
-                let mul = mul_map[record.symbol.as_str()];
-                let mid_price = (record.high + record.low) * dec!(0.5);
-                let mut real_volume = record.volume * mul * mid_price;
-                real_volume.rescale(2);
-                record.volume = real_volume;
-
-                // 更新到本地数据库
-                let record_map = RECORD_MAP.lock().await;
-                update_record(record, record_map, EXCHANGE_NAME).await;
-            }
-        }
-        _ => {
-            // info!("48 未知的数据类型: {:?}", response)
-        }
-    }
-}
+// use std::collections::{BTreeMap, HashMap};
+// use std::str::FromStr;
+// use std::sync::{Arc};
+// use std::sync::atomic::AtomicBool;
+// use lazy_static::lazy_static;
+// use rust_decimal::Decimal;
+// use rust_decimal_macros::dec;
+// use tokio::sync::{Mutex};
+// use exchanges::cointr_swap_rest::CointrSwapRest;
+// use exchanges::cointr_swap_ws::{CointrSwapSubscribeType, CointrSwapWs, CointrSwapWsType};
+// use exchanges::response_base::ResponseData;
+// use serde_json::{json};
+// use standard::exchange::ExchangeEnum;
+// use standard::exchange_struct_handler::ExchangeStructHandler;
+// use standard::utils::symbol_out_mapper;
+// use crate::listener_tools::{RecordMap, TradeMap, update_record, update_trade};
+//
+// const EXCHANGE_NAME: &str = "cointr_usdt_swap";
+//
+// lazy_static! {
+//     // static ref DEPTH_MAP: Mutex<DepthMap> = Mutex::new(HashMap::new());
+//     static ref TRADES_MAP: Mutex<TradeMap> = Mutex::new(HashMap::new());
+//     static ref RECORD_MAP: Mutex<RecordMap> = Mutex::new(HashMap::new());
+//     static ref MUL_MAP: Mutex<HashMap<String, Decimal>> = Mutex::new(HashMap::new());
+// }
+//
+// pub async fn run_listener(is_shutdown_arc: Arc<AtomicBool>) {
+//     let name = "cointr_usdt_swap_listener";
+//     // 订阅所有币种
+//     let login = BTreeMap::new();
+//     let mut cointr_rest = CointrSwapRest::new(false, login);
+//     let params = json!({});
+//     let response = cointr_rest.get_market(params).await;
+//     let mut symbols = vec![];
+//     if response.code == 200 {
+//         let symbol_infos = response.data["data"].as_array().unwrap();
+//         let mut mul_map = MUL_MAP.lock().await;
+//         for symbol_info in symbol_infos {
+//             if symbol_info["quoteCcy"].as_str().unwrap() != "USDT" { continue; }
+//             // quanto_multiplier是ct_val
+//             let symbol = symbol_info["instId"].as_str().unwrap().to_string();
+//             let loc_symbol = format!("{}_{}", symbol_info["baseCcy"].as_str().unwrap(), symbol_info["quoteCcy"].as_str().unwrap());
+//             let mul = Decimal::from_str(symbol_info["ctVal"].as_str().unwrap()).unwrap();
+//             mul_map.insert(symbol_out_mapper(ExchangeEnum::CointrSwap, &loc_symbol), mul);
+//
+//             symbols.push(symbol)
+//         }
+//     }
+//     for chunk in symbols.chunks(1) {
+//         let ws_name = name.to_string();
+//         let (write_tx, write_rx) = futures_channel::mpsc::unbounded();
+//         let write_tx_am = Arc::new(Mutex::new(write_tx));
+//         let symbols_chunk = chunk.iter().cloned().collect::<Vec<String>>();
+//         let is_shutdown_clone = Arc::clone(&is_shutdown_arc);
+//
+//         tokio::spawn(async move {
+//             let mut ws = CointrSwapWs::new_with_tag(ws_name, false, None, CointrSwapWsType::PublicAndPrivate).clone();
+//             ws.set_subscribe(vec![
+//                 CointrSwapSubscribeType::PuFuturesTrades,
+//                 CointrSwapSubscribeType::PuFuturesRecords,
+//                 // CointrSwapSubscribeType::PuFuturesDepth
+//             ]);
+//
+//             // 建立链接
+//             ws.set_symbols(symbols_chunk);
+//             ws.ws_connect_async(is_shutdown_clone, data_listener, &write_tx_am, write_rx).await.expect("链接失败(内部一个心跳线程应该已经关闭了)");
+//         });
+//     }
+// }
+//
+// // 读取数据
+// pub async fn data_listener(response: ResponseData) {
+//     if response.code != 200 {
+//         return;
+//     }
+//
+//     match response.channel.as_str() {
+//         // 深度数据
+//         "futures.order_book" => {
+//             // let depth = ExchangeStructHandler::order_book_handle(ExchangeEnum::CointrSwap, &response);
+//             //
+//             // update_depth(&depth).await;
+//         }
+//         // 订单流数据
+//         "futures.trades" => {
+//             let mut trades = ExchangeStructHandler::trades_handle(ExchangeEnum::CointrSwap, &response);
+//             let mul_map = MUL_MAP.lock().await;
+//
+//             for trade in trades.iter_mut() {
+//                 // 真实交易量处理,因为cointr的量都是张数
+//                 let mul = mul_map[trade.symbol.as_str()];
+//                 let mut real_size = trade.size * mul * trade.price;
+//                 real_size.rescale(2);
+//                 trade.size = real_size;
+//
+//                 // 更新到本地数据库
+//                 let trades_map = TRADES_MAP.lock().await;
+//                 update_trade(trade, trades_map, EXCHANGE_NAME).await;
+//             }
+//         }
+//         // k线数据
+//         "futures.candlesticks" => {
+//             let mut records = ExchangeStructHandler::records_handle(ExchangeEnum::CointrSwap, &response);
+//             let mul_map = MUL_MAP.lock().await;
+//             for record in records.iter_mut() {
+//                 // 真实交易量处理,因为cointr的量都是张数
+//                 let mul = mul_map[record.symbol.as_str()];
+//                 let mid_price = (record.high + record.low) * dec!(0.5);
+//                 let mut real_volume = record.volume * mul * mid_price;
+//                 real_volume.rescale(2);
+//                 record.volume = real_volume;
+//
+//                 // 更新到本地数据库
+//                 let record_map = RECORD_MAP.lock().await;
+//                 update_record(record, record_map, EXCHANGE_NAME).await;
+//             }
+//         }
+//         _ => {
+//             // info!("48 未知的数据类型: {:?}", response)
+//         }
+//     }
+// }