そのため、関数の結果を次の関数に渡す手順として非同期ウォーターフォールを使用しています。現在、クエリの結果としてユーザーにプッシュを呼び出す際に問題が発生しています。
これが私のコードです:
exports.contactList = function(req, res) {
async.waterfall([
function(callback) {
Friend.findOne({userId: req.signedCookies.userid}, function(err, users) {
var friends = [];
if(err) {throw err};
for(var i = 0; i < users.friendStatus.length; i++) {
if(users.friendStatus[i].status === 3) { friends.push(users.friendStatus[i])};
}
//console.log(friends);
callback(null, friends);
});
},
function(friends, callback) {
var friendsinfo = [];
for(var i = 0; i < friends.length; i ++) {
async.each(friends, function(friend, next) {
//friendsinfo.push(friend.favorites)
User.findOne({_id: friend.fuId}, function(err, user) {
if (err) { console.log(err); };
var object = {'fav': friend.favorites, 'user': user};
friendsinfo.push(object);
next(err);
});
}, function(err) {
console.log('friendsINFO');
console.log(friendsinfo);
callback(err, friendsinfo);
});
}
}
],
function(err, results) {
console.log('RESULTS');
console.log(results);
res.render('contactList', {title: 'Weblio', Friends: results});
});
};
Console.log(user) は実際にユーザーを出力します。配列 friendsInfo は未定義として表示されます。