# Update an option value

> Partially update an option value using JSON Merge Patch.

`PATCH /rest/api/product_options/{productOptionId}/option_values/{optionValueId}`

Updates the Option Value resource.

Partially updates an option value. The body is a [JSON Merge Patch](https://datatracker.ietf.org/doc/html/rfc7396) document: include only the fields you want to change. Use it to rename a value or change its `position`.

> **Translations**
>
> Send `X-Flowkiwi-Locale` to update the `value` for a specific locale. Other locales keep their existing translation.

## 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                      |
| ----------------- | -------- | -------- | -------------------------------- |
| `productOptionId` | `string` | Yes      | ProductOptionResource identifier |
| `optionValueId`   | `string` | Yes      | Option Value identifier          |

## Request body

| Property   | Type              | Required | Description                                                                            |
| ---------- | ----------------- | -------- | -------------------------------------------------------------------------------------- |
| `value`    | `string \| null`  | -        | The value of the option.                                                               |
| `position` | `integer \| null` | -        | The position of the option value. Use -1 to put the option value at the end.           |
| `variants` | `string[]`        | -        | A list of `Variant`, each one representing a variant associated with the option value. |

## Response

**200** - Option Value resource updated

| Property        | Type              | Required | Description                                                                            |
| --------------- | ----------------- | -------- | -------------------------------------------------------------------------------------- |
| `@context`      | `object`          | -        |                                                                                        |
| `@id`           | `string`          | Yes      |                                                                                        |
| `@type`         | `string`          | Yes      |                                                                                        |
| `id`            | `string`          | -        |                                                                                        |
| `value`         | `string \| null`  | Yes      | **This property supports translations.**<br><br>The value of the option.               |
| `position`      | `integer \| null` | -        | The position of the option value. Use -1 to put the option value at the end.           |
| `productOption` | `string`          | Yes      | The `Product Option` to which this option value belongs.                               |
| `variants`      | `string[]`        | -        | A list of `Variant`, each one representing a variant associated with the option value. |
| `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/product_options/<option_id>/option_values/<option_value_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 '{
  "variants": [
    "/rest/api/variants/65d6cb60-2a29-5485-b4a3-7cb276e8c56b"
  ]
}'
```

### Example response

```json
{
  "@context": "/rest/api/contexts/OptionValue",
  "@id": "/rest/api/OptionValues/cded2e6d-e4ce-5b6c-8c73-9b29e4ab8fe6",
  "@type": "OptionValue",
  "id": "cded2e6d-e4ce-5b6c-8c73-9b29e4ab8fe6",
  "value": "Navy Blue",
  "position": 0,
  "productOption": "/rest/api/productOptions/5d58ddb2-408e-5c10-90d4-1272555859cc",
  "variants": [
    "/rest/api/variants/a83c6e81-8cd4-58af-a5d6-d8ab12da6014",
    "/rest/api/variants/c19c9878-2fea-5762-bc55-8095b03e2a08"
  ],
  "createdAt": "2024-01-01T00:00:00+00:00",
  "updatedAt": "2024-01-01T00:00:00+00:00"
}
```
