From 848a9964debed951d24bdad1474dfb69b86195fe Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 19 Sep 2025 17:37:24 +0800
Subject: [PATCH] 1
---
trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java | 34 ++++++++++++++++++++++++++++++----
1 files changed, 30 insertions(+), 4 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java
index 7c03453..9ec6abe 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java
@@ -5,16 +5,20 @@
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.google.common.collect.Lists;
+import com.yami.trading.bean.data.domain.Realtime;
import com.yami.trading.bean.ico.domain.Ico;
import com.yami.trading.bean.ico.domain.UserSubscription;
import com.yami.trading.bean.ico.dto.UserSubscriptionDTO;
import com.yami.trading.bean.ico.query.IcoQuery;
import com.yami.trading.bean.item.domain.Item;
import com.yami.trading.bean.item.query.ItemQuery;
+import com.yami.trading.common.config.RequestDataHelper;
import com.yami.trading.common.domain.Result;
import com.yami.trading.common.exception.YamiShopBindException;
import com.yami.trading.common.query.QueryWrapperGenerator;
+import com.yami.trading.huobi.data.DataCache;
import com.yami.trading.security.common.util.SecurityUtils;
+import com.yami.trading.service.data.RealtimeService;
import com.yami.trading.service.ico.IcoService;
import com.yami.trading.service.ico.UserSubscriptionService;
import com.yami.trading.service.item.ItemService;
@@ -25,6 +29,7 @@
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
+import java.math.BigDecimal;
import java.time.Instant;
import java.util.Date;
@@ -42,6 +47,9 @@
@Autowired
ItemService itemService;
+
+ @Autowired
+ RealtimeService realtimeService;
/**
* 产品列表数据
@@ -71,6 +79,9 @@
if(iCount > 0){
throw new YamiShopBindException("产品表已存在数据");
}
+ if(count > 0){
+ throw new YamiShopBindException("代币符号或数据源编码已存在");
+ }
} else {
Ico model = icoService.getById(ico.getId());
if (model == null) {
@@ -84,16 +95,31 @@
}
}
-
count = icoService.count(new LambdaQueryWrapper<Ico>()
.ne(Ico::getId, ico.getId())
.and(wrapper -> wrapper
.eq(Ico::getSymbol, ico.getSymbol())
.or()
.eq(Ico::getSymbolData, ico.getSymbolData())));
- }
- if(count > 0){
- throw new YamiShopBindException("代币符号或数据源编码已存在");
+ if(count > 0){
+ throw new YamiShopBindException("代币符号或数据源编码已存在");
+ }
+
+ //更新ico实时价格
+ if (model.getUnitAmount().compareTo(BigDecimal.ZERO) >0 &&
+ model.getUnitAmount().compareTo(ico.getUnitAmount()) != 0){
+ String symbol = ico.getSymbol();
+ RequestDataHelper.set("symbol", symbol);
+ LambdaQueryWrapper<Realtime> queryWrapper = new LambdaQueryWrapper<Realtime>()
+ .eq(Realtime::getSymbol, symbol)
+ .orderByDesc(Realtime::getTs)
+ .last("LIMIT 1");
+ Realtime realtime = realtimeService.getOne(queryWrapper);
+ realtime.setClose(ico.getUnitAmount());
+ realtimeService.updateById(realtime);
+ RequestDataHelper.clear();
+ DataCache.putRealtime(symbol, realtime);
+ }
}
//新增或编辑表单保存
icoService.saveOrUpdate(ico);
--
Gitblit v1.9.3