# List all custom promotion rules

To [fetch](https://docs.commercelayer.io/core/fetching-resources) a collection of custom promotion rules, send a `GET` request to the `/api/custom_promotion_rules` endpoint.

## Request

**GET** <https://yourdomain.commercelayer.io/api/custom\\_promotion\\_rules>

### **Example**

{% tabs %}
{% tab title="Request" %}
The following request fetches a collection of custom promotion rules:

```shell
curl -g -X GET \
  'https://yourdomain.commercelayer.io/api/custom_promotion_rules/' \
  -H 'Accept: application/vnd.api+json' \
  -H 'Authorization: Bearer your-access-token'
```

{% endtab %}

{% tab title="Response" %}
On success, the API responds with a `200 OK` status code, returning a paginated collection of resource objects:

```json
{
  "data": [
    {
      "id": "XAyRWNUzyN",
      "type": "custom_promotion_rules",
      "links": {
        "self": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN"
      },
      "attributes": {
        "type": "coupon_codes_promotion_rules",
        "created_at": "2018-01-01T12:00:00.000Z",
        "updated_at": "2018-01-01T12:00:00.000Z",
        "reference": "ANY-EXTERNAL-REFEFERNCE",
        "reference_origin": "ANY-EXTERNAL-REFEFERNCE-ORIGIN",
        "metadata": {
          "foo": "bar"
        },
        "filters": {
          "status_eq": "pending",
          "line_items_sku_code_eq": "AAA"
        }
      },
      "relationships": {
        "promotion": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/relationships/promotion",
            "related": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/promotion"
          }
        },
        "versions": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/relationships/versions",
            "related": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/versions"
          }
        },
        "event_stores": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/relationships/event_stores",
            "related": "https://yourdomain.commercelayer.io/api/custom_promotion_rules/XAyRWNUzyN/event_stores"
          }
        }
      },
      "meta": {
        "mode": "test",
        "organization_id": "xRRkjDFafe",
        "trace_id": "69abaa3545913c78132e5578bd26208d44aa9043647d78698fd0021f3958cd74"
      }
    },
    {
      "other": "... 9 custom_promotion_rules (first page)"
    }
  ],
  "meta": {
    "record_count": 140,
    "page_count": 14
  },
  "links": {
    "first": "https://yourdomain.commercelayer.io/api/custom_promotion_rules?page[number]=1&page[size]=10",
    "next": "https://yourdomain.commercelayer.io/api/custom_promotion_rules?page[number]=2&page[size]=10",
    "last": "https://yourdomain.commercelayer.io/api/custom_promotion_rules?page[number]=14&page[size]=10"
  }
}
```

{% endtab %}
{% endtabs %}

Remember that when you fetch a list of resources you get [paginated](https://docs.commercelayer.io/core/pagination) result.

### Sortable fields

The list of custom promotion rules can be [sorted](https://docs.commercelayer.io/core/sorting-results) by the following fields:

#### Attributes

* `type`
* `id`
* `created_at`
* `updated_at`
* `reference`
* `reference_origin`

### Filterable fields

The list of custom promotion rules can be [filtered](https://docs.commercelayer.io/core/filtering-data) by the following fields:

#### Attributes

* `type`
* `id`
* `created_at`
* `updated_at`
* `reference`
* `reference_origin`
* `metadata`

#### Relationships

* `promotion`
