Skip to content

カタログ項目を更新する

put

/catalogs/{catalog_name}/items/{item_id}

このエンドポイントを使用して、カタログのアイテムを更新する。

item_id が見つからない場合は、このエンドポイントがカタログにアイテムを作成する。このエンドポイントは同期である。

前提条件

このエンドポイントを使用するには、API キーcatalogs.replace_itemの権限が必要です。

レート制限

パスパラメーター

パラメータ 必須 データ型 説明
catalog_name 必須 文字列 カタログ名。
item_id 必須 文字列 カタログ項目のID。

リクエストパラメーター

パラメータ 必須 データ型 説明
items 必須 配列 アイテム・オブジェクトを含む配列。項目オブジェクトには、id フィールドを除き、カタログに存在するフィールドを含める必要があります。1つのリクエストにつき、1つのアイテムオブジェクトのみが許可される。

例のリクエスト

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
curl --location --request PUT 'https://rest.iad-03.braze.com/catalogs/restaurants/items/restaurant1' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR-REST-API-KEY' \
--data-raw '{
  "items": [
    {
      "Name": "Restaurant",
      "Loyalty_Program": false,
      "Location": {
        "Latitude": 33.6112,
        "Longitude": -117.8711
      },
      "Top_Dishes": [
        "Hamburger",
        "Deluxe Cheeseburger"
      ],
      "Open_Time": "2021-09-03T09:03:19.967+00:00"
    }
  ]
}'

応答

このエンドポイントには、200400404 という 3 つのステータスコード応答があります。

成功応答の例

ステータスコード 200 は、次の応答本文を返す可能性があります。

1
2
3
{
  "message": "success"
}

エラー応答例

ステータスコード 400 は、次の応答本文を返す可能性があります。遭遇する可能性のあるエラーの詳細については、「トラブルシューティング」を参照のこと。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
{
  "errors": [
    {
      "id": "invalid-fields",
      "message": "Some of the fields given do not exist in the catalog",
      "parameters": [
        "id"
      ],
      "parameter_values": [
        "restaurant1"
      ]
    }
  ],
  "message": "Invalid Request"
}

トラブルシューティング

以下の表は、返される可能性のあるエラーと、それに関連するトラブルシューティングの手順を示したものである。

エラー トラブルシューティング
arbitrary-error 任意のエラーが発生した。もう一度試すか、サポートに連絡する。
catalog-not-found カタログ名が有効であることを確認する。
filtered-set-field-too-long フィールド値は、項目の文字数制限を超えるフィルターセットで使用されている。
id-in-body リクエスト本文の項目 ID を削除します。
ids-too-large 各アイテムIDの文字数制限は250文字である。
invalid-ids アイテムID名に使用できる文字は、アルファベット、数字、ハイフン、アンダースコアである。
invalid-fields APIリクエストで送信するすべてのフィールドが、すでにカタログに存在していることを確認する。これは、エラーに記載されている ID フィールドとは関係ありません。
invalid-keys-in-value-object 項目オブジェクトのキーに . または $ を含めることはできません。
item-already-exists そのアイテムはすでにカタログに存在する。
item-array-invalid items はオブジェクト配列でなければなりません。
items-too-large 各項目の文字数制限は5,000文字である。
request-includes-too-many-items 1つのリクエストにつき1つのカタログ項目しか作成できない。
too-deep-nesting-in-value-object アイテム・オブジェクトは50レベル以上の入れ子を持つことはできない。
unable-to-coerce-value 項目タイプは変換できません。
「このページはどの程度役に立ちましたか?」
New Stuff!