MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Czy mangusta findOne na modelu zwraca obietnicę?

Ponieważ findOne jest asynchroniczna funkcji, jednym ze sposobów na powrót z niej jest użycie callback funkcja

module.exports.isAdmin = function(user_id, callback) {
  var params = {'roles': 'admin'};

  dao.findOne(params, function(err, user) {
    if (err) {
      logger.error(err);
      callback && callback(false);
    }
    if (_.indexOf(user.roles, 'admin') != -1) {
      logger.info("admin user: " + user._id);
      if (user._id == user_id)
          callback && callback(true);
    }
    callback && callback(true);
  });
};

isAdmin(userId, function(v) {
    console.log(v);
})

Innym sposobem jest uzyskanie Promise w findOne , jak powiedział ten dokument, .exec() daje pełną obietnicę. Nawet z Promise , aby spełnić Twoje wymagania, wynik może zostać zwrócony przez funkcję zwrotną.

module.exports.isAdmin = function(user_id, callback) {
  var params = {'roles': 'admin'};

  var queryPromise = dao.findOne(params).exec();
  queryPromise.then(function(user) {
      if (_.indexOf(user.roles, 'admin') != -1) {
        logger.info("admin user: " + user._id);
        if (user._id == user_id)
          callback && callback(true);
      }
    }, function(err) {
      callback && callback(false);
  });
};



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Trzeci argument przy tworzeniu modelu w MongooseJS

  2. Dlaczego PyMongo 3 daje ServerSelectionTimeoutError?

  3. Transakcje w MongoDB

  4. Aliasy pól z Mongoid i Rails

  5. Korzystanie z funkcji Mongoose / MongoDB $addToSet na tablicy obiektów