Я пишу API, который получает прошлые транзакции в сети Stellar для пользователя, ищет соответствующих пользователей в моей базе данных и объединяет все это в JSON (для ответа на запрос - позже).
Проблема: поиск имени пользователя, соответствующего идентификатору учетной записи (поле "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 начинает искать данные, переменная платежа собирается (имя пользователя undefined) и регистрируется, findUser возвращает данные.
Вот журнал: (человек-паук - настоящее имя пользователя из моей базы данных)
[ { 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