REST Array manipulation best practice

后端 未结 2 351
独厮守ぢ
独厮守ぢ 2021-01-21 06:33

I have full access to foo resource via REST:

{
  \"name\": \"foo\",
  \"tags\": [
    \"tag01\",
    \"tag02\",
    \"tag03\"
  ]
}

I would lik

2条回答
  •  臣服心动
    2021-01-21 07:14

    Is there some other way to manipulate arrays via REST?

    Yes, because it is not correct. By REST you map your URLs to resources (not operations) and you manipulate resources using HTTP methods and sending representations. Having an op:remove in an URL or in a representation is wrong.

    Are there some name conventions to do it in PATCH way?

    No there are no REST naming conventions. The URI structure does not matter by REST clients, because they follow hyperlinks with semantic annotations.

    If you need an op:remove or similar somewhere, then it indicates that your URI - resource mapping is not good. Probably you have to define a new resource or rethink the resource structure.

    I would describe what you want as a bulk create and bulk delete. You can model this cases with something like:

    • POST /collection [{},{},...] -> 201
    • DELETE /collection?filter="..." -> 204

    In order to delete something from a collection you need a resource identifier URI. In this case this can contain the tag name or the index in the array (if it is ordered).

    • /foo/tags/tag01
    • /foo/tags/0

    It is up to you, but I would use the tag name.

    After that it is pretty simple:

    • POST /foo/tags ["a","b","c"]
    • DELETE /foor/tags?name="a,b,c"

    So PATCH is not the method you are looking for, because you are creating and removing resources and not replacing them.

提交回复
热议问题