Content API で補助フィードを使用する

補助フィードを使用して商品データを部分的に更新するには、products.insertproducts.deleteproducts.custombatch.insertproducts.custombatch.delete の各メソッドを呼び出す際にクエリ パラメータとして feedId を追加します。

たとえば、次の URL に対して products.insert 補助フィードのメソッド呼び出しを行うことができます。

POST https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products?feedId=feedId

products.insert

補助フィードの products.insert メソッドは、送信した商品フィールドをリクエスト本文に追加し、フィールドが存在する場合は上書きします。補助フィードを使用する場合、同じフィードの以前のリクエストにフィールドが含まれていた場合を除き、他のすべての商品フィールドは変更されません。他のフィードから追加されたデータは影響を受けませんが、同じフィードに対する以前のリクエストは、リクエストごとに上書きされます。つまり、補助フィード リクエストによってフィールドを追加または更新した後、そのフィールドを後続のリクエストに含めなかった場合、省略されたフィールドのデータはフィードから削除されます。この動作は、補助フィードを使用せずに products.insert を呼び出す場合とは異なります。補助フィードを使用すると、既存の商品データがすべて削除され、リクエスト本文で送信するフィールドに置き換えられます。

次の URL を使用して、補助フィードの Product.insert サービスにリクエストを送信します。

POST https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products?feedId=feedId

リクエスト本文には、offerIdfeedLabelchannelcontentLanguage フィールドを含める必要があります。それ以外のフィールドはすべて省略可能です。

商品の在庫状況を「在庫あり」から「在庫なし」に変更するには、次のリクエスト本文を使用して補助フィードの Product.insert メソッド呼び出しを行います。

{
 "offerId": "1111111111",
 "contentLanguage": "en",
 "feedLabel": "US",
 "channel": "online",
 "availability": "out of stock",
}

products.delete

products.delete メソッドは、指定された補助フィードを使用して、以前に products.insert 呼び出しによって追加されたすべての補助データを削除します。補助フィードに対してこのメソッドを呼び出しても、補助フィードの Product.insert 呼び出しが行われる前に追加された元の商品データには影響しません。これは、特定のフィードのデータレイヤを削除するようなものです。他のフィードを介して追加されたデータは影響を受けず、補助フィードのレイヤが追加される前の状態に商品は実質的に元の状態に戻ります。これは、補助フィードなしで products.delete を呼び出す場合と異なり、商品全体とそのすべてのデータが削除されます。

次の URL を使用して、補助フィードの products.delete サービスをリクエストします。ここで、productId は商品の REST ID で、channel:contentLanguage:feedLabel:offerId として表されます。

DELETE https://shoppingcontent.googleapis.com/content/v2.1/merchantId/products/productId?feedId=feedId

補助フィードの products.delete メソッド呼び出しにリクエスト本文は必要ありません。

products.custombatch

custombatch メソッドを使用すると、1 回の API 呼び出しで複数の商品の補助フィードデータを insert または delete にすることで、API 呼び出しの回数を最小限に抑えることができます。

次のリクエスト URL を使用して custombatch を呼び出します。

https://shoppingcontent.googleapis.com/content/v2.1/products/batch

すべての補助フィードの custombatch 呼び出しで、リクエスト本文に batchIdmerchantIDmethodfeedId の各パラメータを含める必要があります。

products.custombatch:insert

products.custombatch:insert メソッドに対して補助フィード呼び出しを行う場合は、必須の batchId パラメータ、merchantID パラメータ、method パラメータに加えて、リクエスト本文に offerIdfeedLabelchannelcontentLanguage を含める必要があります。その他の商品フィールドはすべて省略可能です。

既存の 2 つの商品の price 値を更新するには、次のリクエストを使用して products.custombatch:insert メソッドを呼び出します。

{
  "entries": [
    {
      "batchId": 1111,
      "merchantId": 1234567,
      "method": "insert",
      "feedId": "7654321",
      "product": {
         "offerId": "1111111111",
         "contentLanguage": "en",
         "targetCountry": "US",
         "feedLabel": "US",
         "channel": "online",
         "price": {
          "value": "30.99",
          "currency": "USD"
         }
      }
    },
    {
      "batchId": 1112,
      "merchantId": 1234567,
      "method": "insert",
      "feedId": "7654321",
      "product": {
         "offerId": "2222222222",
         "contentLanguage": "en",
         "targetCountry": "US",
         "feedLabel": "US",
         "channel": "online",
         "price": {
          "value": "33.99",
          "currency": "USD"
         },
      },
    }
}

products.custombatch:delete

指定した補助フィードを使用して 2 つの商品に加えられたすべての更新を削除するには、次のリクエストを使用して products.custombatch:delete メソッド呼び出しを行います。

{
  "entries": [
    {
      "batchId": 1115,
      "merchantId": 1234567,
      "method": "delete",
      "feedId": "7654321",
      "productId": "online:en:US:1111111111"
    },
    {
      "batchId": 1116,
      "merchantId": 1234567,
      "method": "delete",
      "feedId": "7654321",
      "productId": "online:en:US:2222222222"
    }
  ]
}