findandupdate вернуть null с обещанием всем - Мангуст - PullRequest
0 голосов
/ 03 января 2019

Я пытаюсь создать API-интерфейс nodejs, разделенный контроллерами и маршрутами. Я пытаюсь найти и обновить в нескольких коллекциях, а затем поместить их в несколько обещаний, чтобы вернуть один ответ, но я получаю только null Что я делаю не так, как показано ниже?

controller.js

var x = (req, res, next, userID, product) => {

    let query = {
        uid: userID
    }

    let update = {
        $push: {
            product: product,
        }
    }

    let options = {
        safe: true,
        new: true,
        upsert: true
    }

    Model.findOneAndUpdate(query, update, options).exec()
    .then(result => {
        return true
    })
    .catch(err => {
        console.log(err);
        res.status(500).json({ error: err });
    })
};

module.exports = x;

Route.js

const controller = require('./user-product')
router.post('/api', function (req, res, next) {
    var p1 = controller(req, res, next, userID, product)        
    var allDone = Promise.all([p1])
    allDone
        .then(function (e) {
            res.send(e) //this is null
        })
        .catch(function (e) {
            console.log(e);
        })
});

1 Ответ

0 голосов
/ 03 января 2019

Вы не возвращаете обещание от функции контроллера. Вы просто возвращаете result и error

Итак, вместо этого вы должны вернуть обещание внутри функции контроллера

Route.js

const controller = require('./user-product')
router.post('/api', function (req, res, next) {
  var p1 = controller(req, res, next, userID, product)        
  var allDone = Promise.all([p1])
  allDone.then(function (e) {
    res.send(e)
  })
  .catch(function (e) {
    console.log(e);
  })
})

controller.js

var x = (req, res, next, userID, product) => {
  let query = { uid: userID }
  let update = { $push: { product: product }}
  let options = {
      safe: true,
      new: true,
      upsert: true
  }
  return Model.findOneAndUpdate(query, update, options).exec()
}

module.exports = x;

И, возможно, проще с асинхронным ожиданием синтаксис

Route.js

const controller = require('./user-product')
router.post('/api', async(req, res, next) => {
  try {
    const p1 = await controller(req, res, next, userID, product)
    console.log(p1)
  } catch (err) {
    console.log(err)
  }
})

controller.js

var x = async(req, res, next, userID, product) => {
  let query = { uid: userID }

  let update = { $push: { product: product }}

  let options = {
      safe: true,
      new: true,
      upsert: true
  }
  return Model.findOneAndUpdate(query, update, options).exec()
}

module.exports = x;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...