POST
/
v1
/
retrievers
/
retrievers
/
{retriever_id}
/
execute
curl --request POST \
  --url https://api.mixpeek.com/v1/retrievers/retrievers/{retriever_id}/execute \
  --header 'Content-Type: application/json' \
  --data '{
  "inputs": {},
  "filters": {
    "AND": [
      {
        "field": "name",
        "operator": "eq",
        "value": "John"
      },
      {
        "field": "age",
        "operator": "gte",
        "value": 30
      }
    ],
    "OR": [
      {
        "field": "status",
        "operator": "eq",
        "value": "active"
      },
      {
        "field": "role",
        "operator": "eq",
        "value": "admin"
      }
    ],
    "NOT": [
      {
        "field": "department",
        "operator": "eq",
        "value": "HR"
      },
      {
        "field": "location",
        "operator": "eq",
        "value": "remote"
      }
    ],
    "case_sensitive": true
  },
  "sorts": [
    {
      "field": "created_at",
      "direction": "desc"
    }
  ],
  "limit": 10,
  "offset": 0,
  "select": [
    "<string>"
  ],
  "session_id": "<string>",
  "return_urls": false
}'
{
  "execution_time": 123,
  "stage_results": [
    {
      "results": [
        {}
      ],
      "execution_time": 123,
      "total_results": 123
    }
  ]
}

Headers

Authorization
string | null

Bearer token authentication using your API key. Format: 'Bearer your_api_key'. To get an API key, create an account at mixpeek.com/start and generate a key in your account settings. Example: 'Bearer sk_1234567890abcdef'

X-Namespace
string | null

Optional namespace for data isolation. This can be a namespace name or namespace ID. Example: 'netflix_prod' or 'ns_1234567890'. To create a namespace, use the /namespaces endpoint.

Path Parameters

retriever_id
string
required

Body

application/json

Query parameters for executing a retriever pipeline.

This model defines all the parameters that can be provided when running a search using a predefined retriever pipeline. It allows for customizing the query inputs, filtering, sorting, pagination, and result formatting.

inputs
object
required

Input values for the retriever query. These map to the required inputs defined in the retriever's first stage.

filters
object | null

Logical operations for filtering results. Can include AND, OR, NOT conditions with field comparisons.

sorts
object[] | null

Controls the ordering of results. Can sort by score (default) or any other document field. This sorts the results from the last stage.

Specifies how to sort query results.

Attributes: field: Field to sort by direction: Sort direction (ascending or descending)

limit
integer
default:10

Maximum number of results to return. Overrides the default pagination limit in the retriever definition.

Required range: 1 <= x <= 100
offset
integer
default:0

Number of results to skip. Use with limit for pagination. For large offsets, consider using session_id for cursor-based pagination.

Required range: x >= 0
select
string[] | null

Specific fields to include in the response. If not specified, returns all fields.

session_id
string | null

Session identifier for interaction tracking.

return_urls
boolean
default:false

When true, generates pre-signed URLs for any media assets in the results. May increase response time slightly.

Response

200
application/json
Successful Response

Response from a retriever execution

execution_time
number
required
stage_results
object[]

Results from each stage execution

Output from a retriever stage