Operations endpoint
The operations endpoint allows clients to perform multiple resource-level operations in a single, ordered request. It follows the JSON:API Atomic Operations extension and is intended for use cases where bulk writes or tightly ordered changes are needed.
POST /v1/operations
Request format
Clients MUST send a JSON document with an atomic:operations key containing an array of operation objects.
Each operation object MUST specify:
- op: the operation type (e.g.- "add",- "update",- "remove")
- data: the resource object for the operation
Each operation MUST include a resource object with:
- type: the resource type (e.g.- "subscription")
- id: the resource identifier, if applicable
- attributes: resource attributes as appropriate for the action
Headers
Clients MUST set the following headers:
- Content-Type: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
- Accept: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
POST /v1/operations HTTP/1.1
Content-Type: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
Accept: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
Example request
{
  "atomic:operations": [
    {
      "op": "add",
      "data": {
        "type": "subscription",
        "id": "b80719b3-1485-57c0-9e55-fda2b8f7472b",
        "attributes": {
          "feed_url": "https://example.com/rss2"
        }
      }
    },
    {
      "op": "add",
      "data": {
        "type": "subscription",
        "id": "d29519a4-77ee-5e13-bb14-89fc93b993ae",
        "attributes": {
          "feed_url": "https://example.com/rss3"
        }
      }
    }
  ]
}
Server behavior
- The server MUST process operations in order.
- Each operation MUST be executed independently.
- The server MUST return a 200 OKresponse even if one or more operations fail.
- The response MUST include an atomic:resultsarray with the same number of elements as the input.
- Each resultselement corresponds positionally to its respective request operation.
Success response format
For successful operations, the corresponding item in atomic:results MUST contain a data object.
Error response format
If an operation fails, the corresponding item MUST contain an errors array, conforming to the JSON:API error object format.
Response headers
The server MUST set the following headers:
- Content-Type: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
HTTP/1.1 200 OK
Content-Type: application/vnd.api+json;ext="https://jsonapi.org/ext/atomic"
Supported operations
The operations endpoint may be used for:
Additional bulk actions (e.g. update, remove) may be supported in the future.
Clients MUST only use operations documented for this server.
Errors
For error semantics and structure, see error responses.
Errors may occur for:
- Validation failures (422)
- Resource conflicts (409)
- Type mismatches (409or400)
- Invalid resource identifiers (400)
All errors are returned inline within the atomic:results array.