From 51338b0baa2c81175c923fc537a80ba52cfa7d8e Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Thu, 01 Sep 2022 17:13:31 +0800 Subject: [PATCH] 20220822 --- src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 52 +++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 39 insertions(+), 13 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java index bd4bd3b..bed6f12 100644 --- a/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java @@ -5,19 +5,11 @@ import cc.mrbird.febs.common.enumerates.FlowTypeEnum; import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; import cc.mrbird.febs.common.properties.XcxProperties; -import cc.mrbird.febs.common.utils.MallUtils; -import cc.mrbird.febs.common.utils.OssUtils; -import cc.mrbird.febs.common.utils.RedisUtils; -import cc.mrbird.febs.common.utils.SpringContextHolder; +import cc.mrbird.febs.common.utils.*; import cc.mrbird.febs.mall.dto.ApiRechargeWalletDto; import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto; -import cc.mrbird.febs.mall.entity.DataDictionaryCustom; -import cc.mrbird.febs.mall.entity.MallMember; -import cc.mrbird.febs.mall.entity.MallOrderInfo; -import cc.mrbird.febs.mall.entity.MallOrderItem; -import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper; -import cc.mrbird.febs.mall.mapper.MallMemberMapper; -import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper; +import cc.mrbird.febs.mall.entity.*; +import cc.mrbird.febs.mall.mapper.*; import cc.mrbird.febs.mall.service.IMallMoneyFlowService; import cc.mrbird.febs.mall.vo.RechargeWalletMessageSendVo; import cc.mrbird.febs.pay.model.*; @@ -26,6 +18,7 @@ import cc.mrbird.febs.pay.util.WeixinServiceUtil; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.IdUtil; +import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.json.JSONObject; import cn.hutool.json.JSONUtil; @@ -61,6 +54,10 @@ WeixinServiceUtil weixinServiceUtil; @Autowired private DataDictionaryCustomMapper dataDictionaryCustomMapper; + @Autowired + private MallMoneyFlowMapper mallMoneyFlowMapper; + @Autowired + private MallMemberWithdrawMapper mallMemberWithdrawMapper; private final IMallMoneyFlowService mallMoneyFlowService; @Autowired RedisUtils redisUtils; @@ -76,7 +73,7 @@ BrandWCPayRequestData payData; String productNames = "小程序充值"; MallMember mallMember = mallMemberMapper.selectById(apiRechargeWalletDto.getMemberId()); - String rechargeNo = "CZ_"+MallUtils.getOrderNum(); + String rechargeNo = "CZ."+MallUtils.getOrderNum(); Boolean debug = xcxProperties.getDebug(); String attrStr = "{'rechargeNo':"+rechargeNo+",'memberId':"+mallMember.getId()+"}"; if (debug) { @@ -91,7 +88,8 @@ money, MoneyFlowTypeEnum.RECHARGE.getValue(), rechargeNo, - FlowTypeEnum.BALANCE.getValue()); + FlowTypeEnum.BALANCE.getValue(), + "余额充值",1); return payData; } @@ -118,6 +116,34 @@ } @Override + public Boolean memberWithdrawal(MemberWithdrawalDto info) { + boolean flag=false; + BigDecimal unit = new BigDecimal("100"); + BigDecimal money = new BigDecimal(info.getTotalFee().toString()); + String outTradeNo = info.getOutTradeNo(); + String openid = info.getOpenid(); + String desc = info.getDesc(); + + MallMember mallMember = mallMemberMapper.selectMemberByOpenId(openid); + if(ObjectUtil.isEmpty(mallMember)){ + return flag; + } + MallMemberWithdraw mallMemberWithdraw = mallMemberWithdrawMapper.selectByWithDrawNoAndMemberIdAndState(outTradeNo,mallMember.getId(),1); + if(ObjectUtil.isEmpty(mallMemberWithdraw)){ + return flag; + } + Boolean debug = xcxProperties.getDebug(); + if (debug) { + flag = weixinServiceUtil.comPay("[测试]" + desc, outTradeNo, + 1, openid); + } else { + flag = weixinServiceUtil.comPay(desc, outTradeNo, + unit.multiply(money).intValue(),openid); + } + return flag; + } + + @Override public BrandWCPayRequestData startPayment(MallOrderInfo mallOrderInfo) throws Exception { BigDecimal unit = new BigDecimal("100"); BigDecimal money = new BigDecimal(mallOrderInfo.getAmount().toString()); -- Gitblit v1.9.1