node.js - 节点 JS 函数未执行。可能是什么原因?
问题描述
我想使用 Firebase Cloud Functions 捕获付款并立即在付款上创建转帐。捕获正确进行,但未执行传输。可能是什么原因?
参考文档:https ://github.com/razorpay/razorpay-node/blob/master/examples/index.js
以下是我的 Firebase Cloud Function 的源代码:
exports.CapturePayment = functions.database.ref('payment_id').onWrite((event) => {
const payment_id = event.data.val();
// Capture a particular payment
rzp.payments.capture(payment_id, 100000).then((data) => {
return event.data.ref.child('status').set(data);
console.log(data);
// Create transfers on a payment
rzp.payments.transfer(payment_id, {
transfers: [
{
account: 'acc_aldsfkas123123adsf',
amount: 100,
currency: 'INR'
}
]
}).then((data) => {
var db = admin.database();
var ref = db.ref("transfer");
return ref.update("Success");
console.log(data)
}).catch((error) => {
var db = admin.database();
var ref = db.ref("transfer");
return ref.update("Failure");
console.error(error)
})
// success
}).catch((error) => {
console.log(error);
// error
})
});
解决方案
如果您想在初始调用中返回数据,但也进行传输,只需将其更改为以下内容:
// Capture a particular payment
rzp.payments.capture(payment_id, 100000).then((data) => {
const ret = event.data.ref.child('status').set(data);
console.log(data)
// Create transfers on a payment
rzp.payments.transfer(payment_id, {
transfers: [
{
account: 'acc_aldsfkas123123adsf',
amount: 100,
currency: 'INR'
}
]
})
return ret
})
问题是您return
在运行传输功能之前使用过。一旦 areturn
被击中,它后面的代码将永远不会运行。通过将所需的返回值存储在变量中,您可以做其他工作,然后返回它。
或者,您可以以不同的顺序运行代码,因为看起来这两个调用并不相互依赖。
但实际上,您应该将所有异步工作分解为单一服务和可理解的函数,这些函数可以链接在一起以获得更好的可读性。例如,您的链可能如下所示:
capturePayment(payment_id, 100000)
.then(updateDB)
.then(transfer)
.then(data => console.log('success'))
.catch(err => console.error(err))
然后,您所要做的就是确保每个链接函数都接受一个参数,该参数可以从前一个的结果中传递。
推荐阅读
- python - 如何在 Python 文档字符串测试中处理舍入到负零
- python - Python:使用正则表达式匹配电话号码并打印元组(带格式约束)
- php - 如何在容器中安装作曲家依赖项?
- c# - 从 SCCM 中的一台设备获取所有集合
- jenkins - 是否可以在其中包含空格的 Jenkins 参数名称?
- javascript - 节点未接收由 javascript 添加的复选框
- python - 仅将具有扩展名的文件添加到列表
- python - python脚本使用API获取json中的xml数据
- python - 为什么 Docker 说 requirements.txt 文件不存在?
- c++ - 使用自定义比较器,std::map 异常是否安全?