From d9e8ad9fa3eb8558fc93d6fe7876699c7a8e2669 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Tue, 28 Oct 2025 18:18:48 +0800
Subject: [PATCH] etf大宗
---
trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java | 4
trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminETFDzController.java | 92 +++++++++++++++++++++++
trading-order-service/src/main/java/com/yami/trading/service/impl/AwsS3OSSFileServiceImpl.java | 3
trading-order-admin/src/main/java/com/yami/trading/admin/controller/loan/internal/LoanServiceImpl.java | 6 +
trading-order-admin/src/main/java/com/yami/trading/api/controller/RealtimeController.java | 3
trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiETFDzController.java | 98 ++++++++++++++++++++++++
trading-order-admin/src/main/resources/application-dev.yml | 4
7 files changed, 203 insertions(+), 7 deletions(-)
diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminETFDzController.java b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminETFDzController.java
new file mode 100644
index 0000000..76a2f62
--- /dev/null
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/dz/AdminETFDzController.java
@@ -0,0 +1,92 @@
+package com.yami.trading.admin.controller.dz;
+
+import com.yami.trading.bean.dz.StockDz;
+import com.yami.trading.common.constants.Constants;
+import com.yami.trading.common.domain.Result;
+import com.yami.trading.service.dz.StockDzService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+
+@RestController
+@CrossOrigin
+@Api(tags = "后台etf大宗订单")
+@RequestMapping("eftDz")
+@Slf4j
+public class AdminETFDzController {
+
+ @Resource
+ StockDzService stockDzService;
+
+ @ApiOperation("获取etf列表")
+ @PostMapping({"getDzListByAdmin.do"})
+ public Result getDzListByAdmin(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
+ @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
+ @RequestParam(value = "keywords", required = false)String keywords) {
+ return stockDzService.getDzListByAdmin(pageNum, pageSize, keywords, Constants.indices);
+ }
+
+ /**
+ * @Description: 新增大宗
+ * @Param:
+ * @return:
+ */
+ @ApiOperation("新增大宗")
+ @PostMapping({"addByAdmin.do"})
+ public Result addByAdmin(@RequestParam(value = "stockCode") String stockCode,
+ @RequestParam(value = "stockNum") String stockNum,
+ @RequestParam(value = "password", required = false) String password,
+ @RequestParam(value = "startTime") String startTime,
+ @RequestParam(value = "endTime") String endTime,
+ @RequestParam(value = "discount", required = false) String discount,
+ @RequestParam(value = "period") Integer period,
+ @RequestParam(value = "nowPrice") String nowPrice,
+ @RequestParam(value = "switchType", defaultValue = "0") Integer switchType) {
+ return stockDzService.addByAdmin(stockCode, stockNum, password, startTime, endTime, discount, period,nowPrice,switchType);
+ }
+
+ /**
+ * 删除大宗
+ */
+ @ApiOperation("删除大宗")
+ @PostMapping({"deleteByAdmin.do"})
+ public Result deleteByAdmin(@RequestParam(value = "id") String id) {
+ return stockDzService.deleteByAdmin(id);
+ }
+
+ /**
+ * 修改大宗
+ */
+ @ApiOperation("修改大宗")
+ @PostMapping({"updateByAdmin.do"})
+ public Result updateByAdmin(StockDz model) {
+ return stockDzService.updByAdmin(model);
+ }
+
+
+ @ApiOperation("大宗交易审核列表")
+ @PostMapping({"getDzCheckList.do"})
+ @ResponseBody
+ public Result getDzCheckList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
+ @RequestParam(value = "pageSize", defaultValue = "15") int pageSize,
+ @RequestParam(value = "state", required = false) String state,
+ @RequestParam(value = "stockCode", required = false)String stockCode) {
+ return stockDzService.getDzCheckList(pageNum, pageSize, state, stockCode, Constants.indices);
+ }
+
+ @ApiOperation("大宗审核")
+ @PostMapping({"dzCheck.do"})
+ @ResponseBody
+ public Result check(@RequestParam(value = "id") String id,
+ @RequestParam(value = "checkType") Integer checkType,
+ @RequestParam(value = "orderNum", required = false) Double orderNum) {
+ if(checkType != 2 && (id == null || checkType == null || orderNum == null)){
+ return Result.failed("参数不能为空");
+ }
+ return stockDzService.dzCheck(id, checkType, orderNum);
+ }
+
+}
diff --git a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/loan/internal/LoanServiceImpl.java b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/loan/internal/LoanServiceImpl.java
index d2c2f6c..331b138 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/admin/controller/loan/internal/LoanServiceImpl.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/admin/controller/loan/internal/LoanServiceImpl.java
@@ -358,7 +358,11 @@
}
transferMap.put("repayment", new Object[] {rep,repayments.get(rep)});
- transferMap.put("houseImgs", null==houseImgs?new String[0]:commaPattern.split(houseImgs));
+ String[] imgs = null == houseImgs ? new String[0] : commaPattern.split(houseImgs);
+ for (int i = 0; i < imgs.length; i++) {
+ imgs[i] = Constants.IMAGES_HTTP + imgs[i];
+ }
+ transferMap.put("houseImgs", imgs);
transferMap.put("lendingInstitution", new Object[] {led,order.getLendingName()});
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/RealtimeController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/RealtimeController.java
index 97fae9b..6f19d6d 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/RealtimeController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/RealtimeController.java
@@ -362,6 +362,9 @@
log.error("获取行情接口,realtime is null;币种->{}", item.getSymbol());
}
});
+ if (!list.isEmpty()) {
+ list.sort(Comparator.comparing(QueryRealtimeDTO::getChangeRatio).reversed());
+ }
Result<List<QueryRealtimeDTO>> ok = Result.ok(list);
ok.setTotal((long) itemsTotal.size());
return ok;
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiETFDzController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiETFDzController.java
new file mode 100644
index 0000000..c2bdbd4
--- /dev/null
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiETFDzController.java
@@ -0,0 +1,98 @@
+package com.yami.trading.api.controller.dz;
+
+import com.yami.trading.common.constants.Constants;
+import com.yami.trading.common.domain.Result;
+import com.yami.trading.common.exception.YamiShopBindException;
+import com.yami.trading.security.common.util.SecurityUtils;
+import com.yami.trading.service.dz.StockDzService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+
+@RestController
+@CrossOrigin
+@Api(tags = "etf大宗")
+@RequestMapping("api/etfDz")
+@Slf4j
+public class ApiETFDzController {
+
+ @Resource
+ StockDzService stockDzService;
+
+ private static final ThreadLocal<Boolean> orderCreated = ThreadLocal.withInitial(() -> false);
+ private final Lock lock = new ReentrantLock();
+
+ /**
+ * 大宗交易 列表
+ * @param pageNum
+ * @param pageSize
+ * @param orderBy
+ * @param keyWords 搜索内容
+ * @return
+ */
+ @ApiOperation("大宗交易列表")
+ @PostMapping({"getDzList.do"})
+ @ResponseBody
+ public Result getDzList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
+ @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
+ @RequestParam(value = "orderBy", required = false) String orderBy,
+ @RequestParam(value = "keyWords", required = false) String keyWords) {
+ return stockDzService.getDzList(pageNum, pageSize, orderBy,keyWords, Constants.indices);
+ }
+
+
+
+ @ApiOperation("大宗下单")
+ @GetMapping({"buyStockDz.do"})
+ @ResponseBody
+ public Result buyDz(@RequestParam("dzId") String dzId,
+ @RequestParam(value = "password", required = false) String password,
+ @RequestParam("num") double num) {
+ lock.lock();
+ try {
+ if (orderCreated.get()) {
+ throw new YamiShopBindException("当前交易人数过多,请稍后重试");
+ }
+ orderCreated.set(true);
+ String partyId = SecurityUtils.getCurrentUserId();
+ if (partyId == null || partyId.isEmpty()) {
+ throw new YamiShopBindException("请先登录");
+ }
+ return stockDzService.buyDz(dzId, password, num, partyId);
+ } catch (Exception e) {
+ log.error(e.getMessage());
+ } finally{
+ lock.unlock();
+ orderCreated.set(false);
+ }
+ throw new YamiShopBindException("订单异常,请稍后重试");
+ }
+
+
+
+
+ /**
+ * 大宗交易订单列表
+ * @param pageNum
+ * @param pageSize
+ * @param state
+ * @return
+ */
+ @ApiOperation("大宗交易订单列表")
+ @PostMapping({"getDzOrderList.do"})
+ @ResponseBody
+ public Result getDzOrderList(@RequestParam(value = "pageNum", defaultValue = "1") int pageNum,
+ @RequestParam(value = "pageSize", defaultValue = "5") int pageSize,
+ @RequestParam(value = "state", required = false) String state) {
+ String partyId = SecurityUtils.getCurrentUserId();
+ if (partyId == null || partyId.isEmpty()) {
+ throw new YamiShopBindException("请先登录");
+ }
+ return stockDzService.getDzOrderList(pageNum, pageSize, state, partyId, Constants.indices);
+ }
+}
diff --git a/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
index 1d4bf39..b5de259 100644
--- a/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
+++ b/trading-order-admin/src/main/java/com/yami/trading/api/controller/dz/ApiStockDzController.java
@@ -47,9 +47,7 @@
}
- /**
- * 大宗下单
- */
+ @ApiOperation("大宗下单")
@GetMapping({"buyStockDz.do"})
@ResponseBody
public Result buyDz(@RequestParam("dzId") String dzId,
diff --git a/trading-order-admin/src/main/resources/application-dev.yml b/trading-order-admin/src/main/resources/application-dev.yml
index cfe1ac7..8dee311 100644
--- a/trading-order-admin/src/main/resources/application-dev.yml
+++ b/trading-order-admin/src/main/resources/application-dev.yml
@@ -114,10 +114,10 @@
http.server.host: http://localhost:8080/images/
admin_rest_url: https://enjdhdg.site/api
-images.dir: /mydata/img/
+images.dir: /www/wwwroot/alljys/img
admin_url: https://localhost:8080/admin
web_url: http://localhost:8080/wap/
-images_http: https://syimg.yanshiz.com/
+images_http: https://allimg.yanshiz.com/
email:
host: smtp.gmail.com
username: coinzne.com@gmail.com
diff --git a/trading-order-service/src/main/java/com/yami/trading/service/impl/AwsS3OSSFileServiceImpl.java b/trading-order-service/src/main/java/com/yami/trading/service/impl/AwsS3OSSFileServiceImpl.java
index 866d313..13a4935 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/impl/AwsS3OSSFileServiceImpl.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/impl/AwsS3OSSFileServiceImpl.java
@@ -2,6 +2,7 @@
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson2.JSONObject;
+import com.yami.trading.common.constants.Constants;
import com.yami.trading.common.exception.BusinessException;
import com.yami.trading.common.exception.YamiShopBindException;
import com.yami.trading.service.AwsS3OSSFileService;
@@ -174,7 +175,7 @@
String path = filename; // 直接使用文件名作为路径
// 确保目标文件夹存在
- File targetDir = new File(imgDir);
+ File targetDir = new File(Constants.IMAGES_DIR);
if (!targetDir.exists()) {
targetDir.mkdirs();
// 设置目录权限为755 (rwxr-xr-x)
--
Gitblit v1.9.3