猫鼬中的多个填充不起作用

时间:2019-09-04 15:47:13

标签: node.js mongodb mongoose

我有这样的架构:

const mongoose = require('mongoose');
const deepPopulate = require('mongoose-deep-populate')(mongoose);
const Schema = mongoose.Schema;

const AcceptedMessageSchema = new Schema({
  body: String,
  seen: Boolean,
  sender: [{
    type: mongoose.Schema.Types.ObjectId,
    ref: "User"
  }],
  recipient: [{
    type: mongoose.Schema.Types.ObjectId,
    ref: "User"
  }]
}, { timestamps: { createdAt: 'created_at' } });

AcceptedMessageSchema.plugin(deepPopulate);
module.exports = mongoose.model('Accepted', AcceptedMessageSchema);

当我接受来自其他用户的消息/邮件时,我将其保存到acceptedMessageSchema中,因此当其他用户登录时,他可以看到我已经接受了他的消息。

Similary,我想跟踪已接受的邮件数量,因此我尝试了以下操作:

const router = require('express').Router();
const checkJWT = require('../../middlewares/check-jwt');
const AcceptedMessageSchema = require('../../models/mailbox/accepted-messages');

router.get('/getAcceptedMessages', checkJWT, (req, res, next) => {
  AcceptedMessageSchema.find({ recipient: req.decoded.user._id, }, { sender: req.decoded.user._id }).populate('recipient').populate('sender').lean().exec(function (err, messages) {
    console.log('getAcceptedMessages ', messages);
    res.json({
      success: true,
      messages: messages,
      message: "Successful"
    });
  });
});

router.post('/acceptMessage', checkJWT, (req, res, next) => {
  console.log('accept');
  const accept = new AcceptedMessageSchema();
  accept.body = req.decoded.user.name + ' has accepted your message';
  accept.recipient = req.decoded.user._id;
  accept.sender = req.body.id;
  AcceptedMessageSchema.find({ sender: req.body.id }).lean().exec(function (err, senders) {
    const messageFound = senders.some((obj) => {
      return JSON.stringify(obj.recipient) === JSON.stringify(req.decoded.user['_id']);
    });
    if (!messageFound) {
      accept.save().then(messageSaved => {
        res.json({
          success: true,
          message: "Accepted!"
        });
      }).catch(error => {
        next(error);
        res.json({
          success: false,
          message: "Couldn't send message"
        });
      });
    } else {
      res.json({
        success: false,
        message: 'Message already accepted!'
      });
    }
  });
});

module.exports = router;

但是它返回一个空数组。

db中的数据:

{
    "_id": {
        "$oid": "5d6fd251263b282ac0f7860d"
    },
    "updatedAt": {
        "$date": "2019-09-04T15:03:45.842Z"
    },
    "created_at": {
        "$date": "2019-09-04T15:03:45.842Z"
    },
    "sender": {
        "$oid": "5d6b06eca4b60b09b3c376e1"
    },
    "recipient": {
        "$oid": "5d6b0718a4b60b09b3c376e2"
    },
    "body": "John has accepted your message",
    "__v": 0
}

因此发件人5d6b06eca4b60b09b3c376e1已将消息发送给收件人5d6b0718a4b60b09b3c376e2

1 个答案:

答案 0 :(得分:0)

Model.find()的第二个参数是投影,因此您的查询RewriteEngine On RewriteCond %{REQUEST_URI} ^/us/ RewriteCond %{REQUEST_URI} !/feed$ RewriteRule (.*) https://urlocal.news/$1 [R=301,L] 似乎是错误的。应该是:

AcceptedMessageSchema.find({ recipient: req.decoded.user._id, }, { sender: req.decoded.user._id })