# Update a product

> Partially update a product using JSON Merge Patch.

`PATCH /rest/api/products/{id}`

Updates the Product resource.

Partially updates a product. The body is a [JSON Merge Patch](https://datatracker.ietf.org/doc/html/rfc7396) document: any field you include replaces the current value, and any field you omit is left untouched.

> **Merge Patch semantics**
>
> Omit a field to leave it untouched, or send a new value to replace it. Sending `null` clears a nullable field such as `description`; non-nullable fields like `status` reject `null`.

## 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        |
| ---- | -------- | -------- | ------------------ |
| `id` | `string` | Yes      | Product identifier |

## Request body

| Property      | Type                                 | Required | Description                                                                                        |
| ------------- | ------------------------------------ | -------- | -------------------------------------------------------------------------------------------------- |
| `status`      | `string`                             | -        | Status IRI controlling visibility. Required on create.                                             |
| `vendor`      | `string \| null`                     | -        | Brand or manufacturer the product is attributed to.                                                |
| `title`       | `string \| null`                     | -        | Customer-facing product title. Translatable - set the active locale with `X-Flowkiwi-Locale`.      |
| `description` | `string \| null`                     | -        | Long-form description. Markdown is not parsed by the API.                                          |
| `tags`        | `string \| null`                     | -        | Comma-separated list of free-form tags. Used for storefront filtering.                             |
| `category`    | `string \| null`                     | -        | Category IRI this product is attached to. Categories drive the attribute set.                      |
| `channels`    | `Channel.ChannelCreateInput[]`       | -        | List of Channel write inputs. Each entry assigns the product to a channel at creation time.        |
| `collections` | `Collection.CollectionCreateInput[]` | -        | List of Collection write inputs. Each entry attaches the product to a collection at creation time. |
| `medias`      | `Media[]`                            | -        | List of Media write inputs (ordered). Only images are accepted. Position determines display order. |

## Response

**200** - Product resource updated

| Property          | Type             | Required | Description                                                                                                                                                                                                                                                                                                   |
| ----------------- | ---------------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `@context`        | `object`         | -        |                                                                                                                                                                                                                                                                                                               |
| `@id`             | `string`         | Yes      |                                                                                                                                                                                                                                                                                                               |
| `@type`           | `string`         | Yes      |                                                                                                                                                                                                                                                                                                               |
| `id`              | `string`         | -        | Stable UUID of the product.                                                                                                                                                                                                                                                                                   |
| `status`          | `string`         | -        | The status of the product.                                                                                                                                                                                                                                                                                    |
| `vendor`          | `string \| null` | -        | The name of the product's vendor.                                                                                                                                                                                                                                                                             |
| `title`           | `string \| null` | -        | **This property supports translations.**<br><br>The name of the product.                                                                                                                                                                                                                                      |
| `description`     | `string \| null` | -        | **This property supports translations.**<br><br>A description of the product.                                                                                                                                                                                                                                 |
| `tags`            | `string \| null` | -        | A string of comma-separated tags.                                                                                                                                                                                                                                                                             |
| `variants`        | `string[]`       | -        | A list of `Variant`, each one representing a variant associated with the product. Serialized as IRI strings by default; pass `?expand=variants` to embed the full `Variant` objects (including `resolvedPrice`, `lowestPriceLast30Days`, `medias`, and `metafields` when composed with `?expand=metafields`). |
| `options`         | `string[]`       | -        | A list of `Product Option`, each one representing an option associated with the product. Serialized as IRI strings by default; pass `?expand=options` to embed the full `Product Option` objects.                                                                                                             |
| `category`        | `string \| null` | -        | The category to which this product belongs. Serialized as IRI string by default; pass `?expand=category` to embed the full `CategoryResource`.                                                                                                                                                                |
| `attributeValues` | `array`          | -        | A list of `Attribute Values`, each one representing an attribute value associated with the product.                                                                                                                                                                                                           |
| `channels`        | `string[]`       | -        | A list of `Channel`, each one representing a channel associated with the product. Serialized as IRI strings by default; pass `?expand=channels` to embed full `ChannelResource` objects.                                                                                                                      |
| `collections`     | `string[]`       | -        | A list of `Collection`, each one representing a collection associated with the product. Serialized as IRI strings by default; pass `?expand=collections` to embed full `CollectionResource` objects.                                                                                                          |
| `medias`          | `string[]`       | -        | A list of `Media`, ordered by position. Only media of type "image" can be associated with a product. Returned as IRI strings by default; pass `?expand=medias` to embed full `Media` objects.                                                                                                                 |
| `metafields`      | `string[]`       | -        | Metafields owned by this product. Serialized as IRI strings by default; pass `?expand=metafields` to embed full `MetafieldResource` objects.                                                                                                                                                                  |
| `createdAt`       | `string`         | -        | The date and time when the resource was created (ISO 8601 format).                                                                                                                                                                                                                                            |
| `updatedAt`       | `string`         | -        | The date and time when the resource was last modified (ISO 8601 format).                                                                                                                                                                                                                                      |

## Errors

**400** - Invalid input

| Property   | Type             | Required | Description                                                                                                                          |
| ---------- | ---------------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------ |
| `@context` | `object`         | -        |                                                                                                                                      |
| `@id`      | `string`         | Yes      |                                                                                                                                      |
| `@type`    | `string`         | Yes      |                                                                                                                                      |
| `title`    | `string \| null` | -        | A short, human-readable summary of the problem.                                                                                      |
| `detail`   | `string \| null` | -        | A human-readable explanation specific to this occurrence of the problem.                                                             |
| `status`   | `number \| null` | -        |                                                                                                                                      |
| `instance` | `string \| null` | -        | A URI reference that identifies the specific occurrence of the problem. It may or may not yield further information if dereferenced. |
| `type`     | `string`         | -        | A URI reference that identifies the problem type                                                                                     |

**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. |

**404** - Not found

| Property   | Type             | Required | Description                                                                                                                          |
| ---------- | ---------------- | -------- | ------------------------------------------------------------------------------------------------------------------------------------ |
| `@context` | `object`         | -        |                                                                                                                                      |
| `@id`      | `string`         | Yes      |                                                                                                                                      |
| `@type`    | `string`         | Yes      |                                                                                                                                      |
| `title`    | `string \| null` | -        | A short, human-readable summary of the problem.                                                                                      |
| `detail`   | `string \| null` | -        | A human-readable explanation specific to this occurrence of the problem.                                                             |
| `status`   | `number \| null` | -        |                                                                                                                                      |
| `instance` | `string \| null` | -        | A URI reference that identifies the specific occurrence of the problem. It may or may not yield further information if dereferenced. |
| `type`     | `string`         | -        | A URI reference that identifies the problem type                                                                                     |

**422** - An error occurred

| Property     | Type             | Required | Description |
| ------------ | ---------------- | -------- | ----------- |
| `@context`   | `object`         | -        |             |
| `@id`        | `string`         | Yes      |             |
| `@type`      | `string`         | Yes      |             |
| `status`     | `integer`        | -        |             |
| `violations` | `object[]`       | -        |             |
| `detail`     | `string`         | -        |             |
| `type`       | `string`         | -        |             |
| `title`      | `string \| null` | -        |             |
| `instance`   | `string \| null` | -        |             |

## Examples

### Example request

```bash
curl -X PATCH 'https://<tenant>.product-management.flowkiwi.net/rest/api/products/<product_id>' \
  -H 'Authorization: Bearer {token}' \
  -H 'X-Flowkiwi-Organization-Id: <org_id>' \
  -H 'Accept: application/ld+json' \
  -H 'Content-Type: application/merge-patch+json' \
  -d '{
  "channels": [
    "/rest/api/channels/89988dd5-ce8b-5af4-b246-5bcfb92bd410",
    "/rest/api/channels/2786518d-93f7-5487-8966-cb1558f01fa2"
  ]
}'
```

### Example response

```json
{
  "@context": "/rest/api/contexts/Product",
  "@id": "/rest/api/Products/9299445f-547d-57a1-a5b6-5d42dcebe113",
  "@type": "Product",
  "id": "9299445f-547d-57a1-a5b6-5d42dcebe113",
  "status": "/rest/api/statuses/DRAFT",
  "vendor": null,
  "title": null,
  "description": null,
  "tags": null,
  "variants": [],
  "options": [],
  "images": [],
  "category": null,
  "attributeValues": [],
  "channels": [
    "/rest/api/channels/22535ff1-160d-5f39-8a75-143fe0b968dd",
    "/rest/api/channels/01ed2615-09e7-5d17-bed5-8874ffae8a12"
  ],
  "collections": [],
  "createdAt": "2024-01-01T00:00:00+00:00",
  "updatedAt": "2024-01-01T00:00:00+00:00"
}
```
