From d8fb82111f08f7f3be1d9cff9e7a11dfc120ad77 Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Mon, 27 Sep 2021 19:06:20 +0800 Subject: [PATCH] fix alipay callback --- src/main/java/cc/mrbird/febs/pay/service/impl/PayServiceImpl.java | 40 ++++++++++++++++++++++++++++++++++++++++ 1 files changed, 40 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/pay/service/impl/PayServiceImpl.java b/src/main/java/cc/mrbird/febs/pay/service/impl/PayServiceImpl.java index e940f38..68d7505 100644 --- a/src/main/java/cc/mrbird/febs/pay/service/impl/PayServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/pay/service/impl/PayServiceImpl.java @@ -1,20 +1,30 @@ package cc.mrbird.febs.pay.service.impl; +import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum; +import cc.mrbird.febs.common.enumerates.OrderStatusEnum; import cc.mrbird.febs.common.exception.FebsException; import cc.mrbird.febs.mall.entity.MallOrderInfo; +import cc.mrbird.febs.mall.mapper.MallOrderInfoMapper; +import cc.mrbird.febs.mall.service.IApiMallMemberService; +import cc.mrbird.febs.mall.service.IApiMallOrderInfoService; import cc.mrbird.febs.pay.model.AliPayPassbackModel; import cc.mrbird.febs.pay.properties.AliPayProperties; import cc.mrbird.febs.pay.service.IPayService; +import cc.mrbird.febs.rabbit.producter.AgentProducer; +import cn.hutool.core.util.StrUtil; import com.alibaba.fastjson.JSONObject; import com.alipay.api.AlipayApiException; import com.alipay.api.domain.AlipayTradeAppPayModel; import com.alipay.api.response.AlipayTradeAppPayResponse; import com.ijpay.alipay.AliPayApi; import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import javax.annotation.Resource; +import java.util.Date; +import java.util.Map; /** * @author wzy @@ -26,6 +36,13 @@ @Resource private AliPayProperties aliPayProperties; + + @Autowired + private IApiMallMemberService memberService; + @Autowired + private MallOrderInfoMapper orderInfoMapper; + @Autowired + private AgentProducer agentProducer; @Value("${spring.profiles.active}") private String active; @@ -59,4 +76,27 @@ } return resp.getBody(); } + + @Override + public void aliCallback(Map<String, String> params) { + String modelStr = params.get("passback_params"); + + AliPayPassbackModel passback = JSONObject.parseObject(modelStr, AliPayPassbackModel.class); + + MallOrderInfo orderInfo = orderInfoMapper.selectById(passback.getOrderId()); + if ("1".equals(orderInfo.getPayResult())) { + return; + } + + orderInfo.setStatus(OrderStatusEnum.WAIT_SHIPPING.getValue()); + orderInfo.setPayResult("1"); + orderInfo.setPayTime(new Date()); + orderInfo.setPayTradeNo(params.get("trade_no")); + orderInfoMapper.updateById(orderInfo); + + agentProducer.sendReturnMoneyMsg(orderInfo.getId()); + agentProducer.sendAutoLevelUpMsg(orderInfo.getMemberId()); + + memberService.addMoneyFlow(orderInfo.getMemberId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), null, null, null, null); + } } -- Gitblit v1.9.1