Eftersom du inte skickar den hämtade användaren korrekt till query.exec
.
Du måste göra:
var Users = require('../models/users-model.js');
function usernametoid(id) {
return new Promise( function (resolve, reject) {
Users.findOne({ username : id }).then( function(user){
//If you use lodash you can do _.isNull(user)
if(user == null){
return reject({error : 'User not found'});
}
user.exec(function(userdata, error) {
if(userdata){
return resolve(userdata);
}
if(error){
return reject({error : 'Error while executing query'});
}
});
});
});
}
Jag förstår inte riktigt varför du importerar Users Model
sådär. Jag tror inte Node
kommer att kunna hämta det så.
Och du bör kräva mongoose
i din server.js
För att fånga avslaget behöver du följande kod:
UserFactory.userNameToId(id).then( function(response){
if(response.error){
console.log('error '+response.error);
}
if(response){
console.log('Got response '+response);
}
});