From a1c2c8df8c2741fdb4e1d30b1dd70e57133e1cb7 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Wed, 03 Sep 2025 14:51:40 +0800
Subject: [PATCH] 初始化修改

---
 trading-order-admin/src/main/java/com/yami/trading/admin/controller/ico/AdminIcoController.java |   91 ++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 84 insertions(+), 7 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 263527d..3a09604 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,15 +1,25 @@
 package com.yami.trading.admin.controller.ico;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 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.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.domain.Result;
+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.ico.IcoService;
+import com.yami.trading.service.ico.UserSubscriptionService;
+import com.yami.trading.service.item.ItemService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
@@ -24,13 +34,19 @@
 	@Autowired
 	private IcoService icoService;
 
+	@Autowired
+	private UserSubscriptionService	userSubscriptionService;
+
+	@Autowired
+	ItemService itemService;
+
 	/**
 	 * 产品列表数据
 	 */
-	@ApiOperation(value = "新币列表,配置列表")
+	@ApiOperation(value = "新币列表")
 	@GetMapping("list")
-	public Result<Page<Ico>> list(ItemQuery itemQuery, Page<Ico> page) throws Exception {
-		QueryWrapper queryWrapper = QueryWrapperGenerator.buildQueryCondition (itemQuery, ItemQuery.class);
+	public Result<Page<Ico>> list(IcoQuery icoQuery, Page<Ico> page) throws Exception {
+		QueryWrapper queryWrapper = QueryWrapperGenerator.buildQueryCondition (icoQuery, IcoQuery.class);
 		Page<Ico> result = icoService.page(page, queryWrapper);
 		return Result.ok(result);
 	}
@@ -41,6 +57,28 @@
 	@ApiOperation(value = "保存新币")
 	@PostMapping("save")
 	public  Result <String> save(@Valid @RequestBody Ico ico) {
+		long count;
+		if (ico.getId() == null) { //新增校验
+			count = icoService.count(new LambdaQueryWrapper<Ico>()
+					.eq(Ico::getSymbol, ico.getSymbol()).or().eq(Ico::getSymbolData, ico.getSymbolData()));
+
+		} else {
+			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);
         return Result.ok ( "保存产品成功" );
@@ -51,10 +89,49 @@
 	 */
 	@ApiOperation(value = "删除新币")
 	@DeleteMapping("delete")
-	public Result <String> delete(String ids) {
-		String idArray[] = ids.split(",");
-		icoService.removeByIds ( Lists.newArrayList ( idArray ) );
-		return Result.ok("删除产品成功");
+	public Result <String> delete(Integer id) {
+		if (id == null) {
+			throw new YamiShopBindException("id is null");
+		}
+		QueryWrapper<UserSubscription> queryWrapper = new QueryWrapper<>();
+		queryWrapper.eq("ico_project_id", id);
+		long count = userSubscriptionService.count(queryWrapper);
+		if (count > 0) {
+			throw new YamiShopBindException("已有申购记录,删除失败");
+		}
+		if (icoService.removeById(id)) {
+			return Result.ok("删除成功");
+		}
+		return Result.ok("删除失败");
+
+	}
+
+	@ApiOperation(value = "新币申购记录列表")
+	@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);
+	}
+
+	/**
+	 * 修改新币记录
+	 */
+	@ApiOperation(value = "修改新币记录")
+	@PostMapping("updateRecord")
+	public  Result <String> save(@RequestBody UserSubscription userSubscription) {
+		return icoService.updateRecord(userSubscription);
+	}
+
+	/**
+	 * 删除新币记录
+	 */
+	@ApiOperation(value = "删除新币记录")
+	@DeleteMapping("deleteRecord")
+	public Result <String> deleteRecord(Integer id) {
+		userSubscriptionService.removeById(id);
+		return Result.ok("删除记录成功");
 	}
 
 }

--
Gitblit v1.9.3