2

我目前正在构建一个 API,它使用 JSON 补丁规范使用 Mongoose ORM 对 MongoDB 进行部分更新。

我正在使用节点模块mongoose-json-patch将补丁应用于我的文档,如下所示:

var patchUpdate = function(req,  res){
  var patches = req.body;
  var id = req.params.id;
  User.findById(id, function(err, user){
    if(err){ res.send(err);}
    user.patch(patches, function(err){
      if(err){ res.send(err);}
      user.save(function(err){
        if(err) {res.send(err);}
        else {res.send("Update(s) successful" + user);}
      });
    });
  });
};

当我尝试使用 JSON 补丁语法删除或替换数组元素时,会出现主要问题:

var patches = [{"op":"replace", "path": "/interests/0", "value":"Working"}]

var user = {
    name: "Chad",
    interests: ["Walking", "Eating", "Driving"]
}

这应该用新值(“Working”)替换数组中的第一项(“Walking”),但是我不知道如何验证实际被替换的内容。如果在应用补丁之前删除了另一个请求 /interests/0,则“Eating”将被“Working”代替,而不是“Walking”,后者将不再存在于数组中。

我想确定如果客户认为他正在编辑“Walking”,那么他要么成功地编辑它,要么至少得到一个错误。

4

1 回答 1

1

在我自己遇到同样的问题后,我将分享我的解决方案。规范(描述here)描述了六种操作,其中之一是测试。源将测试操作描述为

测试文档中是否设置了指定的值。如果测试失败,则不应应用整个补丁。

为确保您更改预期的值,您应该验证数据的状态。您可以通过在替换或删除操作之前使用测试操作来执行此操作,其中值等于预期的数据状态。如果测试失败,则不会执行以下操作。

通过测试操作,您的补丁数据将如下所示:

var patches = [
  {"op":"test", "path": "/interests/0", "value": currentValue}, //where currentValue is the expected value
  {"op":"replace", "path": "/interests/0", "value":"Working"}
]
于 2018-05-21T11:46:27.893 回答