# List all webhooks

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

## Request

**GET** <https://yourdomain.commercelayer.io/api/webhooks>

### **Example**

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

```shell
curl -g -X GET \
  'https://yourdomain.commercelayer.io/api/webhooks/' \
  -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": "webhooks",
      "links": {
        "self": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN"
      },
      "attributes": {
        "name": "myorg-orders.place",
        "topic": "orders.place",
        "callback_url": "https://yourapp.com/webhooks",
        "include_resources": [
          "customer",
          "shipping_address",
          "billing_address"
        ],
        "disabled_at": "2018-01-01T12:00:00.000Z",
        "shared_secret": "1c0994cc4e996e8c6ee56a2198f66f3c",
        "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"
        }
      },
      "relationships": {
        "last_event_callbacks": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/relationships/last_event_callbacks",
            "related": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/last_event_callbacks"
          }
        },
        "versions": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/relationships/versions",
            "related": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/versions"
          }
        },
        "event_stores": {
          "links": {
            "self": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/relationships/event_stores",
            "related": "https://yourdomain.commercelayer.io/api/webhooks/XAyRWNUzyN/event_stores"
          }
        }
      },
      "meta": {
        "mode": "test",
        "organization_id": "xRRkjDFafe",
        "trace_id": "69abaa3545913c78132e5578bd26208d44aa9043647d78698fd0021f3958cd74"
      }
    },
    {
      "other": "... 9 webhooks (first page)"
    }
  ],
  "meta": {
    "record_count": 140,
    "page_count": 14
  },
  "links": {
    "first": "https://yourdomain.commercelayer.io/api/webhooks?page[number]=1&page[size]=10",
    "next": "https://yourdomain.commercelayer.io/api/webhooks?page[number]=2&page[size]=10",
    "last": "https://yourdomain.commercelayer.io/api/webhooks?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 webhooks can be [sorted](https://docs.commercelayer.io/core/sorting-results) by the following fields:

#### Attributes

* `id`
* `disabled_at`
* `circuit_state`
* `circuit_failure_count`
* `created_at`
* `updated_at`
* `reference`
* `reference_origin`

### Filterable fields

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

#### Attributes

* `name`
* `topic`
* `id`
* `disabled_at`
* `circuit_state`
* `circuit_failure_count`
* `created_at`
* `updated_at`
* `reference`
* `reference_origin`
* `metadata`
