From 640ccb9229224642515527daf87f308a7aa9bdf4 Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Wed, 10 Jun 2026 11:47:26 +0800
Subject: [PATCH] 1
---
trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIcoController.java | 35 +++++++++++++++++++++++++++++++----
1 files changed, 31 insertions(+), 4 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIcoController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIcoController.java
index 207ff85..aff11d0 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIcoController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/ApiIcoController.java
@@ -2,15 +2,18 @@
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+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.query.ItemQuery;
import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.exception.BusinessException;
import com.yami.trading.common.exception.YamiShopBindException;
import com.yami.trading.common.query.QueryWrapperGenerator;
import com.yami.trading.security.common.util.SecurityUtils;
+import com.yami.trading.service.data.DataService;
import com.yami.trading.service.ico.IcoService;
import com.yami.trading.service.ico.UserSubscriptionService;
import io.swagger.annotations.Api;
@@ -23,6 +26,9 @@
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.util.List;
import java.util.concurrent.TimeUnit;
@RestController
@@ -40,6 +46,9 @@
@Autowired
private RedissonClient redissonClient;
+ @Autowired
+ private DataService dataService;
+
@ApiOperation(value = "新币列表")
@GetMapping("list")
public Result<Page<Ico>> list(ItemQuery icoQuery, Page<Ico> page) throws Exception {
@@ -55,7 +64,7 @@
public Result<String> subscribe(@Valid UserSubscription model) {
String partyId = SecurityUtils.getUser().getUserId();
if (StringUtils.isEmpty(partyId)) {
- throw new YamiShopBindException("请重新登录");
+ throw new YamiShopBindException("Please log in again");
}
RLock rLock = redissonClient.getLock("subscribe" + partyId);
boolean lockAcquired = false;
@@ -64,7 +73,7 @@
lockAcquired = rLock.tryLock(5, TimeUnit.SECONDS);
if (!lockAcquired) {
log.warn("无法获取锁: subscribe{}", partyId);
- throw new YamiShopBindException("请稍后再试");
+ throw new YamiShopBindException("Please try again later");
}
model.setUserId(partyId);
return icoService.subscribe(model);
@@ -73,7 +82,7 @@
throw e; // 重新抛出自定义异常
} catch (Exception e) {
log.error("系统异常: {}", e.getMessage(), e);
- throw new YamiShopBindException("操作失败,请稍后再试");
+ throw new YamiShopBindException("Operation failed, please try again later");
} finally {
// 确保释放锁
if (lockAcquired && rLock.isHeldByCurrentThread()) {
@@ -88,11 +97,29 @@
QueryWrapper queryWrapper = QueryWrapperGenerator.buildQueryCondition (icoQuery, IcoQuery.class);
String partyId = SecurityUtils.getUser().getUserId();
if (StringUtils.isEmpty(partyId)) {
- throw new YamiShopBindException("请重新登录");
+ throw new YamiShopBindException("Please log in again");
}
queryWrapper.eq("u.user_id", partyId);
queryWrapper.orderByDesc("created_at");
Page<UserSubscriptionDTO> result = userSubscriptionService.findPage(page, queryWrapper);
+ List<UserSubscriptionDTO> userSubscriptionDTOS = result.getRecords();
+ userSubscriptionDTOS.forEach(f->{
+ List<Realtime> realtime_list = this.dataService.realtime(f.getSymbol());
+ Realtime realtime = null;
+ if (realtime_list.size() > 0) {
+ realtime = realtime_list.get(0);
+ }
+ Ico ico = icoService.getById(f.getIcoProjectId());
+ f.setIssuePrice(ico.getUnitAmount());
+ if (null != realtime) {
+ f.setCurrentPrice(realtime.getClose());
+ f.setCurrentTotalPrice(realtime.getClose().multiply(new BigDecimal(f.getBallotNumber())));
+ BigDecimal profitPercent = (realtime.getClose().subtract(f.getIssuePrice())).divide(f.getIssuePrice()).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP);
+ f.setProfitPercent(profitPercent);
+ }
+ f.setSubscriptionTotalAmount(ico.getUnitAmount().multiply(new BigDecimal(f.getBallotNumber())));
+ f.setProfit(f.getCurrentTotalPrice().subtract(f.getSubscriptionTotalAmount()));
+ });
return Result.ok(result);
}
--
Gitblit v1.9.3