> ## Documentation Index
> Fetch the complete documentation index at: https://docs.jelou.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Search coupons

> Search coupons by code or name, and filter by state, type, or branch.

<ParamField path="app_id" type="string" required>
  Your store ID in Jelou Shop.
</ParamField>

<ParamField query="page" type="integer" default="1">
  Page number to return.
</ParamField>

<ParamField query="limit" type="integer" default="15">
  Number of results per page (max. 100).
</ParamField>

<ParamField query="state" type="string">
  Filter by the derived state: `active`, `scheduled`, `expired`, `depleted`, or `inactive`.
</ParamField>

<ParamField body="search" type="object">
  Text search object.

  <Expandable title="Search properties">
    <ParamField body="value" type="string" required>
      Text to search in the `code` and `name` fields.
    </ParamField>

    <ParamField body="case_sensitive" type="boolean" default="false">
      Whether the search is case sensitive.
    </ParamField>
  </Expandable>
</ParamField>

<ParamField body="filters" type="object[]">
  List of filters to apply.

  <Expandable title="Properties of each filter">
    <ParamField body="field" type="string" required>
      Field to filter by: `status`, `discount_type`, `applies_to_all_branches`, or `branches.id`.
    </ParamField>

    <ParamField body="operator" type="string" default="=">
      Comparison operator. Supported values: `=`, `!=`, `<`, `<=`, `>`, `>=`, `like`, `not like`, `in`, `not in`.
    </ParamField>

    <ParamField body="value" type="string | boolean" required>
      Filter value.
    </ParamField>
  </Expandable>
</ParamField>

<ParamField body="sort" type="object[]">
  Sorting of results.

  <Expandable title="Properties of each sort">
    <ParamField body="field" type="string" required>
      Field to sort by: `created_at`, `valid_from`, `valid_until`, `code`, or `status`.
    </ParamField>

    <ParamField body="direction" type="string" default="asc">
      Sort direction: `asc` or `desc`.
    </ParamField>
  </Expandable>
</ParamField>

<RequestExample>
  ```bash cURL theme={null}
  curl -X POST "https://gateway.jelou.ai/ecommerce/v2/apps/{app_id}/coupons/search?page=1&limit=20" \
    -H "x-api-key: YOUR_API_KEY" \
    -H "Content-Type: application/json" \
    -d '{
      "search": {
        "value": "black",
        "case_sensitive": false
      },
      "filters": [
        { "field": "discount_type", "operator": "=", "value": "percentage" },
        { "field": "status", "operator": "=", "value": true }
      ],
      "sort": [
        { "field": "valid_until", "direction": "asc" }
      ]
    }'
  ```
</RequestExample>

<ResponseExample>
  ```json 200 Success theme={null}
  {
    "data": [
      {
        "id": "9e3f2c1a-8b7d-4e6f-a5c4-d3b2a1e0f9c8",
        "code": "BLACKFRIDAY25",
        "name": "Black Friday 25%",
        "discount_type": "percentage",
        "discount_value": "25.000000",
        "status": true,
        "valid_from": "2026-11-25T00:00:00.000000Z",
        "valid_until": "2026-11-30T23:59:59.000000Z",
        "max_uses": 100,
        "once_per_client": true,
        "applies_to_all_branches": true,
        "uses_count": 0,
        "state": "scheduled",
        "created_at": "2026-07-02T15:30:00.000000Z",
        "updated_at": "2026-07-02T15:30:00.000000Z"
      }
    ],
    "meta": {
      "current_page": 1,
      "per_page": 15,
      "total": 1
    }
  }
  ```
</ResponseExample>

<Tip>
  **Searchable fields:** `code`, `name`
  **Filterable fields:** `status`, `discount_type`, `applies_to_all_branches`, `branches.id`
  **Sortable fields:** `created_at`, `valid_from`, `valid_until`, `code`, `status`
</Tip>
