# List metafields

> Retrieve the metafields stored on an owner record.

`GET /rest/api/{ownerResource}/{ownerId}/metafields`

Retrieves the collection of Metafield resources.

Returns the metafields stored on a single owner record, identified by `ownerResource` (such as `products`) and `ownerId`. Set `X-Flowkiwi-Locale` to read translatable values in a given locale.

## Headers

| Name                         | Type      | Required | Description                                                                                                                                       |
| ---------------------------- | --------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------------- |
| `X-Flowkiwi-Organization-Id` | `string`  | Yes      | The organization the request acts as. Determines the identity, permissions and ownership applied when reading or modifying data on the instance.  |
| `X-Flowkiwi-Locale`          | `string`  | -        | Specifies the locale for properties that support localization. If not provided, the default locale will be used.                                  |
| `X-Flowkiwi-Locale-Fallback` | `boolean` | -        | Enables the use of a fallback locale. If a property lacks a translation for the requested locale, the value from the default locale will be used. |

## Path parameters

| Name            | Type     | Required | Description                                                                                                                |
| --------------- | -------- | -------- | -------------------------------------------------------------------------------------------------------------------------- |
| `ownerResource` | `string` | Yes      | The owner resource type the metafields are scoped to (e.g. "products", "variants"); must match the definition's ownerType. |
| `ownerId`       | `string` | Yes      | The id of the owner record the metafields belong to.                                                                       |

## Query parameters

| Name           | Type      | Required | Description                  |
| -------------- | --------- | -------- | ---------------------------- |
| `page`         | `integer` | -        | The collection page number   |
| `itemsPerPage` | `integer` | -        | The number of items per page |

## Response

**200** - Metafield collection

| Property           | Type          | Required | Description |
| ------------------ | ------------- | -------- | ----------- |
| `hydra:totalItems` | `integer`     | -        |             |
| `hydra:search`     | `object`      | -        |             |
| `hydra:view`       | `object`      | -        |             |
| `hydra:member`     | `Metafield[]` | Yes      |             |

## Errors

**403** - Access denied. The caller is missing one or more identity permissions required for this operation.

| Property             | Type       | Required | Description                                                                                                                                |
| -------------------- | ---------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
| `@context`           | `object`   | -        |                                                                                                                                            |
| `@id`                | `string`   | Yes      |                                                                                                                                            |
| `@type`              | `string`   | Yes      |                                                                                                                                            |
| `type`               | `string`   | -        |                                                                                                                                            |
| `title`              | `string`   | -        |                                                                                                                                            |
| `status`             | `integer`  | -        |                                                                                                                                            |
| `detail`             | `string`   | -        |                                                                                                                                            |
| `missingPermissions` | `string[]` | -        | Identity permissions that the caller is missing for this operation. Present only when the 403 is caused by a denied identity:* permission. |

## Examples

### Example request

```bash
curl -X GET 'https://<tenant>.product-management.flowkiwi.net/rest/api/{ownerResource}/{ownerId}/metafields' \
  -H 'Authorization: Bearer {token}' \
  -H 'X-Flowkiwi-Organization-Id: <org_id>' \
  -H 'Accept: application/ld+json'
```

### Example response

```json
{
  "@context": "/contexts/Metafield",
  "@id": "/rest/api/products/019af93e-420e-79f8-800b-6680f03dce20/metafields",
  "@type": "hydra:Collection",
  "hydra:totalItems": 1,
  "hydra:member": [
    {
      "@context": "/contexts/Metafield",
      "@id": "/rest/api/products/019af93e-420e-79f8-800b-6680f03dce20/metafields/019afb02-2b3c-7d4e-9f50-1a2b3c4d5e6f",
      "@type": "Metafield",
      "id": "019afb02-2b3c-7d4e-9f50-1a2b3c4d5e6f",
      "value": "Machine wash cold at 30°C",
      "ownerId": "019af93e-420e-79f8-800b-6680f03dce20",
      "definition": "/rest/api/metafield_definitions/019afb01-1a2b-7c3d-8e4f-0a1b2c3d4e5f",
      "ownerResource": "products",
      "metaobject": [],
      "createdAt": "2026-01-15T09:30:00+00:00",
      "updatedAt": "2026-02-03T14:45:12+00:00"
    }
  ]
}
```
