From be8c9767089b5e52ed462ea1d083d846e7420a45 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Mon, 15 Jun 2026 11:01:37 +0800
Subject: [PATCH] 1
---
trading-order-admin/src/main/java/com/yami/trading/admin/task/IcoTask.java | 141 ++++++----------------------------------------
1 files changed, 20 insertions(+), 121 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 70cf1d4..77d6bd0 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,149 +1,48 @@
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.common.util.ApplicationContextUtils;
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.io.IOException;
-import java.math.RoundingMode;
-import java.text.DecimalFormat;
-import java.util.*;
+import java.util.ArrayList;
+import java.util.List;
import java.util.stream.Collectors;
-
+/**
+ * ICO 定时任务:到期 ICO 转入交易品种,并触发行情初始化。
+ */
@Component
@Slf4j
public class IcoTask {
@Autowired
- IcoService icoService;
+ private IcoService icoService;
@Autowired
- ItemService itemService;
+ private ItemService itemService;
@Autowired
- InitHandle initHandle;
+ private 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转入产品
+ * ICO 上市时间到期后,写入品种表并刷新行情缓存。
*/
@Scheduled(cron = "0 */1 * * * ?")
public void icoToItem() {
- QueryWrapper<Ico> query = new QueryWrapper<>();
+ QueryWrapper<Ico> query = new QueryWrapper<>();
query.lt("market_date", DateTime.now());
List<Ico> icoList = icoService.list(query);
if (icoList == null || icoList.isEmpty()) {
@@ -151,32 +50,32 @@
}
List<Item> addItemList = new ArrayList<>();
for (Ico ico : icoList) {
- //是否已存在币
- QueryWrapper<Item> iQuery = new QueryWrapper<>();
+ 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);
+ item = icoService.icoToItem(item, ico);
addItemList.add(item);
}
}
if (!addItemList.isEmpty()) {
- log.info("ico转入产品 数据 Start>>");
+ log.info("ico转入产品 数据 Start>> count={}", addItemList.size());
itemService.saveOrUpdateBatch(addItemList);
initHandle.init();
- log.info("成功ico转入产品 数据 End {}", icoList.size());
+ log.info("成功ico转入产品 数据 End count={}", addItemList.size());
}
}
-
/**
- * K线数据修正
+ * K线数据修正(默认关闭定时,需要时取消注释 cron)
*/
- @Scheduled(cron = "0 */5 * * * ?")
+ // @Scheduled(cron = "0 */5 * * * ?")
public void klineInit() {
- List<Item> items = ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list();
+ 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