From 9e3c6fa190b1c59b2178ae1823c994684a4d9df3 Mon Sep 17 00:00:00 2001 From: cloudroam <cloudroam> Date: 星期四, 24 十月 2024 14:20:03 +0800 Subject: [PATCH] fix:结算 --- src/main/java/com/mzl/flower/service/impl/wallet/WalletBillRecordServiceImpl.java | 59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 54 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/mzl/flower/service/impl/wallet/WalletBillRecordServiceImpl.java b/src/main/java/com/mzl/flower/service/impl/wallet/WalletBillRecordServiceImpl.java index 13ffa86..b8ab819 100644 --- a/src/main/java/com/mzl/flower/service/impl/wallet/WalletBillRecordServiceImpl.java +++ b/src/main/java/com/mzl/flower/service/impl/wallet/WalletBillRecordServiceImpl.java @@ -1,19 +1,22 @@ package com.mzl.flower.service.impl.wallet; -import com.mzl.flower.config.exception.ValidationException; -import com.mzl.flower.config.security.SecurityUtils; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.mzl.flower.constant.Constants; import com.mzl.flower.dto.request.wallet.CreateWalletBillRecordDTO; -import com.mzl.flower.dto.response.supplier.SupplierDTO; +import com.mzl.flower.entity.payment.Transfer; +import com.mzl.flower.entity.payment.TransferDetail; import com.mzl.flower.entity.wallet.WalletBillRecordDO; import com.mzl.flower.entity.wallet.WalletDO; +import com.mzl.flower.mapper.payment.TransferDetailMapper; +import com.mzl.flower.mapper.payment.TransferMapper; import com.mzl.flower.mapper.wallet.WalletBillRecordMapper; -import com.mzl.flower.service.supplier.SupplierService; import com.mzl.flower.service.wallet.WalletBillRecordService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.mzl.flower.service.wallet.WalletService; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.util.ObjectUtils; + +import javax.annotation.Resource; /** * <p> @@ -26,10 +29,56 @@ @Service public class WalletBillRecordServiceImpl extends ServiceImpl<WalletBillRecordMapper, WalletBillRecordDO> implements WalletBillRecordService { + @Resource + private TransferMapper transferMapper; + + @Resource + private TransferDetailMapper transferDetailMapper; + + @Resource + private WalletBillRecordMapper walletBillRecordMapper; + + @Resource + private WalletService walletService; @Override public void create(CreateWalletBillRecordDTO dto) { } + + public void updateTransferStatus(String transferId) { + Transfer t = transferMapper.selectById(transferId); + if ("FINISHED".equals(t.getStatus())) { + WalletBillRecordDO walletBillRecordDO = walletBillRecordMapper.selectOne(new QueryWrapper<WalletBillRecordDO>().eq("transfer_id", transferId)); + if (walletBillRecordDO == null) { + return; + } + String transferDetailId = walletBillRecordDO.getTransferDetailId(); + TransferDetail td = transferDetailMapper.selectById(transferDetailId); + if (td == null) { + log.warn("未找到对应明细"); + return; + } + String dStatus = td.getStatus(); + if ("SUCCESS".equals(dStatus)) { + walletBillRecordDO.setTransferState(Constants.SETTLEMENT_STATUS.COMPLETED.name()); + walletBillRecordDO.update("sys"); + walletBillRecordMapper.updateById(walletBillRecordDO); + //更新钱包 + WalletDO walletDO = walletService.getBySupplierId(walletBillRecordDO.getWalletId()); + if(!ObjectUtils.isEmpty(walletDO)){ + //体现中金额 + walletDO.setWithdrawingAmount(walletDO.getWithdrawingAmount().subtract(walletBillRecordDO.getChangeAmount())); + //已提现金额 + walletDO.setWithdrawnAmount(walletDO.getWithdrawnAmount().add(walletBillRecordDO.getChangeAmount())); + } + + } else if ("FAIL".equals(dStatus)) { + walletBillRecordDO.setTransferState(Constants.SETTLEMENT_STATUS.FAILED.name()); + walletBillRecordDO.update("sys"); + walletBillRecordMapper.updateById(walletBillRecordDO); + } + } + } } -- Gitblit v1.9.3