From 4689659b197a13cce2a492bed6c752a39164e1c0 Mon Sep 17 00:00:00 2001
From: 颓废太子 <1098226878@qq.com>
Date: 星期三, 24 十一月 2021 10:25:59 +0800
Subject: [PATCH] 新增优惠券功能

---
 service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java |   48 +++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 41 insertions(+), 7 deletions(-)

diff --git a/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java b/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
index 8cbc7cd..ec3d5e9 100644
--- a/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
+++ b/service-acct/src/main/java/com/java110/acct/cmd/payment/QrCodePaymentCmd.java
@@ -1,17 +1,21 @@
 package com.java110.acct.cmd.payment;
 
 import com.alibaba.fastjson.JSONObject;
-import com.alipay.api.AlipayApiException;
-import com.alipay.api.AlipayClient;
-import com.alipay.api.DefaultAlipayClient;
-import com.alipay.api.domain.AlipayTradeAppPayModel;
-import com.alipay.api.request.AlipayTradeAppPayRequest;
-import com.alipay.api.response.AlipayTradeAppPayResponse;
+import com.java110.acct.smo.IQrCodePaymentSMO;
 import com.java110.core.annotation.Java110Cmd;
 import com.java110.core.context.ICmdDataFlowContext;
 import com.java110.core.event.cmd.AbstractServiceCmdListener;
 import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.CallApiServiceFactory;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.utils.constant.CommonConstant;
 import com.java110.utils.exception.CmdException;
+import com.java110.utils.factory.ApplicationContextFactory;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.StringUtil;
+import com.java110.vo.ResultVo;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
 
 /**
  * 鎵爜浠�
@@ -20,14 +24,44 @@
 public class QrCodePaymentCmd extends AbstractServiceCmdListener {
 
 
+    private IQrCodePaymentSMO qrCodePaymentSMOImpl;
+
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
-
+        Assert.hasKeyAndValue(reqJson, "authCode", "鏈寘鍚巿鏉冪爜");
     }
 
     @Override
     public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+        String orderId = GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_orderId);
+        double receivedAmount = Double.parseDouble(reqJson.getString("receivedAmount"));
+        String authCode = reqJson.getString("authCode");
+        if (StringUtil.isEmpty(authCode) || authCode.length() < 2) {
+            throw new IllegalArgumentException("鎺堟潈鐮侀敊璇�");
+        }
 
+        int pre = Integer.parseInt(authCode.substring(0, 2));
+        if (pre > 24 && pre < 31) { // 鏀粯瀹�
+            qrCodePaymentSMOImpl = ApplicationContextFactory.getBean("qrCodeAliPaymentAdapt", IQrCodePaymentSMO.class);
+        }else{
+            qrCodePaymentSMOImpl = ApplicationContextFactory.getBean("qrCodeWechatPaymentAdapt", IQrCodePaymentSMO.class);
+        }
+
+        ResultVo resultVo = null;
+        try {
+            resultVo = qrCodePaymentSMOImpl.pay(reqJson.getString("communityId"), orderId, receivedAmount, authCode, "");
+        } catch (Exception e) {
+            cmdDataFlowContext.setResponseEntity(ResultVo.error(e.getLocalizedMessage()));
+            return;
+        }
+        if (ResultVo.CODE_OK != resultVo.getCode()) {
+            cmdDataFlowContext.setResponseEntity(ResultVo.error(resultVo.getMsg(),reqJson));
+            return;
+        }
+        String appId = cmdDataFlowContext.getReqHeaders().get(CommonConstant.APP_ID);
+        String userId = cmdDataFlowContext.getReqHeaders().get(CommonConstant.USER_ID);
+        String paramOut = CallApiServiceFactory.postForApi(appId, reqJson.toJSONString(), "fee.payFee", String.class, userId);
+        cmdDataFlowContext.setResponseEntity(new ResponseEntity(paramOut, HttpStatus.OK));
     }
 
 }

--
Gitblit v1.8.0