|
@@ -1,12 +1,15 @@
|
|
|
package cn.iocoder.yudao.module.pay.controller.app.order;
|
|
|
|
|
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
|
|
+import cn.iocoder.yudao.framework.pay.core.enums.channel.PayChannelEnum;
|
|
|
import cn.iocoder.yudao.module.pay.controller.admin.order.vo.PayOrderRespVO;
|
|
|
import cn.iocoder.yudao.module.pay.controller.admin.order.vo.PayOrderSubmitRespVO;
|
|
|
import cn.iocoder.yudao.module.pay.controller.app.order.vo.AppPayOrderSubmitReqVO;
|
|
|
import cn.iocoder.yudao.module.pay.controller.app.order.vo.AppPayOrderSubmitRespVO;
|
|
|
import cn.iocoder.yudao.module.pay.convert.order.PayOrderConvert;
|
|
|
+import cn.iocoder.yudao.module.pay.framework.pay.core.WalletPayClient;
|
|
|
import cn.iocoder.yudao.module.pay.service.order.PayOrderService;
|
|
|
+import com.google.common.collect.Maps;
|
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
@@ -16,8 +19,13 @@ import org.springframework.web.bind.annotation.*;
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
|
|
|
|
+import java.util.Map;
|
|
|
+import java.util.Objects;
|
|
|
+
|
|
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
|
|
import static cn.iocoder.yudao.framework.common.util.servlet.ServletUtils.getClientIP;
|
|
|
+import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getLoginUserId;
|
|
|
+import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getLoginUserType;
|
|
|
|
|
|
@Tag(name = "用户 APP - 支付订单")
|
|
|
@RestController
|
|
@@ -40,6 +48,16 @@ public class AppPayOrderController {
|
|
|
@PostMapping("/submit")
|
|
|
@Operation(summary = "提交支付订单")
|
|
|
public CommonResult<AppPayOrderSubmitRespVO> submitPayOrder(@RequestBody AppPayOrderSubmitReqVO reqVO) {
|
|
|
+ // 1. 钱包支付事,需要额外传 user_id 和 user_type
|
|
|
+ if (Objects.equals(reqVO.getChannelCode(), PayChannelEnum.WALLET.getCode())) {
|
|
|
+ Map<String, String> channelExtras = reqVO.getChannelExtras() == null ?
|
|
|
+ Maps.newHashMapWithExpectedSize(2) : reqVO.getChannelExtras();
|
|
|
+ channelExtras.put(WalletPayClient.USER_ID_KEY, String.valueOf(getLoginUserId()));
|
|
|
+ channelExtras.put(WalletPayClient.USER_TYPE_KEY, String.valueOf(getLoginUserType()));
|
|
|
+ reqVO.setChannelExtras(channelExtras);
|
|
|
+ }
|
|
|
+
|
|
|
+ // 2. 提交支付
|
|
|
PayOrderSubmitRespVO respVO = payOrderService.submitOrder(reqVO, getClientIP());
|
|
|
return success(PayOrderConvert.INSTANCE.convert3(respVO));
|
|
|
}
|