From 41b107ba7acd40fa32ce9ec8f103dfe1061ecf4e Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Wed, 03 Sep 2025 16:52:33 +0800
Subject: [PATCH] 初始化修改
---
trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java | 50 ++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 46 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 9914006..b85a206 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
@@ -1,5 +1,6 @@
package com.yami.trading.admin.controller.ico;
+import cn.hutool.core.date.DateTime;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -8,6 +9,7 @@
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.domain.Result;
import com.yami.trading.common.exception.YamiShopBindException;
@@ -23,6 +25,8 @@
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
+import java.time.Instant;
+import java.util.Date;
@Api(tags ="新币管理")
@@ -35,6 +39,9 @@
@Autowired
private UserSubscriptionService userSubscriptionService;
+
+ @Autowired
+ ItemService itemService;
/**
* 产品列表数据
@@ -53,12 +60,46 @@
@ApiOperation(value = "保存新币")
@PostMapping("save")
public Result <String> save(@Valid @RequestBody Ico ico) {
+ long count;
if (ico.getId() == null) { //新增校验
- long count = icoService.count(new LambdaQueryWrapper<Ico>()
- .eq(Ico::getSymbol, ico.getSymbol()));
- if(count > 0){
- throw new YamiShopBindException("代币符号已存在");
+ count = icoService.count(new LambdaQueryWrapper<Ico>()
+ .eq(Ico::getSymbol, ico.getSymbol()).or().eq(Ico::getSymbolData, ico.getSymbolData()));
+
+ } else {
+ Ico model = icoService.getById(ico.getId());
+ if (model == null) {
+ throw new YamiShopBindException("数据不存在");
}
+ Date now = Date.from(Instant.now());
+ if (model.getMarketDate() != null && model.getMarketDate().before(now)){
+ throw new YamiShopBindException("已上市不能修改");
+ }
+
+ if (!model.getSymbol().equalsIgnoreCase(ico.getSymbol()) ||
+ !model.getSymbolData().equalsIgnoreCase(ico.getSymbolData())) {
+ //修改编码判断是否有人购买
+ QueryWrapper<UserSubscription> queryWrapper = new QueryWrapper<>();
+ queryWrapper.eq("ico_project_id", ico.getId());
+ long uCount = userSubscriptionService.count(queryWrapper);
+ if (uCount > 0) {
+ throw new YamiShopBindException("已有申购,禁止修改代币符号,数据源编码");
+ }
+ }
+ 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("代币符号或数据源编码已存在");
+ }
+ //产品表
+ long iCount = itemService.count(new LambdaQueryWrapper<Item>()
+ .eq(Item::getSymbol, ico.getSymbol()).or().eq(Item::getSymbolData, ico.getSymbolData()));
+ if(iCount > 0){
+ throw new YamiShopBindException("产品表已存在数据");
}
//新增或编辑表单保存
icoService.saveOrUpdate(ico);
@@ -91,6 +132,7 @@
@GetMapping("recordList")
public Result<Page<UserSubscriptionDTO>> recordList(IcoQuery icoQuery, Page<UserSubscriptionDTO> page) throws Exception {
QueryWrapper queryWrapper = QueryWrapperGenerator.buildQueryCondition (icoQuery, IcoQuery.class);
+ queryWrapper.eq("u.del_flag", "0");
Page<UserSubscriptionDTO> result = userSubscriptionService.findPage(page, queryWrapper);
return Result.ok(result);
}
--
Gitblit v1.9.3