From c6085dd1e5fbbe13eae825dda02819c52227596a Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期六, 07 十月 2023 18:15:58 +0800
Subject: [PATCH] 微信对账

---
 server/services/src/main/java/com/doumee/service/business/impl/WxBillServiceImpl.java |  137 ++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 122 insertions(+), 15 deletions(-)

diff --git a/server/services/src/main/java/com/doumee/service/business/impl/WxBillServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/WxBillServiceImpl.java
index f3856d5..d38bd2d 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/WxBillServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/WxBillServiceImpl.java
@@ -1,5 +1,6 @@
 package com.doumee.service.business.impl;
 
+import com.doumee.core.constants.Constants;
 import com.doumee.core.constants.ResponseStatus;
 import com.doumee.core.exception.BusinessException;
 import com.doumee.core.model.PageData;
@@ -7,8 +8,10 @@
 import com.doumee.core.utils.DateUtil;
 import com.doumee.core.utils.Utils;
 import com.doumee.core.wx.WxMiniConfig;
+import com.doumee.dao.business.WxBillDetailMapper;
 import com.doumee.dao.business.WxBillMapper;
 import com.doumee.dao.business.model.WxBill;
+import com.doumee.dao.business.model.WxBillDetail;
 import com.doumee.service.business.WxBillService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
@@ -18,12 +21,14 @@
 import com.github.binarywang.wxpay.bean.result.WxPayBillInfo;
 import com.github.binarywang.wxpay.bean.result.WxPayBillResult;
 import com.github.binarywang.wxpay.exception.WxPayException;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
 
