From 29d9b3490f9deca91801be61aeeed9b8d7e432bb Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Thu, 01 Sep 2022 15:53:07 +0800 Subject: [PATCH] 20220822 --- src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java | 2 src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java | 18 +++++++++ src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java | 7 +++ src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml | 8 ++++ src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java | 3 + src/main/java/cc/mrbird/febs/pay/service/impl/XcxPayServiceImpl.java | 47 ++++++++++++++++++----- src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java | 4 ++ 7 files changed, 76 insertions(+), 13 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java index f412625..3315613 100644 --- a/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java +++ b/src/main/java/cc/mrbird/febs/common/enumerates/MoneyFlowTypeEnum.java @@ -96,7 +96,7 @@ RECHARGE(18), /** - * 团长提成 + * 团长提成(收益) */ LEADERACHIEVE(19); diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java index 32cd998..84b0761 100644 --- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java +++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberWithdrawMapper.java @@ -2,6 +2,10 @@ import cc.mrbird.febs.mall.entity.MallMemberWithdraw; import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import org.apache.ibatis.annotations.Param; public interface MallMemberWithdrawMapper extends BaseMapper<MallMemberWithdraw> { + + MallMemberWithdraw selectByWithDrawNoAndMemberIdAndState(@Param("withdrawNo")String withdrawNo, @Param("memberId")Long id, @Param("status")Integer i); + } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java index ccdde6e..917b67b 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java @@ -295,7 +295,7 @@ wxResultStr = JSONUtil.toJsonStr(brandWCPayRequestData); payResultStr = brandWCPayRequestData.getPrepay_id(); orderInfo.setPayMethod("微信支付"); - agentProducer.sendOrderReturn(orderInfo.getId()); +// agentProducer.sendOrderReturn(orderInfo.getId()); break; case "2": if (StrUtil.isNotBlank(orderInfo.getPayOrderNo())) { @@ -316,6 +316,7 @@ orderInfo.setStatus(OrderStatusEnum.WAIT_SHIPPING.getValue()); orderInfo.setPayTime(new Date()); orderInfo.setPayResult("1"); + orderInfo.setDeliveryState(OrderDeliveryStateEnum.DELIVERY_WAIT.getValue()); // boolean hasTc = false; // // 静态倍数 diff --git a/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java b/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java new file mode 100644 index 0000000..c3e7fec --- /dev/null +++ b/src/main/java/cc/mrbird/febs/pay/model/MemberWithdrawalDto.java @@ -0,0 +1,18 @@ +package cc.mrbird.febs.pay.model; + +import lombok.Data; + +import java.math.BigDecimal; + +@Data +public class MemberWithdrawalDto { + //描述 + private String desc; + //提现申请编号 + private String outTradeNo; + //提现金额(分) + private BigDecimal totalFee; + + private String openid; + +} diff --git a/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java b/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java index f433b50..3c9a015 100644 --- a/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java +++ b/src/main/java/cc/mrbird/febs/pay/service/IXcxPayService.java @@ -5,6 +5,7 @@ import cc.mrbird.febs.mall.dto.RechargeWalletMessageSendDto; import cc.mrbird.febs.mall.entity.MallOrderInfo; import cc.mrbird.febs.pay.model.BrandWCPayRequestData; +import cc.mrbird.febs.pay.model.MemberWithdrawalDto; import cc.mrbird.febs.pay.model.OrderStateDto; import cc.mrbird.febs.pay.model.WxGenerateQrCodeDto; @@ -44,4 +45,10 @@ * 充值到账消息 */ void rechargeWalletMessageSend(RechargeWalletMessageSendDto info); + + + /** + * 用户提现到零钱 + */ + Boolean memberWithdrawal(MemberWithdrawalDto info); } 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 1d6ec95..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; @@ -119,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()); diff --git a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml index 69b88ee..8905ec8 100644 --- a/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml +++ b/src/main/resources/mapper/modules/MallMemberWithdrawMapper.xml @@ -2,4 +2,12 @@ <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="cc.mrbird.febs.mall.mapper.MallMemberWithdrawMapper"> + <select id="selectByWithDrawNoAndMemberIdAndState" resultType="cc.mrbird.febs.mall.entity.MallMemberWithdraw"> + select a.* + from mall_member_withdraw a + where a.withdraw_no = #{withdrawNo} + and a.member_id = #{memberId} + and a.status = #{status} + </select> + </mapper> \ No newline at end of file -- Gitblit v1.9.1