AI-generated Key Takeaways
- 
          Use the Merchant Promotions API to create and manage promotions, showcasing special offers for products sold on Google. 
- 
          Migrate promotion management from the Content API for Shopping to the Merchant Promotions API for enhanced features and functionalities. 
- 
          Leverage the accounts.promotionsresource to manage promotions, replacing previous Content API endpoints with new structured URLs.
- 
          Refer to the comparison table to understand key changes in resource names and attributes when transitioning from the Content API. 
- 
          The Merchant Promotions API currently supports insert, get, and list methods for promotions, with delete functionality to be determined. 
You can use the Merchant Promotions API to create and manage promotions on
Google. The
accounts.promotions
resource lets you showcase special offers for the products you sell on Google.
For more information, see Overview of Merchant Promotions
API.
Overview of changes from Content API for Shopping to Merchant API
A significant difference is that Content API for Shopping automatically
creates the data source upon the first promotion insertion, which doesn't
occur with Merchant API. To insert a promotion using Merchant API, you first
need to create a promotions data source.
For information about the fields in the promotionDataSource object in
accounts.dataSources resource, see PromotionDataSource.
Requests
To make requests, use the following URL.
POST https://merchantapi.googleapis.com/promotions/v1/{ACCOUNT_NAME}/promotions
Migrate from Content API for Shopping
The following compares the Content API for Shopping to the Merchant Promotions API for promotions-related requests.
URL
In the Content API for Shopping:
https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/promotions
in Merchant API becomes:
https://merchantapi.googleapis.com/promotions/v1/{parent=accounts/*}/promotions
Identifiers
In the Content API for Shopping:
{MERCHANT_ID}/promotions/{PROMOTION_ID}
in Merchant API becomes:
{NAME}
Methods
The Merchant API supports the following methods for promotions:
- Insert promotions
- Get promotions
- List promotions
Here's a comparison of promotion methods availability in the Content API for Shopping and the Merchant API:
| Feature | Content API for Shopping | Merchant API | 
|---|---|---|
| URL | https://shoppingcontent.googleapis.com/content/v2.1/{MERCHANT_ID}/promotions | https://merchantapi.googleapis.com/promotions/v1/{parent=accounts/*}/promotions | 
| Identifiers | {MERCHANT_ID}/promotions/{PROMOTION_ID} | {NAME} | 
| Methods | 
 | 
 | 
Field Changes
The table shows what changes for Promotions in the Merchant Promotions API.
To see an example for reference, see Local Inventory.
| Content API for Shopping | Merchant API | Description | 
|---|---|---|
| (not supported) | custom_attributes | A list of custom (user-provided) attributes. You can also use it to submit any attribute of the feed specification in its generic form. For example: 
{
  "name": "size type", "value": "regular"
}
exposed by the API. | 
| Not supported | data_source | Creating a promotion requires an existing data source. | 
| Not supported | attributes | Promotion specific attributes, for example, long_tile, promotion_effective_timeperiod, and others, are part of the attribute message. | 
| item_id | item_id_inclusion | The list of item IDs that a promotion applies to is renamed. | 
| store_id | store_id_inclusion | The list of store IDs that a promotion applies to is renamed. | 
| product_type | product_type_inclusion | The list of product types that a promotion applies to is renamed. | 
| item_group_id | item_group_id_inclusion | The list of item group IDs that a promotion applies to is renamed. | 
| brand | brand_inclusion | The list of brands that a promotion applies to is renamed. | 
| store_code | store_codes_inclusion | The list of store codes that a promotion applies to is renamed. | 
| 
price:
  {
    object (Price)
  }
 | 
price:
  {
    object (Price)
  }
 | The definition of Price has changed. 
   In the Content API for Shopping, Price
    
  The Price amount is now recorded in micros,
   
  The amount field name has changed from value to
   
  The currency field name has changed to
   | 
| order_limit | (not supported) | The order_limit attribute is not supported. | 
| shippingServiceNames[] | (not supported) | shippingServiceNames[] is not supported. | 
| money_budget | (not supported) | money_budget is not supported. | 
| promotion_destination_ids | promotion_destinations | promotionDestinationIds is renamed. | 
| Promotion Status 
{
  "destinationStatuses": [
    {
      "destination": string,
      "status": enum (State)
    }
  ],
  "promotionIssue": [
    {
    "code": string,
    "detail": string
    }
  ],
  "creationDate": string,
  "lastUpdateDate": string
}
 | Promotion Status has changed. More granular-level details are available in the issues. 
promotionStatus = {
  destinationStatuses = [
     {
     reportingContext = Enum
     status = Enum
     },
  ],
  itemLevelIssues = [
    {
    code = String
    severity = Enum
    resolution = String
    reportingContext = Enum
    description = String
    detail = String
    documentation = String applicableCountries = [
      String,
    ]
    }
  ]
}
 | |