我正在编写一个 API,它可以为用户获取 Stellar 网络上的过去交易,在我的数据库中查找相应的用户,然后将它们全部放在一个 JSON 中(以响应请求 - 稍后)。
问题:查找与 accountID(“from”字段)对应的用户名是 mongoose 的异步方法,仅在组装 JSON 后返回数据。
我尝试使用 async/await、promises、.thens 但似乎没有任何效果。
server.payments()
.forAccount(accountId)
.cursor('now')
.order('desc')
.limit(2)
.call()
.then(function (page) {
var history = []
for(var i = 0; i<page.records.length; i++){
var obj = page.records[i]
//Get the username corresponding to the key from my database
//FIXME
var username
findUser(obj["from"]).then(result => {
username = result
})
var payment = {
"currency":obj["asset_code"],
"from": obj["from"],
"username":username,
"amount": obj["amount"],
"timestamp":obj["created_at"]
}
history.push(payment)
}
console.log(history)
//console.log(JSON.stringify(history))
})
.catch((err) => {
console.log(err)
})
async function findUser(senderKey){
var user = await mongoose.User.findOne({publicKey: senderKey})
console.log(user.username)
return user.username
}
预期结果:findUser 返回值,支付变量使用它并一起记录。
会发生什么:findUser 开始查找数据,支付变量被放在一起(用户名未定义)并记录,findUser 返回数据。
这是日志:(spiderman 是我数据库中的实际用户名)
[ { currency: 'MEUR',
from: 'GACRQARPR2OMWRG6IH7HM5DYTA3FMM6UKA7NKS4BIJIADRIKFRPAIE7G',
username: undefined,
amount: '3.0000000',
timestamp: '2019-05-07T13:37:04Z' },
{ currency: 'MEUR',
from: 'GACRQARPR2OMWRG6IH7HM5DYTA3FMM6UKA7NKS4BIJIADRIKFRPAIE7G',
username: undefined,
amount: '2.0000000',
timestamp: '2019-05-07T13:34:21Z' } ]
spiderman
spiderman