From b011546dbdff18eadf1843cda4ecc6b5b5f87de1 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Tue, 23 Sep 2025 11:00:04 +0800
Subject: [PATCH] 1

---
 trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java |  138 ++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 127 insertions(+), 11 deletions(-)

diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java b/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
index cb5ee12..70cf1d4 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java
@@ -1,20 +1,46 @@
 package com.yami.trading.admin.task;
 
 
+import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.date.DateTime;
+import cn.hutool.core.lang.Console;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
+import cn.hutool.http.HttpStatus;
+import cn.hutool.json.JSONUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.yami.trading.api.UD.*;
 import com.yami.trading.bean.ico.domain.Ico;
 import com.yami.trading.bean.item.domain.Item;
+import com.yami.trading.bean.model.ChannelBlockchain;
+import com.yami.trading.bean.model.User;
+import com.yami.trading.bean.model.Withdraw;
+import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.util.*;
+import com.yami.trading.huobi.data.internal.KlineInitService;
+import com.yami.trading.security.common.enums.CryptoCurrencyEnum;
+import com.yami.trading.security.common.enums.SysTypeEnum;
+import com.yami.trading.security.common.manager.PasswordCheckManager;
+import com.yami.trading.security.common.util.SecurityUtils;
+import com.yami.trading.service.IdentifyingCodeService;
+import com.yami.trading.service.WithdrawService;
 import com.yami.trading.service.ico.IcoService;
 import com.yami.trading.service.item.ItemService;
+import com.yami.trading.service.user.UserService;
 import lombok.extern.slf4j.Slf4j;
 
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
-import java.util.ArrayList;
-import java.util.List;
+import java.io.IOException;
+import java.math.RoundingMode;
+import java.text.DecimalFormat;
+import java.util.*;
 import java.util.stream.Collectors;
 
 
@@ -31,6 +57,87 @@
     @Autowired
     InitHandle initHandle;
 
+    @Autowired
+    private KlineInitService klineInitService;
+
+    @Autowired
+    UdunClient udunClient;
+
+    @Autowired
+    RedisTemplate redisTemplate;
+
+    @Autowired
+    WithdrawService withdrawService;
+
+    @Autowired
+    IdentifyingCodeService identifyingCodeService;
+    @Autowired
+    UserService userService;
+    @Autowired
+    PasswordCheckManager passwordCheckManager;
+
+    private double getRandomValue(int value) {
+        double addValue;
+        if (value > 0) {
+            int count = 0;
+            while (value > 0) {
+                value = value / 10;
+                count++;
+            }
+            // 个
+            if (count == 1) {
+                addValue = RandomUtil.randomFloat(0.01, 0.1999, 4);
+                return addValue;
+            }
+            // 十
+            if (count == 2) {
+                addValue = RandomUtil.randomFloat(0.1, 0.5999, 4);
+                return addValue;
+            }
+            // 百
+            if (count == 3) {
+                addValue = RandomUtil.randomFloat(0.1, 2.9999, 4);
+                return addValue;
+            }
+            // 千
+            if (count == 4) {
+                addValue = RandomUtil.randomFloat(1, 3.9999, 4);
+                return addValue;
+            }
+            // 万
+            if (count == 5) {
+                addValue = RandomUtil.randomFloat(1, 5.9999, 4);
+                return addValue;
+            }
+            // 十万
+            else {
+                addValue = RandomUtil.randomFloat(1, 5.9999, 4);
+                return addValue;
+            }
+        } else {
+            addValue = RandomUtil.randomFloat(0.01, 0.2999, 4);
+            return addValue;
+        }
+    }
+
+   // @Scheduled(cron = "*/5 * * * * ?")
+    public void test() throws Exception {
+        double amt = 0.005215;
+        double addPriceValue = getRandomValue((int)amt);
+        double price = Arith.add(amt, addPriceValue);
+
+        String format = "";
+        format = "#.";
+        for (int j = 0; j < 6; j++) {
+            format = format + "#";
+        }
+
+        DecimalFormat df = new DecimalFormat(format);
+        df.setRoundingMode(RoundingMode.FLOOR);// 向下取整
+
+        System.out.println(df.format(price));
+        System.out.println("dd");
+    }
     /**
      * ico转入产品
      */
@@ -42,17 +149,13 @@
         if (icoList == null || icoList.isEmpty()) {
             return;
         }
-        List<String> symbolList = icoList.stream().map(Ico::getSymbol).collect(Collectors.toList());
-
-        QueryWrapper<Item> iQuery  = new QueryWrapper<>();
-        iQuery.in("SYMBOL", symbolList);
-        iQuery.eq("currency_type", 1);
-        List<Item> itemList = itemService.list(iQuery);
-
         List<Item> addItemList = new ArrayList<>();
         for (Ico ico : icoList) {
-            //如何不存在添加
-            Item item = itemList.stream().filter(x -> x.getSymbol().equals(ico.getSymbol())).findFirst().orElse(null);
+            //是否已存在币
+            QueryWrapper<Item> iQuery  = new QueryWrapper<>();
+            iQuery.eq("SYMBOL", ico.getSymbol());
+            iQuery.eq("SYMBOL_DATA", ico.getSymbolData());
+            Item item = itemService.getOne(iQuery);
             if (item == null) {
                 item = new Item();
                 item =icoService.icoToItem(item, ico);
@@ -66,4 +169,17 @@
             log.info("成功ico转入产品 数据 End {}", icoList.size());
         }
     }
+
+
+    /**
+     * K线数据修正
+     */
+    @Scheduled(cron = "0 */5 * * * ?")
+    public void klineInit() {
+        List<Item> items = ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list();
+        if (CollectionUtil.isNotEmpty(items)) {
+            String symbols = items.stream().map(Item::getSymbol).collect(Collectors.joining(","));
+            klineInitService.klineInit(symbols);
+        }
+    }
 }

--
Gitblit v1.9.3