Добро пожаловать в асинхронный мир!
Общее объяснение: Вы собираетесь использовать результаты запросов к базе данных, прежде чем это произойдет. Ваша программа должна дождаться результатов (idCidade
, idEstado
), прежде чем вы сможете ее использовать. Из-за этого вы можете сначала найти запись Will be inserted...
в своих журналах.
Для объяснения я собираюсь использовать Минимальный воспроизводимый пример .
function findCidade(cidade) {
return Promise.resolve(1);
}
function findEstado(uf) {
return Promise.resolve(1);
}
Promise.all([findCidade(), findEstado()])
.then((data) => console.log(data));
Вывод:
[ 1, 1 ]
Чтобы решить эту проблему, вы должны:
- Явно вернуть обещание с помощью оператора
return
. Await
результаты по async/await
или Promise
интерфейсным методам. Или используйте callbacks
, если он вам больше подходит.
module.exports = app => {
const obterHash = (senha, callback) => {
bcrypt.genSalt(10, (err, salt) => {
bcrypt.hash(senha, salt, null, (err, hash) => callback(hash))
})
};
function findCidade(cidade, ) {
return app.db('cidades')
.where({ nome: cidade })
.first()
.then(data => {
idCidade = data.id
console.log('inside findCity. data.id: '+data.id)
}).catch((err) => console.log("erro cidade", err));
}
function findEstado(uf) {
return app.db('estados')
.where({ uf: uf })
.first()
.then(data => {
idEstado = data.id
console.log('inside findState. data.id: '+data.id)
}).catch((err) => console.log("erro estado", err));
}
const save = (req, res) => {
console.log("\n");
Promise.all([findCidade(req.body.cidade), findEstado(req.body.uf)])
.then((data) => {
const [idCidade, idEstado] = data;
obterHash(req.body.senha, hash => {
const senha = hash;
console.log("Will be inserted. idCity: "+idCidade+" idState: "+idEstado);
app.db('salao')
.insert({ idcidade: idCidade,
idestado: idEstado,
senha})
.then(_ => res.status(200).send())
.catch(err =>{res.status(400).json(err)})
})
})
.catch((err) => console.log("general error", err));
};
return { save }
}