-import java.util.Date;
-import java.util.List;
+import java.math.BigDecimal;
+import java.util.*;
 
 /**
  * Service瀹炵幇
@@ -35,6 +40,8 @@
 
     @Autowired
     private WxBillMapper wxBillMapper;
+    @Autowired
+    private WxBillDetailMapper wxBillDetailMapper;
     @Override
     public String create(WxBill wxBill) {
         wxBillMapper.insert(wxBill);
@@ -149,22 +156,122 @@
         return wxBillMapper.selectCount(wrapper);
     }
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public void getWxBill() {
+        // 鑾峰彇浜ゆ槗璐﹀崟鏁版嵁
+        WxPayDownloadBillRequest request = new WxPayDownloadBillRequest();
+        String billDate =  DateUtil.beforeDateToStr(1);
+        request.setBillDate(billDate);
+        request.setBillType("SUCCESS");
+        WxPayBillResult response = null;
         try {
-            // 鑾峰彇浜ゆ槗璐﹀崟鏁版嵁
-            WxPayDownloadBillRequest request = new WxPayDownloadBillRequest();
-            String billDate =  DateUtil.beforeDateToStr(1);
-            request.setBillDate(billDate);
-            request.setBillType("ALL");
-            WxPayBillResult response = WxMiniConfig.wxPayService.downloadBill(request);
-            if(response !=null){
-                List<WxPayBillInfo> detailList = response.getBillInfoList();
-            }else{
-                throw  new BusinessException(ResponseStatus.SERVER_ERROR);
-            }
+            response = WxMiniConfig.wxPayService.downloadBill(request);
+        }catch (WxPayException e){
 
-        } catch (WxPayException e) {
-            e.printStackTrace();
         }
+        request.setBillType("REFUND");
+        //璇锋眰閫�娆惧崟浜ゆ槗璁板綍姹囨�绘暟鎹�
+        WxPayBillResult responseRefund = null;
+        try {
+            responseRefund = WxMiniConfig.wxPayService.downloadBill(request);
+        }catch (WxPayException e){
+
+        }
+        WxBill bill = new WxBill();
+        //鏃ユ湡浣滀负涓婚敭
+        bill.setId(billDate);
+        bill.setSumBill(0);
+        bill.setSumTotalFee(new BigDecimal(0.00));
+        bill.setSumSuccessFee(new BigDecimal(0.00));
+        bill.setSumRefundFee(new BigDecimal(0.00));
+        bill.setSumCouponRefundFee(new BigDecimal(0.00));
+        bill.setSumApplyRefundFee(new BigDecimal(0.00));
+        bill.setSumCmmsAmt(new BigDecimal(0.00));
+        bill.setSumRefundBill(0);
+        bill.setSumRefundCmmsAmt(new BigDecimal(0.00));
+        List<WxBillDetail> detailList = new ArrayList<>();
+        if(response !=null){
+//                List<WxPayBillInfo> detailList = response.getBillInfoList();
+            int totalRefund = 0;
+            BigDecimal totalRefundAmt = new BigDecimal(0.00);
+            bill.setSumBill(Integer.parseInt(response.getTotalRecord()));
+            //璁㈠崟鎬婚噾棰�
+            bill.setSumTotalFee(formatStringToDecimal(response.getTotalAmount()));
+            //搴旂粨璁㈠崟鎬婚噾棰�
+            bill.setSumSuccessFee(formatStringToDecimal(response.getTotalFee()));
+            //閫�娆炬�婚噾棰�
+            bill.setSumRefundFee(formatStringToDecimal(response.getTotalFee()));
+            //閫�娆炬�婚噾棰�
+            bill.setSumApplyRefundFee(formatStringToDecimal(response.getTotalAppliedRefundFee()));
+            //浜ゆ槗鎬绘墜缁垂閲戦
+            bill.setSumCmmsAmt(formatStringToDecimal(response.getTotalPoundageFee()));
+            detailList.addAll(getDetialModelByInfo(bill,response.getBillInfoList()));
+        }
+        if(responseRefund != null){
+            //閫�娆惧崟鎬绘暟绱杩涘叆
+//                bill.setSumBill(bill.getSumBill()+(Integer.parseInt(response.getTotalRecord()));
+            bill.setSumRefundBill(Integer.parseInt(responseRefund.getTotalRecord()));//閫�娆剧殑璁㈠崟鏁�
+            bill.setSumRefundCmmsAmt(formatStringToDecimal(responseRefund.getTotalPoundageFee()));//閫�娆炬�绘墜缁垂
+            bill.setSumCouponRefundFee(formatStringToDecimal(responseRefund.getTotalCouponFee()));//閫�娆炬�绘墜缁垂
+            detailList.addAll(getDetialModelByInfo(bill,responseRefund.getBillInfoList()));
+        }
+        wxBillMapper.delete(new UpdateWrapper<WxBill>().lambda().eq( WxBill::getId, bill.getId()));
+        wxBillDetailMapper.delete(new UpdateWrapper<WxBillDetail>().lambda().eq( WxBillDetail::getPid, bill.getId()));
+        wxBillMapper.insert(bill);
+        if(detailList.size()>0){
+            wxBillDetailMapper.insertBatch(detailList);
+        }
+    }
+
+    private  List<WxBillDetail> getDetialModelByInfo(WxBill bill, List<WxPayBillInfo> billInfoList) {
+        List<WxBillDetail> detailList = new ArrayList<>();
+        if(billInfoList!=null){
+            for (int i = 0; i <billInfoList.size(); i++) {
+                WxPayBillInfo info =billInfoList.get(i);
+                WxBillDetail detail = new WxBillDetail();
+                detail.setId(UUID.randomUUID().toString());
+                detail.setPid(bill.getId());
+                detail.setBillDate(DateUtil.getDateFromString2(info.getTradeTime()));//浜ゆ槗鏃堕棿
+                detail.setAppid(info.getAppId());//鍏紬璐﹀彿ID
+                detail.setMchId(info.getMchId());//鍟嗘埛鍙�
+                detail.setSubMchid(info.getSubMchId());//鐗圭害鍟嗘埛鍙�
+                detail.setDeviceInfo(info.getDeviceInfo());//璁惧
+
+                detail.setTransactionId(info.getTransactionId());//寰俊璁㈠崟鍙�
+                detail.setOutTradeNo(info.getOutTradeNo());//鍟嗘埛璁㈠崟鍙�
+                detail.setOpenid(info.getOpenId());//鐢ㄦ埛鏍囪瘑
+                detail.setBillType(info.getTradeType());//浜ゆ槗绫诲瀷
+                detail.setBillStatus(info.getTradeState());//浜ゆ槗鐘舵��
+                detail.setBankType(info.getBankType());//浠樻閾惰
+                detail.setFeeType(info.getFeeType());//璐у竵绉嶇被
+                detail.setSettlementTotalFee(formatStringToDecimal(info.getTotalFee()));//搴旂粨璁㈠崟閲戦
+                detail.setCouponFee(formatStringToDecimal(info.getCouponFee()));//浠i噾鍒搁噾棰�
+                detail.setRefundId(info.getRefundId());//寰俊閫�娆惧崟鍙�
+                detail.setOutRefundNo(info.getOutRefundNo());//鍟嗘埛閫�娆惧崟鍙�
+                detail.setRefundFee(formatStringToDecimal(info.getSettlementRefundFee()));//閫�娆鹃噾棰�
+                detail.setCouponRefundFee(formatStringToDecimal(info.getCouponRefundFee()));//鍏呭�煎埜閫�娆鹃噾棰�
+                detail.setRefundType(info.getRefundChannel());//閫�娆剧被鍨�
+                detail.setRefundSuccessStatus(info.getRefundState());//閫�娆剧姸鎬�
+                detail.setBody(info.getBody());//鍟嗗搧鍚嶇О
+                detail.setAttach(info.getAttach());//鍟嗘埛鏁版嵁鍖�
+                detail.setCmmsAmt(formatStringToDecimal(info.getPoundage()));//鎵嬬画璐�
+                detail.setRate(formatStringToDecimal(info.getPoundageRate().replace("%", "")));//璐圭巼
+                detail.setTotalFee(formatStringToDecimal(info.getTotalAmount()));//璁㈠崟閲戦
+                detail.setApplyRefundFee(formatStringToDecimal(info.getAppliedRefundAmount()));//鐢宠閫�娆鹃噾棰�
+                detail.setRateRemark(info.getFeeRemark());//璐圭巼澶囨敞
+                detail.setRefundSuccessDate(DateUtil.getDateFromString2(info.getRefundSuccessTime()));//鎴愬姛閫�娆炬椂闂�
+                detail.setRefundApplyDate(DateUtil.getDateFromString2(info.getRefundTime())); //鐢宠閫�娆炬椂闂�
+
+                detailList.add(detail);
+            }
+        }
+        return detailList;
+    }
+
+    public static BigDecimal formatStringToDecimal(String str){
+        if(str == null){
+            return  new BigDecimal(0.00);
+        }
+        return new BigDecimal(Double.parseDouble(str));
     }
 }

--
Gitblit v1.9.3