# service/pay/createPayment.js
'use strict';
const vkPay = require("vk-uni-pay");
module.exports = {
/**
* 统一支付
* @url pay/createPayment 前端调用的url参数地址
* @param {String} provider 供应商:wxpay、alipay
* @param {String} openid 用户openid,小程序支付时必传
* @param {String} out_trade_no 商户支付订单号
* @param {Number} total_fee 订单金额(单位分 100 = 1元)
* @param {String} subject 订单标题
* @param {String} body 订单详情
* @param {String} type 必填,如recharge(充值订单)、goods(商品订单)、vip(会员订单)等。
* res 返回参数说明
* @param {Number} code 错误码,0表示成功
* @param {String} msg 详细信息
* @param {String} out_trade_no 商户支付订单号
* @param {String} orderInfo 支付订单信息
*/
main: async (event) => {
let { data = {}, originalParam, uniIdToken } = event;
let res = { code: 0, msg: '' };
/**
* 实际项目支付的时候,应该先下单(先执行你系统的下单逻辑)
* 你系统订单下单成功后,返回订单号,再调用await vkPay.createPayment接口,
* 商品订单中,await vkPay.createPayment 内的金额应该从你系统的订单表中获取,而不是前端传过来)
* 当然如果充值余额,则金额是从前端传过来的。
*/
// 这里示例是给充值余额的订单,故金额是从前端传过来的
// 尝试解析下 uniIdToken,如果能拿到user_id,则传给支付接口(主要用作记录用,做支付统计时会用到)
let user_id = await vkPay.checkTokenReturnUserId({ uniIdToken, context: originalParam.context });
let nickname = await vkPay.getUserNickname(user_id);
// 获取支付参数开始-----------------------------------------------------------
res = await vkPay.createPayment({
context: originalParam.context,
provider: data.provider,
alipayAppPayToH5Pay: data.alipayAppPayToH5Pay,
isPC: data.isPC,
data: {
openid: data.openid, // 用户的openid
out_trade_no: data.out_trade_no, // 商户支付订单号,需自行保证全局唯一(必填)
total_fee: Number(data.total_fee), // 订单金额(单位分 100 = 1元)(必填)
subject: data.subject, // 订单标题(必填)
body: data.body, // 订单内容(选填)
type: data.type, // 此处type的值如果是goods,则回调时就会执行 pay-notify 目录下的 goods.js 内的逻辑(必填)
user_id: user_id, // 用户id(选填)
nickname: nickname, // 用户昵称(选填)
profit_sharing: data.profit_sharing, // 若为true,则本单资金会冻结(以便后面发起分账请求),默认false
// 自定义回调数据,回调函数中通过 let { out_trade_no, user_id, recharge_balance } = data;方式获取(不可与data内的一级属性名重复)
custom: {
// custom1: data.custom.custom1,
// custom2: data.custom.custom2
},
// 微信、支付宝文档上的其他选填参数(other内的参数会原样发送给微信、支付宝)
other: {
}
}
});
// 获取支付参数结束-----------------------------------------------------------
return res;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64