page.corvus.getOps

corvus.page

{
  "id": "page.corvus.getOps",
  "defs": {
    "main": {
      "type": "query",
      "errors": [
        {
          "name": "InvalidCursor",
          "description": "The supplied cursor is malformed or beyond the server's current high-water."
        }
      ],
      "output": {
        "schema": {
          "type": "object",
          "required": [
            "ops"
          ],
          "properties": {
            "ops": {
              "type": "array",
              "items": {
                "ref": "page.corvus.subscribeOps#op",
                "type": "ref"
              },
              "description": "Ops for the requested blocks with cursor strictly greater than the input `cursor`, in ascending cursor order. Up to `limit` entries. Shape is identical to a live `page.corvus.subscribeOps#op` frame."
            },
            "cursor": {
              "type": "integer",
              "description": "Cursor of the last op in `ops`. Pass this as `cursor` on the next call to continue paginating. Omitted when `ops` is empty (caller is caught up to the server's high-water for these blocks)."
            }
          }
        },
        "encoding": "application/json"
      },
      "parameters": {
        "type": "params",
        "required": [
          "blockIds"
        ],
        "properties": {
          "limit": {
            "type": "integer",
            "default": 500,
            "maximum": 1000,
            "minimum": 1,
            "description": "Maximum number of ops to return in this page."
          },
          "cursor": {
            "type": "integer",
            "description": "Server-assigned cursor (exclusive) to resume from. Omitted = start from cursor 0 (every op the server has for the requested blocks). Same semantic as `page.corvus.subscribeOps#main.cursor`."
          },
          "blockIds": {
            "type": "array",
            "items": {
              "type": "string",
              "format": "at-uri"
            },
            "description": "The explicit set of block ids to read ops for. No transitive walk — only ops whose `blockId` is in this set are returned."
          },
          "includeDids": {
            "type": "array",
            "items": {
              "type": "string",
              "format": "did"
            },
            "description": "The dids of the users to include."
          }
        }
      },
      "description": "Read ops for the requested `blockIds` in forward cursor order, strictly after `cursor`."
    }
  },
  "$type": "com.atproto.lexicon.schema",
  "lexicon": 1,
  "description": "Paginated forward read of an op log scoped to an explicit block set. Pull-based alternative to opening a `page.corvus.subscribeOps` WebSocket at `cursor: 0` — same op shape, same cursor semantics, just delivered as a query page instead of a live tail. Each entry is a `page.corvus.subscribeOps#op` so live and historical paths feed the same applier.\n\nLike `subscribeOps`, this query does NOT walk graph relations. Callers fetch ops for the blocks they care about and follow refs explicitly with subsequent calls."
}

Validate Record

Validate a record against page.corvus.getOps

Validation Options
Automatically resolve and include external schemas for full validation
Treat any remaining unresolved references as valid

Metadata

DID
did:plc:3qc4cbzcriye72qqqodeda26
CID
bafyreietab747ssc3ihmplglbxm7t5docl7fk5xelcuq677tmi57otztsu
Indexed At
2026-05-21 03:27 UTC
AT-URI
at://did:plc:3qc4cbzcriye72qqqodeda26/com.atproto.lexicon.schema/page.corvus.getOps

Referenced Schemas (1)

Lexicon Garden

@