新版仿ok交易所-后端
1
zj
yesterday 640ccb9229224642515527daf87f308a7aa9bdf4
trading-order-service/src/main/java/com/yami/trading/service/impl/WalletServiceImpl.java
@@ -145,7 +145,7 @@
        log.info("=============111111===>"+walletType);
        walletExtend.setAmount(Arith.add(walletExtend.getAmount(), amount));
        if (!walletExtendService.updateById(walletExtend)) {
            throw new YamiShopBindException("操作钱包失败!");
            throw new YamiShopBindException("Wallet operation failed!");
        }
        redisTemplate.opsForValue().set(WalletRedisKeys.WALLET_EXTEND_PARTY_ID + partyId.toString() + walletType, walletExtend);
@@ -180,12 +180,12 @@
        wallet.setMoney(wallet.getMoney().add(money));
        if(wallet.getMoney().compareTo(BigDecimal.ZERO) < 0){
            wallet.setMoney(BigDecimal.ZERO);
            throw new YamiShopBindException("Insufficient balance");
        }
        wallet.setUpdateTime(now);
        if (wallet.getMoney().doubleValue() <= 0) {
            throw new YamiShopBindException("余额不足");
        }
        /*if (wallet.getMoney().doubleValue() < 0) {
            throw new YamiShopBindException("Insufficient balance");
        }*/
        updateById(wallet);
        // 账变日志
        MoneyLog moneyLog = new MoneyLog();
@@ -297,7 +297,7 @@
            close = realtimes.get(0).getClose().doubleValue();
        } else {
            close = 0;
            //throw new YamiShopBindException("参数错误");
            //throw new YamiShopBindException("Invalid parameters");
        }
        return close;
    }
@@ -751,11 +751,41 @@
        Wallet wallet = findByUserId(userId);
        wallet.setMoney(new BigDecimal(Arith.add(wallet.getMoney().doubleValue(), amount)));
        if (!updateById(wallet)) {
            throw new YamiShopBindException("操作钱包失败!");
            throw new YamiShopBindException("Wallet operation failed!");
        }
    }
    @Override
    public Wallet updateToBeCovered(Wallet wallet, BigDecimal amount, Integer type) {
        amount = amount.abs();
        if (type == 1) {  //入款
            if(wallet.getAmountToBeCovered().compareTo(BigDecimal.ZERO) > 0){
                BigDecimal availableBalance = amount.subtract(wallet.getAmountToBeCovered());
                if(availableBalance.compareTo(BigDecimal.ZERO) >= 0){
                    wallet.setMoney(wallet.getMoney().add(availableBalance));
                    wallet.setAmountToBeCovered(BigDecimal.ZERO);
                }else {
                    wallet.setAmountToBeCovered(availableBalance.abs());
                }
            } else {
                wallet.setMoney(wallet.getMoney().add(amount));
            }
        } else if (type == 2) { //扣款
            BigDecimal subtract = amount.subtract(wallet.getMoney());
            if (subtract.compareTo(BigDecimal.ZERO) > 0) { //资金不足 放入待补
                wallet.setMoney(BigDecimal.ZERO);
                wallet.setAmountToBeCovered(wallet.getAmountToBeCovered().add(subtract));
            } else {
                wallet.setMoney(subtract.negate());
            }
        }
        if (!updateById(wallet)) {
            throw new YamiShopBindException("Wallet operation failed!");
        }
        return wallet;
    }
    @Override
    public void updateExtendWithLockAndFreeze(String partyId, String walletType, double amount, double lockAmount, double freezeAmount) {