9433cfb9创建于 2025年12月31日历史提交
'use strict';
/**
 * 此处建议只改下订单状态,保证能及时返回给第三方支付服务器成功状态
 * 限制4秒内必须执行完全部的异步回调逻辑,建议将消息发送、返佣、业绩结算等业务逻辑异步处理(如用定时任务去处理这些异步逻辑)
 * 建议再判断下金额和你业务系统订单中的金额是否一致
 */

const payCrypto = require('../libs/crypto.js'); // 获取加密服务

module.exports = async (obj) => {
	let user_order_success = true;
	let { data = {} } = obj;
	let {
		order_no,
		out_trade_no,
		total_fee
	} = data; // uni-pay-orders 表内的数据均可获取到
	
	console.log("type:test");
	
	// 此处写你自己的支付成功逻辑开始-----------------------------------------------------------
	// 有三种方式
	// 方式一:直接写数据库操作
	// 方式二:使用 await uniCloud.callFunction 调用其他云函数或云对象,云对象则使用 uniCloud.importObject('云对象名称')来请求
	// 方式三:使用 await uniCloud.httpclient.request 调用http接口地址


	/* 
	// 方式二安全模式一(加密)
	let encrypted = payCrypto.aes.encrypt({
		data: data, // 待加密的原文
	});
	await uniCloud.callFunction({
		name: "你的云函数名称",
		data: {
			encrypted, // 传输加密数据
		},
	});
	*/


	/* 
	// 方式二安全模式二(只传一个订单号 out_trade_no,你自己的回调里查数据库表  uni-pay-orders 判断 status是否等于1来判断是否真的支付了)
	await uniCloud.callFunction({
		name: "你的云函数名称",
		data: {
			out_trade_no, // 支付插件订单号
		},
	});
 */


	/* 
	// 方式三安全模式一(加密)
	let encrypted = payCrypto.aes.encrypt({
		data: data, // 待加密的原文
	});
	await uniCloud.httpclient.request("你的服务器接口请求地址", {
		method: "POST",
		data: {
			encrypted, // 传输加密数据
		},
	});
 */


	/* 
	// 方式三安全模式二(只传一个订单号 out_trade_no,你自己的回调里执行url请求来请求 uni-pay-co 云对象的 getOrder 接口来判断订单是否真的支付了)
	await uniCloud.httpclient.request("你的服务器接口请求地址", {
		method: "POST",
		data: {
			out_trade_no, // 支付插件订单号
		},
	});
 */


	// 此处写你自己的支付成功逻辑结束-----------------------------------------------------------
	// user_order_success =  true 代表你自己的逻辑处理成功 返回 false 代表你自己的处理逻辑失败。
	return user_order_success;
};