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;
|
import com.doumee.core.model.PageWrap;
|
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;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.github.binarywang.wxpay.bean.request.WxPayDownloadBillRequest;
|
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.math.BigDecimal;
|
import java.util.*;
|
|
/**
|
* Service实现
|
* @author 江蹄蹄
|
* @date 2023/09/27 18:08
|
*/
|
@Service
|
public class WxBillServiceImpl implements WxBillService {
|
|
@Autowired
|
private WxBillMapper wxBillMapper;
|
@Autowired
|
private WxBillDetailMapper wxBillDetailMapper;
|
@Override
|
public String create(WxBill wxBill) {
|
wxBillMapper.insert(wxBill);
|
return wxBill.getId();
|
}
|
|
@Override
|
public void deleteById(String id) {
|
wxBillMapper.deleteById(id);
|
}
|
|
@Override
|
public void delete(WxBill wxBill) {
|
UpdateWrapper<WxBill> deleteWrapper = new UpdateWrapper<>(wxBill);
|
wxBillMapper.delete(deleteWrapper);
|
}
|
|
@Override
|
public void deleteByIdInBatch(List<String> ids) {
|
if (CollectionUtils.isEmpty(ids)) {
|
return;
|
}
|
wxBillMapper.deleteBatchIds(ids);
|
}
|
|
@Override
|
public void updateById(WxBill wxBill) {
|
wxBillMapper.updateById(wxBill);
|
}
|
|
@Override
|
public void updateByIdInBatch(List<WxBill> wxBills) {
|
if (CollectionUtils.isEmpty(wxBills)) {
|
return;
|
}
|
for (WxBill wxBill: wxBills) {
|
this.updateById(wxBill);
|
}
|
}
|
|
@Override
|
public WxBill findById(String id) {
|
return wxBillMapper.selectById(id);
|
}
|
|
@Override
|
public WxBill findOne(WxBill wxBill) {
|
QueryWrapper<WxBill> wrapper = new QueryWrapper<>(wxBill);
|
return wxBillMapper.selectOne(wrapper);
|
}
|
|
@Override
|
public List<WxBill> findList(WxBill wxBill) {
|
QueryWrapper<WxBill> wrapper = new QueryWrapper<>(wxBill);
|
return wxBillMapper.selectList(wrapper);
|
}
|
|
@Override
|
public PageData<WxBill> findPage(PageWrap<WxBill> pageWrap) {
|
IPage<WxBill> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
|
QueryWrapper<WxBill> queryWrapper = new QueryWrapper<>();
|
Utils.MP.blankToNull(pageWrap.getModel());
|
if (pageWrap.getModel().getId() != null) {
|
queryWrapper.lambda().eq(WxBill::getId, pageWrap.getModel().getId());
|
}
|
if (pageWrap.getModel().getSumBill() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumBill, pageWrap.getModel().getSumBill());
|
}
|
if (pageWrap.getModel().getSumRefundBill() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumRefundBill, pageWrap.getModel().getSumRefundBill());
|
}
|
if (pageWrap.getModel().getSumSuccessFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumSuccessFee, pageWrap.getModel().getSumSuccessFee());
|
}
|
if (pageWrap.getModel().getSumRefundFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumRefundFee, pageWrap.getModel().getSumRefundFee());
|
}
|
if (pageWrap.getModel().getSumCouponRefundFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumCouponRefundFee, pageWrap.getModel().getSumCouponRefundFee());
|
}
|
if (pageWrap.getModel().getSumCmmsAmt() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumCmmsAmt, pageWrap.getModel().getSumCmmsAmt());
|
}
|
if (pageWrap.getModel().getSumTotalFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumTotalFee, pageWrap.getModel().getSumTotalFee());
|
}
|
if (pageWrap.getModel().getSumApplyRefundFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumApplyRefundFee, pageWrap.getModel().getSumApplyRefundFee());
|
}
|
if (pageWrap.getModel().getSumRefundCmmsAmt() != null) {
|
queryWrapper.lambda().eq(WxBill::getSumRefundCmmsAmt, pageWrap.getModel().getSumRefundCmmsAmt());
|
}
|
if (pageWrap.getModel().getTotal() != null) {
|
queryWrapper.lambda().eq(WxBill::getTotal, pageWrap.getModel().getTotal());
|
}
|
if (pageWrap.getModel().getBikeFee() != null) {
|
queryWrapper.lambda().eq(WxBill::getBikeFee, pageWrap.getModel().getBikeFee());
|
}
|
for(PageWrap.SortData sortData: pageWrap.getSorts()) {
|
if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
|
queryWrapper.orderByDesc(sortData.getProperty());
|
} else {
|
queryWrapper.orderByAsc(sortData.getProperty());
|
}
|
}
|
return PageData.from(wxBillMapper.selectPage(page, queryWrapper));
|
}
|
|
@Override
|
public long count(WxBill wxBill) {
|
QueryWrapper<WxBill> wrapper = new QueryWrapper<>(wxBill);
|
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 {
|
response = WxMiniConfig.wxPayService.downloadBill(request);
|
}catch (WxPayException e){
|
|
}
|
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()));//代金券金额
|
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));
|
}
|
}
|