xtract.bot
POST /api/jq-filter

Apply jq filter expressions to JSON over HTTP. Full language including pipes, map, select, and paths. Streaming output, raw mode, slurp, null-input flags supported.

Applies a jq filter expression to the supplied JSON input. The full jq language is supported: pipes, map, select, paths, group_by, reduce, recursive descent, etc. Common flags are exposed: - `rawOutput` (= `-r`): emit string values as plain text rather than quoted JSON. - `slurp` (= `-s`): wrap multiple input values into a single array before filtering. - `compact` (= `-c`): compact output instead of pretty-print. - `nullInput` (= `-n`): use `null` as input (filter is the whole expression). Examples: `.users[].name`, `map(select(.active))`, `.items | group_by(.category) | map({category: .[0].category, count: length})`.

Inputs

NameTypeDefaultDescription
filter*string"."filter expression, e.g. `.`, `.name`, `.items | map(.id)`.
input*fileJSON input to filter. UTF-8 text.
rawOutputbooleanfalseEmit raw strings without JSON quoting ( `-r`).
slurpbooleanfalseRead the entire input stream into a single array ( `-s`).
compactbooleanfalseCompact output instead of pretty-printed ( `-c`).
nullInputbooleanfalseUse null as the single input value; ignore input ( `-n`).

Response

Modes: json, text. Cache: yes (24h TTL).

Code samples

Built from the identity example.

# Download or substitute the example input:
#   curl -O https://xtract.bot/examples/jq-filter/hello-world.json
INPUT=$(base64 -w0 < hello-world.json)

curl -X POST https://api.xtract.bot/api/jq-filter \
  -H "Content-Type: application/json" \
  -H "Accept: application/json" \
  -H "X-Account-Id: $XTRACT_ACCOUNT_ID" \
  -H "X-Api-Key: $XTRACT_API_KEY" \
  -d '{
  "filter": ".",
  "rawOutput": false,
  "slurp": false,
  "compact": false,
  "nullInput": false,
  "input": "'"$INPUT"'"
}'