Sails.js / Waterline .add() 和 .remove() 仅适用于第二次调用

Sails.js / Waterline .add() and .remove() only works on second call

我正在尝试在 2 个模型之间使用多对多关联,我必须调用 .add() 或 .remove() 两次才能正常工作:

// User.js Model
module.exports = {
  attributes: {
    connections: {
      collection: 'connection',
      via: 'users'
    }
  }
}

// Connection.js Model
module.exports = {
  attributes: {
    users: {
      collection: 'user',
      via: 'connections'
    }
  }
}

这是我 UsersController.js:

中的代码
    User.findById(req.params.user)
    .populate('connections')
    .exec(function(err, users) {
      if (err) return res.status(404).end(); // Not really a 404 but good for now

      var user = users[0];
      user.connections.add(req.body.connection_id);
      user.save(function(err) {
        // In my tests err is null/undefined
        return res.status(204).end();
      }
    });

我收到 204 返回,日志中没有错误,也没有其他失败。当我检查我的 MongoDB 数据库时,用户的连接字段只是一个空数组。如果我再次发送相同的请求,则会收到一条错误消息,指出该用户的 connection_id 已存在。我查看数据库,现在连接出现在用户的连接字段中。当我删除连接时它做同样的事情,我必须发送两次才能生效。有人有什么想法吗?

以下是我使用的模块版本:

听起来像是与同步方法和异步方法相关的东西...意味着您在某个请求完成之前退出该方法。但是不确定发生在哪里。看看这是否有帮助:

var connectionId = req.param('connection_id');
var userId = req.param('user');

User.find(userId)
.populate('connections')
.exec(function(err, users) {
  if (err) return res.status(404).end(); // Not really a 404 but good for now

//BTW might be good to double check doing console.log("users: "+JSON.stringify(users));

  var user = users[0];
  user.connections.push(connectionId);

//Is it really there? console.log("user: "+JSON.stringify(user));

  user.save(function(err) {
    // In my tests err is null/undefined
    return res.status(204).end();
  }
});