Skip to content

Latest commit

 

History

History
85 lines (69 loc) · 2.13 KB

workspaceitem-data-coarnotify.md

File metadata and controls

85 lines (69 loc) · 2.13 KB

WorkspaceItem data of COAR Notify sectionType

Back to the definition of the workspaceitems endpoint

The section data represents the data about the selected COAR Notify patterns to request

[
  {
    "endorsement": [ 1, 2, 3 ],
    "review": [ 6 ]
  }
]

the attributes represent the pattern that will be requested to the selected service(s), the value of each attribute is the array of the id of the selected services. The above example shows a submission where three services (id 1, 2, 3) were selected to request an endorsement and one service (id 6) has been selected to request a review.

Patch operations

The PATCH method expects a JSON body according to the JSON Patch specification RFC6902

Each successful Patch operation will return a HTTP 200 CODE with the updated workspaceitem as body.

If the requested path doesn't match a valid pattern for the current configuration or a specified service id doesn't exist 422 Unprocessable Entity will be returned.

Add

To specify which services request for a specific pattern

[
  {
    "op": "add",
    "path": "/sections/coarnotify/review/-",
    "value": [1, 2, 6]
  }
]

Replace

To replace the 2nd previous selected service for the endorsement pattern

[
  {
    "op": "replace",
    "path": "/sections/coarnotify/endorsement/1",
    "value": 4
  }
]

Please note that the number in the path (/1) represent the idx of the previous selected services, the number in the value represent the id of the new selected service. The above path applied to the initial sample

[
  {
    "endorsement": [ 1, 2, 3 ],
    "review": [ 6 ]
  }
]

will modify the section data as follow

[
  {
    "endorsement": [ 1, 4, 3 ],
    "review": [ 6 ]
  }
]

Remove

It is possible to remove a previously selected service for a specific pattern (review) curl --data '{[ { "op": "remove", "path": "/sections/coarnotify/endorsement/0"}]' -X PATCH ${dspace7-url}/api/submission/workspaceitems/1

The result applied to the previous example will be

[
  {
    "endorsement": [4, 3 ],
    "review": [ 6 ]
  }
]