From 36be00e0f3cbe0d559c646fd2977e6e3a74aa6f9 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 30 Sep 2024 16:57:22 +0800
Subject: [PATCH] Merge branch 'bea' of http://120.27.238.55:7000/r/exchange into bea

---
 src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcEntrustOrderServiceImpl.java |    9 +++++----
 1 files changed, 5 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcEntrustOrderServiceImpl.java b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcEntrustOrderServiceImpl.java
index 684578f..c335ebd 100644
--- a/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcEntrustOrderServiceImpl.java
+++ b/src/main/java/com/xcong/excoin/modules/otc/service/impl/OtcEntrustOrderServiceImpl.java
@@ -110,7 +110,6 @@
     public void modify(EntrustOrderAddDto modifyDto) {
         MemberEntity member = LoginUserUtils.getAppLoginUser();
         OtcEntrustOrder otcEntrustOrder = OtcEntrustOrderMapper.INSTANCE.entrustOrderDtoToEntity(modifyDto);
-        BigDecimal remainAmount = otcEntrustOrder.getRemainCoinAmount();
         otcEntrustOrder.setMemberId(member.getId());
 
         otcEntrustOrder.setRemainCoinAmount(modifyDto.getAmount());
@@ -138,16 +137,18 @@
 
         BigDecimal totalAmount = modifyDto.getUnitPrice().multiply(modifyDto.getAmount());
         otcEntrustOrder.setTotalAmount(totalAmount);
+
+        BigDecimal remainAmount = prevEntity.getRemainCoinAmount();
         if (OtcEntrustOrder.ORDER_TYPE_S.equals(modifyDto.getType())) {
             MemberWalletCoinEntity coinWallet = memberWalletCoinDao.selectWalletCoinBymIdAndCode(member.getId(), "USDT");
             coinWallet.setAvailableBalance(coinWallet.getAvailableBalance().add(remainAmount));
-            if(coinWallet.getAvailableBalance().compareTo(totalAmount) < 0) {
+            if(coinWallet.getAvailableBalance().compareTo(modifyDto.getAmount()) < 0) {
                 throw new GlobalException("可用金额不足");
             }
 
             BigDecimal frozen = coinWallet.getFrozenBalance().subtract(remainAmount);
-            coinWallet.setAvailableBalance(coinWallet.getAvailableBalance().subtract(totalAmount));
-            coinWallet.setFrozenBalance(frozen.add(totalAmount));
+            coinWallet.setAvailableBalance(coinWallet.getAvailableBalance().subtract(modifyDto.getAmount()));
+            coinWallet.setFrozenBalance(frozen.add(modifyDto.getAmount()));
             memberWalletCoinDao.updateById(coinWallet);
         }
 

--
Gitblit v1.9.1