{
  "canonicalName": "Shopping Content",
  "name": "content",
  "resources": {
    "csses": {
      "methods": {
        "list": {
          "flatPath": "{cssGroupId}/csses",
          "response": {
            "$ref": "ListCssesResponse"
          },
          "id": "content.csses.list",
          "parameterOrder": [
            "cssGroupId"
          ],
          "path": "{cssGroupId}/csses",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "cssGroupId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "int64",
              "description": "Required. The CSS group ID of CSS domains to be listed."
            },
            "pageSize": {
              "description": "The maximum number of CSS domains to return. The service may return fewer than this value. If unspecified, at most 50 CSS domains will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
              "location": "query",
              "format": "int32",
              "type": "integer"
            },
            "pageToken": {
              "location": "query",
              "description": "A page token, received from a previous `ListCsses` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListCsses` must match the call that provided the page token.",
              "type": "string"
            }
          },
          "description": "Lists CSS domains affiliated with a CSS group."
        },
        "updatelabels": {
          "request": {
            "$ref": "LabelIds"
          },
          "response": {
            "$ref": "Css"
          },
          "id": "content.csses.updatelabels",
          "flatPath": "{cssGroupId}/csses/{cssDomainId}/updatelabels",
          "path": "{cssGroupId}/csses/{cssDomainId}/updatelabels",
          "httpMethod": "POST",
          "parameterOrder": [
            "cssGroupId",
            "cssDomainId"
          ],
          "description": "Updates labels that are assigned to a CSS domain by its CSS group.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "cssDomainId": {
              "description": "Required. The ID of the updated CSS domain.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "cssGroupId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The CSS group ID of the updated CSS domain.",
              "format": "int64"
            }
          }
        },
        "get": {
          "path": "{cssGroupId}/csses/{cssDomainId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "cssGroupId",
            "cssDomainId"
          ],
          "description": "Retrieves a single CSS domain by ID.",
          "parameters": {
            "cssGroupId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the managing account. If this parameter is not the same as [cssDomainId](#cssDomainId), then this ID must be a CSS group ID and `cssDomainId` must be the ID of a CSS domain affiliated with this group.",
              "format": "int64"
            },
            "cssDomainId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. The ID of the CSS domain to return.",
              "format": "int64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.csses.get",
          "response": {
            "$ref": "Css"
          },
          "flatPath": "{cssGroupId}/csses/{cssDomainId}"
        }
      }
    },
    "reports": {
      "methods": {
        "search": {
          "path": "{merchantId}/reports/search",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Retrieves merchant performance metrics matching the search query and optionally segmented by selected dimensions.",
          "parameters": {
            "merchantId": {
              "description": "Required. Id of the merchant making the call. Must be a standalone account or an MCA subaccount.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.reports.search",
          "request": {
            "$ref": "SearchRequest"
          },
          "response": {
            "$ref": "SearchResponse"
          },
          "flatPath": "{merchantId}/reports/search"
        }
      }
    },
    "accounttax": {
      "methods": {
        "update": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accounttax/{accountId}",
          "httpMethod": "PUT",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "accountId": {
              "format": "uint64",
              "description": "The ID of the account for which to get/update account tax settings.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "description": "Updates the tax settings of the account. Any fields that are not provided are deleted from the resource.",
          "flatPath": "{merchantId}/accounttax/{accountId}",
          "request": {
            "$ref": "AccountTax"
          },
          "response": {
            "$ref": "AccountTax"
          },
          "id": "content.accounttax.update"
        },
        "list": {
          "flatPath": "{merchantId}/accounttax",
          "response": {
            "$ref": "AccounttaxListResponse"
          },
          "id": "content.accounttax.list",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/accounttax",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "pageToken": {
              "type": "string",
              "description": "The token returned by the previous request.",
              "location": "query"
            },
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account."
            },
            "maxResults": {
              "description": "The maximum number of tax settings to return in the response, used for paging.",
              "location": "query",
              "format": "uint32",
              "type": "integer"
            }
          },
          "description": "Lists the tax settings of the sub-accounts in your Merchant Center account."
        },
        "get": {
          "id": "content.accounttax.get",
          "response": {
            "$ref": "AccountTax"
          },
          "flatPath": "{merchantId}/accounttax/{accountId}",
          "description": "Retrieves the tax settings of the account.",
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "accountId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account for which to get/update account tax settings.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/accounttax/{accountId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ]
        },
        "custombatch": {
          "flatPath": "accounttax/batch",
          "id": "content.accounttax.custombatch",
          "request": {
            "$ref": "AccounttaxCustomBatchRequest"
          },
          "response": {
            "$ref": "AccounttaxCustomBatchResponse"
          },
          "parameterOrder": [],
          "path": "accounttax/batch",
          "httpMethod": "POST",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves and updates tax settings of multiple accounts in a single request."
        }
      }
    },
    "recommendations": {
      "methods": {
        "reportInteraction": {
          "request": {
            "$ref": "ReportInteractionRequest"
          },
          "id": "content.recommendations.reportInteraction",
          "flatPath": "{merchantId}/recommendations/reportInteraction",
          "description": "Reports an interaction on a recommendation for a merchant.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account that wants to report an interaction."
            }
          },
          "path": "{merchantId}/recommendations/reportInteraction",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ]
        },
        "generate": {
          "path": "{merchantId}/recommendations/generate",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Generates recommendations for a merchant.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "languageCode": {
              "description": "Optional. Language code of the client. If not set, the result will be in default language (English). This language code affects all fields prefixed with \"localized\". This should be set to ISO 639-1 country code. List of currently verified supported language code: en, fr, cs, da, de, es, it, nl, no, pl, pt, pt, fi, sv, vi, tr, th, ko, zh-CN, zh-TW, ja, id, hi",
              "location": "query",
              "type": "string"
            },
            "allowedTag": {
              "description": "Optional. List of allowed tags. Tags are a set of predefined strings that describe the category that individual recommendation types belong to. User can specify zero or more tags in this field to indicate what categories of recommendations they want to receive. Current list of supported tags: - TREND",
              "repeated": true,
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account to fetch recommendations for.",
              "required": true,
              "type": "string",
              "location": "path"
            }
          },
          "response": {
            "$ref": "GenerateRecommendationsResponse"
          },
          "id": "content.recommendations.generate",
          "flatPath": "{merchantId}/recommendations/generate"
        }
      }
    },
    "conversionsources": {
      "methods": {
        "delete": {
          "path": "{merchantId}/conversionsources/{conversionSourceId}",
          "httpMethod": "DELETE",
          "parameterOrder": [
            "merchantId",
            "conversionSourceId"
          ],
          "id": "content.conversionsources.delete",
          "description": "Archives an existing conversion source. It will be recoverable for 30 days. This archiving behavior is not typical in the Content API and unique to this service.",
          "flatPath": "{merchantId}/conversionsources/{conversionSourceId}",
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account that owns the new conversion source."
            },
            "conversionSourceId": {
              "description": "Required. The ID of the conversion source to be deleted.",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "create": {
          "path": "{merchantId}/conversionsources",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Creates a new conversion source.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. The ID of the account that owns the new conversion source.",
              "format": "int64"
            }
          },
          "request": {
            "$ref": "ConversionSource"
          },
          "response": {
            "$ref": "ConversionSource"
          },
          "id": "content.conversionsources.create",
          "flatPath": "{merchantId}/conversionsources"
        },
        "patch": {
          "request": {
            "$ref": "ConversionSource"
          },
          "response": {
            "$ref": "ConversionSource"
          },
          "id": "content.conversionsources.patch",
          "flatPath": "{merchantId}/conversionsources/{conversionSourceId}",
          "description": "Updates information of an existing conversion source.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "updateMask": {
              "format": "google-fieldmask",
              "type": "string",
              "description": "Optional. List of fields being updated. The following fields can be updated: `attribution_settings`, `display_name`, `currency_code`.",
              "location": "query"
            },
            "merchantId": {
              "description": "Required. The ID of the account that owns the new conversion source.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "conversionSourceId": {
              "description": "Required. The ID of the conversion source to be updated.",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "path": "{merchantId}/conversionsources/{conversionSourceId}",
          "httpMethod": "PATCH",
          "parameterOrder": [
            "merchantId",
            "conversionSourceId"
          ]
        },
        "list": {
          "flatPath": "{merchantId}/conversionsources",
          "id": "content.conversionsources.list",
          "response": {
            "$ref": "ListConversionSourcesResponse"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/conversionsources",
          "httpMethod": "GET",
          "parameters": {
            "pageSize": {
              "description": "The maximum number of conversion sources to return in a page. If no `page_size` is specified, `100` is used as the default value. The maximum value is `200`. Values above `200` will be coerced to `200`. Regardless of pagination, at most `200` conversion sources are returned in total.",
              "location": "query",
              "format": "int32",
              "type": "integer"
            },
            "pageToken": {
              "description": "Page token.",
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account that owns the new conversion source.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "showDeleted": {
              "type": "boolean",
              "description": "If true, also returns archived conversion sources.",
              "location": "query"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves the list of conversion sources the caller has access to."
        },
        "get": {
          "flatPath": "{merchantId}/conversionsources/{conversionSourceId}",
          "response": {
            "$ref": "ConversionSource"
          },
          "id": "content.conversionsources.get",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account that owns the new conversion source."
            },
            "conversionSourceId": {
              "required": true,
              "type": "string",
              "description": "Required. The REST ID of the collection.",
              "location": "path"
            }
          },
          "description": "Fetches a conversion source.",
          "parameterOrder": [
            "merchantId",
            "conversionSourceId"
          ],
          "path": "{merchantId}/conversionsources/{conversionSourceId}",
          "httpMethod": "GET"
        },
        "undelete": {
          "parameterOrder": [
            "merchantId",
            "conversionSourceId"
          ],
          "path": "{merchantId}/conversionsources/{conversionSourceId}:undelete",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account that owns the new conversion source.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "conversionSourceId": {
              "required": true,
              "type": "string",
              "description": "Required. The ID of the conversion source to be undeleted.",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Re-enables an archived conversion source.",
          "flatPath": "{merchantId}/conversionsources/{conversionSourceId}:undelete",
          "id": "content.conversionsources.undelete",
          "request": {
            "$ref": "UndeleteConversionSourceRequest"
          }
        }
      }
    },
    "promotions": {
      "methods": {
        "list": {
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/promotions",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "pageSize": {
              "location": "query",
              "description": "The maximum number of promotions to return. The service may return fewer than this value. If unspecified, at most 50 labels will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
              "type": "integer",
              "format": "int32"
            },
            "pageToken": {
              "type": "string",
              "description": "A page token, received from a previous `ListPromotion` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListPromotion` must match the call that provided the page token.",
              "location": "query"
            },
            "countryCode": {
              "description": "[CLDR country code](http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) (for example, \"US\"), used as a filter on promotions target country.",
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the account that contains the collection.",
              "format": "int64"
            },
            "languageCode": {
              "type": "string",
              "location": "query",
              "description": "The two-letter ISO 639-1 language code associated with the promotions, used as a filter."
            }
          },
          "description": "List all promotions from your Merchant Center account.",
          "flatPath": "{merchantId}/promotions",
          "response": {
            "$ref": "ListPromotionResponse"
          },
          "id": "content.promotions.list"
        },
        "get": {
          "id": "content.promotions.get",
          "response": {
            "$ref": "Promotion"
          },
          "flatPath": "{merchantId}/promotions/{id}",
          "path": "{merchantId}/promotions/{id}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "id"
          ],
          "description": "Retrieves a promotion from your Merchant Center account.",
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account that contains the collection."
            },
            "id": {
              "required": true,
              "type": "string",
              "description": "Required. REST ID of the promotion to retrieve.",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "create": {
          "id": "content.promotions.create",
          "request": {
            "$ref": "Promotion"
          },
          "response": {
            "$ref": "Promotion"
          },
          "flatPath": "{merchantId}/promotions",
          "description": "Inserts a promotion for your Merchant Center account. If the promotion already exists, then it updates the promotion instead. To [end or delete] (https://developers.google.com/shopping-content/guides/promotions#end_a_promotion) a promotion update the time period of the promotion to a time that has already passed.",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account that contains the collection.",
              "required": true,
              "type": "string",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/promotions",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ]
        }
      }
    },
    "shippingsettings": {
      "methods": {
        "getsupportedpickupservices": {
          "flatPath": "{merchantId}/supportedPickupServices",
          "id": "content.shippingsettings.getsupportedpickupservices",
          "response": {
            "$ref": "ShippingsettingsGetSupportedPickupServicesResponse"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/supportedPickupServices",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account for which to retrieve the supported pickup services."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves supported pickup services for an account."
        },
        "getsupportedholidays": {
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account for which to retrieve the supported holidays.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves supported holidays for an account.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/supportedHolidays",
          "httpMethod": "GET",
          "flatPath": "{merchantId}/supportedHolidays",
          "id": "content.shippingsettings.getsupportedholidays",
          "response": {
            "$ref": "ShippingsettingsGetSupportedHolidaysResponse"
          }
        },
        "getsupportedcarriers": {
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/supportedCarriers",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the account for which to retrieve the supported carriers.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves supported carriers and carrier services for an account.",
          "flatPath": "{merchantId}/supportedCarriers",
          "id": "content.shippingsettings.getsupportedcarriers",
          "response": {
            "$ref": "ShippingsettingsGetSupportedCarriersResponse"
          }
        },
        "update": {
          "description": "Updates the shipping settings of the account. Any fields that are not provided are deleted from the resource.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64"
            },
            "accountId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account for which to get/update shipping settings."
            }
          },
          "path": "{merchantId}/shippingsettings/{accountId}",
          "httpMethod": "PUT",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "request": {
            "$ref": "ShippingSettings"
          },
          "response": {
            "$ref": "ShippingSettings"
          },
          "id": "content.shippingsettings.update",
          "flatPath": "{merchantId}/shippingsettings/{accountId}"
        },
        "list": {
          "path": "{merchantId}/shippingsettings",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Lists the shipping settings of the sub-accounts in your Merchant Center account.",
          "parameters": {
            "maxResults": {
              "description": "The maximum number of shipping settings to return in the response, used for paging.",
              "location": "query",
              "format": "uint32",
              "type": "integer"
            },
            "pageToken": {
              "location": "query",
              "description": "The token returned by the previous request.",
              "type": "string"
            },
            "merchantId": {
              "description": "The ID of the managing account. This must be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.shippingsettings.list",
          "response": {
            "$ref": "ShippingsettingsListResponse"
          },
          "flatPath": "{merchantId}/shippingsettings"
        },
        "get": {
          "flatPath": "{merchantId}/shippingsettings/{accountId}",
          "id": "content.shippingsettings.get",
          "response": {
            "$ref": "ShippingSettings"
          },
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/shippingsettings/{accountId}",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "accountId": {
              "description": "The ID of the account for which to get/update shipping settings.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves the shipping settings of the account."
        },
        "custombatch": {
          "parameterOrder": [],
          "path": "shippingsettings/batch",
          "httpMethod": "POST",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves and updates the shipping settings of multiple accounts in a single request.",
          "flatPath": "shippingsettings/batch",
          "id": "content.shippingsettings.custombatch",
          "request": {
            "$ref": "ShippingsettingsCustomBatchRequest"
          },
          "response": {
            "$ref": "ShippingsettingsCustomBatchResponse"
          }
        }
      }
    },
    "liasettings": {
      "methods": {
        "get": {
          "response": {
            "$ref": "LiaSettings"
          },
          "id": "content.liasettings.get",
          "flatPath": "{merchantId}/liasettings/{accountId}",
          "path": "{merchantId}/liasettings/{accountId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "description": "Retrieves the LIA settings of the account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "accountId": {
              "description": "The ID of the account for which to get or update LIA settings.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "required": true,
              "type": "string",
              "location": "path"
            }
          }
        },
        "listposdataproviders": {
          "id": "content.liasettings.listposdataproviders",
          "response": {
            "$ref": "LiasettingsListPosDataProvidersResponse"
          },
          "flatPath": "liasettings/posdataproviders",
          "path": "liasettings/posdataproviders",
          "httpMethod": "GET",
          "parameterOrder": [],
          "description": "Retrieves the list of POS data providers that have active settings for the all eiligible countries.",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "getaccessiblegmbaccounts": {
          "flatPath": "{merchantId}/liasettings/{accountId}/accessiblegmbaccounts",
          "id": "content.liasettings.getaccessiblegmbaccounts",
          "response": {
            "$ref": "LiasettingsGetAccessibleGmbAccountsResponse"
          },
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/liasettings/{accountId}/accessiblegmbaccounts",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "accountId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account for which to retrieve accessible Business Profiles.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves the list of accessible Business Profiles."
        },
        "requestgmbaccess": {
          "flatPath": "{merchantId}/liasettings/{accountId}/requestgmbaccess",
          "response": {
            "$ref": "LiasettingsRequestGmbAccessResponse"
          },
          "id": "content.liasettings.requestgmbaccess",
          "parameterOrder": [
            "merchantId",
            "accountId",
            "gmbEmail"
          ],
          "path": "{merchantId}/liasettings/{accountId}/requestgmbaccess",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "accountId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account for which Business Profile access is requested.",
              "format": "uint64"
            },
            "gmbEmail": {
              "type": "string",
              "required": true,
              "location": "query",
              "description": "The email of the Business Profile."
            }
          },
          "description": "Requests access to a specified Business Profile."
        },
        "requestinventoryverification": {
          "flatPath": "{merchantId}/liasettings/{accountId}/requestinventoryverification/{country}",
          "response": {
            "$ref": "LiasettingsRequestInventoryVerificationResponse"
          },
          "id": "content.liasettings.requestinventoryverification",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "country": {
              "location": "path",
              "description": "The country for which inventory validation is requested.",
              "type": "string",
              "required": true
            },
            "accountId": {
              "description": "The ID of the account that manages the order. This cannot be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "description": "Requests inventory validation for the specified country.",
          "parameterOrder": [
            "merchantId",
            "accountId",
            "country"
          ],
          "path": "{merchantId}/liasettings/{accountId}/requestinventoryverification/{country}",
          "httpMethod": "POST"
        },
        "setposdataprovider": {
          "parameterOrder": [
            "merchantId",
            "accountId",
            "country"
          ],
          "path": "{merchantId}/liasettings/{accountId}/setposdataprovider",
          "httpMethod": "POST",
          "parameters": {
            "accountId": {
              "description": "The ID of the account for which to retrieve accessible Business Profiles.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "posDataProviderId": {
              "type": "string",
              "format": "uint64",
              "location": "query",
              "description": "The ID of POS data provider."
            },
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64"
            },
            "country": {
              "type": "string",
              "required": true,
              "location": "query",
              "description": "The country for which the POS data provider is selected."
            },
            "posExternalAccountId": {
              "type": "string",
              "location": "query",
              "description": "The account ID by which this merchant is known to the POS data provider."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Sets the POS data provider for the specified country.",
          "flatPath": "{merchantId}/liasettings/{accountId}/setposdataprovider",
          "id": "content.liasettings.setposdataprovider",
          "response": {
            "$ref": "LiasettingsSetPosDataProviderResponse"
          }
        },
        "update": {
          "path": "{merchantId}/liasettings/{accountId}",
          "httpMethod": "PUT",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "description": "Updates the LIA settings of the account. Any fields that are not provided are deleted from the resource.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "accountId": {
              "description": "The ID of the account for which to get or update LIA settings.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "request": {
            "$ref": "LiaSettings"
          },
          "response": {
            "$ref": "LiaSettings"
          },
          "id": "content.liasettings.update",
          "flatPath": "{merchantId}/liasettings/{accountId}"
        },
        "setomnichannelexperience": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/liasettings/{accountId}/setomnichannelexperience",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "accountId": {
              "description": "The ID of the account for which to retrieve accessible Business Profiles.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "lsfType": {
              "type": "string",
              "location": "query",
              "description": "The Local Store Front (LSF) type for this country. Acceptable values are: - \"`ghlsf`\" (Google-Hosted Local Store Front) - \"`mhlsfBasic`\" (Merchant-Hosted Local Store Front Basic) - \"`mhlsfFull`\" (Merchant-Hosted Local Store Front Full) More details about these types can be found here."
            },
            "pickupTypes": {
              "description": "The Pickup types for this country. Acceptable values are: - \"`pickupToday`\" - \"`pickupLater`\" ",
              "repeated": true,
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "country": {
              "location": "query",
              "description": "The CLDR country code (for example, \"US\") for which the omnichannel experience is selected.",
              "type": "string"
            }
          },
          "description": "Sets the omnichannel experience for the specified country. Only supported for merchants whose POS data provider is trusted to enable the corresponding experience. For more context, see these help articles [about LFP](https://support.google.com/merchants/answer/7676652) and [how to get started](https://support.google.com/merchants/answer/7676578) with it.",
          "flatPath": "{merchantId}/liasettings/{accountId}/setomnichannelexperience",
          "response": {
            "$ref": "LiaOmnichannelExperience"
          },
          "id": "content.liasettings.setomnichannelexperience"
        },
        "custombatch": {
          "id": "content.liasettings.custombatch",
          "request": {
            "$ref": "LiasettingsCustomBatchRequest"
          },
          "response": {
            "$ref": "LiasettingsCustomBatchResponse"
          },
          "flatPath": "liasettings/batch",
          "description": "Retrieves and/or updates the LIA settings of multiple accounts in a single request.",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "liasettings/batch",
          "httpMethod": "POST",
          "parameterOrder": []
        },
        "setinventoryverificationcontact": {
          "id": "content.liasettings.setinventoryverificationcontact",
          "response": {
            "$ref": "LiasettingsSetInventoryVerificationContactResponse"
          },
          "flatPath": "{merchantId}/liasettings/{accountId}/setinventoryverificationcontact",
          "path": "{merchantId}/liasettings/{accountId}/setinventoryverificationcontact",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "accountId",
            "country",
            "language",
            "contactName",
            "contactEmail"
          ],
          "description": "Sets the inventory verification contact for the specified country.",
          "parameters": {
            "accountId": {
              "format": "uint64",
              "description": "The ID of the account that manages the order. This cannot be a multi-client account.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "country": {
              "description": "The country for which inventory verification is requested.",
              "location": "query",
              "required": true,
              "type": "string"
            },
            "contactName": {
              "location": "query",
              "description": "The name of the inventory verification contact.",
              "type": "string",
              "required": true
            },
            "language": {
              "location": "query",
              "description": "The language for which inventory verification is requested.",
              "type": "string",
              "required": true
            },
            "contactEmail": {
              "description": "The email of the inventory verification contact.",
              "location": "query",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "list": {
          "description": "Lists the LIA settings of the sub-accounts in your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "pageToken": {
              "location": "query",
              "description": "The token returned by the previous request.",
              "type": "string"
            },
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account."
            },
            "maxResults": {
              "format": "uint32",
              "type": "integer",
              "description": "The maximum number of LIA settings to return in the response, used for paging.",
              "location": "query"
            }
          },
          "path": "{merchantId}/liasettings",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "response": {
            "$ref": "LiasettingsListResponse"
          },
          "id": "content.liasettings.list",
          "flatPath": "{merchantId}/liasettings"
        }
      }
    },
    "pos": {
      "methods": {
        "list": {
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the POS or inventory data provider."
            },
            "targetMerchantId": {
              "description": "The ID of the target merchant.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Lists the stores of the target merchant.",
          "parameterOrder": [
            "merchantId",
            "targetMerchantId"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/store",
          "httpMethod": "GET",
          "flatPath": "{merchantId}/pos/{targetMerchantId}/store",
          "id": "content.pos.list",
          "response": {
            "$ref": "PosListResponse"
          }
        },
        "custombatch": {
          "flatPath": "pos/batch",
          "request": {
            "$ref": "PosCustomBatchRequest"
          },
          "response": {
            "$ref": "PosCustomBatchResponse"
          },
          "id": "content.pos.custombatch",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {},
          "description": "Batches multiple POS-related calls in a single request.",
          "parameterOrder": [],
          "path": "pos/batch",
          "httpMethod": "POST"
        },
        "sale": {
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "description": "The ID of the POS or inventory data provider.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "targetMerchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the target merchant."
            }
          },
          "description": "Submit a sale event for the given merchant.",
          "parameterOrder": [
            "merchantId",
            "targetMerchantId"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/sale",
          "httpMethod": "POST",
          "flatPath": "{merchantId}/pos/{targetMerchantId}/sale",
          "request": {
            "$ref": "PosSaleRequest"
          },
          "response": {
            "$ref": "PosSaleResponse"
          },
          "id": "content.pos.sale"
        },
        "get": {
          "flatPath": "{merchantId}/pos/{targetMerchantId}/store/{storeCode}",
          "response": {
            "$ref": "PosStore"
          },
          "id": "content.pos.get",
          "parameterOrder": [
            "merchantId",
            "targetMerchantId",
            "storeCode"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/store/{storeCode}",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "storeCode": {
              "description": "A store code that is unique per merchant.",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "targetMerchantId": {
              "format": "uint64",
              "description": "The ID of the target merchant.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "merchantId": {
              "description": "The ID of the POS or inventory data provider.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "description": "Retrieves information about the given store."
        },
        "delete": {
          "parameterOrder": [
            "merchantId",
            "targetMerchantId",
            "storeCode"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/store/{storeCode}",
          "httpMethod": "DELETE",
          "flatPath": "{merchantId}/pos/{targetMerchantId}/store/{storeCode}",
          "parameters": {
            "targetMerchantId": {
              "format": "uint64",
              "description": "The ID of the target merchant.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the POS or inventory data provider.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "storeCode": {
              "required": true,
              "type": "string",
              "description": "A store code that is unique per merchant.",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.pos.delete",
          "description": "Deletes a store for the given merchant."
        },
        "inventory": {
          "id": "content.pos.inventory",
          "request": {
            "$ref": "PosInventoryRequest"
          },
          "response": {
            "$ref": "PosInventoryResponse"
          },
          "flatPath": "{merchantId}/pos/{targetMerchantId}/inventory",
          "description": "Submit inventory for the given merchant.",
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the POS or inventory data provider."
            },
            "targetMerchantId": {
              "format": "uint64",
              "description": "The ID of the target merchant.",
              "required": true,
              "type": "string",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/inventory",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "targetMerchantId"
          ]
        },
        "insert": {
          "id": "content.pos.insert",
          "request": {
            "$ref": "PosStore"
          },
          "response": {
            "$ref": "PosStore"
          },
          "flatPath": "{merchantId}/pos/{targetMerchantId}/store",
          "description": "Creates a store for the given merchant.",
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the POS or inventory data provider."
            },
            "targetMerchantId": {
              "description": "The ID of the target merchant.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/pos/{targetMerchantId}/store",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "targetMerchantId"
          ]
        }
      }
    },
    "productstatuses": {
      "methods": {
        "list": {
          "flatPath": "{merchantId}/productstatuses",
          "id": "content.productstatuses.list",
          "response": {
            "$ref": "ProductstatusesListResponse"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/productstatuses",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the account that contains the products. This account cannot be a multi-client account.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "pageToken": {
              "type": "string",
              "location": "query",
              "description": "The token returned by the previous request."
            },
            "maxResults": {
              "type": "integer",
              "format": "uint32",
              "location": "query",
              "description": "The maximum number of product statuses to return in the response, used for paging. The default value is 25. The maximum value is 250."
            },
            "destinations": {
              "type": "string",
              "location": "query",
              "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
              "repeated": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Lists the statuses of the products in your Merchant Center account."
        },
        "get": {
          "path": "{merchantId}/productstatuses/{productId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "description": "Gets the status of a product from your Merchant Center account.",
          "parameters": {
            "productId": {
              "required": true,
              "type": "string",
              "description": "The REST ID of the product.",
              "location": "path"
            },
            "destinations": {
              "location": "query",
              "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
              "repeated": true,
              "type": "string"
            },
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.productstatuses.get",
          "response": {
            "$ref": "ProductStatus"
          },
          "flatPath": "{merchantId}/productstatuses/{productId}"
        },
        "custombatch": {
          "flatPath": "productstatuses/batch",
          "request": {
            "$ref": "ProductstatusesCustomBatchRequest"
          },
          "response": {
            "$ref": "ProductstatusesCustomBatchResponse"
          },
          "id": "content.productstatuses.custombatch",
          "parameterOrder": [],
          "path": "productstatuses/batch",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {},
          "description": "Gets the statuses of multiple products in a single request."
        }
      }
    },
    "datafeeds": {
      "methods": {
        "list": {
          "description": "Lists the configurations for datafeeds in your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "maxResults": {
              "type": "integer",
              "format": "uint32",
              "location": "query",
              "description": "The maximum number of products to return in the response, used for paging."
            },
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account that manages the datafeeds. This account cannot be a multi-client account.",
              "format": "uint64"
            },
            "pageToken": {
              "location": "query",
              "description": "The token returned by the previous request.",
              "type": "string"
            }
          },
          "path": "{merchantId}/datafeeds",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "response": {
            "$ref": "DatafeedsListResponse"
          },
          "id": "content.datafeeds.list",
          "flatPath": "{merchantId}/datafeeds"
        },
        "update": {
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account."
            },
            "datafeedId": {
              "description": "The ID of the datafeed.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Updates a datafeed configuration of your Merchant Center account. Any fields that are not provided are deleted from the resource.",
          "parameterOrder": [
            "merchantId",
            "datafeedId"
          ],
          "path": "{merchantId}/datafeeds/{datafeedId}",
          "httpMethod": "PUT",
          "flatPath": "{merchantId}/datafeeds/{datafeedId}",
          "id": "content.datafeeds.update",
          "request": {
            "$ref": "Datafeed"
          },
          "response": {
            "$ref": "Datafeed"
          }
        },
        "custombatch": {
          "flatPath": "datafeeds/batch",
          "id": "content.datafeeds.custombatch",
          "request": {
            "$ref": "DatafeedsCustomBatchRequest"
          },
          "response": {
            "$ref": "DatafeedsCustomBatchResponse"
          },
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Deletes, fetches, gets, inserts and updates multiple datafeeds in a single request.",
          "parameterOrder": [],
          "path": "datafeeds/batch",
          "httpMethod": "POST"
        },
        "get": {
          "path": "{merchantId}/datafeeds/{datafeedId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "datafeedId"
          ],
          "description": "Retrieves a datafeed configuration from your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "datafeedId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the datafeed."
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account."
            }
          },
          "response": {
            "$ref": "Datafeed"
          },
          "id": "content.datafeeds.get",
          "flatPath": "{merchantId}/datafeeds/{datafeedId}"
        },
        "delete": {
          "id": "content.datafeeds.delete",
          "description": "Deletes a datafeed configuration from your Merchant Center account.",
          "flatPath": "{merchantId}/datafeeds/{datafeedId}",
          "parameters": {
            "datafeedId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the datafeed."
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/datafeeds/{datafeedId}",
          "httpMethod": "DELETE",
          "parameterOrder": [
            "merchantId",
            "datafeedId"
          ]
        },
        "fetchnow": {
          "flatPath": "{merchantId}/datafeeds/{datafeedId}/fetchNow",
          "id": "content.datafeeds.fetchnow",
          "response": {
            "$ref": "DatafeedsFetchNowResponse"
          },
          "parameterOrder": [
            "merchantId",
            "datafeedId"
          ],
          "path": "{merchantId}/datafeeds/{datafeedId}/fetchNow",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "datafeedId": {
              "format": "uint64",
              "description": "The ID of the datafeed to be fetched.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Invokes a fetch for the datafeed in your Merchant Center account. If you need to call this method more than once per day, we recommend you use the [Products service](https://developers.google.com/shopping-content/reference/rest/v2.1/products) to update your product data."
        },
        "insert": {
          "request": {
            "$ref": "Datafeed"
          },
          "response": {
            "$ref": "Datafeed"
          },
          "id": "content.datafeeds.insert",
          "flatPath": "{merchantId}/datafeeds",
          "path": "{merchantId}/datafeeds",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Registers a datafeed configuration with your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          }
        }
      }
    },
    "regionalinventory": {
      "methods": {
        "insert": {
          "request": {
            "$ref": "RegionalInventory"
          },
          "response": {
            "$ref": "RegionalInventory"
          },
          "id": "content.regionalinventory.insert",
          "flatPath": "{merchantId}/products/{productId}/regionalinventory",
          "path": "{merchantId}/products/{productId}/regionalinventory",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "description": "Updates the regional inventory of a product in your Merchant Center account. If a regional inventory with the same region ID already exists, this method updates that entry.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "productId": {
              "type": "string",
              "required": true,
              "location": "path",
              "description": "The REST ID of the product for which to update the regional inventory."
            },
            "merchantId": {
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          }
        },
        "custombatch": {
          "parameterOrder": [],
          "path": "regionalinventory/batch",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {},
          "description": "Updates regional inventory for multiple products or regions in a single request.",
          "flatPath": "regionalinventory/batch",
          "request": {
            "$ref": "RegionalinventoryCustomBatchRequest"
          },
          "response": {
            "$ref": "RegionalinventoryCustomBatchResponse"
          },
          "id": "content.regionalinventory.custombatch"
        }
      }
    },
    "shoppingadsprogram": {
      "methods": {
        "get": {
          "path": "{merchantId}/shoppingadsprogram",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Retrieves the status and review eligibility for the Shopping Ads program. Returns errors and warnings if they require action to resolve, will become disapprovals, or impact impressions. Use `accountstatuses` to view all issues for an account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account."
            }
          },
          "response": {
            "$ref": "ShoppingAdsProgramStatus"
          },
          "id": "content.shoppingadsprogram.get",
          "flatPath": "{merchantId}/shoppingadsprogram"
        },
        "requestreview": {
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "description": "Required. The ID of the account.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "description": "Requests a review of Shopping ads in a specific region. This method deprecated. Use the `MerchantSupportService` to view product and account issues and request a review.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/shoppingadsprogram/requestreview",
          "httpMethod": "POST",
          "flatPath": "{merchantId}/shoppingadsprogram/requestreview",
          "request": {
            "$ref": "RequestReviewShoppingAdsRequest"
          },
          "id": "content.shoppingadsprogram.requestreview"
        }
      }
    },
    "quotas": {
      "methods": {
        "list": {
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/quotas",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account that has quota. This account must be an admin.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "pageSize": {
              "location": "query",
              "description": "The maximum number of quotas to return in the response, used for paging. Defaults to 500; values above 1000 will be coerced to 1000.",
              "type": "integer",
              "format": "int32"
            },
            "pageToken": {
              "location": "query",
              "description": "Token (if provided) to retrieve the subsequent page. All other parameters must match the original call that provided the page token.",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Lists the daily call quota and usage per method for your Merchant Center account.",
          "flatPath": "{merchantId}/quotas",
          "id": "content.quotas.list",
          "response": {
            "$ref": "ListMethodQuotasResponse"
          }
        }
      }
    },
    "localinventory": {
      "methods": {
        "insert": {
          "request": {
            "$ref": "LocalInventory"
          },
          "response": {
            "$ref": "LocalInventory"
          },
          "id": "content.localinventory.insert",
          "flatPath": "{merchantId}/products/{productId}/localinventory",
          "description": "Updates the local inventory of a product in your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "productId": {
              "type": "string",
              "required": true,
              "location": "path",
              "description": "The REST ID of the product for which to update local inventory."
            },
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "uint64"
            }
          },
          "path": "{merchantId}/products/{productId}/localinventory",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "productId"
          ]
        },
        "custombatch": {
          "parameterOrder": [],
          "path": "localinventory/batch",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {},
          "description": "Updates local inventory for multiple products or stores in a single request.",
          "flatPath": "localinventory/batch",
          "request": {
            "$ref": "LocalinventoryCustomBatchRequest"
          },
          "response": {
            "$ref": "LocalinventoryCustomBatchResponse"
          },
          "id": "content.localinventory.custombatch"
        }
      }
    },
    "returnpolicyonline": {
      "methods": {
        "delete": {
          "parameterOrder": [
            "merchantId",
            "returnPolicyId"
          ],
          "path": "{merchantId}/returnpolicyonline/{returnPolicyId}",
          "httpMethod": "DELETE",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "flatPath": "{merchantId}/returnpolicyonline/{returnPolicyId}",
          "parameters": {
            "merchantId": {
              "description": "Required. The id of the merchant for which to retrieve the return policy online object.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "returnPolicyId": {
              "type": "string",
              "required": true,
              "location": "path",
              "description": "Required. The id of the return policy to delete."
            }
          },
          "description": "Deletes an existing return policy.",
          "id": "content.returnpolicyonline.delete"
        },
        "create": {
          "flatPath": "{merchantId}/returnpolicyonline",
          "id": "content.returnpolicyonline.create",
          "request": {
            "$ref": "ReturnPolicyOnline"
          },
          "response": {
            "$ref": "ReturnPolicyOnline"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/returnpolicyonline",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "int64",
              "description": "Required. The id of the merchant for which to retrieve the return policy online object."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Creates a new return policy."
        },
        "list": {
          "flatPath": "{merchantId}/returnpolicyonline",
          "response": {
            "$ref": "ListReturnPolicyOnlineResponse"
          },
          "id": "content.returnpolicyonline.list",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "description": "Required. The id of the merchant for which to retrieve the return policy online object.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "description": "Lists all existing return policies.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/returnpolicyonline",
          "httpMethod": "GET"
        },
        "patch": {
          "description": "Updates an existing return policy.",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The id of the merchant for which to retrieve the return policy online object.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "returnPolicyId": {
              "location": "path",
              "description": "Required. The id of the return policy to update.",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/returnpolicyonline/{returnPolicyId}",
          "httpMethod": "PATCH",
          "parameterOrder": [
            "merchantId",
            "returnPolicyId"
          ],
          "id": "content.returnpolicyonline.patch",
          "request": {
            "$ref": "ReturnPolicyOnline"
          },
          "response": {
            "$ref": "ReturnPolicyOnline"
          },
          "flatPath": "{merchantId}/returnpolicyonline/{returnPolicyId}"
        },
        "get": {
          "flatPath": "{merchantId}/returnpolicyonline/{returnPolicyId}",
          "id": "content.returnpolicyonline.get",
          "response": {
            "$ref": "ReturnPolicyOnline"
          },
          "parameterOrder": [
            "merchantId",
            "returnPolicyId"
          ],
          "path": "{merchantId}/returnpolicyonline/{returnPolicyId}",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. The id of the merchant for which to retrieve the return policy online object.",
              "format": "int64"
            },
            "returnPolicyId": {
              "description": "Required. The id of the return policy to retrieve.",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Gets an existing return policy."
        }
      }
    },
    "collectionstatuses": {
      "methods": {
        "get": {
          "flatPath": "{merchantId}/collectionstatuses/{collectionId}",
          "id": "content.collectionstatuses.get",
          "response": {
            "$ref": "CollectionStatus"
          },
          "parameterOrder": [
            "merchantId",
            "collectionId"
          ],
          "path": "{merchantId}/collectionstatuses/{collectionId}",
          "httpMethod": "GET",
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account.",
              "format": "int64"
            },
            "collectionId": {
              "location": "path",
              "description": "Required. The collectionId of the collection. CollectionId is the same as the REST ID of the collection.",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Gets the status of a collection from your Merchant Center account."
        },
        "list": {
          "description": "Lists the statuses of the collections in your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "pageSize": {
              "type": "integer",
              "format": "int32",
              "location": "query",
              "description": "The maximum number of collection statuses to return in the response, used for paging. Defaults to 50; values above 1000 will be coerced to 1000."
            },
            "pageToken": {
              "type": "string",
              "description": "Token (if provided) to retrieve the subsequent page. All other parameters must match the original call that provided the page token.",
              "location": "query"
            }
          },
          "path": "{merchantId}/collectionstatuses",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "response": {
            "$ref": "ListCollectionStatusesResponse"
          },
          "id": "content.collectionstatuses.list",
          "flatPath": "{merchantId}/collectionstatuses"
        }
      }
    },
    "freelistingsprogram": {
      "methods": {
        "requestreview": {
          "id": "content.freelistingsprogram.requestreview",
          "request": {
            "$ref": "RequestReviewFreeListingsRequest"
          },
          "flatPath": "{merchantId}/freelistingsprogram/requestreview",
          "path": "{merchantId}/freelistingsprogram/requestreview",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Requests a review of free listings in a specific region. This method deprecated. Use the `MerchantSupportService` to view product and account issues and request a review.",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "get": {
          "id": "content.freelistingsprogram.get",
          "response": {
            "$ref": "FreeListingsProgramStatus"
          },
          "flatPath": "{merchantId}/freelistingsprogram",
          "path": "{merchantId}/freelistingsprogram",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Retrieves the status and review eligibility for the free listing program. Returns errors and warnings if they require action to resolve, will become disapprovals, or impact impressions. Use `accountstatuses` to view all issues for an account.",
          "parameters": {
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        }
      },
      "resources": {
        "checkoutsettings": {
          "methods": {
            "get": {
              "description": "Gets Checkout settings for the given merchant. This includes information about review state, enrollment state and URL settings.",
              "parameters": {
                "merchantId": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Required. The ID of the account.",
                  "format": "int64"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "path": "{merchantId}/freelistingsprogram/checkoutsettings",
              "httpMethod": "GET",
              "parameterOrder": [
                "merchantId"
              ],
              "id": "content.freelistingsprogram.checkoutsettings.get",
              "response": {
                "$ref": "CheckoutSettings"
              },
              "flatPath": "{merchantId}/freelistingsprogram/checkoutsettings"
            },
            "insert": {
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "parameters": {
                "merchantId": {
                  "type": "string",
                  "required": true,
                  "location": "path",
                  "format": "int64",
                  "description": "Required. The ID of the account."
                }
              },
              "description": "Enrolls merchant in `Checkout` program.",
              "parameterOrder": [
                "merchantId"
              ],
              "path": "{merchantId}/freelistingsprogram/checkoutsettings",
              "httpMethod": "POST",
              "flatPath": "{merchantId}/freelistingsprogram/checkoutsettings",
              "request": {
                "$ref": "InsertCheckoutSettingsRequest"
              },
              "response": {
                "$ref": "CheckoutSettings"
              },
              "id": "content.freelistingsprogram.checkoutsettings.insert"
            },
            "delete": {
              "id": "content.freelistingsprogram.checkoutsettings.delete",
              "description": "Deletes `Checkout` settings and unenrolls merchant from `Checkout` program.",
              "flatPath": "{merchantId}/freelistingsprogram/checkoutsettings",
              "parameters": {
                "merchantId": {
                  "required": true,
                  "type": "string",
                  "location": "path",
                  "format": "int64",
                  "description": "Required. The ID of the account."
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "path": "{merchantId}/freelistingsprogram/checkoutsettings",
              "httpMethod": "DELETE",
              "parameterOrder": [
                "merchantId"
              ]
            }
          }
        }
      }
    },
    "products": {
      "methods": {
        "insert": {
          "id": "content.products.insert",
          "request": {
            "$ref": "Product"
          },
          "response": {
            "$ref": "Product"
          },
          "flatPath": "{merchantId}/products",
          "path": "{merchantId}/products",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Uploads a product to your Merchant Center account. If an item with the same channel, contentLanguage, offerId, and targetCountry already exists, this method updates that entry.",
          "parameters": {
            "feedId": {
              "location": "query",
              "description": "The Content API Supplemental Feed ID. If present then product insertion applies to the data in a supplemental feed.",
              "type": "string",
              "format": "uint64"
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "delete": {
          "path": "{merchantId}/products/{productId}",
          "httpMethod": "DELETE",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "id": "content.products.delete",
          "description": "Deletes a product from your Merchant Center account.",
          "flatPath": "{merchantId}/products/{productId}",
          "parameters": {
            "feedId": {
              "format": "uint64",
              "type": "string",
              "description": "The Content API Supplemental Feed ID. If present then product deletion applies to the data in a supplemental feed. If absent, entire product will be deleted.",
              "location": "query"
            },
            "merchantId": {
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "productId": {
              "required": true,
              "type": "string",
              "description": "The REST ID of the product.",
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "get": {
          "path": "{merchantId}/products/{productId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "description": "Retrieves a product from your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "productId": {
              "type": "string",
              "required": true,
              "location": "path",
              "description": "The REST ID of the product."
            },
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "response": {
            "$ref": "Product"
          },
          "id": "content.products.get",
          "flatPath": "{merchantId}/products/{productId}"
        },
        "custombatch": {
          "flatPath": "products/batch",
          "id": "content.products.custombatch",
          "request": {
            "$ref": "ProductsCustomBatchRequest"
          },
          "response": {
            "$ref": "ProductsCustomBatchResponse"
          },
          "parameterOrder": [],
          "path": "products/batch",
          "httpMethod": "POST",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Retrieves, inserts, and deletes multiple products in a single request."
        },
        "update": {
          "flatPath": "{merchantId}/products/{productId}",
          "id": "content.products.update",
          "request": {
            "$ref": "Product"
          },
          "response": {
            "$ref": "Product"
          },
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the account that contains the product. This account cannot be a multi-client account.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "productId": {
              "description": "The REST ID of the product for which to update.",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "updateMask": {
              "location": "query",
              "description": "The comma-separated list of product attributes to be updated. Example: `\"title,salePrice\"`. Attributes specified in the update mask without a value specified in the body will be deleted from the product. *You must specify the update mask to delete attributes.* Only top-level product attributes can be updated. If not defined, product attributes with set values will be updated and other attributes will stay unchanged.",
              "type": "string",
              "format": "google-fieldmask"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Updates an existing product in your Merchant Center account. Only updates attributes provided in the request.",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "path": "{merchantId}/products/{productId}",
          "httpMethod": "PATCH"
        },
        "list": {
          "response": {
            "$ref": "ProductsListResponse"
          },
          "id": "content.products.list",
          "flatPath": "{merchantId}/products",
          "path": "{merchantId}/products",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Lists the products in your Merchant Center account. The response might contain fewer items than specified by maxResults. Rely on nextPageToken to determine if there are more items to be requested.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that contains the products. This account cannot be a multi-client account."
            },
            "pageToken": {
              "description": "The token returned by the previous request.",
              "location": "query",
              "type": "string"
            },
            "maxResults": {
              "type": "integer",
              "format": "uint32",
              "location": "query",
              "description": "The maximum number of products to return in the response, used for paging. The default value is 25. The maximum value is 250."
            }
          }
        }
      }
    },
    "regions": {
      "methods": {
        "delete": {
          "parameterOrder": [
            "merchantId",
            "regionId"
          ],
          "path": "{merchantId}/regions/{regionId}",
          "httpMethod": "DELETE",
          "flatPath": "{merchantId}/regions/{regionId}",
          "parameters": {
            "regionId": {
              "description": "Required. The id of the region to delete.",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "merchantId": {
              "description": "Required. The id of the merchant for which to delete region definition.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.regions.delete",
          "description": "Deletes a region definition from your Merchant Center account."
        },
        "create": {
          "path": "{merchantId}/regions",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Creates a region definition in your Merchant Center account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "regionId": {
              "description": "Required. The id of the region to create.",
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "description": "Required. The id of the merchant for which to create region definition.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "request": {
            "$ref": "Region"
          },
          "response": {
            "$ref": "Region"
          },
          "id": "content.regions.create",
          "flatPath": "{merchantId}/regions"
        },
        "patch": {
          "parameterOrder": [
            "merchantId",
            "regionId"
          ],
          "path": "{merchantId}/regions/{regionId}",
          "httpMethod": "PATCH",
          "parameters": {
            "regionId": {
              "description": "Required. The id of the region to update.",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "merchantId": {
              "format": "int64",
              "description": "Required. The id of the merchant for which to update region definition.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "updateMask": {
              "description": "Optional. The comma-separated field mask indicating the fields to update. Example: `\"displayName,postalCodeArea.regionCode\"`.",
              "location": "query",
              "format": "google-fieldmask",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Updates a region definition in your Merchant Center account.",
          "flatPath": "{merchantId}/regions/{regionId}",
          "id": "content.regions.patch",
          "request": {
            "$ref": "Region"
          },
          "response": {
            "$ref": "Region"
          }
        },
        "list": {
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/regions",
          "httpMethod": "GET",
          "parameters": {
            "pageSize": {
              "description": "The maximum number of regions to return. The service may return fewer than this value. If unspecified, at most 50 rules will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
              "location": "query",
              "format": "int32",
              "type": "integer"
            },
            "pageToken": {
              "description": "A page token, received from a previous `ListRegions` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListRegions` must match the call that provided the page token.",
              "location": "query",
              "type": "string"
            },
            "merchantId": {
              "description": "Required. The id of the merchant for which to list region definitions.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Lists the regions in your Merchant Center account.",
          "flatPath": "{merchantId}/regions",
          "id": "content.regions.list",
          "response": {
            "$ref": "ListRegionsResponse"
          }
        },
        "get": {
          "id": "content.regions.get",
          "response": {
            "$ref": "Region"
          },
          "flatPath": "{merchantId}/regions/{regionId}",
          "description": "Retrieves a region defined in your Merchant Center account.",
          "parameters": {
            "regionId": {
              "required": true,
              "type": "string",
              "description": "Required. The id of the region to retrieve.",
              "location": "path"
            },
            "merchantId": {
              "format": "int64",
              "description": "Required. The id of the merchant for which to retrieve region definition.",
              "type": "string",
              "required": true,
              "location": "path"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/regions/{regionId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "regionId"
          ]
        }
      }
    },
    "ordertrackingsignals": {
      "methods": {
        "create": {
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the merchant for which the order signal is created.",
              "format": "int64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Creates new order tracking signal.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/ordertrackingsignals",
          "httpMethod": "POST",
          "flatPath": "{merchantId}/ordertrackingsignals",
          "id": "content.ordertrackingsignals.create",
          "request": {
            "$ref": "OrderTrackingSignal"
          },
          "response": {
            "$ref": "OrderTrackingSignal"
          }
        }
      }
    },
    "productdeliverytime": {
      "methods": {
        "delete": {
          "path": "{merchantId}/productdeliverytime/{productId}",
          "httpMethod": "DELETE",
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "description": "Deletes the delivery time of a product.",
          "id": "content.productdeliverytime.delete",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "flatPath": "{merchantId}/productdeliverytime/{productId}",
          "parameters": {
            "productId": {
              "required": true,
              "type": "string",
              "description": "Required. The Content API ID of the product, in the form `channel:contentLanguage:targetCountry:offerId`.",
              "location": "path"
            },
            "merchantId": {
              "description": "Required. The Google merchant ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          }
        },
        "get": {
          "response": {
            "$ref": "ProductDeliveryTime"
          },
          "id": "content.productdeliverytime.get",
          "flatPath": "{merchantId}/productdeliverytime/{productId}",
          "description": "Gets `productDeliveryTime` by `productId`.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "productId": {
              "required": true,
              "type": "string",
              "description": "Required. The Content API ID of the product, in the form `channel:contentLanguage:targetCountry:offerId`.",
              "location": "path"
            },
            "merchantId": {
              "description": "Required. The Google merchant ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "path": "{merchantId}/productdeliverytime/{productId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "productId"
          ]
        },
        "create": {
          "flatPath": "{merchantId}/productdeliverytime",
          "id": "content.productdeliverytime.create",
          "request": {
            "$ref": "ProductDeliveryTime"
          },
          "response": {
            "$ref": "ProductDeliveryTime"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/productdeliverytime",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "description": "The Google merchant ID of the account that contains the product. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Creates or updates the delivery time of a product."
        }
      }
    },
    "accounts": {
      "methods": {
        "delete": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accounts/{accountId}",
          "httpMethod": "DELETE",
          "flatPath": "{merchantId}/accounts/{accountId}",
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account, and accountId must be the ID of a sub-account of this account.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "accountId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account.",
              "format": "uint64"
            },
            "force": {
              "type": "boolean",
              "description": "Option to delete sub-accounts with products. The default value is false.",
              "default": "false",
              "location": "query"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.accounts.delete",
          "description": "Deletes a Merchant Center sub-account."
        },
        "verifyphonenumber": {
          "description": "Validates verification code to verify phone number for the account. If successful this will overwrite the value of `accounts.businessinformation.phoneNumber`. Only verified phone number will replace an existing verified phone number.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "accountId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. The ID of the account.",
              "format": "int64"
            },
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and accountId must be the ID of a sub-account of this account."
            }
          },
          "path": "{merchantId}/accounts/{accountId}/verifyphonenumber",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "request": {
            "$ref": "VerifyPhoneNumberRequest"
          },
          "response": {
            "$ref": "VerifyPhoneNumberResponse"
          },
          "id": "content.accounts.verifyphonenumber",
          "flatPath": "{merchantId}/accounts/{accountId}/verifyphonenumber"
        },
        "insert": {
          "description": "Creates a Merchant Center sub-account.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account."
            }
          },
          "path": "{merchantId}/accounts",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId"
          ],
          "request": {
            "$ref": "Account"
          },
          "response": {
            "$ref": "Account"
          },
          "id": "content.accounts.insert",
          "flatPath": "{merchantId}/accounts"
        },
        "list": {
          "id": "content.accounts.list",
          "response": {
            "$ref": "AccountsListResponse"
          },
          "flatPath": "{merchantId}/accounts",
          "path": "{merchantId}/accounts",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Lists the sub-accounts in your Merchant Center account.",
          "parameters": {
            "merchantId": {
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "maxResults": {
              "location": "query",
              "description": "The maximum number of accounts to return in the response, used for paging.",
              "type": "integer",
              "format": "uint32"
            },
            "view": {
              "description": "Controls which fields will be populated. Acceptable values are: \"merchant\" and \"css\". The default value is \"merchant\".",
              "enumDescriptions": [
                "Default. View is populated with Merchant Center fields.",
                "View is populated with Comparison Shopping Services fields."
              ],
              "enum": [
                "MERCHANT",
                "CSS"
              ],
              "type": "string",
              "location": "query"
            },
            "label": {
              "type": "string",
              "format": "uint64",
              "location": "query",
              "description": "If view is set to \"css\", only return accounts that are assigned label with given ID."
            },
            "pageToken": {
              "type": "string",
              "description": "The token returned by the previous request.",
              "location": "query"
            },
            "name": {
              "type": "string",
              "location": "query",
              "description": "If set, only the accounts with the given name (case sensitive) will be returned."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "authinfo": {
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Returns information about the authenticated user.",
          "parameterOrder": [],
          "path": "accounts/authinfo",
          "httpMethod": "GET",
          "flatPath": "accounts/authinfo",
          "id": "content.accounts.authinfo",
          "response": {
            "$ref": "AccountsAuthInfoResponse"
          }
        },
        "link": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accounts/{accountId}/link",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account."
            },
            "accountId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "uint64",
              "description": "The ID of the account that should be linked."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Performs an action on a link between two Merchant Center accounts, namely accountId and linkedAccountId.",
          "flatPath": "{merchantId}/accounts/{accountId}/link",
          "id": "content.accounts.link",
          "request": {
            "$ref": "AccountsLinkRequest"
          },
          "response": {
            "$ref": "AccountsLinkResponse"
          }
        },
        "requestphoneverification": {
          "path": "{merchantId}/accounts/{accountId}/requestphoneverification",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "description": "Request verification code to start phone verification.",
          "parameters": {
            "accountId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. The ID of the account.",
              "format": "int64"
            },
            "merchantId": {
              "description": "Required. The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and accountId must be the ID of a sub-account of this account.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.accounts.requestphoneverification",
          "request": {
            "$ref": "RequestPhoneVerificationRequest"
          },
          "response": {
            "$ref": "RequestPhoneVerificationResponse"
          },
          "flatPath": "{merchantId}/accounts/{accountId}/requestphoneverification"
        },
        "claimwebsite": {
          "id": "content.accounts.claimwebsite",
          "response": {
            "$ref": "AccountsClaimWebsiteResponse"
          },
          "flatPath": "{merchantId}/accounts/{accountId}/claimwebsite",
          "path": "{merchantId}/accounts/{accountId}/claimwebsite",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "description": "Claims the website of a Merchant Center sub-account. Merchant accounts with approved third-party CSSs aren't required to claim a website.",
          "parameters": {
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "accountId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account whose website is claimed.",
              "format": "uint64"
            },
            "overwrite": {
              "type": "boolean",
              "location": "query",
              "description": "Only available to selected merchants, for example multi-client accounts (MCAs) and their sub-accounts. When set to `True`, this option removes any existing claim on the requested website and replaces it with a claim from the account that makes the request."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ]
        },
        "update": {
          "parameters": {
            "accountId": {
              "format": "uint64",
              "description": "The ID of the account.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Updates a Merchant Center account. Any fields that are not provided are deleted from the resource.",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accounts/{accountId}",
          "httpMethod": "PUT",
          "flatPath": "{merchantId}/accounts/{accountId}",
          "id": "content.accounts.update",
          "request": {
            "$ref": "Account"
          },
          "response": {
            "$ref": "Account"
          }
        },
        "updatelabels": {
          "request": {
            "$ref": "AccountsUpdateLabelsRequest"
          },
          "response": {
            "$ref": "AccountsUpdateLabelsResponse"
          },
          "id": "content.accounts.updatelabels",
          "flatPath": "{merchantId}/accounts/{accountId}/updatelabels",
          "path": "{merchantId}/accounts/{accountId}/updatelabels",
          "httpMethod": "POST",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "description": "Updates labels that are assigned to the Merchant Center account by CSS user.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account."
            },
            "accountId": {
              "description": "The ID of the account whose labels are updated.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          }
        },
        "listlinks": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accounts/{accountId}/listlinks",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "accountId": {
              "format": "uint64",
              "description": "The ID of the account for which to list links.",
              "required": true,
              "type": "string",
              "location": "path"
            },
            "pageToken": {
              "type": "string",
              "location": "query",
              "description": "The token returned by the previous request."
            },
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64"
            },
            "maxResults": {
              "type": "integer",
              "format": "uint32",
              "location": "query",
              "description": "The maximum number of links to return in the response, used for pagination. The minimum allowed value is 5 results per page. If provided value is lower than 5, it will be automatically increased to 5."
            }
          },
          "description": "Returns the list of accounts linked to your Merchant Center account.",
          "flatPath": "{merchantId}/accounts/{accountId}/listlinks",
          "response": {
            "$ref": "AccountsListLinksResponse"
          },
          "id": "content.accounts.listlinks"
        },
        "get": {
          "description": "Retrieves a Merchant Center account.",
          "parameters": {
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "view": {
              "type": "string",
              "location": "query",
              "description": "Controls which fields will be populated. Acceptable values are: \"merchant\" and \"css\". The default value is \"merchant\".",
              "enumDescriptions": [
                "Default. View is populated with Merchant Center fields.",
                "View is populated with Comparison Shopping Services fields."
              ],
              "enum": [
                "MERCHANT",
                "CSS"
              ]
            },
            "accountId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/accounts/{accountId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "id": "content.accounts.get",
          "response": {
            "$ref": "Account"
          },
          "flatPath": "{merchantId}/accounts/{accountId}"
        },
        "custombatch": {
          "path": "accounts/batch",
          "httpMethod": "POST",
          "parameterOrder": [],
          "description": "Retrieves, inserts, updates, and deletes multiple Merchant Center (sub-)accounts in a single request.",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.accounts.custombatch",
          "request": {
            "$ref": "AccountsCustomBatchRequest"
          },
          "response": {
            "$ref": "AccountsCustomBatchResponse"
          },
          "flatPath": "accounts/batch"
        }
      },
      "resources": {
        "credentials": {
          "methods": {
            "create": {
              "request": {
                "$ref": "AccountCredentials"
              },
              "response": {
                "$ref": "AccountCredentials"
              },
              "id": "content.accounts.credentials.create",
              "flatPath": "accounts/{accountId}/credentials",
              "path": "accounts/{accountId}/credentials",
              "httpMethod": "POST",
              "parameterOrder": [
                "accountId"
              ],
              "description": "Uploads credentials for the Merchant Center account. If credentials already exist for this Merchant Center account and purpose, this method updates them.",
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "parameters": {
                "accountId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The merchant id of the account these credentials belong to.",
                  "format": "int64"
                }
              }
            }
          }
        },
        "labels": {
          "methods": {
            "create": {
              "description": "Creates a new label, not assigned to any account.",
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "parameters": {
                "accountId": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Required. The id of the account this label belongs to.",
                  "format": "int64"
                }
              },
              "path": "accounts/{accountId}/labels",
              "httpMethod": "POST",
              "parameterOrder": [
                "accountId"
              ],
              "request": {
                "$ref": "AccountLabel"
              },
              "response": {
                "$ref": "AccountLabel"
              },
              "id": "content.accounts.labels.create",
              "flatPath": "accounts/{accountId}/labels"
            },
            "list": {
              "flatPath": "accounts/{accountId}/labels",
              "id": "content.accounts.labels.list",
              "response": {
                "$ref": "ListAccountLabelsResponse"
              },
              "parameters": {
                "accountId": {
                  "format": "int64",
                  "description": "Required. The account id for whose labels are to be listed.",
                  "type": "string",
                  "required": true,
                  "location": "path"
                },
                "pageSize": {
                  "description": "The maximum number of labels to return. The service may return fewer than this value. If unspecified, at most 50 labels will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                  "location": "query",
                  "format": "int32",
                  "type": "integer"
                },
                "pageToken": {
                  "type": "string",
                  "location": "query",
                  "description": "A page token, received from a previous `ListAccountLabels` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListAccountLabels` must match the call that provided the page token."
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "description": "Lists the labels assigned to an account.",
              "parameterOrder": [
                "accountId"
              ],
              "path": "accounts/{accountId}/labels",
              "httpMethod": "GET"
            },
            "delete": {
              "path": "accounts/{accountId}/labels/{labelId}",
              "httpMethod": "DELETE",
              "parameterOrder": [
                "accountId",
                "labelId"
              ],
              "id": "content.accounts.labels.delete",
              "description": "Deletes a label and removes it from all accounts to which it was assigned.",
              "flatPath": "accounts/{accountId}/labels/{labelId}",
              "parameters": {
                "labelId": {
                  "type": "string",
                  "required": true,
                  "location": "path",
                  "format": "int64",
                  "description": "Required. The id of the label to delete."
                },
                "accountId": {
                  "description": "Required. The id of the account that owns the label.",
                  "format": "int64",
                  "location": "path",
                  "required": true,
                  "type": "string"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ]
            },
            "patch": {
              "parameters": {
                "labelId": {
                  "description": "Required. The id of the label to update.",
                  "format": "int64",
                  "location": "path",
                  "type": "string",
                  "required": true
                },
                "accountId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The id of the account this label belongs to.",
                  "format": "int64"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "description": "Updates a label.",
              "parameterOrder": [
                "accountId",
                "labelId"
              ],
              "path": "accounts/{accountId}/labels/{labelId}",
              "httpMethod": "PATCH",
              "flatPath": "accounts/{accountId}/labels/{labelId}",
              "id": "content.accounts.labels.patch",
              "request": {
                "$ref": "AccountLabel"
              },
              "response": {
                "$ref": "AccountLabel"
              }
            }
          }
        },
        "returncarrier": {
          "methods": {
            "delete": {
              "flatPath": "accounts/{accountId}/returncarrier/{carrierAccountId}",
              "parameters": {
                "carrierAccountId": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Required. The Google-provided unique carrier ID, used to update the resource.",
                  "format": "int64"
                },
                "accountId": {
                  "format": "int64",
                  "description": "Required. The Merchant Center Account Id under which the Return Carrier is to be linked.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "id": "content.accounts.returncarrier.delete",
              "description": "Delete a return carrier in the merchant account.",
              "parameterOrder": [
                "accountId",
                "carrierAccountId"
              ],
              "path": "accounts/{accountId}/returncarrier/{carrierAccountId}",
              "httpMethod": "DELETE"
            },
            "list": {
              "flatPath": "accounts/{accountId}/returncarrier",
              "response": {
                "$ref": "ListAccountReturnCarrierResponse"
              },
              "id": "content.accounts.returncarrier.list",
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "parameters": {
                "accountId": {
                  "format": "int64",
                  "description": "Required. The Merchant Center Account Id under which the Return Carrier is to be linked.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "description": "Lists available return carriers in the merchant account.",
              "parameterOrder": [
                "accountId"
              ],
              "path": "accounts/{accountId}/returncarrier",
              "httpMethod": "GET"
            },
            "patch": {
              "flatPath": "accounts/{accountId}/returncarrier/{carrierAccountId}",
              "id": "content.accounts.returncarrier.patch",
              "request": {
                "$ref": "AccountReturnCarrier"
              },
              "response": {
                "$ref": "AccountReturnCarrier"
              },
              "parameters": {
                "carrierAccountId": {
                  "format": "int64",
                  "description": "Required. The Google-provided unique carrier ID, used to update the resource.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                },
                "accountId": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Required. The Merchant Center Account Id under which the Return Carrier is to be linked.",
                  "format": "int64"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "description": "Updates a return carrier in the merchant account.",
              "parameterOrder": [
                "accountId",
                "carrierAccountId"
              ],
              "path": "accounts/{accountId}/returncarrier/{carrierAccountId}",
              "httpMethod": "PATCH"
            },
            "create": {
              "description": "Links return carrier to a merchant account.",
              "parameters": {
                "accountId": {
                  "description": "Required. The Merchant Center Account Id under which the Return Carrier is to be linked.",
                  "format": "int64",
                  "location": "path",
                  "type": "string",
                  "required": true
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/content"
              ],
              "path": "accounts/{accountId}/returncarrier",
              "httpMethod": "POST",
              "parameterOrder": [
                "accountId"
              ],
              "id": "content.accounts.returncarrier.create",
              "request": {
                "$ref": "AccountReturnCarrier"
              },
              "response": {
                "$ref": "AccountReturnCarrier"
              },
              "flatPath": "accounts/{accountId}/returncarrier"
            }
          }
        }
      }
    },
    "collections": {
      "methods": {
        "create": {
          "flatPath": "{merchantId}/collections",
          "id": "content.collections.create",
          "request": {
            "$ref": "Collection"
          },
          "response": {
            "$ref": "Collection"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/collections",
          "httpMethod": "POST",
          "parameters": {
            "merchantId": {
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Uploads a collection to your Merchant Center account. If a collection with the same collectionId already exists, this method updates that entry. In each update, the collection is completely replaced by the fields in the body of the update request."
        },
        "get": {
          "path": "{merchantId}/collections/{collectionId}",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId",
            "collectionId"
          ],
          "description": "Retrieves a collection from your Merchant Center account.",
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account.",
              "format": "int64"
            },
            "collectionId": {
              "description": "Required. The REST ID of the collection.",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "id": "content.collections.get",
          "response": {
            "$ref": "Collection"
          },
          "flatPath": "{merchantId}/collections/{collectionId}"
        },
        "list": {
          "path": "{merchantId}/collections",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ],
          "description": "Lists the collections in your Merchant Center account. The response might contain fewer items than specified by page_size. Rely on next_page_token to determine if there are more items to be requested.",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "pageSize": {
              "location": "query",
              "description": "The maximum number of collections to return in the response, used for paging. Defaults to 50; values above 1000 will be coerced to 1000.",
              "type": "integer",
              "format": "int32"
            },
            "pageToken": {
              "location": "query",
              "description": "Token (if provided) to retrieve the subsequent page. All other parameters must match the original call that provided the page token.",
              "type": "string"
            },
            "merchantId": {
              "required": true,
              "type": "string",
              "location": "path",
              "format": "int64",
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account."
            }
          },
          "response": {
            "$ref": "ListCollectionsResponse"
          },
          "id": "content.collections.list",
          "flatPath": "{merchantId}/collections"
        },
        "delete": {
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "flatPath": "{merchantId}/collections/{collectionId}",
          "parameters": {
            "merchantId": {
              "description": "Required. The ID of the account that contains the collection. This account cannot be a multi-client account.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "collectionId": {
              "location": "path",
              "description": "Required. The collectionId of the collection. CollectionId is the same as the REST ID of the collection.",
              "type": "string",
              "required": true
            }
          },
          "description": "Deletes a collection from your Merchant Center account.",
          "id": "content.collections.delete",
          "parameterOrder": [
            "merchantId",
            "collectionId"
          ],
          "path": "{merchantId}/collections/{collectionId}",
          "httpMethod": "DELETE"
        }
      }
    },
    "merchantsupport": {
      "methods": {
        "renderaccountissues": {
          "flatPath": "{merchantId}/merchantsupport/renderaccountissues",
          "id": "content.merchantsupport.renderaccountissues",
          "request": {
            "$ref": "RenderAccountIssuesRequestPayload"
          },
          "response": {
            "$ref": "RenderAccountIssuesResponse"
          },
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the account to fetch issues for.",
              "format": "int64"
            },
            "timeZone": {
              "type": "string",
              "description": "Optional. The [IANA](https://www.iana.org/time-zones) timezone used to localize times in support content. For example 'America/Los_Angeles'. If not set, results will use as a default UTC.",
              "location": "query"
            },
            "languageCode": {
              "type": "string",
              "location": "query",
              "description": "Optional. The [IETF BCP-47](https://tools.ietf.org/html/bcp47) language code used to localize support content. If not set, the result will be in default language `en-US`."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Provide a list of merchant's issues with a support content and available actions. This content and actions are meant to be rendered and shown in third-party applications.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/merchantsupport/renderaccountissues",
          "httpMethod": "POST"
        },
        "renderproductissues": {
          "parameterOrder": [
            "merchantId",
            "productId"
          ],
          "path": "{merchantId}/merchantsupport/renderproductissues/{productId}",
          "httpMethod": "POST",
          "parameters": {
            "productId": {
              "type": "string",
              "required": true,
              "location": "path",
              "description": "Required. The [REST_ID](https://developers.google.com/shopping-content/reference/rest/v2.1/products#Product.FIELDS.id) of the product to fetch issues for."
            },
            "languageCode": {
              "type": "string",
              "description": "Optional. The [IETF BCP-47](https://tools.ietf.org/html/bcp47) language code used to localize support content. If not set, the result will be in default language `en-US`.",
              "location": "query"
            },
            "merchantId": {
              "format": "int64",
              "description": "Required. The ID of the account that contains the product.",
              "type": "string",
              "required": true,
              "location": "path"
            },
            "timeZone": {
              "location": "query",
              "description": "Optional. The [IANA](https://www.iana.org/time-zones) timezone used to localize times in support content. For example 'America/Los_Angeles'. If not set, results will use as a default UTC.",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Provide a list of issues for merchant's product with a support content and available actions. This content and actions are meant to be rendered and shown in third-party applications.",
          "flatPath": "{merchantId}/merchantsupport/renderproductissues/{productId}",
          "id": "content.merchantsupport.renderproductissues",
          "request": {
            "$ref": "RenderProductIssuesRequestPayload"
          },
          "response": {
            "$ref": "RenderProductIssuesResponse"
          }
        },
        "triggeraction": {
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "Required. The ID of the merchant's account.",
              "format": "int64"
            },
            "languageCode": {
              "location": "query",
              "description": "Optional. Language code [IETF BCP 47 syntax](https://tools.ietf.org/html/bcp47) used to localize the response. If not set, the result will be in default language `en-US`.",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Start an action. The action can be requested by merchants in third-party application. Before merchants can request the action, the third-party application needs to show them action specific content and display a user input form. You can request access using [Trigger action allowlist form](https://docs.google.com/forms/d/e/1FAIpQLSfeV_sBW9MBQv9BMTV6JZ1g11PGHLdHsrefca-9h0LmpU7CUg/viewform?usp=sharing). The action can be successfully started only once all `required` inputs are provided. If any `required` input is missing, or invalid value was provided, the service will return 400 error. Validation errors will contain Ids for all problematic field together with translated, human readable error messages that can be shown to the user.",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/merchantsupport/triggeraction",
          "httpMethod": "POST",
          "flatPath": "{merchantId}/merchantsupport/triggeraction",
          "id": "content.merchantsupport.triggeraction",
          "request": {
            "$ref": "TriggerActionPayload"
          },
          "response": {
            "$ref": "TriggerActionResponse"
          }
        }
      }
    },
    "accountstatuses": {
      "methods": {
        "list": {
          "id": "content.accountstatuses.list",
          "response": {
            "$ref": "AccountstatusesListResponse"
          },
          "flatPath": "{merchantId}/accountstatuses",
          "description": "Lists the statuses of the sub-accounts in your Merchant Center account.",
          "parameters": {
            "pageToken": {
              "location": "query",
              "description": "The token returned by the previous request.",
              "type": "string"
            },
            "name": {
              "description": "If set, only the accounts with the given name (case sensitive) will be returned.",
              "location": "query",
              "type": "string"
            },
            "destinations": {
              "type": "string",
              "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
              "repeated": true,
              "location": "query"
            },
            "maxResults": {
              "description": "The maximum number of account statuses to return in the response, used for paging.",
              "location": "query",
              "format": "uint32",
              "type": "integer"
            },
            "merchantId": {
              "type": "string",
              "required": true,
              "location": "path",
              "format": "uint64",
              "description": "The ID of the managing account. This must be a multi-client account."
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "{merchantId}/accountstatuses",
          "httpMethod": "GET",
          "parameterOrder": [
            "merchantId"
          ]
        },
        "custombatch": {
          "description": "Retrieves multiple Merchant Center account statuses in a single request.",
          "parameters": {},
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "path": "accountstatuses/batch",
          "httpMethod": "POST",
          "parameterOrder": [],
          "id": "content.accountstatuses.custombatch",
          "request": {
            "$ref": "AccountstatusesCustomBatchRequest"
          },
          "response": {
            "$ref": "AccountstatusesCustomBatchResponse"
          },
          "flatPath": "accountstatuses/batch"
        },
        "get": {
          "parameterOrder": [
            "merchantId",
            "accountId"
          ],
          "path": "{merchantId}/accountstatuses/{accountId}",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "destinations": {
              "type": "string",
              "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
              "repeated": true,
              "location": "query"
            },
            "accountId": {
              "description": "The ID of the account.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "merchantId": {
              "description": "The ID of the managing account. If this parameter is not the same as accountId, then this account must be a multi-client account and `accountId` must be the ID of a sub-account of this account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            }
          },
          "description": "Retrieves the status of a Merchant Center account. No itemLevelIssues are returned for multi-client accounts.",
          "flatPath": "{merchantId}/accountstatuses/{accountId}",
          "response": {
            "$ref": "AccountStatus"
          },
          "id": "content.accountstatuses.get"
        }
      }
    },
    "datafeedstatuses": {
      "methods": {
        "list": {
          "flatPath": "{merchantId}/datafeedstatuses",
          "id": "content.datafeedstatuses.list",
          "response": {
            "$ref": "DatafeedstatusesListResponse"
          },
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/datafeedstatuses",
          "httpMethod": "GET",
          "parameters": {
            "maxResults": {
              "location": "query",
              "description": "The maximum number of products to return in the response, used for paging.",
              "type": "integer",
              "format": "uint32"
            },
            "merchantId": {
              "description": "The ID of the account that manages the datafeeds. This account cannot be a multi-client account.",
              "format": "uint64",
              "location": "path",
              "type": "string",
              "required": true
            },
            "pageToken": {
              "description": "The token returned by the previous request.",
              "location": "query",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Lists the statuses of the datafeeds in your Merchant Center account."
        },
        "get": {
          "parameterOrder": [
            "merchantId",
            "datafeedId"
          ],
          "path": "{merchantId}/datafeedstatuses/{datafeedId}",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account that manages the datafeed. This account cannot be a multi-client account.",
              "format": "uint64"
            },
            "country": {
              "description": "Deprecated. Use `feedLabel` instead. The country to get the datafeed status for. If this parameter is provided then `language` must also be provided. Note that this parameter is required for feeds targeting multiple countries and languages, since a feed may have a different status for each target.",
              "location": "query",
              "type": "string"
            },
            "feedLabel": {
              "type": "string",
              "description": "The feed label to get the datafeed status for. If this parameter is provided then `language` must also be provided. Note that this parameter is required for feeds targeting multiple countries and languages, since a feed may have a different status for each target.",
              "location": "query"
            },
            "language": {
              "type": "string",
              "location": "query",
              "description": "The language to get the datafeed status for. If this parameter is provided then `country` must also be provided. Note that this parameter is required for feeds targeting multiple countries and languages, since a feed may have a different status for each target."
            },
            "datafeedId": {
              "description": "The ID of the datafeed.",
              "format": "uint64",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "description": "Retrieves the status of a datafeed from your Merchant Center account.",
          "flatPath": "{merchantId}/datafeedstatuses/{datafeedId}",
          "response": {
            "$ref": "DatafeedStatus"
          },
          "id": "content.datafeedstatuses.get"
        },
        "custombatch": {
          "flatPath": "datafeedstatuses/batch",
          "request": {
            "$ref": "DatafeedstatusesCustomBatchRequest"
          },
          "response": {
            "$ref": "DatafeedstatusesCustomBatchResponse"
          },
          "id": "content.datafeedstatuses.custombatch",
          "parameterOrder": [],
          "path": "datafeedstatuses/batch",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {},
          "description": "Gets multiple Merchant Center datafeed statuses in a single request."
        }
      }
    },
    "pubsubnotificationsettings": {
      "methods": {
        "get": {
          "flatPath": "{merchantId}/pubsubnotificationsettings",
          "response": {
            "$ref": "PubsubNotificationSettings"
          },
          "id": "content.pubsubnotificationsettings.get",
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/pubsubnotificationsettings",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "parameters": {
            "merchantId": {
              "location": "path",
              "type": "string",
              "required": true,
              "description": "The ID of the account for which to get pubsub notification settings.",
              "format": "uint64"
            }
          },
          "description": "Retrieves a Merchant Center account's pubsub notification settings."
        },
        "update": {
          "parameterOrder": [
            "merchantId"
          ],
          "path": "{merchantId}/pubsubnotificationsettings",
          "httpMethod": "PUT",
          "parameters": {
            "merchantId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "The ID of the account.",
              "format": "uint64"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/content"
          ],
          "description": "Register a Merchant Center account for pubsub notifications. Note that cloud topic name shouldn't be provided as part of the request.",
          "flatPath": "{merchantId}/pubsubnotificationsettings",
          "id": "content.pubsubnotificationsettings.update",
          "request": {
            "$ref": "PubsubNotificationSettings"
          },
          "response": {
            "$ref": "PubsubNotificationSettings"
          }
        }
      }
    }
  },
  "fullyEncodeReservedExpansion": true,
  "ownerDomain": "google.com",
  "baseUrl": "https://shoppingcontent.googleapis.com/content/v2.1/",
  "parameters": {
    "alt": {
      "description": "Data format for response.",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "type": "string",
      "default": "json",
      "location": "query"
    },
    "upload_protocol": {
      "location": "query",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "type": "string"
    },
    "fields": {
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query",
      "type": "string"
    },
    "callback": {
      "location": "query",
      "description": "JSONP",
      "type": "string"
    },
    "key": {
      "location": "query",
      "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token.",
      "type": "string"
    },
    "oauth_token": {
      "type": "string",
      "location": "query",
      "description": "OAuth 2.0 token for the current user."
    },
    "access_token": {
      "type": "string",
      "description": "OAuth access token.",
      "location": "query"
    },
    "quotaUser": {
      "location": "query",
      "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.",
      "type": "string"
    },
    "$.xgafv": {
      "location": "query",
      "type": "string",
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ]
    },
    "uploadType": {
      "type": "string",
      "location": "query",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\")."
    },
    "prettyPrint": {
      "description": "Returns response with indentations and line breaks.",
      "default": "true",
      "location": "query",
      "type": "boolean"
    }
  },
  "basePath": "/content/v2.1/",
  "revision": "20260303",
  "id": "content:v2.1",
  "version": "v2.1",
  "batchPath": "batch",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/content": {
          "description": "Manage your product listings and accounts for Google Shopping"
        }
      }
    }
  },
  "description": "This API is deprecated. Please use Merchant API instead: https://developers.google.com/merchant/api. ",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "documentationLink": "https://developers.google.com/shopping-content/v2/",
  "schemas": {
    "RegionalInventory": {
      "description": "Regional inventory resource. contains the regional name and all attributes which are overridden for the specified region.",
      "id": "RegionalInventory",
      "properties": {
        "salePriceEffectiveDate": {
          "description": "A date range represented by a pair of ISO 8601 dates separated by a space, comma, or slash. Both dates might be specified as 'null' if undecided.",
          "type": "string"
        },
        "price": {
          "description": "The price of the product.",
          "$ref": "Price"
        },
        "customAttributes": {
          "description": "A list of custom (merchant-provided) attributes. It can also be used for submitting any attribute of the feed specification in its generic form.",
          "items": {
            "$ref": "CustomAttribute"
          },
          "type": "array"
        },
        "regionId": {
          "type": "string",
          "description": "The ID uniquely identifying each region."
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#regionalInventory`\"."
        },
        "salePrice": {
          "description": "The sale price of the product. Mandatory if `sale_price_effective_date` is defined.",
          "$ref": "Price"
        },
        "availability": {
          "description": "The availability of the product.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "OrderTrackingSignalShipmentLineItemMapping": {
      "id": "OrderTrackingSignalShipmentLineItemMapping",
      "description": "Represents how many items are in the shipment for the given shipment_id and line_item_id.",
      "type": "object",
      "properties": {
        "lineItemId": {
          "type": "string",
          "description": "Required. The line item ID."
        },
        "quantity": {
          "format": "int64",
          "type": "string",
          "description": "The line item quantity in the shipment."
        },
        "shipmentId": {
          "type": "string",
          "description": "Required. The shipment ID. This field will be hashed in returned OrderTrackingSignal creation response."
        }
      }
    },
    "ProductShippingDimension": {
      "type": "object",
      "properties": {
        "unit": {
          "type": "string",
          "description": "The unit of value."
        },
        "value": {
          "type": "number",
          "format": "double",
          "description": "The dimension of the product used to calculate the shipping cost of the item."
        }
      },
      "id": "ProductShippingDimension"
    },
    "InputValueCheckboxInputValue": {
      "id": "InputValueCheckboxInputValue",
      "description": "Value for checkbox input field.",
      "type": "object",
      "properties": {
        "value": {
          "description": "Required. True if the merchant checked the box field. False otherwise.",
          "type": "boolean"
        }
      }
    },
    "ProductId": {
      "type": "object",
      "properties": {
        "productId": {
          "description": "The Content API ID of the product, in the form `channel:contentLanguage:targetCountry:offerId`.",
          "type": "string"
        }
      },
      "id": "ProductId",
      "description": "The Content API ID of the product."
    },
    "RequestPhoneVerificationResponse": {
      "type": "object",
      "properties": {
        "verificationId": {
          "description": "The verification ID to use in subsequent calls to `verifyphonenumber`.",
          "type": "string"
        }
      },
      "id": "RequestPhoneVerificationResponse",
      "description": "Response message for the RequestPhoneVerification method."
    },
    "TextWithTooltip": {
      "type": "object",
      "properties": {
        "tooltipIconStyle": {
          "description": "The suggested type of an icon for tooltip, if a tooltip is present.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Used when the tooltip adds additional information to the context, the 'i' can be used as an icon.",
            "Used when the tooltip shows helpful information, the '?' can be used as an icon."
          ],
          "enum": [
            "TOOLTIP_ICON_STYLE_UNSPECIFIED",
            "INFO",
            "QUESTION"
          ],
          "type": "string"
        },
        "simpleValue": {
          "type": "string",
          "description": "Value of the message as a simple text."
        },
        "simpleTooltipValue": {
          "description": "Value of the tooltip as a simple text.",
          "type": "string"
        }
      },
      "id": "TextWithTooltip",
      "description": "Block of text that may contain a tooltip with more information."
    },
    "GmbAccountsGmbAccount": {
      "id": "GmbAccountsGmbAccount",
      "type": "object",
      "properties": {
        "listingCount": {
          "format": "uint64",
          "type": "string",
          "description": "Number of listings under this account."
        },
        "type": {
          "description": "The type of the Business Profile (User or Business).",
          "type": "string"
        },
        "email": {
          "type": "string",
          "description": "The email which identifies the Business Profile."
        },
        "name": {
          "type": "string",
          "description": "The name of the Business Profile."
        }
      }
    },
    "RenderAccountIssuesResponse": {
      "type": "object",
      "properties": {
        "issues": {
          "description": "List of account issues for a given account. This list can be shown with compressed, expandable items. In the compressed form, the title and impact should be shown for each issue. Once the issue is expanded, the detailed content and available actions should be rendered.",
          "items": {
            "$ref": "AccountIssue"
          },
          "type": "array"
        },
        "alternateDisputeResolution": {
          "description": "Alternate Dispute Resolution (ADR) is deprecated. Use `prerendered_out_of_court_dispute_settlement` instead.",
          "deprecated": true,
          "$ref": "AlternateDisputeResolution"
        }
      },
      "id": "RenderAccountIssuesResponse",
      "description": "Response containing support content and actions for listed account issues."
    },
    "ShoppingAdsProgramStatus": {
      "description": "Response message for GetShoppingAdsProgramStatus.",
      "id": "ShoppingAdsProgramStatus",
      "properties": {
        "globalState": {
          "description": "State of the program. `ENABLED` if there are offers for at least one region.",
          "enumDescriptions": [
            "State is unknown.",
            "Program is not enabled for any country.",
            "No products have been uploaded for any region. Upload products to Merchant Center.",
            "Program is enabled and offers are uploaded for at least one country."
          ],
          "enum": [
            "PROGRAM_STATE_UNSPECIFIED",
            "NOT_ENABLED",
            "NO_OFFERS_UPLOADED",
            "ENABLED"
          ],
          "type": "string"
        },
        "regionStatuses": {
          "type": "array",
          "description": "Status of the program in each region. Regions with the same status and review eligibility are grouped together in `regionCodes`.",
          "items": {
            "$ref": "ShoppingAdsProgramStatusRegionStatus"
          }
        }
      },
      "type": "object"
    },
    "Segments": {
      "type": "object",
      "properties": {
        "categoryL2": {
          "type": "string",
          "description": "[Product category (2nd level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in Google's product taxonomy."
        },
        "offerId": {
          "type": "string",
          "description": "Merchant-provided id of the product."
        },
        "productTypeL5": {
          "description": "[Product type (5th level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in merchant's own product taxonomy.",
          "type": "string"
        },
        "customLabel0": {
          "description": "Custom label 0 for custom grouping of products.",
          "type": "string"
        },
        "brand": {
          "type": "string",
          "description": "Brand of the product."
        },
        "categoryL3": {
          "type": "string",
          "description": "[Product category (3rd level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in Google's product taxonomy."
        },
        "program": {
          "description": "Program to which metrics apply, for example, Free Product Listing.",
          "enumDescriptions": [
            "Not specified.",
            "Shopping Ads.",
            "Free Product Listing.",
            "Free Local Product Listing.",
            "*Deprecated*: This value is no longer supported. Retrieving all metrics for the `BUY_ON_GOOGLE_LISTING` program returns 0 starting from May 2024. Buy on Google Listing."
          ],
          "enum": [
            "PROGRAM_UNSPECIFIED",
            "SHOPPING_ADS",
            "FREE_PRODUCT_LISTING",
            "FREE_LOCAL_PRODUCT_LISTING",
            "BUY_ON_GOOGLE_LISTING"
          ],
          "type": "string"
        },
        "productTypeL4": {
          "description": "[Product type (4th level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in merchant's own product taxonomy.",
          "type": "string"
        },
        "customerCountryCode": {
          "description": "Code of the country where the customer is located at the time of the event. Represented in the ISO 3166 format. If the customer country cannot be determined, a special 'ZZ' code is returned.",
          "type": "string"
        },
        "customLabel1": {
          "type": "string",
          "description": "Custom label 1 for custom grouping of products."
        },
        "date": {
          "description": "Date in the merchant timezone to which metrics apply.",
          "$ref": "Date"
        },
        "productTypeL3": {
          "type": "string",
          "description": "[Product type (3rd level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in merchant's own product taxonomy."
        },
        "customLabel4": {
          "type": "string",
          "description": "Custom label 4 for custom grouping of products."
        },
        "categoryL4": {
          "description": "[Product category (4th level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in Google's product taxonomy.",
          "type": "string"
        },
        "productTypeL1": {
          "description": "[Product type (1st level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in merchant's own product taxonomy.",
          "type": "string"
        },
        "categoryL1": {
          "type": "string",
          "description": "[Product category (1st level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in Google's product taxonomy."
        },
        "currencyCode": {
          "description": "Currency in which price metrics are represented, for example, if you select `ordered_item_sales_micros`, the returned value will be represented by this currency.",
          "type": "string"
        },
        "title": {
          "type": "string",
          "description": "Title of the product."
        },
        "week": {
          "description": "First day of the week (Monday) of the metrics date in the merchant timezone.",
          "$ref": "Date"
        },
        "categoryL5": {
          "description": "[Product category (5th level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in Google's product taxonomy.",
          "type": "string"
        },
        "customLabel2": {
          "description": "Custom label 2 for custom grouping of products.",
          "type": "string"
        },
        "customLabel3": {
          "description": "Custom label 3 for custom grouping of products.",
          "type": "string"
        },
        "productTypeL2": {
          "description": "[Product type (2nd level)](https://developers.google.com/shopping-content/guides/reports/segmentation#category_and_product_type) in merchant's own product taxonomy.",
          "type": "string"
        }
      },
      "id": "Segments",
      "description": "Dimensions according to which metrics are segmented in the response. Values of product dimensions, such as `offer_id`, reflect the state of a product at the time of the corresponding event, for example, impression or order. Segment fields cannot be selected in queries without also selecting at least one metric field. Values are only set for dimensions requested explicitly in the request's search query."
    },
    "Region": {
      "type": "object",
      "properties": {
        "regionId": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Immutable. The ID uniquely identifying each region."
        },
        "merchantId": {
          "type": "string",
          "format": "int64",
          "readOnly": true,
          "description": "Output only. Immutable. Merchant that owns the region."
        },
        "displayName": {
          "description": "The display name of the region.",
          "type": "string"
        },
        "postalCodeArea": {
          "description": "A list of postal codes that defines the region area.",
          "$ref": "RegionPostalCodeArea"
        },
        "geotargetArea": {
          "description": "A list of geotargets that defines the region area.",
          "$ref": "RegionGeoTargetArea"
        },
        "shippingEligible": {
          "type": "boolean",
          "description": "Output only. Indicates if the region is eligible to use in the Shipping Services configuration.",
          "readOnly": true
        },
        "regionalInventoryEligible": {
          "type": "boolean",
          "readOnly": true,
          "description": "Output only. Indicates if the region is eligible to use in the Regional Inventory configuration."
        }
      },
      "id": "Region",
      "description": "Represents a geographic region that you can use as a target with both the `RegionalInventory` and `ShippingSettings` services. You can define regions as collections of either postal codes or, in some countries, using predefined geotargets."
    },
    "LoyaltyProgram": {
      "id": "LoyaltyProgram",
      "description": "Allows the setting up of loyalty program benefits (for example price or points). https://support.google.com/merchants/answer/12922446",
      "type": "object",
      "properties": {
        "memberPriceEffectiveDate": {
          "type": "string",
          "description": "Optional. A date range during which the item is eligible for member price. If not specified, the member price is always applicable. The date range is represented by a pair of ISO 8601 dates separated by a space, comma, or slash."
        },
        "price": {
          "description": "Optional. The price for members of the given tier (instant discount price). Must be smaller or equal to the regular price.",
          "$ref": "Price"
        },
        "programLabel": {
          "type": "string",
          "description": "Required. The label of the loyalty program. This is an internal label that uniquely identifies the relationship between a merchant entity and a loyalty program entity. It must be provided so that system can associate the assets below (for example, price and points) with a merchant. The corresponding program must be linked to the merchant account."
        },
        "loyaltyPoints": {
          "description": "Optional. The amount of loyalty points earned on a purchase.",
          "type": "string",
          "format": "int64"
        },
        "shippingLabel": {
          "description": "Optional. The shipping label for the loyalty program. You can use this label to indicate whether this offer has the loyalty shipping benefit. If not specified, the item is not eligible for loyalty shipping for the given loyalty tier.",
          "type": "string"
        },
        "tierLabel": {
          "description": "Required. The label of the tier within the loyalty program. Must match one of the labels within the program.",
          "type": "string"
        },
        "cashbackForFutureUse": {
          "description": "Optional. The cashback that can be used for future purchases.",
          "$ref": "Price"
        }
      }
    },
    "RequestReviewShoppingAdsRequest": {
      "properties": {
        "regionCode": {
          "type": "string",
          "description": "The code [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) of the country for which review is to be requested."
        }
      },
      "type": "object",
      "description": "Request message for the RequestReviewShoppingAds program method.",
      "id": "RequestReviewShoppingAdsRequest"
    },
    "ShippingsettingsListResponse": {
      "id": "ShippingsettingsListResponse",
      "properties": {
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of shipping settings.",
          "type": "string"
        },
        "resources": {
          "type": "array",
          "items": {
            "$ref": "ShippingSettings"
          }
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsListResponse`\".",
          "type": "string"
        }
      },
      "type": "object"
    },
    "GoogleAnalyticsLink": {
      "type": "object",
      "properties": {
        "attributionSettings": {
          "$ref": "AttributionSettings",
          "description": "Output only. Attribution settings for the linked Google Analytics property.",
          "readOnly": true
        },
        "propertyId": {
          "description": "Required. Immutable. ID of the Google Analytics property the merchant is linked to.",
          "type": "string",
          "format": "int64"
        },
        "propertyName": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Name of the Google Analytics property the merchant is linked to."
        }
      },
      "id": "GoogleAnalyticsLink",
      "description": "\"Google Analytics Link\" sources can be used to get conversion data from an existing Google Analytics property into the linked Merchant Center account."
    },
    "RegionPostalCodeArea": {
      "properties": {
        "regionCode": {
          "type": "string",
          "description": "Required. CLDR territory code or the country the postal code group applies to."
        },
        "postalCodes": {
          "description": "Required. A range of postal codes.",
          "items": {
            "$ref": "RegionPostalCodeAreaPostalCodeRange"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "A list of postal codes that defines the region area. Note: All regions defined using postal codes are accessible via the account's `ShippingSettings.postalCodeGroups` resource.",
      "id": "RegionPostalCodeArea"
    },
    "ProductProductDetail": {
      "id": "ProductProductDetail",
      "type": "object",
      "properties": {
        "attributeValue": {
          "type": "string",
          "description": "The value of the product detail."
        },
        "sectionName": {
          "type": "string",
          "description": "The section header used to group a set of product details."
        },
        "attributeName": {
          "type": "string",
          "description": "The name of the product detail."
        }
      }
    },
    "AccountBusinessIdentity": {
      "type": "object",
      "properties": {
        "veteranOwned": {
          "description": "Specifies whether the business identifies itself as being veteran-owned. This optional field is only available for merchants with a business country set to \"US\". This field is not allowed for marketplaces or marketplace sellers.",
          "$ref": "AccountIdentityType"
        },
        "blackOwned": {
          "description": "Specifies whether the business identifies itself as being black-owned. This optional field is only available for merchants with a business country set to \"US\". This field is not allowed for marketplaces or marketplace sellers.",
          "$ref": "AccountIdentityType"
        },
        "includeForPromotions": {
          "description": "Required. By setting this field, your business may be included in promotions for all the selected attributes. If you clear this option, it won't affect your identification with any of the attributes. For this field to be set, the merchant must self identify with at least one of the `AccountIdentityType`. If none are included, the request will be considered invalid.",
          "type": "boolean"
        },
        "smallBusiness": {
          "description": "Specifies whether the business identifies itself as a small business. This optional field is only available for merchants with a business country set to \"US\". It is also not allowed for marketplaces, but it is allowed to marketplace sellers.",
          "$ref": "AccountIdentityType"
        },
        "womenOwned": {
          "description": "Specifies whether the business identifies itself as being women-owned. This optional field is only available for merchants with a business country set to \"US\". This field is not allowed for marketplaces or marketplace sellers.",
          "$ref": "AccountIdentityType"
        },
        "latinoOwned": {
          "description": "Specifies whether the business identifies itself as being latino-owned. This optional field is only available for merchants with a business country set to \"US\". This field is not allowed for marketplaces or marketplace sellers.",
          "$ref": "AccountIdentityType"
        }
      },
      "id": "AccountBusinessIdentity",
      "description": "The [business identity attributes](https://support.google.com/merchants/answer/10342414) can be used to self-declare attributes that let customers know more about your business."
    },
    "CollectionStatus": {
      "properties": {
        "lastUpdateDate": {
          "type": "string",
          "description": "Date on which the collection has been last updated in [ISO 8601](http://en.wikipedia.org/wiki/ISO_8601) format: Date, time, and offset, for example \"2020-01-02T09:00:00+01:00\" or \"2020-01-02T09:00:00Z\""
        },
        "collectionLevelIssuses": {
          "type": "array",
          "description": "A list of all issues associated with the collection.",
          "items": {
            "$ref": "CollectionStatusItemLevelIssue"
          }
        },
        "id": {
          "type": "string",
          "description": "Required. The ID of the collection for which status is reported."
        },
        "creationDate": {
          "type": "string",
          "description": "Date on which the collection has been created in [ISO 8601](http://en.wikipedia.org/wiki/ISO_8601) format: Date, time, and offset, for example \"2020-01-02T09:00:00+01:00\" or \"2020-01-02T09:00:00Z\""
        },
        "destinationStatuses": {
          "description": "The intended destinations for the collection.",
          "items": {
            "$ref": "CollectionStatusDestinationStatus"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "The collectionstatus message.",
      "id": "CollectionStatus"
    },
    "ReturnPolicyOnlinePolicy": {
      "properties": {
        "days": {
          "description": "The number of days items can be returned after delivery, where one day is defined to be 24 hours after the delivery timestamp. Required for `numberOfDaysAfterDelivery` returns.",
          "format": "int64",
          "type": "string"
        },
        "type": {
          "description": "Policy type.",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Number of days after a return is delivered.",
            "No returns.",
            "Life time returns."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "NUMBER_OF_DAYS_AFTER_DELIVERY",
            "NO_RETURNS",
            "LIFETIME_RETURNS"
          ],
          "type": "string"
        }
      },
      "type": "object",
      "description": "The available policies.",
      "id": "ReturnPolicyOnlinePolicy"
    },
    "InsertCheckoutSettingsRequest": {
      "id": "InsertCheckoutSettingsRequest",
      "description": "Request message for the `InsertCheckoutSettings` method.",
      "type": "object",
      "properties": {
        "uriSettings": {
          "description": "Required. The `UrlSettings` for the request. The presence of URL settings indicates `Checkout` enrollment.",
          "$ref": "UrlSettings"
        }
      }
    },
    "ProductDeliveryTime": {
      "type": "object",
      "properties": {
        "areaDeliveryTimes": {
          "description": "Required. A set of associations between `DeliveryArea` and `DeliveryTime` entries. The total number of `areaDeliveryTimes` can be at most 100.",
          "items": {
            "$ref": "ProductDeliveryTimeAreaDeliveryTime"
          },
          "type": "array"
        },
        "productId": {
          "description": "Required. The `id` of the product.",
          "$ref": "ProductId"
        }
      },
      "id": "ProductDeliveryTime",
      "description": "The estimated days to deliver a product after an order is placed. Only authorized shipping signals partners working with a merchant can use this resource. Merchants should use the [`products`](https://developers.google.com/shopping-content/reference/rest/v2.1/products#productshipping) resource instead."
    },
    "DateTime": {
      "properties": {
        "timeZone": {
          "description": "Time zone.",
          "$ref": "TimeZone"
        },
        "year": {
          "format": "int32",
          "type": "integer",
          "description": "Optional. Year of date. Must be from 1 to 9999, or 0 if specifying a datetime without a year."
        },
        "utcOffset": {
          "description": "UTC offset. Must be whole seconds, between -18 hours and +18 hours. For example, a UTC offset of -4:00 would be represented as { seconds: -14400 }.",
          "type": "string",
          "format": "google-duration"
        },
        "hours": {
          "description": "Optional. Hours of day in 24 hour format. Should be from 0 to 23, defaults to 0 (midnight). An API may choose to allow the value \"24:00:00\" for scenarios like business closing time.",
          "type": "integer",
          "format": "int32"
        },
        "minutes": {
          "type": "integer",
          "format": "int32",
          "description": "Optional. Minutes of hour of day. Must be from 0 to 59, defaults to 0."
        },
        "month": {
          "format": "int32",
          "type": "integer",
          "description": "Optional. Month of year. Must be from 1 to 12, or 0 if specifying a datetime without a month."
        },
        "seconds": {
          "format": "int32",
          "type": "integer",
          "description": "Optional. Seconds of minutes of the time. Must normally be from 0 to 59, defaults to 0. An API may allow the value 60 if it allows leap-seconds."
        },
        "nanos": {
          "description": "Optional. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999, defaults to 0.",
          "type": "integer",
          "format": "int32"
        },
        "day": {
          "description": "Optional. Day of month. Must be from 1 to 31 and valid for the year and month, or 0 if specifying a datetime without a day.",
          "type": "integer",
          "format": "int32"
        }
      },
      "type": "object",
      "description": "Represents civil time (or occasionally physical time). This type can represent a civil time in one of a few possible ways: * When utc_offset is set and time_zone is unset: a civil time on a calendar day with a particular offset from UTC. * When time_zone is set and utc_offset is unset: a civil time on a calendar day in a particular time zone. * When neither time_zone nor utc_offset is set: a civil time on a calendar day in local time. The date is relative to the Proleptic Gregorian Calendar. If year, month, or day are 0, the DateTime is considered not to have a specific year, month, or day respectively. This type may also be used to represent a physical time if all the date and time fields are set and either case of the `time_offset` oneof is set. Consider using `Timestamp` message for physical time instead. If your use case also would like to store the user's timezone, that can be done in another field. This type is more flexible than some applications may want. Make sure to document and validate your application's limitations.",
      "id": "DateTime"
    },
    "PosSaleRequest": {
      "properties": {
        "storeCode": {
          "type": "string",
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile."
        },
        "itemId": {
          "description": "Required. A unique identifier for the item.",
          "type": "string"
        },
        "saleId": {
          "description": "A unique ID to group items from the same sale event.",
          "type": "string"
        },
        "contentLanguage": {
          "description": "Required. The two-letter ISO 639-1 language code for the item.",
          "type": "string"
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        },
        "quantity": {
          "format": "int64",
          "type": "string",
          "description": "Required. The relative change of the available quantity. Negative for items returned."
        },
        "price": {
          "description": "Required. The price of the item.",
          "$ref": "Price"
        },
        "timestamp": {
          "type": "string",
          "description": "Required. The inventory timestamp, in ISO 8601 format."
        }
      },
      "type": "object",
      "id": "PosSaleRequest"
    },
    "AccountsCustomBatchRequestEntry": {
      "properties": {
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "An entry ID, unique within the batch request."
        },
        "linkRequest": {
          "description": "Details about the `link` request.",
          "$ref": "AccountsCustomBatchRequestEntryLinkRequest"
        },
        "accountId": {
          "description": "The ID of the targeted account. Only defined if the method is not `insert`.",
          "format": "uint64",
          "type": "string"
        },
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`claimWebsite`\" - \"`delete`\" - \"`get`\" - \"`insert`\" - \"`link`\" - \"`update`\" ",
          "type": "string"
        },
        "account": {
          "description": "The account to create or update. Only defined if the method is `insert` or `update`.",
          "$ref": "Account"
        },
        "labelIds": {
          "description": "Label IDs for the 'updatelabels' request.",
          "items": {
            "type": "string",
            "format": "uint64"
          },
          "type": "array"
        },
        "overwrite": {
          "description": "Only applicable if the method is `claimwebsite`. Indicates whether or not to take the claim from another account in case there is a conflict.",
          "type": "boolean"
        },
        "view": {
          "type": "string",
          "description": "Controls which fields are visible. Only applicable if the method is 'get'."
        },
        "force": {
          "type": "boolean",
          "description": "Whether the account should be deleted if the account has offers. Only applicable if the method is `delete`."
        }
      },
      "type": "object",
      "description": "A batch entry encoding a single non-batch accounts request.",
      "id": "AccountsCustomBatchRequestEntry"
    },
    "CheckoutSettings": {
      "properties": {
        "effectiveEnrollmentState": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. The effective value of enrollment state for a given merchant ID. If account level settings are present then this value will be a copy of the account level settings. Otherwise, it will have the value of the parent account.",
          "enumDescriptions": [
            "Default enrollment state when enrollment state is not specified.",
            "Merchant has not enrolled into the feature.",
            "Merchant has enrolled into the feature by providing either an account level URL or checkout URLs as part of their feed.",
            "Merchant has previously enrolled but opted out of the feature."
          ],
          "enum": [
            "CHECKOUT_ON_MERCHANT_ENROLLMENT_STATE_UNSPECIFIED",
            "INACTIVE",
            "ENROLLED",
            "OPT_OUT"
          ]
        },
        "uriSettings": {
          "description": "URL settings for cart or checkout URL.",
          "$ref": "UrlSettings"
        },
        "effectiveReviewState": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The effective value of review state for a given merchant ID. If account level settings are present then this value will be a copy of the account level settings. Otherwise, it will have the value of the parent account.",
          "enumDescriptions": [
            "Default review state when review state is not specified.",
            "Merchant provided URLs are being reviewed for data quality issues.",
            "Merchant account has been approved. Indicates the data quality checks have passed.",
            "Merchant account has been disapproved due to data quality issues."
          ],
          "enum": [
            "CHECKOUT_ON_MERCHANT_REVIEW_STATE_UNSPECIFIED",
            "IN_REVIEW",
            "APPROVED",
            "DISAPPROVED"
          ]
        },
        "merchantId": {
          "format": "int64",
          "type": "string",
          "description": "Required. The ID of the account."
        },
        "enrollmentState": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. Reflects the merchant enrollment state in `Checkout` feature.",
          "enumDescriptions": [
            "Default enrollment state when enrollment state is not specified.",
            "Merchant has not enrolled into the feature.",
            "Merchant has enrolled into the feature by providing either an account level URL or checkout URLs as part of their feed.",
            "Merchant has previously enrolled but opted out of the feature."
          ],
          "enum": [
            "CHECKOUT_ON_MERCHANT_ENROLLMENT_STATE_UNSPECIFIED",
            "INACTIVE",
            "ENROLLED",
            "OPT_OUT"
          ]
        },
        "reviewState": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Reflects the merchant review state in `Checkout` feature. This is set based on the data quality reviews of the URL provided by the merchant. A merchant with enrollment state as `ENROLLED` can be in the following review states: `IN_REVIEW`, `APPROVED` or `DISAPPROVED`. A merchant must be in an enrollment_state of `ENROLLED` before a review can begin for the merchant.",
          "enumDescriptions": [
            "Default review state when review state is not specified.",
            "Merchant provided URLs are being reviewed for data quality issues.",
            "Merchant account has been approved. Indicates the data quality checks have passed.",
            "Merchant account has been disapproved due to data quality issues."
          ],
          "enum": [
            "CHECKOUT_ON_MERCHANT_REVIEW_STATE_UNSPECIFIED",
            "IN_REVIEW",
            "APPROVED",
            "DISAPPROVED"
          ]
        },
        "effectiveUriSettings": {
          "description": "The effective value of `url_settings` for a given merchant ID. If account level settings are present then this value will be a copy of the account level settings. Otherwise, it will have the value of the parent account.",
          "$ref": "UrlSettings"
        }
      },
      "type": "object",
      "description": "`CheckoutSettings` for a specific merchant ID.",
      "id": "CheckoutSettings"
    },
    "AccountsListLinksResponse": {
      "id": "AccountsListLinksResponse",
      "properties": {
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of links.",
          "type": "string"
        },
        "links": {
          "description": "The list of available links.",
          "items": {
            "$ref": "LinkedAccount"
          },
          "type": "array"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsListLinksResponse`\"."
        }
      },
      "type": "object"
    },
    "AccountsCustomBatchRequestEntryLinkRequest": {
      "id": "AccountsCustomBatchRequestEntryLinkRequest",
      "type": "object",
      "properties": {
        "action": {
          "description": "Action to perform for this link. The `\"request\"` action is only available to select merchants. Acceptable values are: - \"`approve`\" - \"`remove`\" - \"`request`\" ",
          "type": "string"
        },
        "services": {
          "type": "array",
          "description": "Provided services. Acceptable values are: - \"`shoppingAdsProductManagement`\" - \"`shoppingActionsProductManagement`\" - \"`shoppingActionsOrderManagement`\" - \"`paymentProcessing`\" - \"`localProductManagement`\" ",
          "items": {
            "type": "string"
          }
        },
        "linkedAccountId": {
          "type": "string",
          "description": "The ID of the linked account."
        },
        "linkType": {
          "type": "string",
          "description": "Type of the link between the two accounts. Acceptable values are: - \"`channelPartner`\" - \"`eCommercePlatform`\" - \"`paymentServiceProvider`\" - \"`localProductManager`\" "
        }
      }
    },
    "RecommendationCallToAction": {
      "type": "object",
      "properties": {
        "localizedText": {
          "description": "Output only. Localized text of the CTA. Optional.",
          "readOnly": true,
          "type": "string"
        },
        "uri": {
          "description": "Optional. URL of the CTA. This field will only be set for some recommendations where there is a suggested landing URL. Otherwise it will be set to an empty string. We recommend developers to use their own custom landing page according to the description of the intent field above when this uri field is empty.",
          "type": "string"
        },
        "intent": {
          "type": "string",
          "description": "Output only. Intent of the action. This value describes the intent (for example, `OPEN_CREATE_EMAIL_CAMPAIGN_FLOW`) and can vary from recommendation to recommendation. This value can change over time for the same recommendation. Currently available intent values: - OPEN_CREATE_EMAIL_CAMPAIGN_FLOW: Opens a user journey where they can create a marketing email campaign. (No default URL) - OPEN_CREATE_COLLECTION_TAB: Opens a user journey where they can [create a collection](https://support.google.com/merchants/answer/9703228) for their Merchant account. (No default URL)",
          "readOnly": true
        }
      },
      "id": "RecommendationCallToAction",
      "description": "Call to action (CTA) that explains how a merchant can implement this recommendation"
    },
    "ProductDimension": {
      "id": "ProductDimension",
      "properties": {
        "unit": {
          "description": "Required. The length units. Acceptable values are: - \"`in`\" - \"`cm`\" ",
          "type": "string"
        },
        "value": {
          "type": "number",
          "format": "double",
          "description": "Required. The length value represented as a number. The value can have a maximum precision of four decimal places."
        }
      },
      "type": "object"
    },
    "InputFieldChoiceInputChoiceInputOption": {
      "properties": {
        "label": {
          "description": "Short description of the choice option. There may be more information to be shown as a tooltip.",
          "$ref": "TextWithTooltip"
        },
        "id": {
          "type": "string",
          "description": "Not for display but need to be sent back for the selected choice option."
        },
        "additionalInput": {
          "description": "Input that should be displayed when this option is selected. The additional input will not contain a `ChoiceInput`.",
          "$ref": "InputField"
        }
      },
      "type": "object",
      "description": "A choice that merchant can select.",
      "id": "InputFieldChoiceInputChoiceInputOption"
    },
    "FreeListingsProgramStatus": {
      "id": "FreeListingsProgramStatus",
      "description": "Response message for GetFreeListingsProgramStatus.",
      "type": "object",
      "properties": {
        "globalState": {
          "type": "string",
          "description": "State of the program. `ENABLED` if there are offers for at least one region.",
          "enumDescriptions": [
            "State is unknown.",
            "Program is not enabled for any country.",
            "No products have been uploaded for any region. Upload products to Merchant Center.",
            "Program is enabled and offers are uploaded for at least one country."
          ],
          "enum": [
            "PROGRAM_STATE_UNSPECIFIED",
            "NOT_ENABLED",
            "NO_OFFERS_UPLOADED",
            "ENABLED"
          ]
        },
        "regionStatuses": {
          "type": "array",
          "description": "Status of the program in each region. Regions with the same status and review eligibility are grouped together in `regionCodes`.",
          "items": {
            "$ref": "FreeListingsProgramStatusRegionStatus"
          }
        }
      }
    },
    "BestSellers": {
      "description": "Fields related to the [Best sellers reports](https://support.google.com/merchants/answer/9488679).",
      "id": "BestSellers",
      "properties": {
        "relativeDemand": {
          "description": "Estimated demand in relation to the item with the highest popularity rank in the same category and country.",
          "enumDescriptions": [
            "Relative demand is unknown.",
            "Demand is 0-5% of the demand of the highest ranked product clusters or brands.",
            "Demand is 6-10% of the demand of the highest ranked product clusters or brands.",
            "Demand is 11-20% of the demand of the highest ranked product clusters or brands.",
            "Demand is 21-50% of the demand of the highest ranked product clusters or brands.",
            "Demand is 51-100% of the demand of the highest ranked product clusters or brands."
          ],
          "enum": [
            "RELATIVE_DEMAND_UNSPECIFIED",
            "VERY_LOW",
            "LOW",
            "MEDIUM",
            "HIGH",
            "VERY_HIGH"
          ],
          "type": "string"
        },
        "countryCode": {
          "description": "Country where the ranking is calculated. A `WHERE` condition on `best_sellers.country_code` is required in the query.",
          "type": "string"
        },
        "categoryId": {
          "type": "string",
          "format": "int64",
          "description": "Google product category ID to calculate the ranking for, represented in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436). If a `WHERE` condition on `best_sellers.category_id` is not specified in the query, rankings for all top-level categories are returned."
        },
        "reportDate": {
          "description": "Report date. The value of this field can only be one of the following: * The first day of the week (Monday) for weekly reports. * The first day of the month for monthly reports. If a `WHERE` condition on `best_sellers.report_date` is not specified in the query, the latest available weekly or monthly report is returned.",
          "$ref": "Date"
        },
        "relativeDemandChange": {
          "type": "string",
          "description": "Change in the estimated demand. Whether it rose, sank or remained flat.",
          "enumDescriptions": [
            "Relative demand change is unknown.",
            "Relative demand is lower than previous time period.",
            "Relative demand is equal to previous time period.",
            "Relative demand is higher than the previous time period."
          ],
          "enum": [
            "RELATIVE_DEMAND_CHANGE_TYPE_UNSPECIFIED",
            "SINKER",
            "FLAT",
            "RISER"
          ]
        },
        "previousRank": {
          "description": "Popularity rank in the previous week or month.",
          "type": "string",
          "format": "int64"
        },
        "reportGranularity": {
          "description": "Granularity of the report. The ranking can be done over a week or a month timeframe. A `WHERE` condition on `best_sellers.report_granularity` is required in the query.",
          "enumDescriptions": [
            "Report granularity is unknown.",
            "Ranking is done over a week timeframe.",
            "Ranking is done over a month timeframe."
          ],
          "enum": [
            "REPORT_GRANULARITY_UNSPECIFIED",
            "WEEKLY",
            "MONTHLY"
          ],
          "type": "string"
        },
        "rank": {
          "description": "Popularity on Shopping ads and free listings, in the selected category and country, based on the estimated number of units sold.",
          "format": "int64",
          "type": "string"
        },
        "previousRelativeDemand": {
          "type": "string",
          "description": "Estimated demand in relation to the item with the highest popularity rank in the same category and country in the previous week or month.",
          "enumDescriptions": [
            "Relative demand is unknown.",
            "Demand is 0-5% of the demand of the highest ranked product clusters or brands.",
            "Demand is 6-10% of the demand of the highest ranked product clusters or brands.",
            "Demand is 11-20% of the demand of the highest ranked product clusters or brands.",
            "Demand is 21-50% of the demand of the highest ranked product clusters or brands.",
            "Demand is 51-100% of the demand of the highest ranked product clusters or brands."
          ],
          "enum": [
            "RELATIVE_DEMAND_UNSPECIFIED",
            "VERY_LOW",
            "LOW",
            "MEDIUM",
            "HIGH",
            "VERY_HIGH"
          ]
        }
      },
      "type": "object"
    },
    "LabelIds": {
      "id": "LabelIds",
      "description": "The IDs of labels that should be assigned to the CSS domain.",
      "type": "object",
      "properties": {
        "labelIds": {
          "type": "array",
          "description": "The list of label IDs.",
          "items": {
            "type": "string",
            "format": "int64"
          }
        }
      }
    },
    "PosCustomBatchResponseEntry": {
      "properties": {
        "store": {
          "description": "The retrieved or updated store information.",
          "$ref": "PosStore"
        },
        "inventory": {
          "description": "The updated inventory information.",
          "$ref": "PosInventory"
        },
        "batchId": {
          "description": "The ID of the request entry to which this entry responds.",
          "type": "integer",
          "format": "uint32"
        },
        "sale": {
          "description": "The updated sale information.",
          "$ref": "PosSale"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posCustomBatchResponseEntry`\"",
          "type": "string"
        },
        "errors": {
          "description": "A list of errors defined if, and only if, the request failed.",
          "$ref": "Errors"
        }
      },
      "type": "object",
      "id": "PosCustomBatchResponseEntry"
    },
    "ServiceStoreConfig": {
      "type": "object",
      "properties": {
        "cutoffConfig": {
          "description": "Time local delivery ends for the day. This can be either `local_cutoff_time` or `store_close_offset_hours`, if both are provided an error is thrown.",
          "$ref": "ServiceStoreConfigCutoffConfig"
        },
        "storeServiceType": {
          "description": "Indicates whether all stores listed by this merchant provide local delivery or not. Acceptable values are `all stores` and `selected stores`",
          "type": "string"
        },
        "storeCodes": {
          "type": "array",
          "description": "A list of store codes that provide local delivery. If empty, then `store_service_type` must be `all_stores`, or an error is thrown. If not empty, then `store_service_type` must be `selected_stores`, or an error is thrown.",
          "items": {
            "type": "string"
          }
        },
        "serviceRadius": {
          "description": "Maximum delivery radius. Only needed for local delivery fulfillment type.",
          "$ref": "Distance"
        }
      },
      "id": "ServiceStoreConfig",
      "description": "Stores that provide local delivery. Only valid with local delivery fulfillment."
    },
    "LocalinventoryCustomBatchResponse": {
      "id": "LocalinventoryCustomBatchResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#localinventoryCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "LocalinventoryCustomBatchResponseEntry"
          }
        }
      },
      "type": "object"
    },
    "AccountAutomaticImprovements": {
      "description": "The automatic improvements of the account can be used to automatically update items, improve images and shipping.",
      "id": "AccountAutomaticImprovements",
      "properties": {
        "shippingImprovements": {
          "description": "Not available for MCAs [accounts](https://support.google.com/merchants/answer/188487). By turning on [automatic shipping improvements](https://support.google.com/merchants/answer/10027038), you are allowing Google to improve the accuracy of your delivery times shown to shoppers using Google. More accurate delivery times, especially when faster, typically lead to better conversion rates. Google will improve your estimated delivery times based on various factors: - Delivery address of an order - Current handling time and shipping time settings - Estimated weekdays or business days - Parcel tracking data This field is only updated (cleared) if provided.",
          "$ref": "AccountShippingImprovements"
        },
        "itemUpdates": {
          "description": "Turning on [item updates](https://support.google.com/merchants/answer/3246284) allows Google to automatically update items for you. When item updates are on, Google uses the structured data markup on the website and advanced data extractors to update the price and availability of the items. When the item updates are off, items with mismatched data aren't shown. This field is only updated (cleared) if provided.",
          "$ref": "AccountItemUpdates"
        },
        "imageImprovements": {
          "description": "This improvement will attempt to automatically correct submitted images if they don't meet the [image requirements](https://support.google.com/merchants/answer/6324350), for example, removing overlays. If successful, the image will be replaced and approved. This improvement is only applied to images of disapproved offers. For more information see: [Automatic image improvements](https://support.google.com/merchants/answer/9242973) This field is only updated (cleared) if provided.",
          "$ref": "AccountImageImprovements"
        }
      },
      "type": "object"
    },
    "Product": {
      "description": " Required product attributes are primarily defined by the product data specification. See the Product Data Specification Help Center article for information. Product data. After inserting, updating, or deleting a product, it may take several minutes before changes take effect. The following reference documentation lists the field names in the **camelCase** casing style while the Products Data Specification lists the names in the **snake_case** casing style.",
      "id": "Product",
      "properties": {
        "shipping": {
          "description": "Shipping rules.",
          "items": {
            "$ref": "ProductShipping"
          },
          "type": "array"
        },
        "shippingWidth": {
          "description": "Width of the item for shipping.",
          "$ref": "ProductShippingDimension"
        },
        "structuredTitle": {
          "description": "Structured title, for algorithmically (AI)-generated titles.",
          "$ref": "ProductStructuredTitle"
        },
        "pickupSla": {
          "type": "string",
          "description": "Item store pickup timeline. Acceptable values are: - \"`same day`\" - \"`next day`\" - \"`2-day`\" - \"`3-day`\" - \"`4-day`\" - \"`5-day`\" - \"`6-day`\" - \"`7-day`\" - \"`multi-week`\" "
        },
        "title": {
          "description": "Title of the item.",
          "type": "string"
        },
        "displayAdsTitle": {
          "type": "string",
          "description": "Title of an item for dynamic remarketing campaigns."
        },
        "color": {
          "type": "string",
          "description": "Color of the item."
        },
        "shippingWeight": {
          "description": "Weight of the item for shipping.",
          "$ref": "ProductShippingWeight"
        },
        "ageGroup": {
          "type": "string",
          "description": "Target age group of the item."
        },
        "mobileLinkTemplate": {
          "type": "string",
          "description": "URL template for merchant hosted local storefront optimized for mobile devices."
        },
        "sizeType": {
          "type": "string",
          "description": "The cut of the item. Recommended for apparel items."
        },
        "identifierExists": {
          "description": "False when the item does not have unique product identifiers appropriate to its category, such as GTIN, MPN, and brand. Required according to the Unique Product Identifier Rules for all target countries except for Canada.",
          "type": "boolean"
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item's country of sale.",
          "type": "string"
        },
        "taxes": {
          "type": "array",
          "description": "Tax information.",
          "items": {
            "$ref": "ProductTax"
          }
        },
        "minHandlingTime": {
          "type": "string",
          "format": "int64",
          "description": "Minimal product handling time (in business days)."
        },
        "customLabel4": {
          "description": "Custom label 4 for custom grouping of items in a Shopping campaign.",
          "type": "string"
        },
        "promotionIds": {
          "type": "array",
          "description": "The unique ID of a promotion.",
          "items": {
            "type": "string"
          }
        },
        "canonicalLink": {
          "type": "string",
          "description": "URL for the canonical version of your item's landing page."
        },
        "certifications": {
          "description": "Product [certification](https://support.google.com/merchants/answer/13528839), introduced for EU energy efficiency labeling compliance using the [EU EPREL](https://eprel.ec.europa.eu/screen/home) database.",
          "items": {
            "$ref": "ProductCertification"
          },
          "type": "array"
        },
        "taxCategory": {
          "type": "string",
          "description": "The tax category of the product, used to configure detailed tax nexus in account-level tax settings."
        },
        "id": {
          "type": "string",
          "description": "The REST ID of the product. Content API methods that operate on products take this as their `productId` parameter. The REST ID for a product has one of the 2 forms channel:contentLanguage: targetCountry: offerId or channel:contentLanguage:feedLabel: offerId."
        },
        "feedLabel": {
          "description": "Feed label for the item. Either `targetCountry` or `feedLabel` is required. Must be less than or equal to 20 uppercase letters (A-Z), numbers (0-9), and dashes (-).",
          "type": "string"
        },
        "minEnergyEfficiencyClass": {
          "type": "string",
          "description": "The energy efficiency class as defined in EU directive 2010/30/EU."
        },
        "loyaltyPrograms": {
          "type": "array",
          "description": "Optional. A list of loyalty program information that is used to surface loyalty benefits (for example, better pricing, points, etc) to the user of this item.",
          "items": {
            "$ref": "LoyaltyProgram"
          }
        },
        "imageLink": {
          "description": "URL of an image of the item.",
          "type": "string"
        },
        "unitPricingMeasure": {
          "description": "The measure and dimension of an item.",
          "$ref": "ProductUnitPricingMeasure"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#product`\""
        },
        "maximumRetailPrice": {
          "description": "Maximum retail price (MRP) of the item. Applicable to India only.",
          "$ref": "Price"
        },
        "customAttributes": {
          "type": "array",
          "description": "A list of custom (merchant-provided) attributes. It can also be used for submitting any attribute of the feed specification in its generic form (for example, `{ \"name\": \"size type\", \"value\": \"regular\" }`). This is useful for submitting attributes not explicitly exposed by the API, such as additional attributes used for Buy on Google (formerly known as Shopping Actions).",
          "items": {
            "$ref": "CustomAttribute"
          }
        },
        "availabilityDate": {
          "description": "The day a pre-ordered product becomes available for delivery, in ISO 8601 format.",
          "type": "string"
        },
        "description": {
          "type": "string",
          "description": "Description of the item."
        },
        "channel": {
          "type": "string",
          "description": "Required. The item's channel (online or local). Acceptable values are: - \"`local`\" - \"`online`\" "
        },
        "isBundle": {
          "description": "Whether the item is a merchant-defined bundle. A bundle is a custom grouping of different products sold by a merchant for a single price.",
          "type": "boolean"
        },
        "salePrice": {
          "description": "Advertised sale price of the item.",
          "$ref": "Price"
        },
        "itemGroupId": {
          "description": "Shared identifier for all variants of the same product.",
          "type": "string"
        },
        "condition": {
          "description": "Condition or state of the item.",
          "type": "string"
        },
        "sizes": {
          "type": "array",
          "description": "Size of the item. Only one value is allowed. For variants with different sizes, insert a separate product for each size with the same `itemGroupId` value (see size definition).",
          "items": {
            "type": "string"
          }
        },
        "linkTemplate": {
          "type": "string",
          "description": "URL template for merchant hosted local storefront."
        },
        "excludedDestinations": {
          "description": "The list of [destinations to exclude](//support.google.com/merchants/answer/6324486) for this target (corresponds to cleared check boxes in Merchant Center). Products that are excluded from all destinations for more than 7 days are automatically deleted.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "pattern": {
          "description": "The item's pattern (for example, polka dots).",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number (GTIN) of the item.",
          "type": "string"
        },
        "productWidth": {
          "description": "The width of the product in the units provided. The value must be between 0 (exclusive) and 3000 (inclusive).",
          "$ref": "ProductDimension"
        },
        "pause": {
          "type": "string",
          "description": "Publication of this item should be temporarily paused. Acceptable values are: - \"`ads`\" "
        },
        "price": {
          "description": "Price of the item.",
          "$ref": "Price"
        },
        "sellOnGoogleQuantity": {
          "format": "int64",
          "type": "string",
          "description": "The quantity of the product that is available for selling on Google. Supported only for online products."
        },
        "shoppingAdsExcludedCountries": {
          "description": "List of country codes (ISO 3166-1 alpha-2) to exclude the offer from Shopping Ads destination. Countries from this list are removed from countries configured in MC feed settings.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "customLabel0": {
          "description": "Custom label 0 for custom grouping of items in a Shopping campaign.",
          "type": "string"
        },
        "shippingLabel": {
          "description": "The shipping label of the product, used to group product in account-level shipping rules.",
          "type": "string"
        },
        "productLength": {
          "description": "The length of the product in the units provided. The value must be between 0 (exclusive) and 3000 (inclusive).",
          "$ref": "ProductDimension"
        },
        "unitPricingBaseMeasure": {
          "description": "The preference of the denominator of the unit price.",
          "$ref": "ProductUnitPricingBaseMeasure"
        },
        "freeShippingThreshold": {
          "description": "Optional. Conditions to be met for a product to have free shipping.",
          "items": {
            "$ref": "FreeShippingThreshold"
          },
          "type": "array"
        },
        "productDetails": {
          "description": "Technical specification or additional product details.",
          "items": {
            "$ref": "ProductProductDetail"
          },
          "type": "array"
        },
        "shippingLength": {
          "description": "Length of the item for shipping.",
          "$ref": "ProductShippingDimension"
        },
        "subscriptionCost": {
          "description": "Number of periods (months or years) and amount of payment per period for an item with an associated subscription contract.",
          "$ref": "ProductSubscriptionCost"
        },
        "adult": {
          "type": "boolean",
          "description": "Should be set to true if the item is targeted towards adults."
        },
        "mobileLink": {
          "description": "URL for the mobile-optimized version of your item's landing page.",
          "type": "string"
        },
        "customLabel3": {
          "type": "string",
          "description": "Custom label 3 for custom grouping of items in a Shopping campaign."
        },
        "displayAdsLink": {
          "description": "URL directly to your item's landing page for dynamic remarketing campaigns.",
          "type": "string"
        },
        "adsGrouping": {
          "description": "Used to group items in an arbitrary way. Only for CPA%, discouraged otherwise.",
          "type": "string"
        },
        "includedDestinations": {
          "description": "The list of [destinations to include](//support.google.com/merchants/answer/7501026) for this target (corresponds to checked check boxes in Merchant Center). Default destinations are always included unless provided in `excludedDestinations`.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "additionalSizeType": {
          "type": "string",
          "description": "Additional cut of the item. Used together with size_type to represent combined size types for apparel items."
        },
        "energyEfficiencyClass": {
          "description": "The energy efficiency class as defined in EU directive 2010/30/EU.",
          "type": "string"
        },
        "productTypes": {
          "type": "array",
          "description": "Categories of the item (formatted as in product data specification).",
          "items": {
            "type": "string"
          }
        },
        "offerId": {
          "type": "string",
          "description": "Required. A unique identifier for the item. Leading and trailing whitespaces are stripped and multiple whitespaces are replaced by a single whitespace upon submission. Only valid unicode characters are accepted. See the products feed specification for details. *Note:* Content API methods that operate on products take the REST ID of the product, *not* this identifier."
        },
        "productWeight": {
          "description": "The weight of the product in the units provided. The value must be between 0 (exclusive) and 2000 (inclusive).",
          "$ref": "ProductWeight"
        },
        "sustainabilityIncentives": {
          "type": "array",
          "description": "Optional. The list of sustainability incentive programs.",
          "items": {
            "$ref": "ProductSustainabilityIncentive"
          }
        },
        "salePriceEffectiveDate": {
          "description": "Date range during which the item is on sale (see product data specification ).",
          "type": "string"
        },
        "productHeight": {
          "description": "The height of the product in the units provided. The value must be between 0 (exclusive) and 3000 (inclusive).",
          "$ref": "ProductDimension"
        },
        "pickupMethod": {
          "description": "The pick up option for the item. Acceptable values are: - \"`buy`\" - \"`reserve`\" - \"`ship to store`\" - \"`not supported`\" ",
          "type": "string"
        },
        "gender": {
          "description": "Target gender of the item.",
          "type": "string"
        },
        "link": {
          "type": "string",
          "description": "URL directly linking to your item's page on your website."
        },
        "expirationDate": {
          "type": "string",
          "description": "Date on which the item should expire, as specified upon insertion, in ISO 8601 format. The actual expiration date in Google Shopping is exposed in `productstatuses` as `googleExpirationDate` and might be earlier if `expirationDate` is too far in the future."
        },
        "displayAdsValue": {
          "type": "number",
          "format": "double",
          "description": "Offer margin for dynamic remarketing campaigns."
        },
        "costOfGoodsSold": {
          "description": "Cost of goods sold. Used for gross profit reporting.",
          "$ref": "Price"
        },
        "lifestyleImageLinks": {
          "description": "Additional URLs of lifestyle images of the item. Used to explicitly identify images that showcase your item in a real-world context. See the Help Center article for more information.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "multipack": {
          "description": "The number of identical products in a merchant-defined multipack.",
          "type": "string",
          "format": "int64"
        },
        "structuredDescription": {
          "description": "Structured description, for algorithmically (AI)-generated descriptions.",
          "$ref": "ProductStructuredDescription"
        },
        "mpn": {
          "description": "Manufacturer Part Number (MPN) of the item.",
          "type": "string"
        },
        "brand": {
          "type": "string",
          "description": "Brand of the item."
        },
        "autoPricingMinPrice": {
          "description": "A safeguard in the [Automated Discounts](//support.google.com/merchants/answer/10295759) and [Dynamic Promotions](//support.google.com/merchants/answer/13949249) projects, ensuring that discounts on merchants' offers do not fall below this value, thereby preserving the offer's value and profitability.",
          "$ref": "Price"
        },
        "cloudExportAdditionalProperties": {
          "type": "array",
          "description": "Extra fields to export to the Cloud Retail program.",
          "items": {
            "$ref": "CloudExportAdditionalProperties"
          }
        },
        "material": {
          "type": "string",
          "description": "The material of which the item is made."
        },
        "loyaltyProgram": {
          "description": "Loyalty program information that is used to surface loyalty benefits ( for example, better pricing, points, etc) to the user of this item. This signular field points to the latest uploaded loyalty program info. This field will be deprecated in the coming weeks and should not be used in favor of the plural 'LoyaltyProgram' field below.",
          "$ref": "LoyaltyProgram"
        },
        "adsRedirect": {
          "description": "Allows advertisers to override the item URL when the product is shown within the context of Product Ads.",
          "type": "string"
        },
        "contentLanguage": {
          "description": "Required. The two-letter ISO 639-1 language code for the item.",
          "type": "string"
        },
        "customLabel1": {
          "description": "Custom label 1 for custom grouping of items in a Shopping campaign.",
          "type": "string"
        },
        "transitTimeLabel": {
          "type": "string",
          "description": "The transit time label of the product, used to group product in account-level transit time tables."
        },
        "adsLabels": {
          "description": "Similar to ads_grouping, but only works on CPC.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "customLabel2": {
          "description": "Custom label 2 for custom grouping of items in a Shopping campaign.",
          "type": "string"
        },
        "maxHandlingTime": {
          "type": "string",
          "format": "int64",
          "description": "Maximal product handling time (in business days)."
        },
        "additionalImageLinks": {
          "type": "array",
          "description": "Additional URLs of images of the item.",
          "items": {
            "type": "string"
          }
        },
        "availability": {
          "description": "Availability status of the item.",
          "type": "string"
        },
        "productHighlights": {
          "description": "Bullet points describing the most relevant highlights of a product.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "maxEnergyEfficiencyClass": {
          "type": "string",
          "description": "The energy efficiency class as defined in EU directive 2010/30/EU."
        },
        "source": {
          "type": "string",
          "description": "Output only. The source of the offer, that is, how the offer was created. Acceptable values are: - \"`api`\" - \"`crawl`\" - \"`feed`\" "
        },
        "googleProductCategory": {
          "description": "Google's category of the item (see [Google product taxonomy](https://support.google.com/merchants/answer/1705911)). When querying products, this field will contain the user provided value. There is currently no way to get back the auto assigned google product categories through the API.",
          "type": "string"
        },
        "externalSellerId": {
          "description": "Required for multi-seller accounts. Use this attribute if you're a marketplace uploading products for various sellers to your multi-seller account.",
          "type": "string"
        },
        "disclosureDate": {
          "type": "string",
          "description": "The date time when an offer becomes visible in search results across Google’s YouTube surfaces, in [ISO 8601](http://en.wikipedia.org/wiki/ISO_8601) format. See [Disclosure date](https://support.google.com/merchants/answer/13034208) for more information."
        },
        "virtualModelLink": {
          "type": "string",
          "description": "URL of the 3D model of the item to provide more visuals."
        },
        "installment": {
          "description": "Number and amount of installments to pay for an item.",
          "$ref": "Installment"
        },
        "sizeSystem": {
          "type": "string",
          "description": "System in which the size is specified. Recommended for apparel items."
        },
        "displayAdsSimilarIds": {
          "description": "Advertiser-specified recommendations.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "shippingHeight": {
          "description": "Height of the item for shipping.",
          "$ref": "ProductShippingDimension"
        },
        "displayAdsId": {
          "description": "An identifier for an item for dynamic remarketing campaigns.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "CollectionStatusDestinationStatus": {
      "description": "Destination status message.",
      "id": "CollectionStatusDestinationStatus",
      "properties": {
        "pendingCountries": {
          "type": "array",
          "description": "Country codes (ISO 3166-1 alpha-2) where the collection is pending approval.",
          "items": {
            "type": "string"
          }
        },
        "status": {
          "description": "The status for the specified destination in the collections target country.",
          "type": "string"
        },
        "destination": {
          "type": "string",
          "description": "The name of the destination"
        },
        "approvedCountries": {
          "description": "Country codes (ISO 3166-1 alpha-2) where the collection is approved.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "disapprovedCountries": {
          "description": "Country codes (ISO 3166-1 alpha-2) where the collection is disapproved.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "ProductsListResponse": {
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "The token for the retrieval of the next page of products."
        },
        "resources": {
          "type": "array",
          "items": {
            "$ref": "Product"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productsListResponse`\"."
        }
      },
      "type": "object",
      "id": "ProductsListResponse"
    },
    "CutoffTime": {
      "id": "CutoffTime",
      "properties": {
        "minute": {
          "description": "Minute of the cutoff time until which an order has to be placed to be processed in the same day. Required.",
          "format": "uint32",
          "type": "integer"
        },
        "hour": {
          "description": "Hour of the cutoff time until which an order has to be placed to be processed in the same day. Required.",
          "type": "integer",
          "format": "uint32"
        },
        "timezone": {
          "type": "string",
          "description": "Timezone identifier for the cutoff time (for example, \"Europe/Zurich\"). List of identifiers. Required."
        }
      },
      "type": "object"
    },
    "AccountCredentials": {
      "type": "object",
      "properties": {
        "accessToken": {
          "type": "string",
          "description": "An OAuth access token."
        },
        "purpose": {
          "type": "string",
          "description": "Indicates to Google how Google should use these OAuth tokens.",
          "enumDescriptions": [
            "Unknown purpose.",
            "The credentials allow Google to manage Shopify orders on behalf of the merchant (deprecated).",
            "The credentials allow Google to manage Shopify integration on behalf of the merchant."
          ],
          "enumDeprecated": [
            false,
            true,
            false
          ],
          "enum": [
            "ACCOUNT_CREDENTIALS_PURPOSE_UNSPECIFIED",
            "SHOPIFY_ORDER_MANAGEMENT",
            "SHOPIFY_INTEGRATION"
          ]
        },
        "expiresIn": {
          "format": "int64",
          "type": "string",
          "description": "The amount of time, in seconds, after which the access token is no longer valid."
        }
      },
      "id": "AccountCredentials",
      "description": "Credentials allowing Google to call a partner's API on behalf of a merchant."
    },
    "Promotion": {
      "description": "Represents a promotion. See the following articles for more details. * [Promotions feed specification](https://support.google.com/merchants/answer/2906014) * [Local promotions feed specification](https://support.google.com/merchants/answer/10146130) * [Promotions on Buy on Google product data specification](https://support.google.com/merchants/answer/9173673)",
      "id": "Promotion",
      "properties": {
        "redemptionChannel": {
          "description": "Required. Redemption channel for the promotion. At least one channel is required.",
          "items": {
            "enumDescriptions": [
              "Indicates that the channel is unspecified.",
              "Indicates that the channel is in store.",
              "Indicates that the channel is online."
            ],
            "enum": [
              "REDEMPTION_CHANNEL_UNSPECIFIED",
              "IN_STORE",
              "ONLINE"
            ],
            "type": "string"
          },
          "type": "array"
        },
        "freeGiftItemId": {
          "description": "Free gift item ID for the promotion.",
          "type": "string"
        },
        "promotionDisplayTimePeriod": {
          "description": "`TimePeriod` representation of the promotion's display dates.",
          "$ref": "TimePeriod"
        },
        "id": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. The REST promotion ID to uniquely identify the promotion. Content API methods that operate on promotions take this as their `promotionId` parameter. The REST ID for a promotion is of the form channel:contentLanguage:targetCountry:promotionId The `channel` field has a value of `\"online\"`, `\"in_store\"`, or `\"online_in_store\"`."
        },
        "brandExclusion": {
          "description": "Product filter by brand exclusion for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "maxDiscountAmount": {
          "description": "The maximum monetary discount a customer can receive for the promotion. This field is only supported with the `Percent off` coupon value type.",
          "$ref": "PriceAmount"
        },
        "freeGiftValue": {
          "description": "Free gift value for the promotion.",
          "$ref": "PriceAmount"
        },
        "promotionUrl": {
          "type": "string",
          "description": "URL to the page on the merchant's site where the promotion shows. Local Inventory ads promotions throw an error if no promo url is included. URL is used to confirm that the promotion is valid and can be redeemed."
        },
        "itemId": {
          "type": "array",
          "description": "Product filter by item ID for the promotion.",
          "items": {
            "type": "string"
          }
        },
        "offerType": {
          "description": "Required. Type of the promotion.",
          "enumDescriptions": [
            "Unknown offer type.",
            "Offer type without a code.",
            "Offer type with a code."
          ],
          "enum": [
            "OFFER_TYPE_UNSPECIFIED",
            "NO_CODE",
            "GENERIC_CODE"
          ],
          "type": "string"
        },
        "itemIdExclusion": {
          "type": "array",
          "description": "Product filter by item ID exclusion for the promotion.",
          "items": {
            "type": "string"
          }
        },
        "itemGroupIdExclusion": {
          "description": "Product filter by item group ID exclusion for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "percentOff": {
          "description": "The percentage discount offered in the promotion.",
          "format": "int32",
          "type": "integer"
        },
        "genericRedemptionCode": {
          "type": "string",
          "description": "Generic redemption code for the promotion. To be used with the `offerType` field."
        },
        "minimumPurchaseAmount": {
          "description": "Minimum purchase amount for the promotion.",
          "$ref": "PriceAmount"
        },
        "brand": {
          "description": "Product filter by brand for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "promotionEffectiveDates": {
          "description": "String representation of the promotion effective dates. Deprecated. Use `promotion_effective_time_period` instead.",
          "deprecated": true,
          "type": "string"
        },
        "getThisQuantityDiscounted": {
          "description": "The number of items discounted in the promotion.",
          "format": "int32",
          "type": "integer"
        },
        "promotionDisplayDates": {
          "description": "String representation of the promotion display dates. Deprecated. Use `promotion_display_time_period` instead.",
          "deprecated": true,
          "type": "string"
        },
        "customRedemptionRestriction": {
          "description": "The custom redemption restriction for the promotion. If the `redemption_restriction` field is set to `CUSTOM`, this field must be set.",
          "type": "string"
        },
        "redemptionRestriction": {
          "type": "string",
          "description": "The redemption restriction for the promotion.",
          "enumDescriptions": [
            "The redemption restriction is unspecified.",
            "The customer must subscribe to the merchant's channel to redeem the promotion.",
            "The customer must be a first-time customer to redeem the promotion.",
            "The customer must sign up for email's to redeem the promotion.",
            "The customer must sign up for text to redeem the promotion.",
            "The customer must use a specific form of payment to redeem the promotion.",
            "The customer must meet a custom restriction to redeem the promotion. If selected, the `custom_redemption_restriction` field must be set."
          ],
          "enum": [
            "REDEMPTION_RESTRICTION_UNSPECIFIED",
            "SUBSCRIBE_AND_SAVE",
            "FIRST_ORDER",
            "SIGN_UP_FOR_EMAIL",
            "SIGN_UP_FOR_TEXT",
            "FORMS_OF_PAYMENT",
            "CUSTOM"
          ]
        },
        "productApplicability": {
          "description": "Required. Applicability of the promotion to either all products or only specific products.",
          "enumDescriptions": [
            "Which products the promotion applies to is unknown.",
            "Applicable to all products.",
            "Applicable to only a single product or list of products."
          ],
          "enum": [
            "PRODUCT_APPLICABILITY_UNSPECIFIED",
            "ALL_PRODUCTS",
            "SPECIFIC_PRODUCTS"
          ],
          "type": "string"
        },
        "promotionEffectiveTimePeriod": {
          "description": "Required. `TimePeriod` representation of the promotion's effective dates.",
          "$ref": "TimePeriod"
        },
        "couponValueType": {
          "description": "Required. Coupon value type for the promotion.",
          "enumDescriptions": [
            "Indicates that the coupon value type is unspecified.",
            "Money off coupon value type.",
            "Percent off coupon value type.",
            "Buy M quantity, get N money off coupon value type. `buy_this_quantity` and `get_this_quantity` must be present. `money_off_amount` must also be present.",
            "Buy M quantity, get N percent off coupon value type. `buy_this_quantity` and `get_this_quantity` must be present. `percent_off_percentage` must also be present.",
            "Buy M quantity, get money off. `buy_this_quantity` and `money_off_amount` must be present.",
            "Buy M quantity, get money off. `buy_this_quantity` and `percent_off_percentage` must be present.",
            "Free gift with description only.",
            "Free gift with value (description is optional).",
            "Free gift with item ID (description is optional).",
            "Standard free shipping coupon value type.",
            "Overnight free shipping coupon value type.",
            "Two day free shipping coupon value type."
          ],
          "enum": [
            "COUPON_VALUE_TYPE_UNSPECIFIED",
            "MONEY_OFF",
            "PERCENT_OFF",
            "BUY_M_GET_N_MONEY_OFF",
            "BUY_M_GET_N_PERCENT_OFF",
            "BUY_M_GET_MONEY_OFF",
            "BUY_M_GET_PERCENT_OFF",
            "FREE_GIFT",
            "FREE_GIFT_WITH_VALUE",
            "FREE_GIFT_WITH_ITEM_ID",
            "FREE_SHIPPING_STANDARD",
            "FREE_SHIPPING_OVERNIGHT",
            "FREE_SHIPPING_TWO_DAY"
          ],
          "type": "string"
        },
        "limitValue": {
          "description": "Maximum purchase value for the promotion.",
          "$ref": "PriceAmount"
        },
        "promotionDestinationIds": {
          "description": "Destination ID for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "contentLanguage": {
          "type": "string",
          "description": "Required. The content language used as part of the unique identifier. `en` content language is available for all target countries. `fr` content language is available for `CA` and `FR` target countries. `de` content language is available for `DE` target country. `nl` content language is available for `NL` target country. `it` content language is available for `IT` target country. `pt` content language is available for `BR` target country. `ja` content language is available for `JP` target country. `ko` content language is available for `KR` target country."
        },
        "productType": {
          "type": "array",
          "description": "Product filter by product type for the promotion.",
          "items": {
            "type": "string"
          }
        },
        "moneyBudget": {
          "description": "Cost cap for the promotion.",
          "$ref": "PriceAmount"
        },
        "storeCode": {
          "description": "Store codes to include for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "promotionStatus": {
          "$ref": "PromotionPromotionStatus",
          "readOnly": true,
          "description": "Output only. The current status of the promotion."
        },
        "orderLimit": {
          "format": "int32",
          "type": "integer",
          "description": "Order limit for the promotion."
        },
        "storeCodeExclusion": {
          "type": "array",
          "description": "Store codes to exclude for the promotion.",
          "items": {
            "type": "string"
          }
        },
        "itemGroupId": {
          "description": "Product filter by item group ID for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "longTitle": {
          "type": "string",
          "description": "Required. Long title for the promotion."
        },
        "promotionId": {
          "type": "string",
          "description": "Required. The user provided promotion ID to uniquely identify the promotion."
        },
        "limitQuantity": {
          "type": "integer",
          "format": "int32",
          "description": "Maximum purchase quantity for the promotion."
        },
        "storeApplicability": {
          "description": "Whether the promotion applies to all stores, or only specified stores. Local Inventory ads promotions throw an error if no store applicability is included. An INVALID_ARGUMENT error is thrown if store_applicability is set to ALL_STORES and store_code or score_code_exclusion is set to a value.",
          "enumDescriptions": [
            "Which store codes the promotion applies to is unknown.",
            "Promotion applies to all stores.",
            "Promotion applies to only the specified stores."
          ],
          "enum": [
            "STORE_APPLICABILITY_UNSPECIFIED",
            "ALL_STORES",
            "SPECIFIC_STORES"
          ],
          "type": "string"
        },
        "moneyOffAmount": {
          "description": "The money off amount offered in the promotion.",
          "$ref": "PriceAmount"
        },
        "productTypeExclusion": {
          "description": "Product filter by product type exclusion for the promotion.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "minimumPurchaseQuantity": {
          "format": "int32",
          "type": "integer",
          "description": "Minimum purchase quantity for the promotion."
        },
        "freeGiftDescription": {
          "description": "Free gift description for the promotion.",
          "type": "string"
        },
        "targetCountry": {
          "description": "Required. The target country used as part of the unique identifier. Can be `AU`, `CA`, `DE`, `FR`, `GB`, `IN`, `US`, `BR`, `ES`, `NL`, `JP`, `IT` or `KR`.",
          "type": "string"
        },
        "shippingServiceNames": {
          "type": "array",
          "description": "Shipping service names for the promotion.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object"
    },
    "ListReturnPolicyOnlineResponse": {
      "properties": {
        "returnPolicies": {
          "description": "The retrieved return policies.",
          "items": {
            "$ref": "ReturnPolicyOnline"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Response message for the `ListReturnPolicyOnline` method.",
      "id": "ListReturnPolicyOnlineResponse"
    },
    "FreeShippingThreshold": {
      "id": "FreeShippingThreshold",
      "description": "Conditions to be met for a product to have free shipping.",
      "type": "object",
      "properties": {
        "country": {
          "type": "string",
          "description": "Required. The [CLDR territory code](http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) of the country to which an item will ship."
        },
        "priceThreshold": {
          "description": "Required. The minimum product price for the shipping cost to become free. Represented as a number.",
          "$ref": "Price"
        }
      }
    },
    "ListAccountReturnCarrierResponse": {
      "properties": {
        "accountReturnCarriers": {
          "description": "List of all available account return carriers for the merchant.",
          "items": {
            "$ref": "AccountReturnCarrier"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Response for listing account return carriers.",
      "id": "ListAccountReturnCarrierResponse"
    },
    "MerchantCenterDestination": {
      "description": "\"Merchant Center Destination\" sources can be used to send conversion events from a website using a Google tag directly to a Merchant Center account where the source is created.",
      "id": "MerchantCenterDestination",
      "properties": {
        "attributionSettings": {
          "description": "Required. Attribution settings being used for the Merchant Center Destination.",
          "$ref": "AttributionSettings"
        },
        "displayName": {
          "description": "Required. Merchant-specified display name for the destination. This is the name that identifies the conversion source within the Merchant Center UI. Limited to 64 characters.",
          "type": "string"
        },
        "currencyCode": {
          "type": "string",
          "description": "Required. Three-letter currency code (ISO 4217). The currency code defines in which currency the conversions sent to this destination will be reported in Merchant Center."
        },
        "destinationId": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Merchant Center Destination ID."
        }
      },
      "type": "object"
    },
    "InputValue": {
      "id": "InputValue",
      "description": "Input provided by the merchant for input field.",
      "type": "object",
      "properties": {
        "choiceInputValue": {
          "description": "Value for choice input field.",
          "$ref": "InputValueChoiceInputValue"
        },
        "inputFieldId": {
          "description": "Required. Id of the corresponding input field.",
          "type": "string"
        },
        "textInputValue": {
          "description": "Value for text input field.",
          "$ref": "InputValueTextInputValue"
        },
        "checkboxInputValue": {
          "description": "Value for checkbox input field.",
          "$ref": "InputValueCheckboxInputValue"
        }
      }
    },
    "InputValueTextInputValue": {
      "description": "Value for text input field.",
      "id": "InputValueTextInputValue",
      "properties": {
        "value": {
          "type": "string",
          "description": "Required. Text provided by the merchant."
        }
      },
      "type": "object"
    },
    "AccountConversionSettings": {
      "id": "AccountConversionSettings",
      "description": "Settings for conversion tracking.",
      "type": "object",
      "properties": {
        "freeListingsAutoTaggingEnabled": {
          "description": "When enabled, free listing URLs have a parameter to enable conversion tracking for products owned by the current merchant account. See [auto-tagging](https://support.google.com/merchants/answer/11127659).",
          "type": "boolean"
        }
      }
    },
    "ProductViewItemIssueIssueSeverityPerDestination": {
      "id": "ProductViewItemIssueIssueSeverityPerDestination",
      "description": "Issue severity for all affected regions in a destination.",
      "type": "object",
      "properties": {
        "disapprovedCountries": {
          "type": "array",
          "description": "List of disapproved countries in the destination.",
          "items": {
            "type": "string"
          }
        },
        "demotedCountries": {
          "description": "List of demoted countries in the destination.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "destination": {
          "type": "string",
          "description": "Issue destination."
        }
      }
    },
    "ReportInteractionRequest": {
      "properties": {
        "interactionType": {
          "type": "string",
          "description": "Required. Type of the interaction that is reported, for example INTERACTION_CLICK.",
          "enumDescriptions": [
            "Default value. If provided, the service will throw ApiError with description \"Required parameter: interactionType\".",
            "When a recommendation is dismissed.",
            "When a recommendation is clicked."
          ],
          "enum": [
            "INTERACTION_TYPE_UNSPECIFIED",
            "INTERACTION_DISMISS",
            "INTERACTION_CLICK"
          ]
        },
        "subtype": {
          "description": "Optional. Subtype of the recommendations this interaction happened on. This field must be set only to the value that is returned by {@link `RecommendationsService.GenerateRecommendations`} call.",
          "type": "string"
        },
        "responseToken": {
          "type": "string",
          "description": "Required. Token of the response when recommendation was returned."
        },
        "type": {
          "description": "Required. Type of the recommendations on which this interaction happened. This field must be set only to the value that is returned by {@link `GenerateRecommendationsResponse`} call.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Request to report interactions on a recommendation.",
      "id": "ReportInteractionRequest"
    },
    "DeliveryTime": {
      "properties": {
        "handlingBusinessDayConfig": {
          "description": "The business days during which orders can be handled. If not provided, Monday to Friday business days will be assumed.",
          "$ref": "BusinessDayConfig"
        },
        "maxTransitTimeInDays": {
          "description": "Maximum number of business days that are spent in transit. 0 means same day delivery, 1 means next day delivery. Must be greater than or equal to `minTransitTimeInDays`.",
          "type": "integer",
          "format": "uint32"
        },
        "holidayCutoffs": {
          "description": "Holiday cutoff definitions. If configured, they specify order cutoff times for holiday-specific shipping.",
          "items": {
            "$ref": "HolidayCutoff"
          },
          "type": "array"
        },
        "transitTimeTable": {
          "description": "Transit time table, number of business days spent in transit based on row and column dimensions. Either `{min,max}TransitTimeInDays` or `transitTimeTable` can be set, but not both.",
          "$ref": "TransitTable"
        },
        "minHandlingTimeInDays": {
          "type": "integer",
          "format": "uint32",
          "description": "Minimum number of business days spent before an order is shipped. 0 means same day shipped, 1 means next day shipped."
        },
        "maxHandlingTimeInDays": {
          "format": "uint32",
          "type": "integer",
          "description": "Maximum number of business days spent before an order is shipped. 0 means same day shipped, 1 means next day shipped. Must be greater than or equal to `minHandlingTimeInDays`."
        },
        "transitBusinessDayConfig": {
          "description": "The business days during which orders can be in-transit. If not provided, Monday to Friday business days will be assumed.",
          "$ref": "BusinessDayConfig"
        },
        "minTransitTimeInDays": {
          "type": "integer",
          "format": "uint32",
          "description": "Minimum number of business days that are spent in transit. 0 means same day delivery, 1 means next day delivery. Either `{min,max}TransitTimeInDays` or `transitTimeTable` must be set, but not both."
        },
        "warehouseBasedDeliveryTimes": {
          "type": "array",
          "description": "Indicates that the delivery time should be calculated per warehouse (shipping origin location) based on the settings of the selected carrier. When set, no other transit time related field in DeliveryTime should be set.",
          "items": {
            "$ref": "WarehouseBasedDeliveryTime"
          }
        },
        "cutoffTime": {
          "description": "Business days cutoff time definition. If not configured, the cutoff time will be defaulted to 8AM PST. If local delivery, use Service.StoreConfig.CutoffConfig.",
          "$ref": "CutoffTime"
        }
      },
      "type": "object",
      "id": "DeliveryTime"
    },
    "AccountStatus": {
      "id": "AccountStatus",
      "description": "The status of an account, that is, information about its products, which is computed offline and not returned immediately at insertion time.",
      "type": "object",
      "properties": {
        "accountLevelIssues": {
          "type": "array",
          "description": "A list of account level issues.",
          "items": {
            "$ref": "AccountStatusAccountLevelIssue"
          }
        },
        "products": {
          "description": "List of product-related data by channel, destination, and country. Data in this field may be delayed by up to 30 minutes.",
          "items": {
            "$ref": "AccountStatusProducts"
          },
          "type": "array"
        },
        "websiteClaimed": {
          "type": "boolean",
          "description": "Whether the account's website is claimed or not."
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountStatus`\"",
          "type": "string"
        },
        "accountManagement": {
          "type": "string",
          "description": "How the account is managed. Acceptable values are: - \"`manual`\" - \"`automatic`\" "
        },
        "accountId": {
          "type": "string",
          "description": "The ID of the account for which the status is reported."
        }
      }
    },
    "LiasettingsCustomBatchRequest": {
      "id": "LiasettingsCustomBatchRequest",
      "type": "object",
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "LiasettingsCustomBatchRequestEntry"
          },
          "type": "array"
        }
      }
    },
    "ActionFlow": {
      "id": "ActionFlow",
      "description": "Flow that can be selected for an action. When merchant selects a flow, application should open a dialog with more information and input form.",
      "type": "object",
      "properties": {
        "label": {
          "description": "Text value describing the intent for the action flow. It can be used as an input label if merchant needs to pick one of multiple flows. For example: \"I disagree with the issue\"",
          "type": "string"
        },
        "inputs": {
          "type": "array",
          "description": "A list of input fields.",
          "items": {
            "$ref": "InputField"
          }
        },
        "dialogTitle": {
          "type": "string",
          "description": "Title of the request dialog. For example: \"Before you request a review\""
        },
        "dialogMessage": {
          "description": "Message displayed in the request dialog. For example: \"Make sure you've fixed all your country-specific issues. If not, you may have to wait 7 days to request another review\". There may be an more information to be shown in a tooltip.",
          "$ref": "TextWithTooltip"
        },
        "id": {
          "description": "Not for display but need to be sent back for the selected action flow.",
          "type": "string"
        },
        "dialogCallout": {
          "description": "Important message to be highlighted in the request dialog. For example: \"You can only request a review for disagreeing with this issue once. If it's not approved, you'll need to fix the issue and wait a few days before you can request another review.\"",
          "$ref": "Callout"
        },
        "dialogButtonLabel": {
          "description": "Label for the button to trigger the action from the action dialog. For example: \"Request review\"",
          "type": "string"
        }
      }
    },
    "ReportRow": {
      "id": "ReportRow",
      "description": "Result row returned from the search query.",
      "type": "object",
      "properties": {
        "competitiveVisibility": {
          "description": "Competitive visibility fields requested by the merchant in the query. Field values are only set if the merchant queries `CompetitiveVisibilityTopMerchantView`, `CompetitiveVisibilityBenchmarkView` or `CompetitiveVisibilityCompetitorView`.",
          "$ref": "CompetitiveVisibility"
        },
        "segments": {
          "description": "Segmentation dimensions requested by the merchant in the query. Dimension values are only set for dimensions requested explicitly in the query.",
          "$ref": "Segments"
        },
        "priceInsights": {
          "description": "Price insights fields requested by the merchant in the query. Field values are only set if the merchant queries `PriceInsightsProductView`.",
          "$ref": "PriceInsights"
        },
        "priceCompetitiveness": {
          "description": "Price competitiveness fields requested by the merchant in the query. Field values are only set if the merchant queries `PriceCompetitivenessProductView`.",
          "$ref": "PriceCompetitiveness"
        },
        "metrics": {
          "description": "Metrics requested by the merchant in the query. Metric values are only set for metrics requested explicitly in the query.",
          "$ref": "Metrics"
        },
        "productCluster": {
          "description": "Product cluster fields requested by the merchant in the query. Field values are only set if the merchant queries `BestSellersProductClusterView`.",
          "$ref": "ProductCluster"
        },
        "bestSellers": {
          "description": "Best sellers fields requested by the merchant in the query. Field values are only set if the merchant queries `BestSellersProductClusterView` or `BestSellersBrandView`.",
          "$ref": "BestSellers"
        },
        "productView": {
          "description": "Product fields requested by the merchant in the query. Field values are only set if the merchant queries `ProductView`.",
          "$ref": "ProductView"
        },
        "topicTrends": {
          "description": "[Topic trends](https://support.google.com/merchants/answer/13542370) fields requested by the merchant in the query. Field values are only set if the merchant queries `TopicTrendsView`.",
          "$ref": "TopicTrends"
        },
        "brand": {
          "description": "Brand fields requested by the merchant in the query. Field values are only set if the merchant queries `BestSellersBrandView`.",
          "$ref": "Brand"
        }
      }
    },
    "ReturnPolicyOnline": {
      "properties": {
        "returnPolicyId": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Return policy ID generated by Google."
        },
        "returnMethods": {
          "description": "The return methods of how customers can return an item. This value is required to not be empty unless the type of return policy is noReturns.",
          "items": {
            "enumDescriptions": [
              "Default value. This value is unused.",
              "By mail.",
              "In store.",
              "At a kiosk."
            ],
            "enum": [
              "RETURN_METHOD_UNSPECIFIED",
              "BY_MAIL",
              "IN_STORE",
              "AT_A_KIOSK"
            ],
            "type": "string"
          },
          "type": "array"
        },
        "returnPolicyUri": {
          "type": "string",
          "description": "The return policy uri. This can used by Google to do a sanity check for the policy."
        },
        "returnReasonCategoryInfo": {
          "description": "The return reason category information. This required to not be empty unless the type of return policy is noReturns.",
          "items": {
            "$ref": "ReturnPolicyOnlineReturnReasonCategoryInfo"
          },
          "type": "array"
        },
        "policy": {
          "description": "The return policy.",
          "$ref": "ReturnPolicyOnlinePolicy"
        },
        "itemConditions": {
          "type": "array",
          "description": "The item conditions that are accepted for returns. This is required to not be empty unless the type of return policy is noReturns.",
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Default value. This value is unused.",
              "New.",
              "Used."
            ],
            "enum": [
              "ITEM_CONDITION_UNSPECIFIED",
              "NEW",
              "USED"
            ]
          }
        },
        "label": {
          "type": "string",
          "description": "The unique user-defined label of the return policy. The same label cannot be used in different return policies for the same country. Policies with the label 'default' will apply to all products, unless a product specifies a return_policy_label attribute."
        },
        "name": {
          "description": "The name of the policy as shown in Merchant Center.",
          "type": "string"
        },
        "countries": {
          "description": "The countries of sale where the return policy is applicable. The values must be a valid 2 letter ISO 3166 code, e.g. \"US\".",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "restockingFee": {
          "description": "The restocking fee that applies to all return reason categories. This would be treated as a free restocking fee if the value is not set.",
          "$ref": "ReturnPolicyOnlineRestockingFee"
        }
      },
      "type": "object",
      "description": "Return policy online object. This is currently used to represent return policies for ads and free listings programs.",
      "id": "ReturnPolicyOnline"
    },
    "AccountItemUpdatesSettings": {
      "properties": {
        "allowPriceUpdates": {
          "description": "If price updates are enabled, Google always updates the active price with the crawled information.",
          "type": "boolean"
        },
        "allowAvailabilityUpdates": {
          "description": "If availability updates are enabled, any previous availability values get overwritten if Google finds an out-of-stock annotation on the offer's page. If additionally `allow_availability_updates` field is set to true, values get overwritten if Google finds an in-stock annotation on the offer’s page.",
          "type": "boolean"
        },
        "allowStrictAvailabilityUpdates": {
          "type": "boolean",
          "description": "If allow_availability_updates is enabled, items are automatically updated in all your Shopping target countries. By default, availability updates will only be applied to items that are 'out of stock' on your website but 'in stock' on Shopping. Set this to true to also update items that are 'in stock' on your website, but 'out of stock' on Google Shopping. In order for this field to have an effect, you must also allow availability updates."
        },
        "allowConditionUpdates": {
          "description": "If condition updates are enabled, Google always updates item condition with the condition detected from the details of your product.",
          "type": "boolean"
        }
      },
      "type": "object",
      "description": "Settings for the Automatic Item Updates.",
      "id": "AccountItemUpdatesSettings"
    },
    "AccountIssueImpact": {
      "description": "Overall impact of the issue.",
      "id": "AccountIssueImpact",
      "properties": {
        "severity": {
          "description": "The severity of the issue.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Causes either an account suspension or an item disapproval. Errors should be resolved as soon as possible to ensure items are eligible to appear in results again.",
            "Warnings can negatively impact the performance of ads and can lead to item or account suspensions in the future unless the issue is resolved.",
            "Infos are suggested optimizations to increase data quality. Resolving these issues is recommended, but not required."
          ],
          "enum": [
            "SEVERITY_UNSPECIFIED",
            "ERROR",
            "WARNING",
            "INFO"
          ],
          "type": "string"
        },
        "message": {
          "type": "string",
          "description": "Optional. Message summarizing the overall impact of the issue. If present, it should be rendered to the merchant. For example: \"Disapproves 90k offers in 25 countries\""
        },
        "breakdowns": {
          "description": "Detailed impact breakdown. Explains the types of restriction the issue has in different shopping destinations and territory. If present, it should be rendered to the merchant. Can be shown as a mouse over dropdown or a dialog. Each breakdown item represents a group of regions with the same impact details.",
          "items": {
            "$ref": "Breakdown"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "AccountStatusProducts": {
      "id": "AccountStatusProducts",
      "type": "object",
      "properties": {
        "channel": {
          "description": "The channel the data applies to. Acceptable values are: - \"`local`\" - \"`online`\" ",
          "type": "string"
        },
        "statistics": {
          "description": "Aggregated product statistics.",
          "$ref": "AccountStatusStatistics"
        },
        "destination": {
          "type": "string",
          "description": "The destination the data applies to."
        },
        "country": {
          "description": "The country the data applies to.",
          "type": "string"
        },
        "itemLevelIssues": {
          "type": "array",
          "description": "List of item-level issues.",
          "items": {
            "$ref": "AccountStatusItemLevelIssue"
          }
        }
      }
    },
    "AccountLabel": {
      "properties": {
        "description": {
          "description": "The description of this label.",
          "type": "string"
        },
        "accountId": {
          "description": "Immutable. The ID of account this label belongs to.",
          "format": "int64",
          "type": "string"
        },
        "name": {
          "description": "The display name of this label.",
          "type": "string"
        },
        "labelType": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. The type of this label.",
          "enumDescriptions": [
            "Unknown label type.",
            "Indicates that the label was created manually.",
            "Indicates that the label was created automatically by CSS Center."
          ],
          "enum": [
            "LABEL_TYPE_UNSPECIFIED",
            "MANUAL",
            "AUTOMATIC"
          ]
        },
        "labelId": {
          "readOnly": true,
          "description": "Output only. The ID of the label.",
          "type": "string",
          "format": "int64"
        }
      },
      "type": "object",
      "description": "Label assigned by CSS domain or CSS group to one of its sub-accounts.",
      "id": "AccountLabel"
    },
    "DatafeedsCustomBatchRequestEntry": {
      "description": "A batch entry encoding a single non-batch datafeeds request.",
      "id": "DatafeedsCustomBatchRequestEntry",
      "properties": {
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "type": "integer",
          "format": "uint32"
        },
        "merchantId": {
          "description": "The ID of the managing account.",
          "type": "string",
          "format": "uint64"
        },
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`delete`\" - \"`fetchNow`\" - \"`get`\" - \"`insert`\" - \"`update`\" ",
          "type": "string"
        },
        "datafeedId": {
          "format": "uint64",
          "type": "string",
          "description": "The ID of the data feed to get, delete or fetch."
        },
        "datafeed": {
          "description": "The data feed to insert.",
          "$ref": "Datafeed"
        }
      },
      "type": "object"
    },
    "VerifyPhoneNumberResponse": {
      "description": "Response message for the VerifyPhoneNumber method.",
      "id": "VerifyPhoneNumberResponse",
      "properties": {
        "verifiedPhoneNumber": {
          "type": "string",
          "description": "Verified phone number if verification is successful. This phone number can only be replaced by another verified phone number."
        }
      },
      "type": "object"
    },
    "AccountStatusItemLevelIssue": {
      "id": "AccountStatusItemLevelIssue",
      "type": "object",
      "properties": {
        "documentation": {
          "type": "string",
          "description": "The URL of a web page to help with resolving this issue."
        },
        "servability": {
          "type": "string",
          "description": "How this issue affects serving of the offer."
        },
        "numItems": {
          "description": "Number of items with this issue.",
          "type": "string",
          "format": "int64"
        },
        "code": {
          "type": "string",
          "description": "The error code of the issue."
        },
        "resolution": {
          "description": "Whether the issue can be resolved by the merchant.",
          "type": "string"
        },
        "detail": {
          "description": "A detailed issue description in English.",
          "type": "string"
        },
        "attributeName": {
          "type": "string",
          "description": "The attribute's name, if the issue is caused by a single attribute."
        },
        "description": {
          "type": "string",
          "description": "A short issue description in English."
        }
      }
    },
    "PosSaleResponse": {
      "id": "PosSaleResponse",
      "properties": {
        "contentLanguage": {
          "description": "Required. The two-letter ISO 639-1 language code for the item.",
          "type": "string"
        },
        "storeCode": {
          "type": "string",
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile."
        },
        "itemId": {
          "type": "string",
          "description": "Required. A unique identifier for the item."
        },
        "saleId": {
          "description": "A unique ID to group items from the same sale event.",
          "type": "string"
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        },
        "quantity": {
          "description": "Required. The relative change of the available quantity. Negative for items returned.",
          "type": "string",
          "format": "int64"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posSaleResponse`\".",
          "type": "string"
        },
        "timestamp": {
          "type": "string",
          "description": "Required. The inventory timestamp, in ISO 8601 format."
        },
        "price": {
          "description": "Required. The price of the item.",
          "$ref": "Price"
        }
      },
      "type": "object"
    },
    "AccounttaxListResponse": {
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accounttaxListResponse`\".",
          "type": "string"
        },
        "nextPageToken": {
          "type": "string",
          "description": "The token for the retrieval of the next page of account tax settings."
        },
        "resources": {
          "items": {
            "$ref": "AccountTax"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "AccounttaxListResponse"
    },
    "ProductStatusItemLevelIssue": {
      "id": "ProductStatusItemLevelIssue",
      "type": "object",
      "properties": {
        "description": {
          "description": "A short issue description in English.",
          "type": "string"
        },
        "code": {
          "type": "string",
          "description": "The error code of the issue."
        },
        "detail": {
          "type": "string",
          "description": "A detailed issue description in English."
        },
        "servability": {
          "type": "string",
          "description": "How this issue affects serving of the offer."
        },
        "destination": {
          "type": "string",
          "description": "The destination the issue applies to."
        },
        "documentation": {
          "type": "string",
          "description": "The URL of a web page to help with resolving this issue."
        },
        "attributeName": {
          "type": "string",
          "description": "The attribute's name, if the issue is caused by a single attribute."
        },
        "resolution": {
          "type": "string",
          "description": "Whether the issue can be resolved by the merchant."
        },
        "applicableCountries": {
          "type": "array",
          "description": "List of country codes (ISO 3166-1 alpha-2) where issue applies to the offer.",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "CompetitiveVisibility": {
      "id": "CompetitiveVisibility",
      "description": "Fields related to [competitive visibility reports] (https://support.google.com/merchants/answer/11366442).",
      "type": "object",
      "properties": {
        "countryCode": {
          "description": "The country where impression appeared. Required in the `SELECT` clause. A `WHERE` condition on `competitive_visibility.country_code` is required in the query.",
          "type": "string"
        },
        "adsOrganicRatio": {
          "type": "number",
          "format": "double",
          "description": "[Ads / organic ratio] (https://support.google.com/merchants/answer/11366442#zippy=%2Cadsfree-ratio) shows how often a merchant receives impressions from Shopping ads compared to organic traffic. The number is rounded and bucketed. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause."
        },
        "categoryId": {
          "description": "Google product category ID to calculate the report for, represented in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436). Required in the `SELECT` clause. A `WHERE` condition on `competitive_visibility.category_id` is required in the query.",
          "format": "int64",
          "type": "string"
        },
        "categoryBenchmarkVisibilityTrend": {
          "description": "Change in visibility based on impressions with respect to the start of the selected time range (or first day with non-zero impressions) for a combined set of merchants with highest visibility approximating the market. Available only in `CompetitiveVisibilityBenchmarkView`. Cannot be filtered on in the 'WHERE' clause.",
          "type": "number",
          "format": "double"
        },
        "higherPositionRate": {
          "type": "number",
          "format": "double",
          "description": "Higher position rate shows how often a competitor’s offer got placed in a higher position on the page than your offer. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause."
        },
        "date": {
          "description": "Date of this row. Available only in `CompetitiveVisibilityBenchmarkView` and `CompetitiveVisibilityCompetitorView`. Required in the `SELECT` clause for `CompetitiveVisibilityMarketBenchmarkView`.",
          "$ref": "Date"
        },
        "domain": {
          "description": "Domain of your competitor or your domain, if 'is_your_domain' is true. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Required in the `SELECT` clause for `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause.",
          "type": "string"
        },
        "pageOverlapRate": {
          "type": "number",
          "format": "double",
          "description": "Page overlap rate describes how frequently competing retailers’ offers are shown together with your offers on the same page. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause."
        },
        "rank": {
          "description": "Position of the domain in the top merchants ranking for the selected keys (`date`, `category_id`, `country_code`, `listing_type`) based on impressions. 1 is the highest. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause.",
          "format": "uint64",
          "type": "string"
        },
        "isYourDomain": {
          "description": "True if this row contains data for your domain. Available only in `CompetitiveVisibilityTopMerchantView` and `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause.",
          "type": "boolean"
        },
        "trafficSource": {
          "description": "Type of impression listing. Required in the `SELECT` clause. Cannot be filtered on in the 'WHERE' clause.",
          "enumDescriptions": [
            "Traffic source is unknown.",
            "Organic traffic.",
            "Traffic from Ads.",
            "Organic and Ads traffic."
          ],
          "enum": [
            "UNKNOWN",
            "ORGANIC",
            "ADS",
            "ALL"
          ],
          "type": "string"
        },
        "yourDomainVisibilityTrend": {
          "type": "number",
          "format": "double",
          "description": "Change in visibility based on impressions for your domain with respect to the start of the selected time range (or first day with non-zero impressions). Available only in `CompetitiveVisibilityBenchmarkView`. Cannot be filtered on in the 'WHERE' clause."
        },
        "relativeVisibility": {
          "type": "number",
          "format": "double",
          "description": "Relative visibility shows how often your competitors’ offers are shown compared to your offers. In other words, this is the number of displayed impressions of a competitor retailer divided by the number of your displayed impressions during a selected time range for a selected product category and country. Available only in `CompetitiveVisibilityCompetitorView`. Cannot be filtered on in the 'WHERE' clause."
        }
      }
    },
    "AccountStatusStatistics": {
      "type": "object",
      "properties": {
        "pending": {
          "description": "Number of pending offers.",
          "format": "int64",
          "type": "string"
        },
        "disapproved": {
          "type": "string",
          "format": "int64",
          "description": "Number of disapproved offers."
        },
        "expiring": {
          "format": "int64",
          "type": "string",
          "description": "Number of expiring offers."
        },
        "active": {
          "description": "Number of active offers.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "AccountStatusStatistics"
    },
    "DatafeedStatusError": {
      "properties": {
        "count": {
          "type": "string",
          "format": "uint64",
          "description": "The number of occurrences of the error in the feed."
        },
        "examples": {
          "type": "array",
          "description": "A list of example occurrences of the error, grouped by product.",
          "items": {
            "$ref": "DatafeedStatusExample"
          }
        },
        "code": {
          "description": "The code of the error, for example, \"validation/invalid_value\".",
          "type": "string"
        },
        "message": {
          "description": "The error message, for example, \"Invalid price\".",
          "type": "string"
        }
      },
      "type": "object",
      "description": "An error occurring in the feed, like \"invalid price\".",
      "id": "DatafeedStatusError"
    },
    "ConversionSource": {
      "properties": {
        "merchantCenterDestination": {
          "description": "Conversion Source of type \"Merchant Center Tag Destination\".",
          "$ref": "MerchantCenterDestination"
        },
        "expireTime": {
          "format": "google-datetime",
          "type": "string",
          "description": "Output only. The time when an archived conversion source becomes permanently deleted and is no longer available to undelete.",
          "readOnly": true
        },
        "conversionSourceId": {
          "type": "string",
          "description": "Output only. Generated by the Content API upon creation of a new `ConversionSource`. Format: [a-z]{4}:.+ The four characters before the colon represent the type of conversio source. Content after the colon represents the ID of the conversion source within that type. The ID of two different conversion sources might be the same across different types. The following type prefixes are supported: - galk: For GoogleAnalyticsLink sources. - mcdn: For MerchantCenterDestination sources.",
          "readOnly": true
        },
        "googleAnalyticsLink": {
          "description": "Immutable. Conversion Source of type \"Link to Google Analytics Property\".",
          "$ref": "GoogleAnalyticsLink"
        },
        "state": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Current state of this conversion source. Can't be edited through the API.",
          "enumDescriptions": [
            "",
            "Conversion source is fully functional.",
            "Conversion source has been archived in the last 30 days and not currently functional. Can be restored using the undelete method.",
            "Conversion source creation has started but not fully finished yet."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "ACTIVE",
            "ARCHIVED",
            "PENDING"
          ]
        }
      },
      "type": "object",
      "description": "Represents a conversion source owned by a Merchant account. A merchant account can have up to 200 conversion sources.",
      "id": "ConversionSource"
    },
    "AccountImageImprovements": {
      "id": "AccountImageImprovements",
      "description": "This improvement will attempt to automatically correct submitted images if they don't meet the [image requirements](https://support.google.com/merchants/answer/6324350), for example, removing overlays. If successful, the image will be replaced and approved. This improvement is only applied to images of disapproved offers. For more information see: [Automatic image improvements](https://support.google.com/merchants/answer/9242973)",
      "type": "object",
      "properties": {
        "effectiveAllowAutomaticImageImprovements": {
          "description": "Output only. The effective value of allow_automatic_image_improvements. If account_image_improvements_settings is present, then this value is the same. Otherwise, it represents the inherited value of the parent account. Read-only.",
          "readOnly": true,
          "type": "boolean"
        },
        "accountImageImprovementsSettings": {
          "description": "Determines how the images should be automatically updated. If this field is not present, then the settings will be deleted. If there are no settings for subaccount, they are inherited from aggregator.",
          "$ref": "AccountImageImprovementsSettings"
        }
      }
    },
    "DatafeedstatusesListResponse": {
      "id": "DatafeedstatusesListResponse",
      "type": "object",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedstatusesListResponse`\".",
          "type": "string"
        },
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of datafeed statuses.",
          "type": "string"
        },
        "resources": {
          "items": {
            "$ref": "DatafeedStatus"
          },
          "type": "array"
        }
      }
    },
    "ListPromotionResponse": {
      "id": "ListPromotionResponse",
      "description": "Response message for Promotions.List method.",
      "type": "object",
      "properties": {
        "promotions": {
          "description": "List of all available promotions for the merchant.",
          "items": {
            "$ref": "Promotion"
          },
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      }
    },
    "ProductView": {
      "properties": {
        "productTypeL3": {
          "description": "Third level of the product type in merchant's own [product taxonomy](https://support.google.com/merchants/answer/6324436).",
          "type": "string"
        },
        "categoryL4": {
          "type": "string",
          "description": "Fourth level of the product category in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436)."
        },
        "categoryL5": {
          "description": "Fifth level of the product category in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436).",
          "type": "string"
        },
        "title": {
          "type": "string",
          "description": "Title of the product."
        },
        "categoryL1": {
          "description": "First level of the product category in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436).",
          "type": "string"
        },
        "channel": {
          "type": "string",
          "description": "Channel of the product (online versus local).",
          "enumDescriptions": [
            "Indicates that the channel is unspecified.",
            "Indicates that the channel is local.",
            "Indicates that the channel is online."
          ],
          "enum": [
            "CHANNEL_UNSPECIFIED",
            "LOCAL",
            "ONLINE"
          ]
        },
        "priceMicros": {
          "type": "string",
          "format": "int64",
          "description": "Product price specified as micros (1 millionth of a standard unit, 1 USD = 1000000 micros) in the product currency. Absent in case the information about the price of the product is not available."
        },
        "offerId": {
          "type": "string",
          "description": "Merchant-provided id of the product."
        },
        "availability": {
          "description": "Availability of the product.",
          "type": "string"
        },
        "itemGroupId": {
          "type": "string",
          "description": "Item group ID provided by the merchant for grouping variants together."
        },
        "condition": {
          "description": "Condition of the product.",
          "type": "string"
        },
        "languageCode": {
          "description": "Language code of the product in BCP 47 format.",
          "type": "string"
        },
        "productTypeL1": {
          "type": "string",
          "description": "First level of the product type in merchant's own [product taxonomy](https://support.google.com/merchants/answer/6324436)."
        },
        "gtin": {
          "type": "array",
          "description": "GTIN of the product.",
          "items": {
            "type": "string"
          }
        },
        "expirationDate": {
          "description": "Expiration date for the product. Specified on insertion.",
          "$ref": "Date"
        },
        "id": {
          "type": "string",
          "description": "The REST ID of the product, in the form of channel:contentLanguage:targetCountry:offerId. Content API methods that operate on products take this as their productId parameter. Should always be included in the SELECT clause."
        },
        "productTypeL2": {
          "type": "string",
          "description": "Second level of the product type in merchant's own [product taxonomy](https://support.google.com/merchants/answer/6324436)."
        },
        "currencyCode": {
          "description": "Product price currency code (for example, ISO 4217). Absent if product price is not available.",
          "type": "string"
        },
        "itemIssues": {
          "type": "array",
          "description": "List of item issues for the product.",
          "items": {
            "$ref": "ProductViewItemIssue"
          }
        },
        "productTypeL5": {
          "description": "Fifth level of the product type in merchant's own [product taxonomy](https://support.google.com/merchants/answer/6324436).",
          "type": "string"
        },
        "categoryL2": {
          "type": "string",
          "description": "Second level of the product category in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436)."
        },
        "creationTime": {
          "description": "The time the merchant created the product in timestamp seconds.",
          "format": "google-datetime",
          "type": "string"
        },
        "clickPotential": {
          "type": "string",
          "description": "Estimated performance potential compared to highest performing products of the merchant.",
          "enumDescriptions": [
            "Unknown predicted clicks impact.",
            "Potential to receive a low number of clicks compared to the highest performing products of the merchant.",
            "Potential to receive a moderate number of clicks compared to the highest performing products of the merchant.",
            "Potential to receive a similar number of clicks as the highest performing products of the merchant."
          ],
          "enum": [
            "CLICK_POTENTIAL_UNSPECIFIED",
            "LOW",
            "MEDIUM",
            "HIGH"
          ]
        },
        "productTypeL4": {
          "type": "string",
          "description": "Fourth level of the product type in merchant's own [product taxonomy](https://support.google.com/merchants/answer/6324436)."
        },
        "aggregatedDestinationStatus": {
          "description": "Aggregated destination status.",
          "enumDescriptions": [
            "Undefined aggregated status.",
            "Offer isn't eligible, or is disapproved for all destinations.",
            "Offer's status is pending in all destinations.",
            "Offer is eligible for some (but not all) destinations.",
            "Offer is eligible for all destinations."
          ],
          "enum": [
            "AGGREGATED_STATUS_UNSPECIFIED",
            "NOT_ELIGIBLE_OR_DISAPPROVED",
            "PENDING",
            "ELIGIBLE_LIMITED",
            "ELIGIBLE"
          ],
          "type": "string"
        },
        "shippingLabel": {
          "description": "The normalized shipping label specified in the feed",
          "type": "string"
        },
        "brand": {
          "type": "string",
          "description": "Brand of the product."
        },
        "categoryL3": {
          "description": "Third level of the product category in [Google's product taxonomy](https://support.google.com/merchants/answer/6324436).",
          "type": "string"
        },
        "clickPotentialRank": {
          "format": "int64",
          "type": "string",
          "description": "Normalized click potential of the product. Values range from 1 to 1000, where 1 is the highest click potential and 1000 is the theoretical lowest."
        }
      },
      "type": "object",
      "description": "Product fields. Values are only set for fields requested explicitly in the request's search query.",
      "id": "ProductView"
    },
    "WarehouseCutoffTime": {
      "id": "WarehouseCutoffTime",
      "type": "object",
      "properties": {
        "hour": {
          "description": "Required. Hour (24-hour clock) of the cutoff time until which an order has to be placed to be processed in the same day by the warehouse. Hour is based on the timezone of warehouse.",
          "type": "integer",
          "format": "int32"
        },
        "minute": {
          "description": "Required. Minute of the cutoff time until which an order has to be placed to be processed in the same day by the warehouse. Minute is based on the timezone of warehouse.",
          "format": "int32",
          "type": "integer"
        }
      }
    },
    "AccountBusinessInformation": {
      "type": "object",
      "properties": {
        "customerService": {
          "description": "The customer service information of the business.",
          "$ref": "AccountCustomerService"
        },
        "koreanBusinessRegistrationNumber": {
          "type": "string",
          "description": "The 10-digit [Korean business registration number](https://support.google.com/merchants/answer/9037766) separated with dashes in the format: XXX-XX-XXXXX. This field will only be updated if explicitly set."
        },
        "phoneNumber": {
          "description": "The phone number of the business in [E.164](https://en.wikipedia.org/wiki/E.164) format. This can only be updated if a verified phone number is not already set. To replace a verified phone number use the `Accounts.requestphoneverification` and `Accounts.verifyphonenumber`.",
          "type": "string"
        },
        "phoneVerificationStatus": {
          "type": "string",
          "description": "Verification status of the phone number of the business. This status is read only and can be updated only by successful phone verification. Acceptable values are: - \"`verified`\" - \"`unverified`\" "
        },
        "address": {
          "description": "The address of the business. Use `\\n` to add a second address line.",
          "$ref": "AccountAddress"
        }
      },
      "id": "AccountBusinessInformation"
    },
    "PosSale": {
      "id": "PosSale",
      "description": "The change of the available quantity of an item at the given store.",
      "type": "object",
      "properties": {
        "quantity": {
          "description": "Required. The relative change of the available quantity. Negative for items returned.",
          "format": "int64",
          "type": "string"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posSale`\"",
          "type": "string"
        },
        "timestamp": {
          "description": "Required. The inventory timestamp, in ISO 8601 format.",
          "type": "string"
        },
        "price": {
          "description": "Required. The price of the item.",
          "$ref": "Price"
        },
        "contentLanguage": {
          "description": "Required. The two-letter ISO 639-1 language code for the item.",
          "type": "string"
        },
        "storeCode": {
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile.",
          "type": "string"
        },
        "itemId": {
          "type": "string",
          "description": "Required. A unique identifier for the item."
        },
        "saleId": {
          "type": "string",
          "description": "A unique ID to group items from the same sale event."
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        }
      }
    },
    "ShippingsettingsGetSupportedCarriersResponse": {
      "id": "ShippingsettingsGetSupportedCarriersResponse",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsGetSupportedCarriersResponse`\"."
        },
        "carriers": {
          "description": "A list of supported carriers. May be empty.",
          "items": {
            "$ref": "CarriersCarrier"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "InputFieldCheckboxInput": {
      "properties": {},
      "type": "object",
      "description": "Checkbox input allows merchants to provide a boolean value. Corresponds to the [html input type=checkbox](https://www.w3.org/TR/2012/WD-html-markup-20121025/input.checkbox.html#input.checkbox). If merchant checks the box, the input value for the field is `true`, otherwise it is `false`. This type of input is often used as a confirmation that the merchant completed required steps before they are allowed to start the action. In such a case, the input field is marked as required and the button to trigger the action should stay disabled until the merchant checks the box.",
      "id": "InputFieldCheckboxInput"
    },
    "ReturnPolicyOnlineRestockingFee": {
      "description": "The restocking fee. This can either be a fixed fee or a micro percent.",
      "id": "ReturnPolicyOnlineRestockingFee",
      "properties": {
        "microPercent": {
          "type": "integer",
          "format": "int32",
          "description": "Percent of total price in micros. 15,000,000 means 15% of the total price would be charged."
        },
        "fixedFee": {
          "description": "Fixed restocking fee.",
          "$ref": "PriceAmount"
        }
      },
      "type": "object"
    },
    "ListConversionSourcesResponse": {
      "properties": {
        "conversionSources": {
          "description": "List of conversion sources.",
          "items": {
            "$ref": "ConversionSource"
          },
          "type": "array"
        },
        "nextPageToken": {
          "description": "Token to be used to fetch the next results page.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Response message for the ListConversionSources method.",
      "id": "ListConversionSourcesResponse"
    },
    "ShoppingAdsProgramStatusReviewIneligibilityReasonDetails": {
      "id": "ShoppingAdsProgramStatusReviewIneligibilityReasonDetails",
      "description": "Additional details for review ineligibility reasons.",
      "type": "object",
      "properties": {
        "cooldownTime": {
          "description": "This timestamp represents end of cooldown period for review ineligbility reason `IN_COOLDOWN_PERIOD`.",
          "format": "google-datetime",
          "type": "string"
        }
      }
    },
    "RenderProductIssuesResponse": {
      "type": "object",
      "properties": {
        "issues": {
          "type": "array",
          "description": "List of issues for a given product. This list can be shown with compressed, expandable items. In the compressed form, the title and impact should be shown for each issue. Once the issue is expanded, the detailed content and available actions should be rendered.",
          "items": {
            "$ref": "ProductIssue"
          }
        },
        "alternateDisputeResolution": {
          "description": "Alternate Dispute Resolution (ADR) is deprecated. Use `prerendered_out_of_court_dispute_settlement` instead.",
          "deprecated": true,
          "$ref": "AlternateDisputeResolution"
        }
      },
      "id": "RenderProductIssuesResponse",
      "description": "Response containing support content and actions for listed product issues."
    },
    "TransitTableTransitTimeRow": {
      "properties": {
        "values": {
          "type": "array",
          "items": {
            "$ref": "TransitTableTransitTimeRowTransitTimeValue"
          }
        }
      },
      "type": "object",
      "id": "TransitTableTransitTimeRow"
    },
    "Metrics": {
      "description": "Performance metrics. Values are only set for metrics requested explicitly in the request's search query.",
      "id": "Metrics",
      "properties": {
        "conversionRate": {
          "type": "number",
          "format": "double",
          "description": "Number of conversions divided by the number of clicks, reported on the impression date. The metric is currently available only for the `FREE_PRODUCT_LISTING` program."
        },
        "daysToShip": {
          "format": "double",
          "type": "number",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Average number of days between an order being placed and the order being fully shipped, reported on the last shipment date. **This metric cannot be segmented by product dimensions and customer_country_code.**"
        },
        "conversionValueMicros": {
          "description": "Value of conversions in micros (1 millionth of a standard unit, 1 USD = 1000000 micros) attributed to the product, reported on the conversion date. The metric is currently available only for the `FREE_PRODUCT_LISTING` program. The currency of the returned value is stored in the currency_code segment. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response.",
          "type": "string",
          "format": "int64"
        },
        "itemFillRate": {
          "type": "number",
          "format": "double",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Percentage of shipped items in relation to all finalized items (shipped or rejected by the merchant; unshipped items are not taken into account), reported on the order date. Item fill rate is lowered by merchant rejections. **This metric cannot be segmented by customer_country_code.**"
        },
        "rejectedItems": {
          "type": "string",
          "format": "int64",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of ordered items canceled by the merchant, reported on the order date. **This metric cannot be segmented by customer_country_code.**"
        },
        "conversions": {
          "format": "double",
          "type": "number",
          "description": "Number of conversions attributed to the product, reported on the conversion date. Depending on the attribution model, a conversion might be distributed across multiple clicks, where each click gets its own credit assigned. This metric is a sum of all such credits. The metric is currently available only for the `FREE_PRODUCT_LISTING` program."
        },
        "aos": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Average order size - the average number of items in an order. **This metric cannot be segmented by product dimensions and customer_country_code.**",
          "format": "double",
          "type": "number"
        },
        "itemDaysToShip": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Average number of days between an item being ordered and the item being **This metric cannot be segmented by customer_country_code.**",
          "type": "number",
          "format": "double"
        },
        "orderedItems": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of ordered items. Excludes customer cancellations that happened within 30 minutes of placing the order. **This metric cannot be segmented by customer_country_code.**",
          "format": "int64",
          "type": "string"
        },
        "ctr": {
          "description": "Click-through rate - the number of clicks merchant's products receive (clicks) divided by the number of times the products are shown (impressions).",
          "type": "number",
          "format": "double"
        },
        "shippedOrders": {
          "type": "string",
          "format": "int64",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of fully shipped orders, reported on the last shipment date. **This metric cannot be segmented by product dimensions and customer_country_code.**"
        },
        "returnedItems": {
          "type": "string",
          "format": "int64",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of ordered items sent back for return, reported on the date when the merchant accepted the return. **This metric cannot be segmented by customer_country_code.**"
        },
        "unshippedOrders": {
          "type": "number",
          "format": "double",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of orders not shipped or partially shipped up until the end of the queried day. If a multi-day period is specified in the search query, the returned value is the average number of unshipped orders over the days in the queried period. **This metric cannot be segmented by product dimensions and customer_country_code.**"
        },
        "impressions": {
          "format": "int64",
          "type": "string",
          "description": "Number of times merchant's products are shown."
        },
        "aovMicros": {
          "type": "number",
          "format": "double",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Average order value in micros (1 millionth of a standard unit, 1 USD = 1000000 micros) - the average value (total price of items) of all placed orders. The currency of the returned value is stored in the currency_code segment. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response. **This metric cannot be segmented by product dimensions and customer_country_code.**"
        },
        "returnRate": {
          "format": "double",
          "type": "number",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Total price of returned items divided by the total price of shipped items, reported on the order date. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response. **This metric cannot be segmented by customer_country_code.**"
        },
        "clicks": {
          "description": "Number of clicks.",
          "format": "int64",
          "type": "string"
        },
        "shippedItems": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of shipped items, reported on the shipment date. **This metric cannot be segmented by customer_country_code.**",
          "format": "int64",
          "type": "string"
        },
        "shippedItemSalesMicros": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Total price of shipped items in micros (1 millionth of a standard unit, 1 USD = 1000000 micros), reported on the order date. Excludes shipping and taxes (US only). The currency of the returned value is stored in the currency_code segment. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response. **This metric cannot be segmented by customer_country_code.**",
          "format": "int64",
          "type": "string"
        },
        "returnsMicros": {
          "type": "string",
          "format": "int64",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Total price of ordered items sent back for return in micros (1 millionth of a standard unit, 1 USD = 1000000 micros), reported on the date when the merchant accepted the return. The currency of the returned value is stored in the currency_code segment. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response. **This metric cannot be segmented by customer_country_code.**"
        },
        "orderedItemSalesMicros": {
          "type": "string",
          "format": "int64",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Total price of ordered items in micros (1 millionth of a standard unit, 1 USD = 1000000 micros). Excludes shipping, taxes (US only), and customer cancellations that happened within 30 minutes of placing the order. The currency of the returned value is stored in the currency_code segment. If this metric is selected, 'segments.currency_code' is automatically added to the SELECT clause in the search query (unless it is explicitly selected by the user) and the currency_code segment is populated in the response. **This metric cannot be segmented by customer_country_code.**"
        },
        "unshippedItems": {
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of ordered items not shipped up until the end of the queried day. If a multi-day period is specified in the search query, the returned value is the average number of unshipped items over the days in the queried period. **This metric cannot be segmented by customer_country_code.**",
          "type": "number",
          "format": "double"
        },
        "orders": {
          "format": "int64",
          "type": "string",
          "description": "*Deprecated*: This field is no longer supported and retrieving it returns 0 starting from May 2024. Number of placed orders. Excludes customer cancellations that happened within 30 minutes of placing the order. **This metric cannot be segmented by product dimensions and customer_country_code.**"
        }
      },
      "type": "object"
    },
    "LiasettingsCustomBatchRequestEntry": {
      "properties": {
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" - \"`getAccessibleGmbAccounts`\" - \"`requestGmbAccess`\" - \"`requestInventoryVerification`\" - \"`setInventoryVerificationContact`\" - \"`update`\" ",
          "type": "string"
        },
        "omnichannelExperience": {
          "description": "The omnichannel experience for a country. Required only for SetOmnichannelExperience.",
          "$ref": "LiaOmnichannelExperience"
        },
        "accountId": {
          "format": "uint64",
          "type": "string",
          "description": "The ID of the account for which to get/update account LIA settings."
        },
        "gmbEmail": {
          "description": "The Business Profile. Required only for RequestGmbAccess.",
          "type": "string"
        },
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        },
        "country": {
          "description": "The country code. Required only for RequestInventoryVerification.",
          "type": "string"
        },
        "contactName": {
          "description": "Inventory validation contact name. Required only for SetInventoryValidationContact.",
          "type": "string"
        },
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "format": "uint32",
          "type": "integer"
        },
        "posExternalAccountId": {
          "description": "The account ID by which this merchant is known to the POS provider.",
          "type": "string"
        },
        "contactEmail": {
          "type": "string",
          "description": "Inventory validation contact email. Required only for SetInventoryValidationContact."
        },
        "posDataProviderId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of POS data provider. Required only for SetPosProvider."
        },
        "liaSettings": {
          "description": "The account Lia settings to update. Only defined if the method is `update`.",
          "$ref": "LiaSettings"
        }
      },
      "type": "object",
      "id": "LiasettingsCustomBatchRequestEntry"
    },
    "VerifyPhoneNumberRequest": {
      "id": "VerifyPhoneNumberRequest",
      "description": "Request message for the VerifyPhoneNumber method.",
      "type": "object",
      "properties": {
        "verificationId": {
          "type": "string",
          "description": "The verification ID returned by `requestphoneverification`."
        },
        "phoneVerificationMethod": {
          "description": "Verification method used to receive verification code.",
          "enumDescriptions": [
            "Unknown method.",
            "Receive verification code by SMS.",
            "Receive verification code by phone call."
          ],
          "enum": [
            "PHONE_VERIFICATION_METHOD_UNSPECIFIED",
            "SMS",
            "PHONE_CALL"
          ],
          "type": "string"
        },
        "verificationCode": {
          "description": "The verification code that was sent to the phone number for validation.",
          "type": "string"
        }
      }
    },
    "AccounttaxCustomBatchRequestEntry": {
      "description": "A batch entry encoding a single non-batch accounttax request.",
      "id": "AccounttaxCustomBatchRequestEntry",
      "properties": {
        "batchId": {
          "type": "integer",
          "format": "uint32",
          "description": "An entry ID, unique within the batch request."
        },
        "accountTax": {
          "description": "The account tax settings to update. Only defined if the method is `update`.",
          "$ref": "AccountTax"
        },
        "merchantId": {
          "description": "The ID of the managing account.",
          "type": "string",
          "format": "uint64"
        },
        "method": {
          "type": "string",
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" - \"`update`\" "
        },
        "accountId": {
          "description": "The ID of the account for which to get/update account tax settings.",
          "format": "uint64",
          "type": "string"
        }
      },
      "type": "object"
    },
    "ProductStructuredTitle": {
      "id": "ProductStructuredTitle",
      "description": "Structured title, for algorithmically (AI)-generated titles. See [title](https://support.google.com/merchants/answer/6324415#Whentouse) for more information.",
      "type": "object",
      "properties": {
        "digitalSourceType": {
          "description": "Optional. The digital source type. Acceptable values are: - \"`trained_algorithmic_media`\" - \"`default`\" ",
          "type": "string"
        },
        "content": {
          "description": "Required. The title text. Maximum length is 150 characters.",
          "type": "string"
        }
      }
    },
    "ListRegionsResponse": {
      "id": "ListRegionsResponse",
      "description": "Response message for the `ListRegions` method.",
      "type": "object",
      "properties": {
        "regions": {
          "type": "array",
          "description": "The regions from the specified merchant.",
          "items": {
            "$ref": "Region"
          }
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      }
    },
    "ProductStatus": {
      "type": "object",
      "properties": {
        "googleExpirationDate": {
          "description": "Date on which the item expires in Google Shopping, in ISO 8601 format.",
          "type": "string"
        },
        "link": {
          "description": "The link to the product.",
          "type": "string"
        },
        "lastUpdateDate": {
          "description": "Date on which the item has been last updated, in ISO 8601 format.",
          "type": "string"
        },
        "destinationStatuses": {
          "type": "array",
          "description": "The intended destinations for the product.",
          "items": {
            "$ref": "ProductStatusDestinationStatus"
          }
        },
        "creationDate": {
          "type": "string",
          "description": "Date on which the item has been created, in ISO 8601 format."
        },
        "productId": {
          "description": "The ID of the product for which status is reported.",
          "type": "string"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productStatus`\""
        },
        "title": {
          "type": "string",
          "description": "The title of the product."
        },
        "itemLevelIssues": {
          "type": "array",
          "description": "A list of all issues associated with the product.",
          "items": {
            "$ref": "ProductStatusItemLevelIssue"
          }
        }
      },
      "id": "ProductStatus",
      "description": "The status of a product, that is, information about a product computed asynchronously."
    },
    "RegionalinventoryCustomBatchRequest": {
      "type": "object",
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "RegionalinventoryCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "id": "RegionalinventoryCustomBatchRequest"
    },
    "ShippingsettingsGetSupportedHolidaysResponse": {
      "id": "ShippingsettingsGetSupportedHolidaysResponse",
      "properties": {
        "holidays": {
          "type": "array",
          "description": "A list of holidays applicable for delivery guarantees. May be empty.",
          "items": {
            "$ref": "HolidaysHoliday"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsGetSupportedHolidaysResponse`\"."
        }
      },
      "type": "object"
    },
    "UrlSettings": {
      "properties": {
        "checkoutUriTemplate": {
          "description": "URL template when the placeholders are expanded will redirect the buyer to the merchant checkout page with the item in the cart.",
          "type": "string"
        },
        "cartUriTemplate": {
          "type": "string",
          "description": "URL template when the placeholders are expanded will redirect the buyer to the cart page on the merchant website with the selected item in cart."
        }
      },
      "type": "object",
      "description": "Specifications related to the `Checkout` URL. The `UriTemplate` is of the form `https://www.mystore.com/checkout?item_id={id}` where `{id}` will be automatically replaced with data from the merchant account with this attribute [offer_id](https://developers.google.com/shopping-content/reference/rest/v2.1/products#Product.FIELDS.offer_id)",
      "id": "UrlSettings"
    },
    "AccountsListResponse": {
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of accounts.",
          "type": "string"
        },
        "resources": {
          "type": "array",
          "items": {
            "$ref": "Account"
          }
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsListResponse`\".",
          "type": "string"
        }
      },
      "id": "AccountsListResponse"
    },
    "ShoppingAdsProgramStatusRegionStatus": {
      "type": "object",
      "properties": {
        "regionCodes": {
          "description": "The two-letter [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) codes for all the regions with the same `eligibilityStatus` and `reviewEligibility`.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "reviewIssues": {
          "type": "array",
          "description": "Issues evaluated in the review process. Fix all issues before requesting a review.",
          "items": {
            "type": "string"
          }
        },
        "onboardingIssues": {
          "description": "Issues that must be fixed to be eligible for review.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "disapprovalDate": {
          "description": "Date by which eligibilityStatus will go from `WARNING` to `DISAPPROVED`. Only visible when your eligibilityStatus is WARNING. In [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) format: `YYYY-MM-DD`.",
          "type": "string"
        },
        "reviewEligibilityStatus": {
          "type": "string",
          "description": "If a program is eligible for review in a specific region. Only visible if `eligibilityStatus` is `DISAPPROVED`.",
          "enumDescriptions": [
            "Review eligibility state is unknown.",
            "Account is eligible for review for a specified region code.",
            "Account is not eligible for review for a specified region code."
          ],
          "enum": [
            "REVIEW_ELIGIBILITY_UNSPECIFIED",
            "ELIGIBLE",
            "INELIGIBLE"
          ]
        },
        "reviewIneligibilityReason": {
          "description": "Review ineligibility reason if account is not eligible for review.",
          "enumDescriptions": [
            "Requesting a review from Google is not possible.",
            "All onboarding issues needs to be fixed.",
            "Not enough offers uploaded for this country.",
            "Cooldown period applies. Wait until cooldown period ends.",
            "Account is already under review.",
            "No issues available to review.",
            "Account will be automatically reviewed at the end of the grace period.",
            "Account is retired. Should not appear in MC.",
            "Account has already been reviewed. You can't request further reviews."
          ],
          "enum": [
            "REVIEW_INELIGIBILITY_REASON_UNSPECIFIED",
            "ONBOARDING_ISSUES",
            "NOT_ENOUGH_OFFERS",
            "IN_COOLDOWN_PERIOD",
            "ALREADY_UNDER_REVIEW",
            "NO_REVIEW_REQUIRED",
            "WILL_BE_REVIEWED_AUTOMATICALLY",
            "IS_RETIRED",
            "ALREADY_REVIEWED"
          ],
          "type": "string"
        },
        "reviewIneligibilityReasonDescription": {
          "type": "string",
          "description": "Reason a program in a specific region isn’t eligible for review. Only visible if `reviewEligibilityStatus` is `INELIGIBLE`."
        },
        "eligibilityStatus": {
          "type": "string",
          "description": "Eligibility status of the Shopping Ads program.",
          "enumDescriptions": [
            "State is not known.",
            "If the account has no issues and review is completed successfully.",
            "There are one or more issues that needs to be resolved for account to be active for the program. Detailed list of account issues are available in [accountstatuses](https://developers.google.com/shopping-content/reference/rest/v2.1/accountstatuses) API.",
            "If account has issues but offers are servable. Some of the issue can make account DISAPPROVED after a certain deadline.",
            "Account is under review.",
            "Account is waiting for review to start.",
            "Program is currently onboarding. Upload valid offers to complete onboarding."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "APPROVED",
            "DISAPPROVED",
            "WARNING",
            "UNDER_REVIEW",
            "PENDING_REVIEW",
            "ONBOARDING"
          ]
        },
        "reviewIneligibilityReasonDetails": {
          "description": "Additional information for ineligibility. If `reviewIneligibilityReason` is `IN_COOLDOWN_PERIOD`, a timestamp for the end of the cooldown period is provided.",
          "$ref": "ShoppingAdsProgramStatusReviewIneligibilityReasonDetails"
        }
      },
      "id": "ShoppingAdsProgramStatusRegionStatus",
      "description": "Status of program and region."
    },
    "Error": {
      "properties": {
        "domain": {
          "description": "The domain of the error.",
          "type": "string"
        },
        "reason": {
          "description": "The error code.",
          "type": "string"
        },
        "message": {
          "description": "A description of the error.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "An error returned by the API.",
      "id": "Error"
    },
    "Collection": {
      "description": "The collection message.",
      "id": "Collection",
      "properties": {
        "language": {
          "description": "The language of a collection and the language of any featured products linked to the collection. [language attribute](https://support.google.com/merchants/answer/9673781)",
          "type": "string"
        },
        "customLabel1": {
          "description": "Label that you assign to a collection to help organize bidding and reporting in Shopping campaigns.",
          "type": "string"
        },
        "customLabel4": {
          "description": "Label that you assign to a collection to help organize bidding and reporting in Shopping campaigns.",
          "type": "string"
        },
        "link": {
          "type": "string",
          "description": "A collection’s landing page. URL directly linking to your collection's page on your website. [link attribute](https://support.google.com/merchants/answer/9673983)"
        },
        "mobileLink": {
          "description": "A collection’s mobile-optimized landing page when you have a different URL for mobile and desktop traffic. [mobile_link attribute](https://support.google.com/merchants/answer/9646123)",
          "type": "string"
        },
        "customLabel2": {
          "type": "string",
          "description": "Label that you assign to a collection to help organize bidding and reporting in Shopping campaigns."
        },
        "customLabel3": {
          "description": "Label that you assign to a collection to help organize bidding and reporting in Shopping campaigns.",
          "type": "string"
        },
        "id": {
          "description": "Required. The REST ID of the collection. Content API methods that operate on collections take this as their collectionId parameter. The REST ID for a collection is of the form collectionId. [id attribute](https://support.google.com/merchants/answer/9649290)",
          "type": "string"
        },
        "imageLink": {
          "type": "array",
          "description": "The URL of a collection’s image. [image_link attribute](https://support.google.com/merchants/answer/9703236)",
          "items": {
            "type": "string"
          }
        },
        "headline": {
          "type": "array",
          "description": "Your collection's name. [headline attribute](https://support.google.com/merchants/answer/9673580)",
          "items": {
            "type": "string"
          }
        },
        "customLabel0": {
          "description": "Label that you assign to a collection to help organize bidding and reporting in Shopping campaigns. [Custom label](https://support.google.com/merchants/answer/9674217)",
          "type": "string"
        },
        "productCountry": {
          "type": "string",
          "description": "[product_country attribute](https://support.google.com/merchants/answer/9674155)"
        },
        "featuredProduct": {
          "type": "array",
          "description": "This identifies one or more products associated with the collection. Used as a lookup to the corresponding product ID in your product feeds. Provide a maximum of 100 featuredProduct (for collections). Provide up to 10 featuredProduct (for Shoppable Images only) with ID and X and Y coordinates. [featured_product attribute](https://support.google.com/merchants/answer/9703736)",
          "items": {
            "$ref": "CollectionFeaturedProduct"
          }
        }
      },
      "type": "object"
    },
    "AccountIdentifier": {
      "type": "object",
      "properties": {
        "aggregatorId": {
          "format": "uint64",
          "type": "string",
          "description": "The aggregator ID, set for aggregators and subaccounts (in that case, it represents the aggregator of the subaccount)."
        },
        "merchantId": {
          "description": "The merchant account ID, set for individual accounts and subaccounts.",
          "type": "string",
          "format": "uint64"
        }
      },
      "id": "AccountIdentifier"
    },
    "LiasettingsCustomBatchResponseEntry": {
      "id": "LiasettingsCustomBatchResponseEntry",
      "type": "object",
      "properties": {
        "errors": {
          "description": "A list of errors defined if, and only if, the request failed.",
          "$ref": "Errors"
        },
        "gmbAccounts": {
          "description": "The list of accessible Business Profiles.",
          "$ref": "GmbAccounts"
        },
        "omnichannelExperience": {
          "description": "The updated omnichannel experience for a country.",
          "$ref": "LiaOmnichannelExperience"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsCustomBatchResponseEntry`\""
        },
        "posDataProviders": {
          "type": "array",
          "description": "The list of POS data providers.",
          "items": {
            "$ref": "PosDataProviders"
          }
        },
        "batchId": {
          "description": "The ID of the request entry to which this entry responds.",
          "type": "integer",
          "format": "uint32"
        },
        "liaSettings": {
          "description": "The retrieved or updated Lia settings.",
          "$ref": "LiaSettings"
        }
      }
    },
    "ProductDeliveryTimeAreaDeliveryTimeDeliveryTime": {
      "description": "A delivery time for this product.",
      "id": "ProductDeliveryTimeAreaDeliveryTimeDeliveryTime",
      "properties": {
        "minHandlingTimeDays": {
          "description": "Required. The minimum number of business days (inclusive) between when an order is placed and when the product ships. If a product ships in the same day, set this value to 0.",
          "type": "integer",
          "format": "int32"
        },
        "minTransitTimeDays": {
          "format": "int32",
          "type": "integer",
          "description": "Required. The minimum number of business days (inclusive) between when the product ships and when the product is delivered."
        },
        "maxHandlingTimeDays": {
          "description": "Required. The maximum number of business days (inclusive) between when an order is placed and when the product ships. If a product ships in the same day, set this value to 0.",
          "format": "int32",
          "type": "integer"
        },
        "maxTransitTimeDays": {
          "type": "integer",
          "format": "int32",
          "description": "Required. The maximum number of business days (inclusive) between when the product ships and when the product is delivered."
        }
      },
      "type": "object"
    },
    "LiaCountrySettings": {
      "properties": {
        "storePickupActive": {
          "type": "boolean",
          "description": "The status of the \"Store pickup\" feature."
        },
        "country": {
          "type": "string",
          "description": "Required. CLDR country code (for example, \"US\")."
        },
        "inventory": {
          "description": "LIA inventory verification settings.",
          "$ref": "LiaInventorySettings"
        },
        "about": {
          "description": "The settings for the About page.",
          "$ref": "LiaAboutPageSettings"
        },
        "posDataProvider": {
          "description": "The POS data provider linked with this country.",
          "$ref": "LiaPosDataProvider"
        },
        "hostedLocalStorefrontActive": {
          "type": "boolean",
          "description": "The status of the \"Merchant hosted local storefront\" feature."
        },
        "onDisplayToOrder": {
          "description": "LIA \"On Display To Order\" settings.",
          "$ref": "LiaOnDisplayToOrderSettings"
        },
        "omnichannelExperience": {
          "description": "The omnichannel experience configured for this country.",
          "$ref": "LiaOmnichannelExperience"
        }
      },
      "type": "object",
      "id": "LiaCountrySettings"
    },
    "PriceInsights": {
      "type": "object",
      "properties": {
        "predictedGrossProfitChangeFraction": {
          "type": "number",
          "format": "double",
          "description": "*Deprecated*: This field is no longer supported and will start returning 0. The predicted change in gross profit as a fraction after introducing the suggested price compared to current active price. For example, 0.05 is a 5% predicted increase in gross profit."
        },
        "predictedMonthlyGrossProfitChangeMicros": {
          "description": "*Deprecated*: This field is no longer supported and will start returning 0. The predicted change in gross profit in micros (1 millionth of a standard unit, 1 USD = 1000000 micros) after introducing the suggested price for a month compared to current active price.",
          "type": "string",
          "format": "int64"
        },
        "predictedMonthlyGrossProfitChangeCurrencyCode": {
          "description": "*Deprecated*: This field is no longer supported and will start returning USD for all requests. The predicted monthly gross profit change currency (ISO 4217 code).",
          "type": "string"
        },
        "suggestedPriceCurrencyCode": {
          "type": "string",
          "description": "The suggested price currency (ISO 4217 code)."
        },
        "predictedConversionsChangeFraction": {
          "format": "double",
          "type": "number",
          "description": "The predicted change in conversions as a fraction after introducing the suggested price compared to current active price. For example, 0.05 is a 5% predicted increase in conversions)."
        },
        "effectiveness": {
          "description": "The predicted effectiveness of applying the price suggestion, bucketed.",
          "enumDescriptions": [
            "Effectiveness is unknown.",
            "Effectiveness is low.",
            "Effectiveness is medium.",
            "Effectiveness is high."
          ],
          "enum": [
            "EFFECTIVENESS_UNSPECIFIED",
            "LOW",
            "MEDIUM",
            "HIGH"
          ],
          "type": "string"
        },
        "predictedImpressionsChangeFraction": {
          "type": "number",
          "format": "double",
          "description": "The predicted change in impressions as a fraction after introducing the suggested price compared to current active price. For example, 0.05 is a 5% predicted increase in impressions."
        },
        "suggestedPriceMicros": {
          "type": "string",
          "format": "int64",
          "description": "The latest suggested price in micros (1 millionth of a standard unit, 1 USD = 1000000 micros) for the product."
        },
        "predictedClicksChangeFraction": {
          "format": "double",
          "type": "number",
          "description": "The predicted change in clicks as a fraction after introducing the suggested price compared to current active price. For example, 0.05 is a 5% predicted increase in clicks."
        }
      },
      "id": "PriceInsights",
      "description": "Price insights fields requested by the merchant in the query. Field values are only set if the merchant queries `PriceInsightsProductView`. https://support.google.com/merchants/answer/11916926"
    },
    "DatafeedStatusExample": {
      "id": "DatafeedStatusExample",
      "description": "An example occurrence for a particular error.",
      "type": "object",
      "properties": {
        "itemId": {
          "description": "The ID of the example item.",
          "type": "string"
        },
        "value": {
          "description": "The problematic value.",
          "type": "string"
        },
        "lineNumber": {
          "type": "string",
          "format": "uint64",
          "description": "Line number in the data feed where the example is found."
        }
      }
    },
    "DatafeedFetchSchedule": {
      "type": "object",
      "properties": {
        "fetchUrl": {
          "type": "string",
          "description": "The URL where the feed file can be fetched. Google Merchant Center will support automatic scheduled uploads using the HTTP, HTTPS, FTP, or SFTP protocols, so the value will need to be a valid link using one of those four protocols."
        },
        "paused": {
          "description": "Whether the scheduled fetch is paused or not.",
          "type": "boolean"
        },
        "username": {
          "description": "An optional user name for fetch_url.",
          "type": "string"
        },
        "password": {
          "description": "An optional password for fetch_url.",
          "type": "string"
        },
        "weekday": {
          "description": "The day of the week the feed file should be fetched. Acceptable values are: - \"`monday`\" - \"`tuesday`\" - \"`wednesday`\" - \"`thursday`\" - \"`friday`\" - \"`saturday`\" - \"`sunday`\" ",
          "type": "string"
        },
        "dayOfMonth": {
          "format": "uint32",
          "type": "integer",
          "description": "The day of the month the feed file should be fetched (1-31)."
        },
        "timeZone": {
          "description": "Time zone used for schedule. UTC by default. For example, \"America/Los_Angeles\".",
          "type": "string"
        },
        "minuteOfHour": {
          "description": "The minute of the hour the feed file should be fetched (0-59). Read-only.",
          "format": "uint32",
          "type": "integer"
        },
        "hour": {
          "description": "The hour of the day the feed file should be fetched (0-23).",
          "type": "integer",
          "format": "uint32"
        }
      },
      "id": "DatafeedFetchSchedule",
      "description": "The required fields vary based on the frequency of fetching. For a monthly fetch schedule, day_of_month and hour are required. For a weekly fetch schedule, weekday and hour are required. For a daily fetch schedule, only hour is required."
    },
    "ProductstatusesListResponse": {
      "id": "ProductstatusesListResponse",
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of products statuses.",
          "type": "string"
        },
        "resources": {
          "type": "array",
          "items": {
            "$ref": "ProductStatus"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productstatusesListResponse`\"."
        }
      }
    },
    "ListCssesResponse": {
      "properties": {
        "csses": {
          "description": "The CSS domains affiliated with the specified CSS group.",
          "items": {
            "$ref": "Css"
          },
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "The response message for the `ListCsses` method",
      "id": "ListCssesResponse"
    },
    "MinimumOrderValueTableStoreCodeSetWithMov": {
      "type": "object",
      "properties": {
        "storeCodes": {
          "description": "A list of unique store codes or empty for the catch all.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "value": {
          "description": "The minimum order value for the given stores.",
          "$ref": "Price"
        }
      },
      "id": "MinimumOrderValueTableStoreCodeSetWithMov",
      "description": "A list of store code sets sharing the same minimum order value. At least two sets are required and the last one must be empty, which signifies 'MOV for all other stores'. Each store code can only appear once across all the sets. All prices within a service must have the same currency."
    },
    "LiaOnDisplayToOrderSettings": {
      "properties": {
        "status": {
          "type": "string",
          "description": "The status of the ?On display to order? feature. Acceptable values are: - \"`active`\" - \"`inactive`\" - \"`pending`\" "
        },
        "shippingCostPolicyUrl": {
          "type": "string",
          "description": "Shipping cost and policy URL."
        }
      },
      "type": "object",
      "id": "LiaOnDisplayToOrderSettings"
    },
    "RegionalinventoryCustomBatchRequestEntry": {
      "properties": {
        "method": {
          "type": "string",
          "description": "Method of the batch request entry. Acceptable values are: - \"`insert`\" "
        },
        "productId": {
          "description": "The ID of the product for which to update price and availability.",
          "type": "string"
        },
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "format": "uint32",
          "type": "integer"
        },
        "merchantId": {
          "description": "The ID of the managing account.",
          "type": "string",
          "format": "uint64"
        },
        "regionalInventory": {
          "description": "Price and availability of the product.",
          "$ref": "RegionalInventory"
        }
      },
      "type": "object",
      "description": "A batch entry encoding a single non-batch regional inventory request.",
      "id": "RegionalinventoryCustomBatchRequestEntry"
    },
    "BreakdownRegion": {
      "description": "Region with code and localized name.",
      "id": "BreakdownRegion",
      "properties": {
        "name": {
          "description": "The localized name of the region. For region with code='001' the value is 'All countries' or the equivalent in other languages.",
          "type": "string"
        },
        "code": {
          "description": "The [CLDR territory code] (http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml)",
          "type": "string"
        }
      },
      "type": "object"
    },
    "AccountsUpdateLabelsRequest": {
      "id": "AccountsUpdateLabelsRequest",
      "properties": {
        "labelIds": {
          "type": "array",
          "description": "The IDs of labels that should be assigned to the account.",
          "items": {
            "format": "uint64",
            "type": "string"
          }
        }
      },
      "type": "object"
    },
    "ProductIssueImpact": {
      "properties": {
        "message": {
          "description": "Optional. Message summarizing the overall impact of the issue. If present, it should be rendered to the merchant. For example: \"Limits visibility in France\"",
          "type": "string"
        },
        "breakdowns": {
          "description": "Detailed impact breakdown. Explains the types of restriction the issue has in different shopping destinations and territory. If present, it should be rendered to the merchant. Can be shown as a mouse over dropdown or a dialog. Each breakdown item represents a group of regions with the same impact details.",
          "items": {
            "$ref": "Breakdown"
          },
          "type": "array"
        },
        "severity": {
          "type": "string",
          "description": "The severity of the issue.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Causes either an account suspension or an item disapproval. Errors should be resolved as soon as possible to ensure items are eligible to appear in results again.",
            "Warnings can negatively impact the performance of ads and can lead to item or account suspensions in the future unless the issue is resolved.",
            "Infos are suggested optimizations to increase data quality. Resolving these issues is recommended, but not required."
          ],
          "enum": [
            "SEVERITY_UNSPECIFIED",
            "ERROR",
            "WARNING",
            "INFO"
          ]
        }
      },
      "type": "object",
      "description": "Overall impact of product issue.",
      "id": "ProductIssueImpact"
    },
    "PickupServicesPickupService": {
      "type": "object",
      "properties": {
        "carrierName": {
          "type": "string",
          "description": "The name of the carrier (for example, `\"UPS\"`). Always present."
        },
        "serviceName": {
          "type": "string",
          "description": "The name of the pickup service (for example, `\"Access point\"`). Always present."
        },
        "country": {
          "description": "The CLDR country code of the carrier (for example, \"US\"). Always present.",
          "type": "string"
        }
      },
      "id": "PickupServicesPickupService"
    },
    "ProductStatusDestinationStatus": {
      "id": "ProductStatusDestinationStatus",
      "type": "object",
      "properties": {
        "pendingCountries": {
          "description": "List of country codes (ISO 3166-1 alpha-2) where the offer is pending approval.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "channel": {
          "type": "string",
          "description": "The channel of the destination."
        },
        "status": {
          "type": "string",
          "description": "Deprecated. Destination approval status in `targetCountry` of the offer.",
          "deprecated": true
        },
        "destination": {
          "type": "string",
          "description": "The name of the destination"
        },
        "approvedCountries": {
          "description": "List of country codes (ISO 3166-1 alpha-2) where the offer is approved.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "disapprovedCountries": {
          "type": "array",
          "description": "List of country codes (ISO 3166-1 alpha-2) where the offer is disapproved.",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ActionReason": {
      "description": "A single reason why the action is not available.",
      "id": "ActionReason",
      "properties": {
        "detail": {
          "description": "Detailed explanation of the reason. Should be displayed as a hint if present.",
          "type": "string"
        },
        "message": {
          "type": "string",
          "description": "Messages summarizing the reason, why the action is not available. For example: \"Review requested on Jan 03. Review requests can take a few days to complete.\""
        },
        "action": {
          "description": "Optional. An action that needs to be performed to solve the problem represented by this reason. This action will always be available. Should be rendered as a link or button next to the summarizing message. For example, the review may be available only once merchant configure all required attributes. In such a situation this action can be a link to the form, where they can fill the missing attribute to unblock the main action.",
          "$ref": "Action"
        }
      },
      "type": "object"
    },
    "ProductstatusesCustomBatchRequestEntry": {
      "description": "A batch entry encoding a single non-batch productstatuses request.",
      "id": "ProductstatusesCustomBatchRequestEntry",
      "properties": {
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" ",
          "type": "string"
        },
        "productId": {
          "type": "string",
          "description": "The ID of the product whose status to get."
        },
        "includeAttributes": {
          "type": "boolean",
          "description": "Deprecated: Setting this field has no effect and attributes are never included.",
          "deprecated": true
        },
        "destinations": {
          "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "An entry ID, unique within the batch request."
        },
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        }
      },
      "type": "object"
    },
    "AccountAdsLink": {
      "id": "AccountAdsLink",
      "type": "object",
      "properties": {
        "adsId": {
          "description": "Customer ID of the Ads account.",
          "type": "string",
          "format": "uint64"
        },
        "status": {
          "description": "Status of the link between this Merchant Center account and the Ads account. Upon retrieval, it represents the actual status of the link and can be either `active` if it was approved in Google Ads or `pending` if it's pending approval. Upon insertion, it represents the *intended* status of the link. Re-uploading a link with status `active` when it's still pending or with status `pending` when it's already active will have no effect: the status will remain unchanged. Re-uploading a link with deprecated status `inactive` is equivalent to not submitting the link at all and will delete the link if it was active or cancel the link request if it was pending. Acceptable values are: - \"`active`\" - \"`pending`\" ",
          "type": "string"
        }
      }
    },
    "Distance": {
      "type": "object",
      "properties": {
        "unit": {
          "description": "The distance unit. Acceptable values are `None`, `Miles`, and `Kilometers`.",
          "type": "string"
        },
        "value": {
          "description": "The distance represented as a number.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "Distance",
      "description": "Distance represented by an integer and unit."
    },
    "DatafeedFormat": {
      "type": "object",
      "properties": {
        "columnDelimiter": {
          "type": "string",
          "description": "Delimiter for the separation of values in a delimiter-separated values feed. If not specified, the delimiter will be auto-detected. Ignored for non-DSV data feeds. Acceptable values are: - \"`pipe`\" - \"`tab`\" - \"`tilde`\" "
        },
        "fileEncoding": {
          "type": "string",
          "description": "Character encoding scheme of the data feed. If not specified, the encoding will be auto-detected. Acceptable values are: - \"`latin-1`\" - \"`utf-16be`\" - \"`utf-16le`\" - \"`utf-8`\" - \"`windows-1252`\" "
        },
        "quotingMode": {
          "description": "Specifies how double quotes are interpreted. If not specified, the mode will be auto-detected. Ignored for non-DSV data feeds. Acceptable values are: - \"`normal character`\" - \"`value quoting`\" ",
          "type": "string"
        }
      },
      "id": "DatafeedFormat"
    },
    "ReturnPolicyOnlineReturnReasonCategoryInfo": {
      "id": "ReturnPolicyOnlineReturnReasonCategoryInfo",
      "description": "The return reason category info wrapper.",
      "type": "object",
      "properties": {
        "returnShippingFee": {
          "description": "The corresponding return shipping fee. This is only applicable when returnLabelSource is not the customer's responsibility.",
          "$ref": "ReturnPolicyOnlineReturnShippingFee"
        },
        "returnReasonCategory": {
          "description": "The return reason category.",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Buyer remorse.",
            "Item defect."
          ],
          "enum": [
            "RETURN_REASON_CATEGORY_UNSPECIFIED",
            "BUYER_REMORSE",
            "ITEM_DEFECT"
          ],
          "type": "string"
        },
        "returnLabelSource": {
          "description": "The corresponding return label source. If the `ReturnMethod` field includes `BY_MAIL`, it is required to specify `ReturnLabelSource` for both `BUYER_REMORSE` and `ITEM_DEFECT` return reason categories.",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "Download and print the label.",
            "Label in the box.",
            "Customers' responsibility to get the label."
          ],
          "enum": [
            "RETURN_LABEL_SOURCE_UNSPECIFIED",
            "DOWNLOAD_AND_PRINT",
            "IN_THE_BOX",
            "CUSTOMER_RESPONSIBILITY"
          ],
          "type": "string"
        }
      }
    },
    "UndeleteConversionSourceRequest": {
      "description": "Request message for the UndeleteConversionSource method.",
      "id": "UndeleteConversionSourceRequest",
      "properties": {},
      "type": "object"
    },
    "Errors": {
      "id": "Errors",
      "description": "A list of errors returned by a failed batch entry.",
      "type": "object",
      "properties": {
        "errors": {
          "type": "array",
          "description": "A list of errors.",
          "items": {
            "$ref": "Error"
          }
        },
        "code": {
          "description": "The HTTP status of the first error in `errors`.",
          "format": "uint32",
          "type": "integer"
        },
        "message": {
          "description": "The message of the first error in `errors`.",
          "type": "string"
        }
      }
    },
    "TriggerActionResponse": {
      "id": "TriggerActionResponse",
      "description": "Response informing about the started action.",
      "type": "object",
      "properties": {
        "message": {
          "description": "The message for merchant.",
          "type": "string"
        }
      }
    },
    "AccountsAuthInfoResponse": {
      "id": "AccountsAuthInfoResponse",
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsAuthInfoResponse`\"."
        },
        "accountIdentifiers": {
          "description": "The account identifiers corresponding to the authenticated user. - For an individual account: only the merchant ID is defined - For an aggregator: only the aggregator ID is defined - For a subaccount of an MCA: both the merchant ID and the aggregator ID are defined. ",
          "items": {
            "$ref": "AccountIdentifier"
          },
          "type": "array"
        }
      }
    },
    "AccountsCustomBatchRequest": {
      "id": "AccountsCustomBatchRequest",
      "type": "object",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "AccountsCustomBatchRequestEntry"
          }
        }
      }
    },
    "PromotionPromotionStatusDestinationStatus": {
      "type": "object",
      "properties": {
        "destination": {
          "description": "The name of the destination.",
          "type": "string"
        },
        "status": {
          "description": "The status for the specified destination.",
          "enumDescriptions": [
            "Unknown promotion state.",
            "The promotion is under review.",
            "The promotion is disapproved",
            "The promotion is approved and active.",
            "The promotion is stopped by merchant.",
            "The promotion is no longer active.",
            "The promotion is not stopped, and all reviews are approved, but the active date is in the future."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "IN_REVIEW",
            "REJECTED",
            "LIVE",
            "STOPPED",
            "EXPIRED",
            "PENDING"
          ],
          "type": "string"
        }
      },
      "id": "PromotionPromotionStatusDestinationStatus",
      "description": "The destination status of the promotion."
    },
    "Recommendation": {
      "description": "Recommendations are suggested ways to improve your merchant account's performance. For example, to engage with a feature, or start using a new Google product.",
      "id": "Recommendation",
      "properties": {
        "creative": {
          "description": "Output only. Any creatives attached to the recommendation. Repeated.",
          "items": {
            "$ref": "RecommendationCreative"
          },
          "readOnly": true,
          "type": "array"
        },
        "additionalCallToAction": {
          "type": "array",
          "description": "Output only. CTAs of this recommendation. Repeated.",
          "items": {
            "$ref": "RecommendationCallToAction"
          },
          "readOnly": true
        },
        "type": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Type of the recommendation. List of currently available recommendation types: - OPPORTUNITY_CREATE_NEW_COLLECTION - OPPORTUNITY_CREATE_EMAIL_CAMPAIGN"
        },
        "title": {
          "type": "string",
          "description": "Optional. Localized Recommendation Title. Localization uses the {@link `GenerateRecommendationsRequest.language_code`} field in {@link `GenerateRecommendationsRequest`} requests."
        },
        "paid": {
          "description": "Optional. Indicates whether a user needs to pay when they complete the user journey suggested by the recommendation.",
          "type": "boolean"
        },
        "defaultDescription": {
          "description": "Optional. Localized recommendation description. The localization the {@link `GenerateRecommendationsRequest.language_code`} field in {@link `GenerateRecommendationsRequest`} requests.",
          "type": "string"
        },
        "additionalDescriptions": {
          "description": "Output only. List of additional localized descriptions for a recommendation. Localication uses the `languageCode` field in `GenerateRecommendations` requests. Not all description types are guaranteed to be present and we recommend to rely on default description.",
          "items": {
            "$ref": "RecommendationDescription"
          },
          "readOnly": true,
          "type": "array"
        },
        "numericalImpact": {
          "type": "integer",
          "format": "int32",
          "description": "Optional. A numerical score of the impact from the recommendation's description. For example, a recommendation might suggest an upward trend in sales for a certain product. Higher number means larger impact."
        },
        "recommendationName": {
          "description": "Optional. Localized recommendation name. The localization uses the {@link `GenerateRecommendationsRequest.language_code`} field in {@link `GenerateRecommendationsRequest`} requests.",
          "type": "string"
        },
        "defaultCallToAction": {
          "description": "Optional. Default CTA of the recommendation.",
          "$ref": "RecommendationCallToAction"
        },
        "subType": {
          "type": "string",
          "description": "Optional. Subtype of the recommendations. Only applicable when multiple recommendations can be generated per type, and is used as an identifier of recommendation under the same recommendation type."
        }
      },
      "type": "object"
    },
    "AccountUser": {
      "id": "AccountUser",
      "type": "object",
      "properties": {
        "readOnly": {
          "type": "boolean",
          "description": "Optional. Whether user has standard read-only access."
        },
        "paymentsAnalyst": {
          "deprecated": true,
          "description": "This role is deprecated and can no longer be assigned. Any value set will be ignored.",
          "type": "boolean"
        },
        "emailAddress": {
          "type": "string",
          "description": "User's email address."
        },
        "reportingManager": {
          "description": "Whether user is a reporting manager. This role is equivalent to the Performance and insights role in Merchant Center.",
          "type": "boolean"
        },
        "orderManager": {
          "deprecated": true,
          "description": "This role is deprecated and can no longer be assigned. Any value set will be ignored.",
          "type": "boolean"
        },
        "paymentsManager": {
          "type": "boolean",
          "description": "This role is deprecated and can no longer be assigned. Any value set will be ignored.",
          "deprecated": true
        },
        "admin": {
          "description": "Whether user is an admin.",
          "type": "boolean"
        }
      }
    },
    "AccountsLinkRequest": {
      "id": "AccountsLinkRequest",
      "properties": {
        "services": {
          "type": "array",
          "description": " Acceptable values are: - \"`shoppingAdsProductManagement`\" - \"`shoppingActionsProductManagement`\" - \"`shoppingActionsOrderManagement`\" - \"`paymentProcessing`\" ",
          "items": {
            "type": "string"
          }
        },
        "action": {
          "description": "Action to perform for this link. The `\"request\"` action is only available to select merchants. Acceptable values are: - \"`approve`\" - \"`remove`\" - \"`request`\" ",
          "type": "string"
        },
        "linkedAccountId": {
          "description": "The ID of the linked account.",
          "type": "string"
        },
        "paymentServiceProviderLinkInfo": {
          "description": "Additional information required for `paymentServiceProvider` link type.",
          "$ref": "PaymentServiceProviderLinkInfo"
        },
        "linkType": {
          "type": "string",
          "description": "Type of the link between the two accounts. Acceptable values are: - \"`channelPartner`\" - \"`eCommercePlatform`\" - \"`paymentServiceProvider`\" "
        },
        "eCommercePlatformLinkInfo": {
          "description": "Additional information required for `eCommercePlatform` link type.",
          "$ref": "ECommercePlatformLinkInfo"
        }
      },
      "type": "object"
    },
    "ECommercePlatformLinkInfo": {
      "description": "Additional information required for E_COMMERCE_PLATFORM link type.",
      "id": "ECommercePlatformLinkInfo",
      "properties": {
        "externalAccountId": {
          "type": "string",
          "description": "The id used by the third party service provider to identify the merchant."
        }
      },
      "type": "object"
    },
    "AccountsCustomBatchResponse": {
      "id": "AccountsCustomBatchResponse",
      "type": "object",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "AccountsCustomBatchResponseEntry"
          },
          "type": "array"
        }
      }
    },
    "AccountsCustomBatchResponseEntry": {
      "id": "AccountsCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch accounts response.",
      "type": "object",
      "properties": {
        "account": {
          "description": "The retrieved, created, or updated account. Not defined if the method was `delete`, `claimwebsite` or `link`.",
          "$ref": "Account"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsCustomBatchResponseEntry`\""
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        }
      }
    },
    "AccountstatusesListResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountstatusesListResponse`\"."
        },
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of account statuses.",
          "type": "string"
        },
        "resources": {
          "items": {
            "$ref": "AccountStatus"
          },
          "type": "array"
        }
      },
      "id": "AccountstatusesListResponse"
    },
    "AccountsClaimWebsiteResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsClaimWebsiteResponse`\"."
        }
      },
      "id": "AccountsClaimWebsiteResponse"
    },
    "ProductstatusesCustomBatchResponse": {
      "id": "ProductstatusesCustomBatchResponse",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "ProductstatusesCustomBatchResponseEntry"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productstatusesCustomBatchResponse`\"."
        }
      },
      "type": "object"
    },
    "LinkedAccount": {
      "type": "object",
      "properties": {
        "linkedAccountId": {
          "type": "string",
          "description": "The ID of the linked account."
        },
        "services": {
          "type": "array",
          "description": "List of provided services.",
          "items": {
            "$ref": "LinkService"
          }
        }
      },
      "id": "LinkedAccount"
    },
    "ExternalAction": {
      "type": "object",
      "properties": {
        "type": {
          "description": "The type of external action.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Redirect to Merchant Center where the merchant can request a review for issue related to their product.",
            "Redirect to Merchant Center where the merchant can request a review for issue related to their account.",
            "Redirect to the form in Help Center where the merchant can request a legal appeal for the issue.",
            "Redirect to Merchant Center where the merchant can perform identity verification."
          ],
          "enum": [
            "EXTERNAL_ACTION_TYPE_UNSPECIFIED",
            "REVIEW_PRODUCT_ISSUE_IN_MERCHANT_CENTER",
            "REVIEW_ACCOUNT_ISSUE_IN_MERCHANT_CENTER",
            "LEGAL_APPEAL_IN_HELP_CENTER",
            "VERIFY_IDENTITY_IN_MERCHANT_CENTER"
          ],
          "type": "string"
        },
        "uri": {
          "type": "string",
          "description": "URL to external system, for example Merchant Center, where the merchant can perform the action."
        }
      },
      "id": "ExternalAction",
      "description": "Action that is implemented and performed outside of the third-party application. It should redirect the merchant to the provided URL of an external system where they can perform the action. For example to request a review in the Merchant Center."
    },
    "DatafeedsFetchNowResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedsFetchNowResponse`\".",
          "type": "string"
        }
      },
      "id": "DatafeedsFetchNowResponse"
    },
    "Headers": {
      "type": "object",
      "properties": {
        "prices": {
          "type": "array",
          "description": "A list of inclusive order price upper bounds. The last price's value can be `\"infinity\"`. For example `[{\"value\": \"10\", \"currency\": \"USD\"}, {\"value\": \"500\", \"currency\": \"USD\"}, {\"value\": \"infinity\", \"currency\": \"USD\"}]` represents the headers \"\u003c= $10\", \"\u003c= $500\", and \"\u003e $500\". All prices within a service must have the same currency. Must be non-empty. Can only be set if all other fields are not set.",
          "items": {
            "$ref": "Price"
          }
        },
        "locations": {
          "description": "A list of location ID sets. Must be non-empty. Can only be set if all other fields are not set.",
          "items": {
            "$ref": "LocationIdSet"
          },
          "type": "array"
        },
        "weights": {
          "type": "array",
          "description": "A list of inclusive order weight upper bounds. The last weight's value can be `\"infinity\"`. For example `[{\"value\": \"10\", \"unit\": \"kg\"}, {\"value\": \"50\", \"unit\": \"kg\"}, {\"value\": \"infinity\", \"unit\": \"kg\"}]` represents the headers \"\u003c= 10kg\", \"\u003c= 50kg\", and \"\u003e 50kg\". All weights within a service must have the same unit. Must be non-empty. Can only be set if all other fields are not set.",
          "items": {
            "$ref": "Weight"
          }
        },
        "numberOfItems": {
          "type": "array",
          "description": "A list of inclusive number of items upper bounds. The last value can be `\"infinity\"`. For example `[\"10\", \"50\", \"infinity\"]` represents the headers \"\u003c= 10 items\", \"\u003c= 50 items\", and \"\u003e 50 items\". Must be non-empty. Can only be set if all other fields are not set.",
          "items": {
            "type": "string"
          }
        },
        "postalCodeGroupNames": {
          "type": "array",
          "description": "A list of postal group names. The last value can be `\"all other locations\"`. Example: `[\"zone 1\", \"zone 2\", \"all other locations\"]`. The referred postal code groups must match the delivery country of the service. Must be non-empty. Can only be set if all other fields are not set.",
          "items": {
            "type": "string"
          }
        }
      },
      "id": "Headers",
      "description": "A non-empty list of row or column headers for a table. Exactly one of `prices`, `weights`, `numItems`, `postalCodeGroupNames`, or `location` must be set."
    },
    "PosInventory": {
      "id": "PosInventory",
      "description": "The absolute quantity of an item available at the given store.",
      "type": "object",
      "properties": {
        "price": {
          "description": "Required. The current price of the item.",
          "$ref": "Price"
        },
        "timestamp": {
          "type": "string",
          "description": "Required. The inventory timestamp, in ISO 8601 format."
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posInventory`\"",
          "type": "string"
        },
        "pickupSla": {
          "description": "Optional. Expected date that an order will be ready for pickup relative to the order date. Must be submitted together with `pickupMethod`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342).",
          "type": "string"
        },
        "quantity": {
          "description": "Required. The available quantity of the item.",
          "format": "int64",
          "type": "string"
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        },
        "storeCode": {
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile.",
          "type": "string"
        },
        "itemId": {
          "description": "Required. A unique identifier for the item.",
          "type": "string"
        },
        "contentLanguage": {
          "type": "string",
          "description": "Required. The two-letter ISO 639-1 language code for the item."
        },
        "pickupMethod": {
          "description": "Optional. Supported pickup method for this offer. Unless the value is \"not supported\", this field must be submitted together with `pickupSla`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342).",
          "type": "string"
        }
      }
    },
    "TopicTrends": {
      "description": "Topic trends fields requested by the merchant in the query. Field values are only set if the merchant queries `TopicTrendsView`. Forecast data can be queried up to 13 weeks by passing a future date in the `date` field. Historical data is measured daily, and forecasted data is projected weekly. All data points are normalized based on the highest data points returned in the response. If you make separate queries with different date ranges, you might see different values for the same date in each response. The recommended way to get a trend score of a topic is `last7_days_search_interest / last{$day}_days_search_interest - 1`. You can view trends for up to eight topics at a time.",
      "id": "TopicTrends",
      "properties": {
        "last30DaysSearchInterest": {
          "description": "Search interest in the last 30 days, with the same normalization as search_interest. This field is only present for a past date.",
          "format": "double",
          "type": "number"
        },
        "topic": {
          "description": "Google-provided topic trends are calculated for. Only top eight topics are returned. Topic is what shoppers are searching for on Google, grouped by the same concept.",
          "type": "string"
        },
        "last7DaysSearchInterest": {
          "type": "number",
          "format": "double",
          "description": "Search interest in the last 7 days, with the same normalization as search_interest. This field is only present for a past date."
        },
        "customerCountryCode": {
          "type": "string",
          "description": "Country trends are calculated for. Must be a two-letter country code (ISO 3166-1-alpha-2 code), for example, `“US”`."
        },
        "next7DaysSearchInterest": {
          "description": "Estimated search interest in the next 7 days, with the same normalization as search_interest. This field is only present for a future date.",
          "format": "double",
          "type": "number"
        },
        "searchInterest": {
          "format": "double",
          "type": "number",
          "description": "Daily search interest, normalized to the time and country to make comparisons easier, with 100 representing peak popularity (from 0 to 100) for the requested time period and location."
        },
        "date": {
          "description": "Date the trend score was retrieved.",
          "$ref": "Date"
        },
        "last90DaysSearchInterest": {
          "type": "number",
          "format": "double",
          "description": "Search interest in the last 90 days, with the same normalization as search_interest. This field is only present for a past date."
        },
        "last120DaysSearchInterest": {
          "format": "double",
          "type": "number",
          "description": "Search interest in the last 120 days, with the same normalization as search_interest. This field is only present for a past date."
        }
      },
      "type": "object"
    },
    "DatafeedsCustomBatchRequest": {
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "DatafeedsCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "DatafeedsCustomBatchRequest"
    },
    "PostalCodeGroup": {
      "properties": {
        "country": {
          "description": "The CLDR territory code of the country the postal code group applies to. Required.",
          "type": "string"
        },
        "postalCodeRanges": {
          "type": "array",
          "description": "A range of postal codes. Required.",
          "items": {
            "$ref": "PostalCodeRange"
          }
        },
        "name": {
          "type": "string",
          "description": "The name of the postal code group, referred to in headers. Required."
        }
      },
      "type": "object",
      "id": "PostalCodeGroup"
    },
    "AccounttaxCustomBatchResponse": {
      "id": "AccounttaxCustomBatchResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accounttaxCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "AccounttaxCustomBatchResponseEntry"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "DatafeedstatusesCustomBatchRequest": {
      "id": "DatafeedstatusesCustomBatchRequest",
      "type": "object",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "DatafeedstatusesCustomBatchRequestEntry"
          }
        }
      }
    },
    "ProductstatusesCustomBatchRequest": {
      "id": "ProductstatusesCustomBatchRequest",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "ProductstatusesCustomBatchRequestEntry"
          }
        }
      },
      "type": "object"
    },
    "TimePeriod": {
      "properties": {
        "startTime": {
          "format": "google-datetime",
          "type": "string",
          "description": "The starting timestamp."
        },
        "endTime": {
          "description": "The ending timestamp.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "type": "object",
      "description": "A message that represents a time period.",
      "id": "TimePeriod"
    },
    "Account": {
      "description": "Account data. After the creation of a new account it may take a few minutes before it's fully operational. The methods delete, insert, and update require the admin role.",
      "id": "Account",
      "properties": {
        "users": {
          "description": "Users with access to the account. Every account (except for subaccounts) must have at least one admin user.",
          "items": {
            "$ref": "AccountUser"
          },
          "type": "array"
        },
        "adsLinks": {
          "type": "array",
          "description": "Linked Ads accounts that are active or pending approval. To create a new link request, add a new link with status `active` to the list. It will remain in a `pending` state until approved or rejected either in the Ads interface or through the Google Ads API. To delete an active link, or to cancel a link request, remove it from the list.",
          "items": {
            "$ref": "AccountAdsLink"
          }
        },
        "conversionSettings": {
          "description": "Settings for conversion tracking.",
          "$ref": "AccountConversionSettings"
        },
        "id": {
          "description": "Required. 64-bit Merchant Center account ID.",
          "format": "uint64",
          "type": "string"
        },
        "cssId": {
          "type": "string",
          "format": "uint64",
          "description": "ID of CSS the account belongs to."
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#account`\".",
          "type": "string"
        },
        "automaticImprovements": {
          "description": "The automatic improvements of the account can be used to automatically update items, improve images and shipping. Each section inside AutomaticImprovements is updated separately.",
          "$ref": "AccountAutomaticImprovements"
        },
        "businessInformation": {
          "description": "The business information of the account.",
          "$ref": "AccountBusinessInformation"
        },
        "accountManagement": {
          "description": "Output only. How the account is managed. Acceptable values are: - \"`manual`\" - \"`automatic`\" ",
          "readOnly": true,
          "type": "string"
        },
        "websiteUrl": {
          "description": "The merchant's website.",
          "type": "string"
        },
        "adultContent": {
          "type": "boolean",
          "description": "Indicates whether the merchant sells adult content."
        },
        "googleMyBusinessLink": {
          "description": "The Business Profile which is linked or in the process of being linked with the Merchant Center account.",
          "$ref": "AccountGoogleMyBusinessLink"
        },
        "name": {
          "type": "string",
          "description": "Required. Display name for the account."
        },
        "labelIds": {
          "type": "array",
          "description": "Manually created label IDs that are assigned to the account by CSS.",
          "items": {
            "type": "string",
            "format": "uint64"
          }
        },
        "youtubeChannelLinks": {
          "type": "array",
          "description": "Linked YouTube channels that are active or pending approval. To create a new link request, add a new link with status `active` to the list. It will remain in a `pending` state until approved or rejected in the YT Creator Studio interface. To delete an active link, or to cancel a link request, remove it from the list.",
          "items": {
            "$ref": "AccountYouTubeChannelLink"
          }
        },
        "businessIdentity": {
          "description": "The business identity attributes can be used to self-declare attributes that let customers know more about your business.",
          "$ref": "AccountBusinessIdentity"
        },
        "automaticLabelIds": {
          "type": "array",
          "description": "Automatically created label IDs that are assigned to the account by CSS Center.",
          "items": {
            "format": "uint64",
            "type": "string"
          }
        },
        "sellerId": {
          "description": "Client-specific, locally-unique, internal ID for the child account.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "DatafeedStatus": {
      "properties": {
        "itemsValid": {
          "description": "The number of items in the feed that were valid.",
          "type": "string",
          "format": "uint64"
        },
        "processingStatus": {
          "type": "string",
          "description": "The processing status of the feed. Acceptable values are: - \"`\"`failure`\": The feed could not be processed or all items had errors.`\" - \"`in progress`\": The feed is being processed. - \"`none`\": The feed has not yet been processed. For example, a feed that has never been uploaded will have this processing status. - \"`success`\": The feed was processed successfully, though some items might have had errors. "
        },
        "lastUploadDate": {
          "description": "The last date at which the feed was uploaded.",
          "type": "string"
        },
        "language": {
          "type": "string",
          "description": "The two-letter ISO 639-1 language for which the status is reported."
        },
        "errors": {
          "description": "The list of errors occurring in the feed.",
          "items": {
            "$ref": "DatafeedStatusError"
          },
          "type": "array"
        },
        "itemsTotal": {
          "description": "The number of items in the feed that were processed.",
          "format": "uint64",
          "type": "string"
        },
        "datafeedId": {
          "description": "The ID of the feed for which the status is reported.",
          "format": "uint64",
          "type": "string"
        },
        "warnings": {
          "description": "The list of errors occurring in the feed.",
          "items": {
            "$ref": "DatafeedStatusError"
          },
          "type": "array"
        },
        "country": {
          "type": "string",
          "description": "The country for which the status is reported, represented as a CLDR territory code."
        },
        "feedLabel": {
          "type": "string",
          "description": "The feed label status is reported for."
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedStatus`\""
        }
      },
      "type": "object",
      "description": "The status of a datafeed, that is, the result of the last retrieval of the datafeed computed asynchronously when the feed processing is finished.",
      "id": "DatafeedStatus"
    },
    "ShippingsettingsCustomBatchResponse": {
      "id": "ShippingsettingsCustomBatchResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "ShippingsettingsCustomBatchResponseEntry"
          }
        }
      },
      "type": "object"
    },
    "SearchResponse": {
      "type": "object",
      "properties": {
        "results": {
          "description": "Rows that matched the search query.",
          "items": {
            "$ref": "ReportRow"
          },
          "type": "array"
        },
        "nextPageToken": {
          "description": "Token which can be sent as `page_token` to retrieve the next page. If omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "id": "SearchResponse",
      "description": "Response message for the ReportService.Search method."
    },
    "RateGroup": {
      "type": "object",
      "properties": {
        "mainTable": {
          "description": "A table defining the rate group, when `singleValue` is not expressive enough. Can only be set if `singleValue` is not set.",
          "$ref": "Table"
        },
        "subtables": {
          "description": "A list of subtables referred to by `mainTable`. Can only be set if `mainTable` is set.",
          "items": {
            "$ref": "Table"
          },
          "type": "array"
        },
        "carrierRates": {
          "description": "A list of carrier rates that can be referred to by `mainTable` or `singleValue`.",
          "items": {
            "$ref": "CarrierRate"
          },
          "type": "array"
        },
        "name": {
          "type": "string",
          "description": "Name of the rate group. Optional. If set has to be unique within shipping service."
        },
        "singleValue": {
          "description": "The value of the rate group (for example, flat rate $10). Can only be set if `mainTable` and `subtables` are not set.",
          "$ref": "Value"
        },
        "applicableShippingLabels": {
          "description": "A list of shipping labels defining the products to which this rate group applies to. This is a disjunction: only one of the labels has to match for the rate group to apply. May only be empty for the last rate group of a service. Required.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "id": "RateGroup"
    },
    "ActionInput": {
      "description": "Input provided by the merchant.",
      "id": "ActionInput",
      "properties": {
        "actionFlowId": {
          "description": "Required. Id of the selected action flow.",
          "type": "string"
        },
        "inputValues": {
          "type": "array",
          "description": "Required. Values for input fields.",
          "items": {
            "$ref": "InputValue"
          }
        }
      },
      "type": "object"
    },
    "RegionalinventoryCustomBatchResponseEntry": {
      "type": "object",
      "properties": {
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "regionalInventory": {
          "description": "Price and availability of the product.",
          "$ref": "RegionalInventory"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#regionalinventoryCustomBatchResponseEntry`\".",
          "type": "string"
        }
      },
      "id": "RegionalinventoryCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch regional inventory response."
    },
    "LocationIdSet": {
      "properties": {
        "locationIds": {
          "description": "A non-empty list of location IDs. They must all be of the same location type (for example, state).",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "LocationIdSet"
    },
    "ProductsCustomBatchRequest": {
      "properties": {
        "entries": {
          "type": "array",
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "ProductsCustomBatchRequestEntry"
          }
        }
      },
      "type": "object",
      "id": "ProductsCustomBatchRequest"
    },
    "InputFieldChoiceInput": {
      "description": "Choice input allows merchants to select one of the offered choices. Some choices may be linked to additional input fields that should be displayed under or next to the choice option. The value for the additional input field needs to be provided only when the specific choice is selected by the merchant. For example, additional input field can be hidden or disabled until the merchant selects the specific choice.",
      "id": "InputFieldChoiceInput",
      "properties": {
        "options": {
          "type": "array",
          "description": "A list of choices. Only one option can be selected.",
          "items": {
            "$ref": "InputFieldChoiceInputChoiceInputOption"
          }
        }
      },
      "type": "object"
    },
    "AlternateDisputeResolution": {
      "properties": {
        "uri": {
          "type": "string",
          "description": "The URL pointing to a page, where merchant can request alternative dispute resolution with an [external body](https://support.google.com/european-union-digital-services-act-redress-options/answer/13535501)."
        },
        "label": {
          "description": "The label for the alternate dispute resolution link.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "The Alternate Dispute Resolution (ADR) that may be available to merchants in some regions. If present, the link should be shown on the same page as the list of issues.",
      "id": "AlternateDisputeResolution"
    },
    "AccountYouTubeChannelLink": {
      "properties": {
        "channelId": {
          "description": "Channel ID.",
          "type": "string"
        },
        "status": {
          "description": "Status of the link between this Merchant Center account and the YouTube channel. Upon retrieval, it represents the actual status of the link and can be either `active` if it was approved in YT Creator Studio or `pending` if it's pending approval. Upon insertion, it represents the *intended* status of the link. Re-uploading a link with status `active` when it's still pending or with status `pending` when it's already active will have no effect: the status will remain unchanged. Re-uploading a link with deprecated status `inactive` is equivalent to not submitting the link at all and will delete the link if it was active or cancel the link request if it was pending.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "AccountYouTubeChannelLink"
    },
    "DatafeedsCustomBatchResponseEntry": {
      "id": "DatafeedsCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch datafeeds response.",
      "type": "object",
      "properties": {
        "datafeed": {
          "description": "The requested data feed. Defined if and only if the request was successful.",
          "$ref": "Datafeed"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        }
      }
    },
    "RegionPostalCodeAreaPostalCodeRange": {
      "description": "A range of postal codes that defines the region area.",
      "id": "RegionPostalCodeAreaPostalCodeRange",
      "properties": {
        "begin": {
          "description": "Required. A postal code or a pattern of the form prefix* denoting the inclusive lower bound of the range defining the area. Examples values: \"94108\", \"9410*\", \"9*\".",
          "type": "string"
        },
        "end": {
          "description": "Optional. A postal code or a pattern of the form prefix* denoting the inclusive upper bound of the range defining the area. It must have the same length as postalCodeRangeBegin: if postalCodeRangeBegin is a postal code then postalCodeRangeEnd must be a postal code too; if postalCodeRangeBegin is a pattern then postalCodeRangeEnd must be a pattern with the same prefix length. Optional: if not set, then the area is defined as being all the postal codes matching postalCodeRangeBegin.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "LocalinventoryCustomBatchRequestEntry": {
      "type": "object",
      "properties": {
        "localInventory": {
          "description": "Local inventory of the product.",
          "$ref": "LocalInventory"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "An entry ID, unique within the batch request."
        },
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        },
        "method": {
          "description": "Method of the batch request entry. Acceptable values are: - \"`insert`\" ",
          "type": "string"
        },
        "productId": {
          "description": "The ID of the product for which to update local inventory.",
          "type": "string"
        }
      },
      "id": "LocalinventoryCustomBatchRequestEntry",
      "description": "Batch entry encoding a single local inventory update request."
    },
    "Weight": {
      "id": "Weight",
      "properties": {
        "value": {
          "description": "Required. The weight represented as a number. The weight can have a maximum precision of four decimal places.",
          "type": "string"
        },
        "unit": {
          "description": "Required. The weight unit. Acceptable values are: - \"`kg`\" - \"`lb`\" ",
          "type": "string"
        }
      },
      "type": "object"
    },
    "Breakdown": {
      "id": "Breakdown",
      "description": "A detailed impact breakdown for a group of regions where the impact of the issue on different shopping destinations is the same.",
      "type": "object",
      "properties": {
        "regions": {
          "type": "array",
          "description": "Lists of regions. Should be rendered as a title for this group of details. The full list should be shown to merchant. If the list is too long, it is recommended to make it expandable.",
          "items": {
            "$ref": "BreakdownRegion"
          }
        },
        "details": {
          "description": "Human readable, localized description of issue's effect on different targets. Should be rendered as a list. For example: * \"Products not showing in ads\" * \"Products not showing organically\"",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      }
    },
    "AccountTaxTaxRule": {
      "id": "AccountTaxTaxRule",
      "description": "Tax calculation rule to apply in a state or province (US only).",
      "type": "object",
      "properties": {
        "shippingTaxed": {
          "description": "If true, shipping charges are also taxed.",
          "type": "boolean"
        },
        "useGlobalRate": {
          "type": "boolean",
          "description": "Whether the tax rate is taken from a global tax table or specified explicitly."
        },
        "country": {
          "description": "Country code in which tax is applicable.",
          "type": "string"
        },
        "locationId": {
          "description": "Required. State (or province) is which the tax is applicable, described by its location ID (also called criteria ID).",
          "type": "string",
          "format": "uint64"
        },
        "ratePercent": {
          "description": "Explicit tax rate in percent, represented as a floating point number without the percentage character. Must not be negative.",
          "type": "string"
        }
      }
    },
    "LiasettingsListResponse": {
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "The token for the retrieval of the next page of LIA settings.",
          "type": "string"
        },
        "resources": {
          "items": {
            "$ref": "LiaSettings"
          },
          "type": "array"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsListResponse`\"."
        }
      },
      "id": "LiasettingsListResponse"
    },
    "ProductstatusesCustomBatchResponseEntry": {
      "id": "ProductstatusesCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch productstatuses response.",
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productstatusesCustomBatchResponseEntry`\""
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "type": "integer",
          "format": "uint32",
          "description": "The ID of the request entry this entry responds to."
        },
        "productStatus": {
          "description": "The requested product status. Only defined if the request was successful.",
          "$ref": "ProductStatus"
        }
      }
    },
    "ProductsCustomBatchResponseEntry": {
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productsCustomBatchResponseEntry`\"",
          "type": "string"
        },
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        },
        "product": {
          "description": "The inserted product. Only defined if the method is `insert` and if the request was successful.",
          "$ref": "Product"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        }
      },
      "type": "object",
      "description": "A batch entry encoding a single non-batch products response.",
      "id": "ProductsCustomBatchResponseEntry"
    },
    "CollectionFeaturedProduct": {
      "id": "CollectionFeaturedProduct",
      "description": "The message for FeaturedProduct. [FeaturedProduct](https://support.google.com/merchants/answer/9703736)",
      "type": "object",
      "properties": {
        "y": {
          "description": "Required. Y-coordinate of the product callout on the Shoppable Image.",
          "format": "float",
          "type": "number"
        },
        "offerId": {
          "type": "string",
          "description": "The unique identifier for the product item."
        },
        "x": {
          "format": "float",
          "type": "number",
          "description": "Required. X-coordinate of the product callout on the Shoppable Image."
        }
      }
    },
    "FreeListingsProgramStatusReviewIneligibilityReasonDetails": {
      "properties": {
        "cooldownTime": {
          "description": "This timestamp represents end of cooldown period for review ineligbility reason `IN_COOLDOWN_PERIOD`.",
          "format": "google-datetime",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Additional details for review ineligibility reasons.",
      "id": "FreeListingsProgramStatusReviewIneligibilityReasonDetails"
    },
    "PickupCarrierService": {
      "properties": {
        "carrierName": {
          "type": "string",
          "description": "The name of the pickup carrier (for example, `\"UPS\"`). Required."
        },
        "serviceName": {
          "type": "string",
          "description": "The name of the pickup service (for example, `\"Access point\"`). Required."
        }
      },
      "type": "object",
      "id": "PickupCarrierService"
    },
    "ProductUnitPricingMeasure": {
      "properties": {
        "unit": {
          "type": "string",
          "description": "The unit of the measure."
        },
        "value": {
          "description": "The measure of an item.",
          "type": "number",
          "format": "double"
        }
      },
      "type": "object",
      "id": "ProductUnitPricingMeasure"
    },
    "OrderTrackingSignal": {
      "properties": {
        "deliveryPostalCode": {
          "type": "string",
          "description": "Required. The delivery postal code, as a continuous string without spaces or dashes, e.g. \"95016\". This field will be anonymized in returned OrderTrackingSignal creation response."
        },
        "orderId": {
          "type": "string",
          "description": "Required. The ID of the order on the merchant side. This field will be hashed in returned OrderTrackingSignal creation response."
        },
        "shipmentLineItemMapping": {
          "description": "The mapping of the line items to the shipment information.",
          "items": {
            "$ref": "OrderTrackingSignalShipmentLineItemMapping"
          },
          "type": "array"
        },
        "shippingInfo": {
          "description": "The shipping information for the order.",
          "items": {
            "$ref": "OrderTrackingSignalShippingInfo"
          },
          "type": "array"
        },
        "customerShippingFee": {
          "description": "The shipping fee of the order; this value should be set to zero in the case of free shipping.",
          "$ref": "PriceAmount"
        },
        "orderCreatedTime": {
          "description": "Required. The time when the order was created on the merchant side. Include the year and timezone string, if available.",
          "$ref": "DateTime"
        },
        "lineItems": {
          "type": "array",
          "description": "Information about line items in the order.",
          "items": {
            "$ref": "OrderTrackingSignalLineItemDetails"
          }
        },
        "merchantId": {
          "format": "int64",
          "type": "string",
          "description": "The Google merchant ID of this order tracking signal. This value is optional. If left unset, the caller's merchant ID is used. You must request access in order to provide data on behalf of another merchant. For more information, see [Submitting Order Tracking Signals](/shopping-content/guides/order-tracking-signals)."
        },
        "deliveryRegionCode": {
          "type": "string",
          "description": "Required. The [CLDR territory code] (http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) for the shipping destination."
        },
        "orderTrackingSignalId": {
          "description": "Output only. The ID that uniquely identifies this order tracking signal.",
          "readOnly": true,
          "format": "int64",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Represents a merchant trade from which signals are extracted, e.g. shipping.",
      "id": "OrderTrackingSignal"
    },
    "PaymentServiceProviderLinkInfo": {
      "properties": {
        "externalAccountBusinessCountry": {
          "type": "string",
          "description": "The business country of the merchant account as identified by the third party service provider."
        },
        "externalAccountId": {
          "type": "string",
          "description": "The id used by the third party service provider to identify the merchant."
        }
      },
      "type": "object",
      "description": "Additional information required for PAYMENT_SERVICE_PROVIDER link type.",
      "id": "PaymentServiceProviderLinkInfo"
    },
    "AccountGoogleMyBusinessLink": {
      "properties": {
        "gmbEmail": {
          "description": "The Business Profile email address of a specific account within a Business Profile. A sample account within a Business Profile could be a business account with set of locations, managed under the Business Profile.",
          "type": "string"
        },
        "status": {
          "type": "string",
          "description": "Status of the link between this Merchant Center account and the Business Profile. Acceptable values are: - \"`active`\" - \"`pending`\" "
        },
        "gmbAccountId": {
          "description": "The ID of the Business Profile. If this is provided, then `gmbEmail` is ignored. The value of this field should match the `accountId` used by the Business Profile API.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "AccountGoogleMyBusinessLink"
    },
    "PromotionPromotionStatus": {
      "description": "The status of the promotion.",
      "id": "PromotionPromotionStatus",
      "properties": {
        "destinationStatuses": {
          "description": "The intended destinations for the promotion.",
          "items": {
            "$ref": "PromotionPromotionStatusDestinationStatus"
          },
          "type": "array"
        },
        "lastUpdateDate": {
          "description": "Date on which the promotion status has been last updated in [ISO 8601](http://en.wikipedia.org/wiki/ISO_8601) format: Date, time, and offset, for example \"2020-01-02T09:00:00+01:00\" or \"2020-01-02T09:00:00Z\"",
          "type": "string"
        },
        "promotionIssue": {
          "description": "A list of issues associated with the promotion.",
          "items": {
            "$ref": "PromotionPromotionStatusPromotionIssue"
          },
          "type": "array"
        },
        "creationDate": {
          "type": "string",
          "description": "Date on which the promotion has been created in [ISO 8601](http://en.wikipedia.org/wiki/ISO_8601) format: Date, time, and offset, for example \"2020-01-02T09:00:00+01:00\" or \"2020-01-02T09:00:00Z\""
        }
      },
      "type": "object"
    },
    "LiasettingsRequestGmbAccessResponse": {
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsRequestGmbAccessResponse`\"."
        }
      },
      "type": "object",
      "id": "LiasettingsRequestGmbAccessResponse"
    },
    "Warehouse": {
      "description": "A fulfillment warehouse, which stores and handles inventory.",
      "id": "Warehouse",
      "properties": {
        "handlingDays": {
          "format": "int64",
          "type": "string",
          "description": "Required. The number of days it takes for this warehouse to pack up and ship an item. This is on the warehouse level, but can be overridden on the offer level based on the attributes of an item."
        },
        "cutoffTime": {
          "description": "Required. The latest time of day that an order can be accepted and begin processing. Later orders will be processed in the next day. The time is based on the warehouse postal code.",
          "$ref": "WarehouseCutoffTime"
        },
        "businessDayConfig": {
          "description": "Business days of the warehouse. If not set, will be Monday to Friday by default.",
          "$ref": "BusinessDayConfig"
        },
        "name": {
          "description": "Required. The name of the warehouse. Must be unique within account.",
          "type": "string"
        },
        "shippingAddress": {
          "description": "Required. Shipping address of the warehouse.",
          "$ref": "Address"
        }
      },
      "type": "object"
    },
    "ProductDeliveryTimeAreaDeliveryTime": {
      "description": "A pairing of `DeliveryArea` associated with a `DeliveryTime` for this product.",
      "id": "ProductDeliveryTimeAreaDeliveryTime",
      "properties": {
        "deliveryArea": {
          "description": "Required. The delivery area associated with `deliveryTime` for this product.",
          "$ref": "DeliveryArea"
        },
        "deliveryTime": {
          "description": "Required. The delivery time associated with `deliveryArea` for this product.",
          "$ref": "ProductDeliveryTimeAreaDeliveryTimeDeliveryTime"
        }
      },
      "type": "object"
    },
    "LiasettingsRequestInventoryVerificationResponse": {
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsRequestInventoryVerificationResponse`\".",
          "type": "string"
        }
      },
      "type": "object",
      "id": "LiasettingsRequestInventoryVerificationResponse"
    },
    "PosInventoryResponse": {
      "properties": {
        "storeCode": {
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile.",
          "type": "string"
        },
        "itemId": {
          "type": "string",
          "description": "Required. A unique identifier for the item."
        },
        "contentLanguage": {
          "type": "string",
          "description": "Required. The two-letter ISO 639-1 language code for the item."
        },
        "pickupMethod": {
          "type": "string",
          "description": "Optional. Supported pickup method for this offer. Unless the value is \"not supported\", this field must be submitted together with `pickupSla`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342)."
        },
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posInventoryResponse`\".",
          "type": "string"
        },
        "pickupSla": {
          "type": "string",
          "description": "Optional. Expected date that an order will be ready for pickup relative to the order date. Must be submitted together with `pickupMethod`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342)."
        },
        "quantity": {
          "format": "int64",
          "type": "string",
          "description": "Required. The available quantity of the item."
        },
        "price": {
          "description": "Required. The current price of the item.",
          "$ref": "Price"
        },
        "timestamp": {
          "type": "string",
          "description": "Required. The inventory timestamp, in ISO 8601 format."
        }
      },
      "type": "object",
      "id": "PosInventoryResponse"
    },
    "PosDataProvidersPosDataProvider": {
      "id": "PosDataProvidersPosDataProvider",
      "type": "object",
      "properties": {
        "displayName": {
          "description": "The display name of Pos data Provider.",
          "type": "string"
        },
        "fullName": {
          "type": "string",
          "description": "The full name of this POS data Provider."
        },
        "providerId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the account."
        }
      }
    },
    "LiasettingsSetPosDataProviderResponse": {
      "id": "LiasettingsSetPosDataProviderResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsSetPosDataProviderResponse`\".",
          "type": "string"
        }
      },
      "type": "object"
    },
    "BuiltInSimpleAction": {
      "type": "object",
      "properties": {
        "type": {
          "type": "string",
          "description": "The type of action that represents a functionality that is expected to be available in third-party application.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Redirect merchant to the part of your application where they can verify their phone.",
            "Redirect merchant to the part of your application where they can claim their website.",
            "Redirect merchant to the part of your application where they can add products.",
            "Open a form where the merchant can edit their contact information.",
            "Redirect merchant to the part of your application where they can link ads account.",
            "Open a form where the merchant can add their business registration number.",
            "Open a form where the merchant can edit an attribute. The attribute that needs to be updated is specified in attribute_code field of the action.",
            "Redirect merchant from the product issues to the diagnostic page with their account issues in your application. This action will be returned only for product issues that are caused by an account issue and thus merchant should resolve the problem on the account level.",
            "Show additional content to the merchant. This action will be used for example to deliver a justification from national authority."
          ],
          "enum": [
            "BUILT_IN_SIMPLE_ACTION_TYPE_UNSPECIFIED",
            "VERIFY_PHONE",
            "CLAIM_WEBSITE",
            "ADD_PRODUCTS",
            "ADD_CONTACT_INFO",
            "LINK_ADS_ACCOUNT",
            "ADD_BUSINESS_REGISTRATION_NUMBER",
            "EDIT_ITEM_ATTRIBUTE",
            "FIX_ACCOUNT_ISSUE",
            "SHOW_ADDITIONAL_CONTENT"
          ]
        },
        "attributeCode": {
          "type": "string",
          "description": "The attribute that needs to be updated. Present when the type is `EDIT_ITEM_ATTRIBUTE`. This field contains a code for attribute, represented in snake_case. You can find a list of product's attributes, with their codes [here](https://support.google.com/merchants/answer/7052112)."
        },
        "additionalContent": {
          "description": "Long text from an external source that should be available to the merchant. Present when the type is `SHOW_ADDITIONAL_CONTENT`.",
          "$ref": "BuiltInSimpleActionAdditionalContent"
        }
      },
      "id": "BuiltInSimpleAction",
      "description": "Action that is implemented and performed in (your) third-party application. Represents various functionality that is expected to be available to merchant and will help them with resolving the issue. The application should point the merchant to the place, where they can access the corresponding functionality. If the functionality is not supported, it is recommended to explain the situation to merchant and provide them with instructions how to solve the issue."
    },
    "Date": {
      "description": "Represents a whole or partial calendar date, such as a birthday. The time of day and time zone are either specified elsewhere or are insignificant. The date is relative to the Gregorian Calendar. This can represent one of the following: * A full date, with non-zero year, month, and day values. * A month and day, with a zero year (for example, an anniversary). * A year on its own, with a zero month and a zero day. * A year and month, with a zero day (for example, a credit card expiration date). Related types: * google.type.TimeOfDay * google.type.DateTime * google.protobuf.Timestamp",
      "id": "Date",
      "properties": {
        "year": {
          "description": "Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.",
          "format": "int32",
          "type": "integer"
        },
        "month": {
          "description": "Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.",
          "format": "int32",
          "type": "integer"
        },
        "day": {
          "description": "Day of a month. Must be from 1 to 31 and valid for the year and month, or 0 to specify a year by itself or a year and month where the day isn't significant.",
          "format": "int32",
          "type": "integer"
        }
      },
      "type": "object"
    },
    "DeliveryArea": {
      "type": "object",
      "properties": {
        "postalCodeRange": {
          "description": "A postal code, postal code range or postal code prefix that defines this area. Limited to US and AUS.",
          "$ref": "DeliveryAreaPostalCodeRange"
        },
        "regionCode": {
          "type": "string",
          "description": "A state, territory, or prefecture. This is supported for the United States, Australia, and Japan. Provide a subdivision code from the ISO 3166-2 code tables ([US](https://en.wikipedia.org/wiki/ISO_3166-2:US), [AU](https://en.wikipedia.org/wiki/ISO_3166-2:AU), or [JP](https://en.wikipedia.org/wiki/ISO_3166-2:JP)) without country prefix (for example, `\"NY\"`, `\"NSW\"`, `\"03\"`)."
        },
        "countryCode": {
          "description": "Required. The country that the product can be delivered to. Submit a [unicode CLDR region](http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) such as `US` or `CH`.",
          "type": "string"
        }
      },
      "id": "DeliveryArea",
      "description": "A delivery area for the product. Only one of `countryCode` or `postalCodeRange` must be set."
    },
    "MethodQuota": {
      "type": "object",
      "properties": {
        "method": {
          "readOnly": true,
          "description": "Output only. The method name, for example `products.list`. Method name does not contain version because quota can be shared between different API versions of the same method.",
          "type": "string"
        },
        "quotaLimit": {
          "readOnly": true,
          "description": "Output only. The maximum number of calls allowed per day for the method.",
          "type": "string",
          "format": "int64"
        },
        "quotaUsage": {
          "format": "int64",
          "type": "string",
          "description": "Output only. The current quota usage, meaning the number of calls already made to the method per day. Usage is reset every day at 12 PM midday UTC.",
          "readOnly": true
        },
        "quotaMinuteLimit": {
          "description": "Output only. The maximum number of calls allowed per minute for the method.",
          "readOnly": true,
          "format": "int64",
          "type": "string"
        }
      },
      "id": "MethodQuota",
      "description": "The quota information per method in the Content API."
    },
    "InputFieldTextInput": {
      "properties": {
        "formatInfo": {
          "type": "string",
          "description": "Information about the required format. If present, it should be shown close to the input field to help merchants to provide a correct value. For example: \"VAT numbers should be in a format similar to SK9999999999\""
        },
        "type": {
          "description": "Type of the text input",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Used when a short text is expected. The field can be rendered as a [text field](https://www.w3.org/TR/2012/WD-html-markup-20121025/input.text.html#input.text).",
            "Used when a longer text is expected. The field should be rendered as a [textarea](https://www.w3.org/TR/2012/WD-html-markup-20121025/textarea.html#textarea)."
          ],
          "enum": [
            "TEXT_INPUT_TYPE_UNSPECIFIED",
            "GENERIC_SHORT_TEXT",
            "GENERIC_LONG_TEXT"
          ],
          "type": "string"
        },
        "additionalInfo": {
          "description": "Additional info regarding the field to be displayed to merchant. For example, warning to not include personal identifiable information. There may be more information to be shown in a tooltip.",
          "$ref": "TextWithTooltip"
        },
        "ariaLabel": {
          "description": "Text to be used as the [aria-label](https://www.w3.org/TR/WCAG20-TECHS/ARIA14.html) for the input.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "Text input allows merchants to provide a text value.",
      "id": "InputFieldTextInput"
    },
    "RecommendationCreative": {
      "id": "RecommendationCreative",
      "description": "Creative is a multimedia attachment to recommendation that can be used on the frontend.",
      "type": "object",
      "properties": {
        "uri": {
          "type": "string",
          "description": "URL of the creative."
        },
        "type": {
          "type": "string",
          "description": "Type of the creative.",
          "enumDescriptions": [
            "Default value. If provided, shall be considered invalid.",
            "Video creatives.",
            "Photo creatives."
          ],
          "enum": [
            "CREATIVE_TYPE_UNSPECIFIED",
            "VIDEO",
            "PHOTO"
          ]
        }
      }
    },
    "LiasettingsGetAccessibleGmbAccountsResponse": {
      "properties": {
        "accountId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the Merchant Center account."
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsGetAccessibleGmbAccountsResponse`\"."
        },
        "gmbAccounts": {
          "type": "array",
          "description": "A list of Business Profiles which are available to the merchant.",
          "items": {
            "$ref": "GmbAccountsGmbAccount"
          }
        }
      },
      "type": "object",
      "id": "LiasettingsGetAccessibleGmbAccountsResponse"
    },
    "AccountStatusAccountLevelIssue": {
      "type": "object",
      "properties": {
        "detail": {
          "type": "string",
          "description": "Additional details about the issue."
        },
        "id": {
          "type": "string",
          "description": "Issue identifier."
        },
        "severity": {
          "description": "Severity of the issue. Acceptable values are: - \"`critical`\" - \"`error`\" - \"`suggestion`\" ",
          "type": "string"
        },
        "title": {
          "type": "string",
          "description": "Short description of the issue."
        },
        "country": {
          "type": "string",
          "description": "Country for which this issue is reported."
        },
        "destination": {
          "type": "string",
          "description": "The destination the issue applies to. If this field is empty then the issue applies to all available destinations."
        },
        "documentation": {
          "type": "string",
          "description": "The URL of a web page to help resolving this issue."
        }
      },
      "id": "AccountStatusAccountLevelIssue"
    },
    "ProductsCustomBatchResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#productsCustomBatchResponse`\"."
        },
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "ProductsCustomBatchResponseEntry"
          }
        }
      },
      "id": "ProductsCustomBatchResponse"
    },
    "Service": {
      "properties": {
        "name": {
          "type": "string",
          "description": "Free-form name of the service. Must be unique within target account. Required."
        },
        "rateGroups": {
          "type": "array",
          "description": "Shipping rate group definitions. Only the last one is allowed to have an empty `applicableShippingLabels`, which means \"everything else\". The other `applicableShippingLabels` must not overlap.",
          "items": {
            "$ref": "RateGroup"
          }
        },
        "active": {
          "type": "boolean",
          "description": "A boolean exposing the active status of the shipping service. Required."
        },
        "pickupService": {
          "description": "The carrier-service pair delivering items to collection points. The list of supported pickup services can be retrieved through the `getSupportedPickupServices` method. Required if and only if the service delivery type is `pickup`.",
          "$ref": "PickupCarrierService"
        },
        "storeConfig": {
          "description": "A list of stores your products are delivered from. This is only available for the local delivery shipment type.",
          "$ref": "ServiceStoreConfig"
        },
        "minimumOrderValueTable": {
          "description": "Table of per store minimum order values for the pickup fulfillment type. Cannot be set together with minimum_order_value.",
          "$ref": "MinimumOrderValueTable"
        },
        "deliveryTime": {
          "description": "Time spent in various aspects from order to the delivery of the product. Required.",
          "$ref": "DeliveryTime"
        },
        "eligibility": {
          "type": "string",
          "description": "Eligibility for this service. Acceptable values are: - \"`All scenarios`\" - \"`All scenarios except Shopping Actions`\" - \"`Shopping Actions`\" "
        },
        "deliveryCountry": {
          "type": "string",
          "description": "The CLDR territory code of the country to which the service applies. Required."
        },
        "minimumOrderValue": {
          "description": "Minimum order value for this service. If set, indicates that customers will have to spend at least this amount. All prices within a service must have the same currency. Cannot be set together with minimum_order_value_table.",
          "$ref": "Price"
        },
        "shipmentType": {
          "description": "Type of locations this service ships orders to. Acceptable values are: - \"`delivery`\" - \"`pickup` (deprecated)\" - \"`local_delivery`\" - \"`collection_point`\" ",
          "type": "string"
        },
        "currency": {
          "type": "string",
          "description": "The CLDR code of the currency to which this service applies. Must match that of the prices in rate groups."
        }
      },
      "type": "object",
      "id": "Service"
    },
    "AccountstatusesCustomBatchResponseEntry": {
      "id": "AccountstatusesCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch accountstatuses response.",
      "type": "object",
      "properties": {
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        },
        "accountStatus": {
          "description": "The requested account status. Defined if and only if the request was successful.",
          "$ref": "AccountStatus"
        }
      }
    },
    "ProductWeight": {
      "id": "ProductWeight",
      "type": "object",
      "properties": {
        "unit": {
          "type": "string",
          "description": "Required. The weight unit. Acceptable values are: - \"`g`\" - \"`kg`\" - \"`oz`\" - \"`lb`\" "
        },
        "value": {
          "description": "Required. The weight represented as a number. The weight can have a maximum precision of four decimal places.",
          "format": "double",
          "type": "number"
        }
      }
    },
    "ProductCertification": {
      "description": "Product [certification](https://support.google.com/merchants/answer/13528839), introduced for EU energy efficiency labeling compliance using the [EU EPREL](https://eprel.ec.europa.eu/screen/home) database.",
      "id": "ProductCertification",
      "properties": {
        "certificationAuthority": {
          "description": "The certification authority, for example \"European_Commission\". Maximum length is 2000 characters.",
          "type": "string"
        },
        "certificationCode": {
          "type": "string",
          "description": "The certification code, for eaxample \"123456\". Maximum length is 2000 characters."
        },
        "certificationName": {
          "description": "The name of the certification, for example \"EPREL\". Maximum length is 2000 characters.",
          "type": "string"
        },
        "certificationValue": {
          "description": "The certification value (also known as class, level or grade), for example \"A+\", \"C\", \"gold\". Maximum length is 2000 characters.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "Installment": {
      "id": "Installment",
      "description": "Details of a monthly installment payment offering. [Learn more](https://support.google.com/merchants/answer/6324474) about installments.",
      "type": "object",
      "properties": {
        "downpayment": {
          "description": "Optional. The initial down payment amount the buyer has to pay.",
          "$ref": "Price"
        },
        "months": {
          "format": "int64",
          "type": "string",
          "description": "The number of installments the buyer has to pay."
        },
        "creditType": {
          "description": "Optional. Type of installment payments. Supported values are: - \"`finance`\" - \"`lease`\" ",
          "type": "string"
        },
        "amount": {
          "description": "The amount the buyer has to pay per month.",
          "$ref": "Price"
        }
      }
    },
    "Datafeed": {
      "properties": {
        "contentType": {
          "description": "Required. The type of data feed. For product inventory feeds, only feeds for local stores, not online stores, are supported. Acceptable values are: - \"`local products`\" - \"`product inventory`\" - \"`products`\" ",
          "type": "string"
        },
        "fetchSchedule": {
          "description": "Fetch schedule for the feed file.",
          "$ref": "DatafeedFetchSchedule"
        },
        "fileName": {
          "type": "string",
          "description": "Required. The filename of the feed. All feeds must have a unique file name."
        },
        "id": {
          "type": "string",
          "format": "int64",
          "description": "Required for update. The ID of the data feed."
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeed`\""
        },
        "targets": {
          "description": "The targets this feed should apply to (country, language, destinations).",
          "items": {
            "$ref": "DatafeedTarget"
          },
          "type": "array"
        },
        "attributeLanguage": {
          "type": "string",
          "description": "The two-letter ISO 639-1 language in which the attributes are defined in the data feed."
        },
        "name": {
          "description": "Required for insert. A descriptive name of the data feed.",
          "type": "string"
        },
        "format": {
          "description": "Format of the feed file.",
          "$ref": "DatafeedFormat"
        }
      },
      "type": "object",
      "description": "Datafeed configuration data.",
      "id": "Datafeed"
    },
    "ProductSustainabilityIncentive": {
      "description": "Information regarding sustainability related incentive programs such as rebates or tax relief.",
      "id": "ProductSustainabilityIncentive",
      "properties": {
        "type": {
          "type": "string",
          "description": "Required. Sustainability incentive program.",
          "enumDescriptions": [
            "Unspecified or unknown sustainability incentive type.",
            "Program offering tax liability reductions for electric vehicles and, in some countries, plug-in hybrids. These reductions can be based on a specific amount or a percentage of the sale price.",
            "A subsidy program, often called an environmental bonus, provides a purchase grant for electric vehicles and, in some countries, plug-in hybrids. The grant amount may be a fixed sum or a percentage of the sale price."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "EV_TAX_CREDIT",
            "EV_PRICE_DISCOUNT"
          ]
        },
        "amount": {
          "description": "Optional. The fixed amount of the incentive.",
          "$ref": "Price"
        },
        "percentage": {
          "description": "Optional. The percentage of the sale price that the incentive is applied to.",
          "type": "number",
          "format": "double"
        }
      },
      "type": "object"
    },
    "PosCustomBatchRequestEntry": {
      "properties": {
        "sale": {
          "description": "The sale information to submit. This should be set only if the method is `sale`.",
          "$ref": "PosSale"
        },
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`delete`\" - \"`get`\" - \"`insert`\" - \"`inventory`\" - \"`sale`\" ",
          "type": "string"
        },
        "storeCode": {
          "type": "string",
          "description": "The store code. This should be set only if the method is `delete` or `get`."
        },
        "targetMerchantId": {
          "description": "The ID of the account for which to get/submit data.",
          "format": "uint64",
          "type": "string"
        },
        "store": {
          "description": "The store information to submit. This should be set only if the method is `insert`.",
          "$ref": "PosStore"
        },
        "merchantId": {
          "description": "The ID of the POS data provider.",
          "format": "uint64",
          "type": "string"
        },
        "inventory": {
          "description": "The inventory to submit. This should be set only if the method is `inventory`.",
          "$ref": "PosInventory"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "An entry ID, unique within the batch request."
        }
      },
      "type": "object",
      "id": "PosCustomBatchRequestEntry"
    },
    "AccountIssue": {
      "description": "An issue affecting specific merchant.",
      "id": "AccountIssue",
      "properties": {
        "impact": {
          "description": "Clarifies the severity of the issue. The summarizing message, if present, should be shown right under the title for each issue. It helps merchants to quickly understand the impact of the issue. The detailed breakdown helps the merchant to fully understand the impact of the issue. It can be rendered as dialog that opens when the merchant mouse over the summarized impact statement. Issues with different severity can be styled differently. They may use a different color or icon to signal the difference between `ERROR`, `WARNING` and `INFO`.",
          "$ref": "AccountIssueImpact"
        },
        "actions": {
          "description": "A list of actionable steps that can be executed to solve the issue. An example is requesting a re-review or providing arguments when merchant disagrees with the issue. Actions that are supported in (your) third-party application can be rendered as buttons and should be available to merchant when they expand the issue.",
          "items": {
            "$ref": "Action"
          },
          "type": "array"
        },
        "title": {
          "description": "Title of the issue.",
          "type": "string"
        },
        "prerenderedContent": {
          "type": "string",
          "description": "Details of the issue as a pre-rendered HTML. HTML elements contain CSS classes that can be used to customize the style of the content. Always sanitize the HTML before embedding it directly to your application. The sanitizer needs to allow basic HTML tags, such as: `div`, `span`, `p`, `a`, `ul`, `li`, `table`, `tr`, `td`. For example, you can use [DOMPurify](https://www.npmjs.com/package/dompurify). CSS classes: * `issue-detail` - top level container for the detail of the issue * `callout-banners` - section of the `issue-detail` with callout banners * `callout-banner` - single callout banner, inside `callout-banners` * `callout-banner-info` - callout with important information (default) * `callout-banner-warning` - callout with a warning * `callout-banner-error` - callout informing about an error (most severe) * `issue-content` - section of the `issue-detail`, contains multiple `content-element` * `content-element` - content element such as a list, link or paragraph, inside `issue-content` * `root-causes` - unordered list with items describing root causes of the issue, inside `issue-content` * `root-causes-intro` - intro text before the `root-causes` list, inside `issue-content` * `segment` - section of the text, `span` inside paragraph * `segment-attribute` - section of the text that represents a product attribute, for example 'image\\_link' * `segment-literal` - section of the text that contains a special value, for example '0-1000 kg' * `segment-bold` - section of the text that should be rendered as bold * `segment-italic` - section of the text that should be rendered as italic * `tooltip` - used on paragraphs that should be rendered with a tooltip. A section of the text in such a paragraph will have a class `tooltip-text` and is intended to be shown in a mouse over dialog. If the style is not used, the `tooltip-text` section would be shown on a new line, after the main part of the text. * `tooltip-text` - marks a section of the text within a `tooltip`, that is intended to be shown in a mouse over dialog. * `tooltip-icon` - marks a section of the text within a `tooltip`, that can be replaced with a tooltip icon, for example '?' or 'i'. By default, this section contains a `br` tag, that is separating the main text and the tooltip text when the style is not used. * `tooltip-style-question` - the tooltip shows helpful information, can use the '?' as an icon. * `tooltip-style-info` - the tooltip adds additional information fitting to the context, can use the 'i' as an icon. * `content-moderation` - marks the paragraph that explains how the issue was identified. * `new-element` - Present for new elements added to the pre-rendered content in the future. To make sure that a new content element does not break your style, you can hide everything with this class."
        },
        "prerenderedOutOfCourtDisputeSettlement": {
          "description": "Pre-rendered HTML that contains a link to the external location where the ODS can be requested and instructions for how to request it. HTML elements contain CSS classes that can be used to customize the style of this snippet. Always sanitize the HTML before embedding it directly to your application. The sanitizer needs to allow basic HTML tags, such as: `div`, `span`, `p`, `a`, `ul`, `li`, `table`, `tr`, `td`. For example, you can use [DOMPurify](https://www.npmjs.com/package/dompurify). CSS classes: * `ods-section`* - wrapper around the out-of-court dispute resolution section * `ods-description`* - intro text for the out-of-court dispute resolution. It may contain multiple segments and a link. * `ods-param`* - wrapper around the header-value pair for parameters that merchant may need to provide during the ODS process. * `ods-routing-id`* - ods param for the Routing ID. * `ods-reference-id`* - ods param for the Routing ID. * `ods-param-header`* - header for the ODS parameter * `ods-param-value`* - value of the ODS parameter. This value should be rendered in a way that it is easy for merchants to identify and copy. * `segment` - section of the text, `span` inside paragraph * `segment-attribute` - section of the text that represents a product attribute, for example 'image\\_link' * `segment-literal` - section of the text that contains a special value, for example '0-1000 kg' * `segment-bold` - section of the text that should be rendered as bold * `segment-italic` - section of the text that should be rendered as italic * `tooltip` - used on paragraphs that should be rendered with a tooltip. A section of the text in such a paragraph will have a class `tooltip-text` and is intended to be shown in a mouse over dialog. If the style is not used, the `tooltip-text` section would be shown on a new line, after the main part of the text. * `tooltip-text` - marks a section of the text within a `tooltip`, that is intended to be shown in a mouse over dialog. * `tooltip-icon` - marks a section of the text within a `tooltip`, that can be replaced with a tooltip icon, for example '?' or 'i'. By default, this section contains a `br` tag, that is separating the main text and the tooltip text when the style is not used. * `tooltip-style-question` - the tooltip shows helpful information, can use the '?' as an icon. * `tooltip-style-info` - the tooltip adds additional information fitting to the context, can use the 'i' as an icon.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "LocalInventory": {
      "type": "object",
      "properties": {
        "instoreProductLocation": {
          "description": "The in-store product location.",
          "type": "string"
        },
        "storeCode": {
          "type": "string",
          "description": "Required. The store code of this local inventory resource."
        },
        "pickupMethod": {
          "type": "string",
          "description": "The supported pickup method for this offer. Unless the value is \"not supported\", this field must be submitted together with `pickupSla`. For accepted attribute values, see the local product inventory feed specification."
        },
        "salePriceEffectiveDate": {
          "description": "A date range represented by a pair of ISO 8601 dates separated by a space, comma, or slash. Both dates may be specified as 'null' if undecided.",
          "type": "string"
        },
        "price": {
          "description": "The price of the product.",
          "$ref": "Price"
        },
        "customAttributes": {
          "type": "array",
          "description": "A list of custom (merchant-provided) attributes. Can also be used to submit any attribute of the feed specification in its generic form, for example, `{ \"name\": \"size type\", \"value\": \"regular\" }`.",
          "items": {
            "$ref": "CustomAttribute"
          }
        },
        "pickupSla": {
          "type": "string",
          "description": "The expected date that an order will be ready for pickup relative to the order date. Must be submitted together with `pickupMethod`. For accepted attribute values, see the local product inventory feed specification."
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#localInventory`\"",
          "type": "string"
        },
        "salePrice": {
          "description": "The sale price of the product. Mandatory if `sale_price_effective_date` is defined.",
          "$ref": "Price"
        },
        "availability": {
          "description": "The availability of the product. For accepted attribute values, see the local product inventory feed specification.",
          "type": "string"
        },
        "quantity": {
          "description": "The quantity of the product. Must be nonnegative.",
          "type": "integer",
          "format": "uint32"
        }
      },
      "id": "LocalInventory",
      "description": "Local inventory resource. For accepted attribute values, see the local product inventory feed specification."
    },
    "ProductsCustomBatchRequestEntry": {
      "description": "A batch entry encoding a single non-batch products request.",
      "id": "ProductsCustomBatchRequestEntry",
      "properties": {
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        },
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "type": "integer",
          "format": "uint32"
        },
        "feedId": {
          "description": "The Content API Supplemental Feed ID. If present then product insertion or deletion applies to a supplemental feed instead of primary Content API feed.",
          "type": "string",
          "format": "uint64"
        },
        "updateMask": {
          "type": "string",
          "format": "google-fieldmask",
          "description": "The comma-separated list of product attributes to be updated. Example: `\"title,salePrice\"`. Attributes specified in the update mask without a value specified in the body will be deleted from the product. *You must specify the update mask to delete attributes.* Only top-level product attributes can be updated. If not defined, product attributes with set values will be updated and other attributes will stay unchanged. Only defined if the method is `update`."
        },
        "method": {
          "type": "string",
          "description": "The method of the batch entry. Acceptable values are: - \"`delete`\" - \"`get`\" - \"`insert`\" - \"`update`\" "
        },
        "productId": {
          "description": "The ID of the product to get or mutate. Only defined if the method is `get`, `delete`, or `update`.",
          "type": "string"
        },
        "product": {
          "description": "The product to insert or update. Only required if the method is `insert` or `update`. If the `update` method is used with `updateMask` only to delete a field, then this isn't required. For example, setting `salePrice` on the `updateMask` and not providing a `product` will result in an existing sale price on the product specified by `productId` being deleted.",
          "$ref": "Product"
        }
      },
      "type": "object"
    },
    "DeliveryAreaPostalCodeRange": {
      "type": "object",
      "properties": {
        "firstPostalCode": {
          "description": "Required. A postal code or a pattern of the form prefix* denoting the inclusive lower bound of the range defining the area. Examples values: `\"94108\"`, `\"9410*\"`, `\"9*\"`.",
          "type": "string"
        },
        "lastPostalCode": {
          "type": "string",
          "description": "A postal code or a pattern of the form prefix* denoting the inclusive upper bound of the range defining the area (for example [070* - 078*] results in the range [07000 - 07899]). It must have the same length as `firstPostalCode`: if `firstPostalCode` is a postal code then `lastPostalCode` must be a postal code too; if firstPostalCode is a pattern then `lastPostalCode` must be a pattern with the same prefix length. Ignored if not set, then the area is defined as being all the postal codes matching `firstPostalCode`."
        }
      },
      "id": "DeliveryAreaPostalCodeRange",
      "description": "A range of postal codes that defines the delivery area. Only set `firstPostalCode` when specifying a single postal code."
    },
    "AccountItemUpdates": {
      "type": "object",
      "properties": {
        "effectiveAllowPriceUpdates": {
          "type": "boolean",
          "description": "Output only. The effective value of allow_price_updates. If account_item_updates_settings is present, then this value is the same. Otherwise, it represents the inherited value of the parent account. Read-only.",
          "readOnly": true
        },
        "effectiveAllowStrictAvailabilityUpdates": {
          "type": "boolean",
          "description": "Output only. The effective value of allow_strict_availability_updates. If account_item_updates_settings is present, then this value is the same. Otherwise, it represents the inherited value of the parent account. Read-only.",
          "readOnly": true
        },
        "effectiveAllowConditionUpdates": {
          "readOnly": true,
          "description": "Output only. The effective value of allow_condition_updates. If account_item_updates_settings is present, then this value is the same. Otherwise, it represents the inherited value of the parent account. Read-only.",
          "type": "boolean"
        },
        "accountItemUpdatesSettings": {
          "description": "Determines which attributes of the items should be automatically updated. If this field is not present, then the settings will be deleted. If there are no settings for subaccount, they are inherited from aggregator.",
          "$ref": "AccountItemUpdatesSettings"
        },
        "effectiveAllowAvailabilityUpdates": {
          "description": "Output only. The effective value of allow_availability_updates. If account_item_updates_settings is present, then this value is the same. Otherwise, it represents the inherited value of the parent account. Read-only.",
          "readOnly": true,
          "type": "boolean"
        }
      },
      "id": "AccountItemUpdates",
      "description": "Turning on [item updates](https://support.google.com/merchants/answer/3246284) allows Google to automatically update items for you. When item updates are on, Google uses the structured data markup on the website and advanced data extractors to update the price and availability of the items. When the item updates are off, items with mismatched data aren't shown."
    },
    "DatafeedstatusesCustomBatchRequestEntry": {
      "id": "DatafeedstatusesCustomBatchRequestEntry",
      "description": "A batch entry encoding a single non-batch datafeedstatuses request.",
      "type": "object",
      "properties": {
        "method": {
          "type": "string",
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" "
        },
        "datafeedId": {
          "format": "uint64",
          "type": "string",
          "description": "The ID of the data feed to get."
        },
        "language": {
          "type": "string",
          "description": "The language to get the datafeed status for. If this parameter is provided then `country` must also be provided. Note that for multi-target datafeeds this parameter is required."
        },
        "merchantId": {
          "description": "The ID of the managing account.",
          "type": "string",
          "format": "uint64"
        },
        "country": {
          "type": "string",
          "description": "Deprecated. Use `feedLabel` instead. The country to get the datafeed status for. If this parameter is provided, then `language` must also be provided. Note that for multi-target datafeeds this parameter is required."
        },
        "feedLabel": {
          "description": "The feed label to get the datafeed status for. If this parameter is provided, then `language` must also be provided. Note that for multi-target datafeeds this parameter is required.",
          "type": "string"
        },
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "format": "uint32",
          "type": "integer"
        }
      }
    },
    "RequestReviewFreeListingsRequest": {
      "type": "object",
      "properties": {
        "regionCode": {
          "description": "The code [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) of the country for which review is to be requested.",
          "type": "string"
        }
      },
      "id": "RequestReviewFreeListingsRequest",
      "description": "Request message for the RequestReviewFreeListings Program method."
    },
    "Brand": {
      "description": "Brand fields. Values are only set for fields requested explicitly in the request's search query.",
      "id": "Brand",
      "properties": {
        "name": {
          "description": "Name of the brand.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "CustomAttribute": {
      "properties": {
        "value": {
          "description": "The value of the attribute.",
          "type": "string"
        },
        "groupValues": {
          "description": "Subattributes within this attribute group. Exactly one of value or groupValues must be provided.",
          "items": {
            "$ref": "CustomAttribute"
          },
          "type": "array"
        },
        "name": {
          "type": "string",
          "description": "The name of the attribute. Underscores will be replaced by spaces upon insertion."
        }
      },
      "type": "object",
      "description": "A message that represents custom attributes. Exactly one of `value` or `groupValues` must be provided. Maximum allowed number of characters for each custom attribute is 10240 (represents sum of characters for name and value). Maximum 2500 custom attributes can be set per merchant, with total size of 102.4kB.",
      "id": "CustomAttribute"
    },
    "DatafeedsCustomBatchResponse": {
      "properties": {
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "DatafeedsCustomBatchResponseEntry"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedsCustomBatchResponse`\"."
        }
      },
      "type": "object",
      "id": "DatafeedsCustomBatchResponse"
    },
    "ProductViewItemIssueItemIssueSeverity": {
      "properties": {
        "severityPerDestination": {
          "description": "Item issue severity for every destination.",
          "items": {
            "$ref": "ProductViewItemIssueIssueSeverityPerDestination"
          },
          "type": "array"
        },
        "aggregatedSeverity": {
          "type": "string",
          "description": "Severity of an issue aggregated for destination.",
          "enumDescriptions": [
            "Undefined Issue severity.",
            "Issue disapproves the product in at least one of the selected destinations.",
            "Issue demotes the product in all selected destinations it affects.",
            "Issue resolution is `PENDING_PROCESSING`."
          ],
          "enum": [
            "AGGREGATED_ISSUE_SEVERITY_UNSPECIFIED",
            "DISAPPROVED",
            "DEMOTED",
            "PENDING"
          ]
        }
      },
      "type": "object",
      "description": "Severity of an issue per destination in a region, and aggregated severity.",
      "id": "ProductViewItemIssueItemIssueSeverity"
    },
    "ShippingsettingsCustomBatchRequestEntry": {
      "type": "object",
      "properties": {
        "accountId": {
          "format": "uint64",
          "type": "string",
          "description": "The ID of the account for which to get/update account shipping settings."
        },
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" - \"`update`\" ",
          "type": "string"
        },
        "batchId": {
          "description": "An entry ID, unique within the batch request.",
          "format": "uint32",
          "type": "integer"
        },
        "merchantId": {
          "type": "string",
          "format": "uint64",
          "description": "The ID of the managing account."
        },
        "shippingSettings": {
          "description": "The account shipping settings to update. Only defined if the method is `update`.",
          "$ref": "ShippingSettings"
        }
      },
      "id": "ShippingsettingsCustomBatchRequestEntry",
      "description": "A batch entry encoding a single non-batch shippingsettings request."
    },
    "ShippingSettings": {
      "description": "The merchant account's shipping settings. All methods except getsupportedcarriers and getsupportedholidays require the admin role.",
      "id": "ShippingSettings",
      "properties": {
        "warehouses": {
          "description": "Optional. A list of warehouses which can be referred to in `services`.",
          "items": {
            "$ref": "Warehouse"
          },
          "type": "array"
        },
        "accountId": {
          "format": "uint64",
          "type": "string",
          "description": "The ID of the account to which these account shipping settings belong. Ignored upon update, always present in get request responses."
        },
        "services": {
          "description": "The target account's list of services. Optional.",
          "items": {
            "$ref": "Service"
          },
          "type": "array"
        },
        "postalCodeGroups": {
          "description": "A list of postal code groups that can be referred to in `services`. Optional.",
          "items": {
            "$ref": "PostalCodeGroup"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "Css": {
      "type": "object",
      "properties": {
        "displayName": {
          "type": "string",
          "description": "Output only. Immutable. The CSS domain's display name, used when space is constrained.",
          "readOnly": true
        },
        "fullName": {
          "readOnly": true,
          "description": "Output only. Immutable. The CSS domain's full name.",
          "type": "string"
        },
        "cssDomainId": {
          "readOnly": true,
          "description": "Output only. Immutable. The CSS domain ID.",
          "type": "string",
          "format": "int64"
        },
        "labelIds": {
          "description": "A list of label IDs that are assigned to this CSS domain by its CSS group. Only populated for CSS group users.",
          "items": {
            "type": "string",
            "format": "int64"
          },
          "type": "array"
        },
        "cssGroupId": {
          "format": "int64",
          "type": "string",
          "description": "Output only. Immutable. The ID of the CSS group this CSS domain is affiliated with. Only populated for CSS group users.",
          "readOnly": true
        },
        "homepageUri": {
          "type": "string",
          "description": "Output only. Immutable. The CSS domain's homepage.",
          "readOnly": true
        }
      },
      "id": "Css",
      "description": "Information about CSS domain."
    },
    "Row": {
      "id": "Row",
      "type": "object",
      "properties": {
        "cells": {
          "description": "The list of cells that constitute the row. Must have the same length as `columnHeaders` for two-dimensional tables, a length of 1 for one-dimensional tables. Required.",
          "items": {
            "$ref": "Value"
          },
          "type": "array"
        }
      }
    },
    "DatafeedsListResponse": {
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedsListResponse`\"."
        },
        "nextPageToken": {
          "type": "string",
          "description": "The token for the retrieval of the next page of datafeeds."
        },
        "resources": {
          "items": {
            "$ref": "Datafeed"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "DatafeedsListResponse"
    },
    "BuiltInSimpleActionAdditionalContent": {
      "id": "BuiltInSimpleActionAdditionalContent",
      "description": "Long text from external source.",
      "type": "object",
      "properties": {
        "title": {
          "type": "string",
          "description": "Title of the additional content;"
        },
        "paragraphs": {
          "type": "array",
          "description": "Long text organized into paragraphs.",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "RegionGeoTargetArea": {
      "properties": {
        "geotargetCriteriaIds": {
          "description": "Required. A non-empty list of [location IDs](https://developers.google.com/adwords/api/docs/appendix/geotargeting). They must all be of the same location type (e.g., state).",
          "items": {
            "type": "string",
            "format": "int64"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "A list of geotargets that defines the region area.",
      "id": "RegionGeoTargetArea"
    },
    "BusinessDayConfig": {
      "properties": {
        "businessDays": {
          "type": "array",
          "description": "Regular business days, such as '\"monday\"'. May not be empty.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object",
      "id": "BusinessDayConfig"
    },
    "ListCollectionStatusesResponse": {
      "description": "Response message for the ListCollectionStatuses method.",
      "id": "ListCollectionStatusesResponse",
      "properties": {
        "resources": {
          "description": "The collectionstatuses listed.",
          "items": {
            "$ref": "CollectionStatus"
          },
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "MinimumOrderValueTable": {
      "id": "MinimumOrderValueTable",
      "properties": {
        "storeCodeSetWithMovs": {
          "type": "array",
          "items": {
            "$ref": "MinimumOrderValueTableStoreCodeSetWithMov"
          }
        }
      },
      "type": "object"
    },
    "ProductIssue": {
      "properties": {
        "actions": {
          "description": "A list of actionable steps that can be executed to solve the issue. An example is requesting a re-review or providing arguments when merchant disagrees with the issue. Actions that are supported in (your) third-party application can be rendered as buttons and should be available to merchant when they expand the issue.",
          "items": {
            "$ref": "Action"
          },
          "type": "array"
        },
        "impact": {
          "description": "Clarifies the severity of the issue. The summarizing message, if present, should be shown right under the title for each issue. It helps merchants to quickly understand the impact of the issue. The detailed breakdown helps the merchant to fully understand the impact of the issue. It can be rendered as dialog that opens when the merchant mouse over the summarized impact statement. Issues with different severity can be styled differently. They may use a different color or icon to signal the difference between `ERROR`, `WARNING` and `INFO`.",
          "$ref": "ProductIssueImpact"
        },
        "prerenderedOutOfCourtDisputeSettlement": {
          "type": "string",
          "description": "Pre-rendered HTML that contains a link to the external location where the ODS can be requested and instructions for how to request it. HTML elements contain CSS classes that can be used to customize the style of this snippet. Always sanitize the HTML before embedding it directly to your application. The sanitizer needs to allow basic HTML tags, such as: `div`, `span`, `p`, `a`, `ul`, `li`, `table`, `tr`, `td`. For example, you can use [DOMPurify](https://www.npmjs.com/package/dompurify). CSS classes: * `ods-section`* - wrapper around the out-of-court dispute resolution section * `ods-description`* - intro text for the out-of-court dispute resolution. It may contain multiple segments and a link. * `ods-param`* - wrapper around the header-value pair for parameters that merchant may need to provide during the ODS process. * `ods-routing-id`* - ods param for the Routing ID. * `ods-reference-id`* - ods param for the Routing ID. * `ods-param-header`* - header for the ODS parameter * `ods-param-value`* - value of the ODS parameter. This value should be rendered in a way that it is easy for merchants to identify and copy. * `segment` - section of the text, `span` inside paragraph * `segment-attribute` - section of the text that represents a product attribute, for example 'image\\_link' * `segment-literal` - section of the text that contains a special value, for example '0-1000 kg' * `segment-bold` - section of the text that should be rendered as bold * `segment-italic` - section of the text that should be rendered as italic * `tooltip` - used on paragraphs that should be rendered with a tooltip. A section of the text in such a paragraph will have a class `tooltip-text` and is intended to be shown in a mouse over dialog. If the style is not used, the `tooltip-text` section would be shown on a new line, after the main part of the text. * `tooltip-text` - marks a section of the text within a `tooltip`, that is intended to be shown in a mouse over dialog. * `tooltip-icon` - marks a section of the text within a `tooltip`, that can be replaced with a tooltip icon, for example '?' or 'i'. By default, this section contains a `br` tag, that is separating the main text and the tooltip text when the style is not used. * `tooltip-style-question` - the tooltip shows helpful information, can use the '?' as an icon. * `tooltip-style-info` - the tooltip adds additional information fitting to the context, can use the 'i' as an icon."
        },
        "title": {
          "type": "string",
          "description": "Title of the issue."
        },
        "prerenderedContent": {
          "description": "Details of the issue as a pre-rendered HTML. HTML elements contain CSS classes that can be used to customize the style of the content. Always sanitize the HTML before embedding it directly to your application. The sanitizer needs to allow basic HTML tags, such as: `div`, `span`, `p`, `a`, `ul`, `li`, `table`, `tr`, `td`. For example, you can use [DOMPurify](https://www.npmjs.com/package/dompurify). CSS classes: * `issue-detail` - top level container for the detail of the issue * `callout-banners` - section of the `issue-detail` with callout banners * `callout-banner` - single callout banner, inside `callout-banners` * `callout-banner-info` - callout with important information (default) * `callout-banner-warning` - callout with a warning * `callout-banner-error` - callout informing about an error (most severe) * `issue-content` - section of the `issue-detail`, contains multiple `content-element` * `content-element` - content element such as a list, link or paragraph, inside `issue-content` * `root-causes` - unordered list with items describing root causes of the issue, inside `issue-content` * `root-causes-intro` - intro text before the `root-causes` list, inside `issue-content` * `segment` - section of the text, `span` inside paragraph * `segment-attribute` - section of the text that represents a product attribute, for example 'image\\_link' * `segment-literal` - section of the text that contains a special value, for example '0-1000 kg' * `segment-bold` - section of the text that should be rendered as bold * `segment-italic` - section of the text that should be rendered as italic * `tooltip` - used on paragraphs that should be rendered with a tooltip. A section of the text in such a paragraph will have a class `tooltip-text` and is intended to be shown in a mouse over dialog. If the style is not used, the `tooltip-text` section would be shown on a new line, after the main part of the text. * `tooltip-text` - marks a section of the text within a `tooltip`, that is intended to be shown in a mouse over dialog. * `tooltip-icon` - marks a section of the text within a `tooltip`, that can be replaced with a tooltip icon, for example '?' or 'i'. By default, this section contains a `br` tag, that is separating the main text and the tooltip text when the style is not used. * `tooltip-style-question` - the tooltip shows helpful information, can use the '?' as an icon. * `tooltip-style-info` - the tooltip adds additional information fitting to the context, can use the 'i' as an icon. * `content-moderation` - marks the paragraph that explains how the issue was identified. * `list-intro` - marks the paragraph that contains an intro for a list. This paragraph will be always followed by a list. * `new-element` - Present for new elements added to the pre-rendered content in the future. To make sure that a new content element does not break your style, you can hide everything with this class.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "An issue affecting specific product.",
      "id": "ProductIssue"
    },
    "RenderProductIssuesRequestPayload": {
      "description": "The payload for configuring how the content should be rendered.",
      "id": "RenderProductIssuesRequestPayload",
      "properties": {
        "contentOption": {
          "type": "string",
          "description": "Optional. How the detailed content should be returned. Default option is to return the content as a pre-rendered HTML text.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Returns the detail of the issue as a pre-rendered HTML text."
          ],
          "enum": [
            "CONTENT_OPTION_UNSPECIFIED",
            "PRE_RENDERED_HTML"
          ]
        },
        "userInputActionOption": {
          "type": "string",
          "description": "Optional. How actions with user input form should be handled. If not provided, actions will be returned as links that points merchant to Merchant Center where they can request the action.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Actions that require user input are represented only as links that points merchant to Merchant Center where they can request the action. Provides easier to implement alternative to `BUILT_IN_USER_INPUT_ACTIONS`.",
            "Returns content and input form definition for each complex action. Your application needs to display this content and input form to the merchant before they can request processing of the action. To start the action, your application needs to call the `triggeraction` method."
          ],
          "enum": [
            "USER_INPUT_ACTION_RENDERING_OPTION_UNSPECIFIED",
            "REDIRECT_TO_MERCHANT_CENTER",
            "BUILT_IN_USER_INPUT_ACTIONS"
          ]
        }
      },
      "type": "object"
    },
    "PromotionPromotionStatusPromotionIssue": {
      "type": "object",
      "properties": {
        "detail": {
          "description": "Explanation of the issue.",
          "type": "string"
        },
        "code": {
          "type": "string",
          "description": "Code of the issue."
        }
      },
      "id": "PromotionPromotionStatusPromotionIssue",
      "description": "The issue associated with the promotion."
    },
    "Table": {
      "id": "Table",
      "properties": {
        "rowHeaders": {
          "description": "Headers of the table's rows. Required.",
          "$ref": "Headers"
        },
        "rows": {
          "description": "The list of rows that constitute the table. Must have the same length as `rowHeaders`. Required.",
          "items": {
            "$ref": "Row"
          },
          "type": "array"
        },
        "columnHeaders": {
          "description": "Headers of the table's columns. Optional: if not set then the table has only one dimension.",
          "$ref": "Headers"
        },
        "name": {
          "description": "Name of the table. Required for subtables, ignored for the main table.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "GmbAccounts": {
      "properties": {
        "accountId": {
          "description": "The ID of the Merchant Center account.",
          "type": "string",
          "format": "uint64"
        },
        "gmbAccounts": {
          "description": "A list of Business Profiles which are available to the merchant.",
          "items": {
            "$ref": "GmbAccountsGmbAccount"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "GmbAccounts"
    },
    "CarriersCarrier": {
      "type": "object",
      "properties": {
        "name": {
          "description": "The name of the carrier (for example, `\"UPS\"`). Always present.",
          "type": "string"
        },
        "services": {
          "type": "array",
          "description": "A list of supported services (for example, `\"ground\"`) for that carrier. Contains at least one service. This is the list of valid values for CarrierRate.carrierService.",
          "items": {
            "type": "string"
          }
        },
        "eddServices": {
          "description": "A list of services supported for EDD (Estimated Delivery Date) calculation. This is the list of valid values for WarehouseBasedDeliveryTime.carrierService.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "country": {
          "description": "The CLDR country code of the carrier (for example, \"US\"). Always present.",
          "type": "string"
        }
      },
      "id": "CarriersCarrier"
    },
    "AccountTax": {
      "id": "AccountTax",
      "description": "The tax settings of a merchant account. All methods require the admin role.",
      "type": "object",
      "properties": {
        "rules": {
          "description": "Tax rules. Updating the tax rules will enable \"US\" taxes (not reversible). Defining no rules is equivalent to not charging tax at all.",
          "items": {
            "$ref": "AccountTaxTaxRule"
          },
          "type": "array"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountTax`\"."
        },
        "accountId": {
          "description": "Required. The ID of the account to which these account tax settings belong.",
          "format": "uint64",
          "type": "string"
        }
      }
    },
    "TimeZone": {
      "id": "TimeZone",
      "description": "Represents a time zone from the [IANA Time Zone Database](https://www.iana.org/time-zones).",
      "type": "object",
      "properties": {
        "id": {
          "description": "IANA Time Zone Database time zone. For example \"America/New_York\".",
          "type": "string"
        },
        "version": {
          "description": "Optional. IANA Time Zone Database version number. For example \"2019a\".",
          "type": "string"
        }
      }
    },
    "CloudExportAdditionalProperties": {
      "type": "object",
      "properties": {
        "minValue": {
          "type": "number",
          "format": "float",
          "description": "Minimum float value of the given property. For example for a TV product 1.00."
        },
        "maxValue": {
          "format": "float",
          "type": "number",
          "description": "Maximum float value of the given property. For example for a TV product 100.00."
        },
        "propertyName": {
          "description": "Name of the given property. For example, \"Screen-Resolution\" for a TV product. Maximum string size is 256 characters.",
          "type": "string"
        },
        "floatValue": {
          "description": "Float values of the given property. For example for a TV product 1.2345. Maximum number of specified values for this field is 400. Values are stored in an arbitrary but consistent order.",
          "items": {
            "type": "number",
            "format": "float"
          },
          "type": "array"
        },
        "unitCode": {
          "type": "string",
          "description": "Unit of the given property. For example, \"Pixels\" for a TV product. Maximum string size is 256 bytes."
        },
        "textValue": {
          "description": "Text value of the given property. For example, \"8K(UHD)\" could be a text value for a TV product. Maximum number of specified values for this field is 400. Values are stored in an arbitrary but consistent order. Maximum string size is 256 characters.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "boolValue": {
          "description": "Boolean value of the given property. For example for a TV product, \"True\" or \"False\" if the screen is UHD.",
          "type": "boolean"
        },
        "intValue": {
          "description": "Integer values of the given property. For example, 1080 for a screen resolution of a TV product. Maximum number of specified values for this field is 400. Values are stored in an arbitrary but consistent order.",
          "items": {
            "format": "int64",
            "type": "string"
          },
          "type": "array"
        }
      },
      "id": "CloudExportAdditionalProperties",
      "description": "Product property for the Cloud Retail API. For example, properties for a TV product could be \"Screen-Resolution\" or \"Screen-Size\"."
    },
    "TransitTableTransitTimeRowTransitTimeValue": {
      "id": "TransitTableTransitTimeRowTransitTimeValue",
      "type": "object",
      "properties": {
        "minTransitTimeInDays": {
          "description": "Transit time range (min-max) in business days. 0 means same day delivery, 1 means next day delivery.",
          "type": "integer",
          "format": "uint32"
        },
        "maxTransitTimeInDays": {
          "description": "Must be greater than or equal to `minTransitTimeInDays`.",
          "type": "integer",
          "format": "uint32"
        }
      }
    },
    "RequestPhoneVerificationRequest": {
      "type": "object",
      "properties": {
        "phoneNumber": {
          "description": "Phone number to be verified.",
          "type": "string"
        },
        "phoneRegionCode": {
          "description": "Required. Two letter country code for the phone number, for example `CA` for Canadian numbers. See the [ISO 3166-1 alpha-2](https://wikipedia.org/wiki/ISO_3166-1_alpha-2#Officially_assigned_code_elements) officially assigned codes.",
          "type": "string"
        },
        "phoneVerificationMethod": {
          "type": "string",
          "description": "Verification method to receive verification code.",
          "enumDescriptions": [
            "Unknown method.",
            "Receive verification code by SMS.",
            "Receive verification code by phone call."
          ],
          "enum": [
            "PHONE_VERIFICATION_METHOD_UNSPECIFIED",
            "SMS",
            "PHONE_CALL"
          ]
        },
        "languageCode": {
          "description": "Language code [IETF BCP 47 syntax](https://tools.ietf.org/html/bcp47) (for example, en-US). Language code is used to provide localized `SMS` and `PHONE_CALL`. Default language used is en-US if not provided.",
          "type": "string"
        }
      },
      "id": "RequestPhoneVerificationRequest",
      "description": "Request message for the RequestPhoneVerification method."
    },
    "AccountCustomerService": {
      "id": "AccountCustomerService",
      "properties": {
        "url": {
          "type": "string",
          "description": "Customer service URL."
        },
        "email": {
          "description": "Customer service email.",
          "type": "string"
        },
        "phoneNumber": {
          "type": "string",
          "description": "Customer service phone number."
        }
      },
      "type": "object"
    },
    "PostalCodeRange": {
      "type": "object",
      "properties": {
        "postalCodeRangeBegin": {
          "type": "string",
          "description": "A postal code or a pattern of the form `prefix*` denoting the inclusive lower bound of the range defining the area. Examples values: `\"94108\"`, `\"9410*\"`, `\"9*\"`. Required."
        },
        "postalCodeRangeEnd": {
          "description": "A postal code or a pattern of the form `prefix*` denoting the inclusive upper bound of the range defining the area. It must have the same length as `postalCodeRangeBegin`: if `postalCodeRangeBegin` is a postal code then `postalCodeRangeEnd` must be a postal code too; if `postalCodeRangeBegin` is a pattern then `postalCodeRangeEnd` must be a pattern with the same prefix length. Optional: if not set, then the area is defined as being all the postal codes matching `postalCodeRangeBegin`.",
          "type": "string"
        }
      },
      "id": "PostalCodeRange"
    },
    "AccountstatusesCustomBatchResponse": {
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountstatusesCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "AccountstatusesCustomBatchResponseEntry"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "AccountstatusesCustomBatchResponse"
    },
    "DatafeedstatusesCustomBatchResponseEntry": {
      "id": "DatafeedstatusesCustomBatchResponseEntry",
      "description": "A batch entry encoding a single non-batch datafeedstatuses response.",
      "type": "object",
      "properties": {
        "datafeedStatus": {
          "description": "The requested data feed status. Defined if and only if the request was successful.",
          "$ref": "DatafeedStatus"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "The ID of the request entry this entry responds to."
        }
      }
    },
    "ShippingsettingsCustomBatchRequest": {
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "ShippingsettingsCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "ShippingsettingsCustomBatchRequest"
    },
    "ProductViewItemIssue": {
      "id": "ProductViewItemIssue",
      "description": "Item issue associated with the product.",
      "type": "object",
      "properties": {
        "issueType": {
          "description": "Item issue type.",
          "$ref": "ProductViewItemIssueItemIssueType"
        },
        "severity": {
          "description": "Item issue severity.",
          "$ref": "ProductViewItemIssueItemIssueSeverity"
        },
        "resolution": {
          "description": "Item issue resolution.",
          "enumDescriptions": [
            "Unknown resolution type.",
            "The merchant has to fix the issue.",
            "The issue will be resolved automatically (for example, image crawl), or Google review. No merchant action is required now. Resolution might lead to another issue (for example, if crawl fails)."
          ],
          "enum": [
            "UNKNOWN",
            "MERCHANT_ACTION",
            "PENDING_PROCESSING"
          ],
          "type": "string"
        }
      }
    },
    "LiaOmnichannelExperience": {
      "type": "object",
      "properties": {
        "country": {
          "description": "The CLDR country code (for example, \"US\").",
          "type": "string"
        },
        "lsfType": {
          "type": "string",
          "description": "The Local Store Front (LSF) type for this country. Acceptable values are: - \"`ghlsf`\" (Google-Hosted Local Store Front) - \"`mhlsfBasic`\" (Merchant-Hosted Local Store Front Basic) - \"`mhlsfFull`\" (Merchant-Hosted Local Store Front Full) More details about these types can be found here."
        },
        "pickupTypes": {
          "description": "The Pickup types for this country. Acceptable values are: - \"`pickupToday`\" - \"`pickupLater`\" ",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "id": "LiaOmnichannelExperience",
      "description": "Omnichannel experience details."
    },
    "ListCollectionsResponse": {
      "id": "ListCollectionsResponse",
      "description": "Response message for the ListCollections method.",
      "type": "object",
      "properties": {
        "resources": {
          "description": "The collections listed.",
          "items": {
            "$ref": "Collection"
          },
          "type": "array"
        },
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        }
      }
    },
    "ProductCluster": {
      "id": "ProductCluster",
      "description": "Product cluster fields. A product cluster is a grouping for different offers that represent the same product. Values are only set for fields requested explicitly in the request's search query.",
      "type": "object",
      "properties": {
        "categoryL4": {
          "type": "string",
          "description": "Product category (4th level) of the product cluster, represented in Google's product taxonomy."
        },
        "inventoryStatus": {
          "type": "string",
          "description": "Tells whether the product cluster is `IN_STOCK` in your product feed across multiple countries, `OUT_OF_STOCK` in your product feed, or `NOT_IN_INVENTORY` at all. The field doesn't take the Best Sellers report country filter into account.",
          "enumDescriptions": [
            "Inventory status is unknown.",
            "Merchant has a product for this product cluster or brand in stock.",
            "Merchant has a product for this product cluster or brand in inventory but it is currently out of stock.",
            "Merchant does not have a product for this product cluster or brand in inventory."
          ],
          "enum": [
            "INVENTORY_STATUS_UNSPECIFIED",
            "IN_STOCK",
            "OUT_OF_STOCK",
            "NOT_IN_INVENTORY"
          ]
        },
        "categoryL2": {
          "description": "Product category (2nd level) of the product cluster, represented in Google's product taxonomy.",
          "type": "string"
        },
        "categoryL5": {
          "type": "string",
          "description": "Product category (5th level) of the product cluster, represented in Google's product taxonomy."
        },
        "variantGtins": {
          "description": "GTINs of example variants of the product cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "title": {
          "description": "Title of the product cluster.",
          "type": "string"
        },
        "brandInventoryStatus": {
          "type": "string",
          "description": "Tells if there is at least one product of the brand currently `IN_STOCK` in your product feed across multiple countries, all products are `OUT_OF_STOCK` in your product feed, or `NOT_IN_INVENTORY`. The field doesn't take the Best Sellers report country filter into account.",
          "enumDescriptions": [
            "Inventory status is unknown.",
            "Merchant has a product for this product cluster or brand in stock.",
            "Merchant has a product for this product cluster or brand in inventory but it is currently out of stock.",
            "Merchant does not have a product for this product cluster or brand in inventory."
          ],
          "enum": [
            "INVENTORY_STATUS_UNSPECIFIED",
            "IN_STOCK",
            "OUT_OF_STOCK",
            "NOT_IN_INVENTORY"
          ]
        },
        "brand": {
          "description": "Brand of the product cluster.",
          "type": "string"
        },
        "categoryL1": {
          "description": "Product category (1st level) of the product cluster, represented in Google's product taxonomy.",
          "type": "string"
        },
        "categoryL3": {
          "description": "Product category (3rd level) of the product cluster, represented in Google's product taxonomy.",
          "type": "string"
        }
      }
    },
    "LiasettingsListPosDataProvidersResponse": {
      "type": "object",
      "properties": {
        "posDataProviders": {
          "description": "The list of POS data providers for each eligible country",
          "items": {
            "$ref": "PosDataProviders"
          },
          "type": "array"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsListPosDataProvidersResponse`\"."
        }
      },
      "id": "LiasettingsListPosDataProvidersResponse"
    },
    "ProductViewItemIssueItemIssueType": {
      "description": "Type of the item issue.",
      "id": "ProductViewItemIssueItemIssueType",
      "properties": {
        "code": {
          "type": "string",
          "description": "Error code of the issue."
        },
        "canonicalAttribute": {
          "description": "Canonical attribute name for attribute-specific issues.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "GenerateRecommendationsResponse": {
      "properties": {
        "responseToken": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Response token is a string created for each `GenerateRecommendationsResponse`. This token doesn't expire, and is globally unique. This token must be used when reporting interactions for recommendations."
        },
        "recommendations": {
          "description": "Recommendations generated for a request.",
          "items": {
            "$ref": "Recommendation"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Response containing generated recommendations.",
      "id": "GenerateRecommendationsResponse"
    },
    "AccountstatusesCustomBatchRequest": {
      "id": "AccountstatusesCustomBatchRequest",
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "AccountstatusesCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "type": "object"
    },
    "InputField": {
      "description": "Input field that needs to be available to the merchant. If the field is marked as required, then a value needs to be provided for a successful processing of the request.",
      "id": "InputField",
      "properties": {
        "textInput": {
          "description": "Input field to provide text information. Corresponds to the [html input type=text](https://www.w3.org/TR/2012/WD-html-markup-20121025/input.text.html#input.text) or [html textarea](https://www.w3.org/TR/2012/WD-html-markup-20121025/textarea.html#textarea).",
          "$ref": "InputFieldTextInput"
        },
        "choiceInput": {
          "description": "Input field to select one of the offered choices. Corresponds to the [html input type=radio](https://www.w3.org/TR/2012/WD-html-markup-20121025/input.radio.html#input.radio).",
          "$ref": "InputFieldChoiceInput"
        },
        "required": {
          "description": "Whether the field is required. The action button needs to stay disabled till values for all required fields are provided.",
          "type": "boolean"
        },
        "id": {
          "description": "Not for display but need to be sent back for the given input field.",
          "type": "string"
        },
        "label": {
          "description": "Input field label. There may be more information to be shown in a tooltip.",
          "$ref": "TextWithTooltip"
        },
        "checkboxInput": {
          "description": "Input field to provide a boolean value. Corresponds to the [html input type=checkbox](https://www.w3.org/TR/2012/WD-html-markup-20121025/input.checkbox.html#input.checkbox).",
          "$ref": "InputFieldCheckboxInput"
        }
      },
      "type": "object"
    },
    "Callout": {
      "description": "An important message that should be highlighted. Usually displayed as a banner.",
      "id": "Callout",
      "properties": {
        "fullMessage": {
          "description": "A full message that needs to be shown to the merchant.",
          "$ref": "TextWithTooltip"
        },
        "styleHint": {
          "type": "string",
          "description": "Can be used to render messages with different severity in different styles. Snippets off all types contain important information that should be displayed to merchants.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "The most important type of information highlighting problems, like an unsuccessful outcome of previously requested actions.",
            "Information warning about pending problems, risks or deadlines.",
            "Default severity for important information like pending status of previously requested action or cooldown for re-review."
          ],
          "enum": [
            "CALLOUT_STYLE_HINT_UNSPECIFIED",
            "ERROR",
            "WARNING",
            "INFO"
          ]
        }
      },
      "type": "object"
    },
    "OrderTrackingSignalShippingInfo": {
      "properties": {
        "latestDeliveryPromiseTime": {
          "description": "The latest delivery promised time. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: tracking_id or carrier_name.",
          "$ref": "DateTime"
        },
        "originPostalCode": {
          "type": "string",
          "description": "The origin postal code, as a continuous string without spaces or dashes, e.g. \"95016\". This field will be anonymized in returned OrderTrackingSignal creation response."
        },
        "trackingId": {
          "type": "string",
          "description": "The tracking ID of the shipment. This field is required if one of the following fields is absent: earliest_delivery_promise_time, latest_delivery_promise_time, and actual_delivery_time."
        },
        "actualDeliveryTime": {
          "description": "The time when the shipment was actually delivered. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: tracking_id or carrier_name.",
          "$ref": "DateTime"
        },
        "earliestDeliveryPromiseTime": {
          "description": "The earliest delivery promised time. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: tracking_id or carrier_name.",
          "$ref": "DateTime"
        },
        "originRegionCode": {
          "type": "string",
          "description": "The [CLDR territory code] (http://www.unicode.org/repos/cldr/tags/latest/common/main/en.xml) for the shipping origin."
        },
        "shipmentId": {
          "description": "Required. The shipment ID. This field will be hashed in returned OrderTrackingSignal creation response.",
          "type": "string"
        },
        "carrierName": {
          "type": "string",
          "description": "The name of the shipping carrier for the delivery. This field is required if one of the following fields is absent: earliest_delivery_promise_time, latest_delivery_promise_time, and actual_delivery_time."
        },
        "carrierServiceName": {
          "description": "The service type for fulfillment, e.g., GROUND, FIRST_CLASS, etc.",
          "type": "string"
        },
        "shippingStatus": {
          "description": "The status of the shipment.",
          "enumDescriptions": [
            "The shipping status is not known to merchant.",
            "All items are shipped.",
            "The shipment is already delivered."
          ],
          "enum": [
            "SHIPPING_STATE_UNSPECIFIED",
            "SHIPPED",
            "DELIVERED"
          ],
          "type": "string"
        },
        "shippedTime": {
          "description": "The time when the shipment was shipped. Include the year and timezone string, if available.",
          "$ref": "DateTime"
        }
      },
      "type": "object",
      "description": "The shipping information for the order.",
      "id": "OrderTrackingSignalShippingInfo"
    },
    "ServiceStoreConfigCutoffConfig": {
      "properties": {
        "storeCloseOffsetHours": {
          "format": "int64",
          "type": "string",
          "description": "Represents cutoff time as the number of hours before store closing. Mutually exclusive with other fields (hour and minute)."
        },
        "noDeliveryPostCutoff": {
          "description": "Merchants can opt-out of showing n+1 day local delivery when they have a shipping service configured to n day local delivery. For example, if the shipping service defines same-day delivery, and it's past the cut-off, setting this field to `true` results in the calculated shipping service rate returning `NO_DELIVERY_POST_CUTOFF`. In the same example, setting this field to `false` results in the calculated shipping time being one day. This is only for local delivery.",
          "type": "boolean"
        },
        "localCutoffTime": {
          "description": "Time in hours and minutes in the local timezone when local delivery ends.",
          "$ref": "ServiceStoreConfigCutoffConfigLocalCutoffTime"
        }
      },
      "type": "object",
      "description": "Time local delivery ends for the day based on the local timezone of the store. `local_cutoff_time` and `store_close_offset_hours` are mutually exclusive.",
      "id": "ServiceStoreConfigCutoffConfig"
    },
    "AttributionSettingsConversionType": {
      "type": "object",
      "properties": {
        "includeInReporting": {
          "readOnly": true,
          "description": "Output only. Option indicating if the type should be included in Merchant Center reporting.",
          "type": "boolean"
        },
        "name": {
          "readOnly": true,
          "description": "Output only. Conversion event name, as it'll be reported by the client.",
          "type": "string"
        }
      },
      "id": "AttributionSettingsConversionType",
      "description": "Message representing a types of conversion events"
    },
    "BuiltInUserInputAction": {
      "type": "object",
      "properties": {
        "actionContext": {
          "description": "Internal details. Not for display but need to be sent back when triggering the action.",
          "type": "string"
        },
        "flows": {
          "type": "array",
          "description": "Actions may provide multiple different flows. Merchant selects one that fits best to their intent. Selecting the flow is the first step in user's interaction with the action. It affects what input fields will be available and required and also how the request will be processed.",
          "items": {
            "$ref": "ActionFlow"
          }
        }
      },
      "id": "BuiltInUserInputAction",
      "description": "Action that is implemented and performed in (your) third-party application. The application needs to show an additional content and input form to the merchant. They can start the action only when they provided all required inputs. The application will request processing of the action by calling the [triggeraction method](https://developers.google.com/shopping-content/reference/rest/v2.1/merchantsupport/triggeraction)."
    },
    "ProductUnitPricingBaseMeasure": {
      "id": "ProductUnitPricingBaseMeasure",
      "properties": {
        "value": {
          "type": "string",
          "format": "int64",
          "description": "The denominator of the unit price."
        },
        "unit": {
          "description": "The unit of the denominator.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "LiaInventorySettings": {
      "id": "LiaInventorySettings",
      "type": "object",
      "properties": {
        "status": {
          "description": "The status of the inventory verification process. Acceptable values are: - \"`active`\" - \"`inactive`\" - \"`pending`\" ",
          "type": "string"
        },
        "inventoryVerificationContactName": {
          "type": "string",
          "description": "The name of the contact for the inventory verification process."
        },
        "inventoryVerificationContactEmail": {
          "description": "The email of the contact for the inventory verification process.",
          "type": "string"
        },
        "inventoryVerificationContactStatus": {
          "type": "string",
          "description": "The status of the verification contact. Acceptable values are: - \"`active`\" - \"`inactive`\" - \"`pending`\" "
        }
      }
    },
    "Action": {
      "description": "An actionable step that can be executed to solve the issue.",
      "id": "Action",
      "properties": {
        "externalAction": {
          "description": "Action that is implemented and performed outside of (your) third-party application. The application needs to redirect the merchant to the external location where they can perform the action.",
          "$ref": "ExternalAction"
        },
        "builtinUserInputAction": {
          "description": "Action implemented and performed in (your) third-party application. The application needs to show an additional content and input form to the merchant as specified for given action. They can trigger the action only when they provided all required inputs.",
          "$ref": "BuiltInUserInputAction"
        },
        "buttonLabel": {
          "type": "string",
          "description": "Label of the action button."
        },
        "isAvailable": {
          "description": "Controlling whether the button is active or disabled. The value is 'false' when the action was already requested or is not available. If the action is not available then a reason will be present. If (your) third-party application shows a disabled button for action that is not available, then it should also show reasons.",
          "type": "boolean"
        },
        "reasons": {
          "description": "List of reasons why the action is not available. The list of reasons is empty if the action is available. If there is only one reason, it can be displayed next to the disabled button. If there are more reasons, all of them should be displayed, for example in a pop-up dialog.",
          "items": {
            "$ref": "ActionReason"
          },
          "type": "array"
        },
        "builtinSimpleAction": {
          "description": "Action implemented and performed in (your) third-party application. The application should point the merchant to the place, where they can access the corresponding functionality or provide instructions, if the specific functionality is not available.",
          "$ref": "BuiltInSimpleAction"
        }
      },
      "type": "object"
    },
    "ServiceStoreConfigCutoffConfigLocalCutoffTime": {
      "type": "object",
      "properties": {
        "hour": {
          "format": "int64",
          "type": "string",
          "description": "Hour local delivery orders must be placed by to process the same day."
        },
        "minute": {
          "format": "int64",
          "type": "string",
          "description": "Minute local delivery orders must be placed by to process the same day."
        }
      },
      "id": "ServiceStoreConfigCutoffConfigLocalCutoffTime",
      "description": "Time in hours and minutes in the local timezone when local delivery ends."
    },
    "LiaPosDataProvider": {
      "properties": {
        "posDataProviderId": {
          "description": "The ID of the POS data provider.",
          "type": "string",
          "format": "uint64"
        },
        "posExternalAccountId": {
          "type": "string",
          "description": "The account ID by which this merchant is known to the POS data provider."
        }
      },
      "type": "object",
      "id": "LiaPosDataProvider"
    },
    "AccountShippingImprovements": {
      "description": "Not available for MCAs [accounts](https://support.google.com/merchants/answer/188487). By turning on [automatic shipping improvements](https://support.google.com/merchants/answer/10027038), you are allowing Google to improve the accuracy of your delivery times shown to shoppers using Google. More accurate delivery times, especially when faster, typically lead to better conversion rates. Google will improve your estimated delivery times based on various factors: * Delivery address of an order * Current handling time and shipping time settings * Estimated weekdays or business days * Parcel tracking data",
      "id": "AccountShippingImprovements",
      "properties": {
        "allowShippingImprovements": {
          "description": "Enables automatic shipping improvements.",
          "type": "boolean"
        }
      },
      "type": "object"
    },
    "Address": {
      "type": "object",
      "properties": {
        "country": {
          "type": "string",
          "description": "Required. [CLDR country code](https://github.com/unicode-org/cldr/blob/latest/common/main/en.xml) (for example, \"US\")."
        },
        "administrativeArea": {
          "type": "string",
          "description": "Required. Top-level administrative subdivision of the country. For example, a state like California (\"CA\") or a province like Quebec (\"QC\")."
        },
        "postalCode": {
          "description": "Required. Postal code or ZIP (for example, \"94043\").",
          "type": "string"
        },
        "city": {
          "description": "Required. City, town or commune. May also include dependent localities or sublocalities (for example, neighborhoods or suburbs).",
          "type": "string"
        },
        "streetAddress": {
          "type": "string",
          "description": "Street-level part of the address. Use `\\n` to add a second line."
        }
      },
      "id": "Address"
    },
    "PosInventoryRequest": {
      "id": "PosInventoryRequest",
      "properties": {
        "targetCountry": {
          "description": "Required. The CLDR territory code for the item.",
          "type": "string"
        },
        "gtin": {
          "description": "Global Trade Item Number.",
          "type": "string"
        },
        "pickupMethod": {
          "description": "Optional. Supported pickup method for this offer. Unless the value is \"not supported\", this field must be submitted together with `pickupSla`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342).",
          "type": "string"
        },
        "contentLanguage": {
          "type": "string",
          "description": "Required. The two-letter ISO 639-1 language code for the item."
        },
        "storeCode": {
          "description": "Required. The identifier of the merchant's store. Either a `storeCode` inserted through the API or the code of the store in a Business Profile.",
          "type": "string"
        },
        "itemId": {
          "description": "Required. A unique identifier for the item.",
          "type": "string"
        },
        "timestamp": {
          "type": "string",
          "description": "Required. The inventory timestamp, in ISO 8601 format."
        },
        "price": {
          "description": "Required. The current price of the item.",
          "$ref": "Price"
        },
        "quantity": {
          "description": "Required. The available quantity of the item.",
          "type": "string",
          "format": "int64"
        },
        "pickupSla": {
          "description": "Optional. Expected date that an order will be ready for pickup relative to the order date. Must be submitted together with `pickupMethod`. For accepted attribute values, see the [local product inventory feed specification](https://support.google.com/merchants/answer/3061342).",
          "type": "string"
        }
      },
      "type": "object"
    },
    "AccountsUpdateLabelsResponse": {
      "id": "AccountsUpdateLabelsResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsUpdateLabelsResponse`\".",
          "type": "string"
        }
      },
      "type": "object"
    },
    "CarrierRate": {
      "type": "object",
      "properties": {
        "name": {
          "type": "string",
          "description": "Name of the carrier rate. Must be unique per rate group. Required."
        },
        "flatAdjustment": {
          "description": "Additive shipping rate modifier. Can be negative. For example `{ \"value\": \"1\", \"currency\" : \"USD\" }` adds $1 to the rate, `{ \"value\": \"-3\", \"currency\" : \"USD\" }` removes $3 from the rate. Optional.",
          "$ref": "Price"
        },
        "carrierName": {
          "description": "Carrier service, such as `\"UPS\"` or `\"Fedex\"`. The list of supported carriers can be retrieved through the `getSupportedCarriers` method. Required.",
          "type": "string"
        },
        "originPostalCode": {
          "type": "string",
          "description": "Shipping origin for this carrier rate. Required."
        },
        "carrierService": {
          "type": "string",
          "description": "Carrier service, such as `\"ground\"` or `\"2 days\"`. The list of supported services for a carrier can be retrieved through the `getSupportedCarriers` method. Required."
        },
        "percentageAdjustment": {
          "description": "Multiplicative shipping rate modifier as a number in decimal notation. Can be negative. For example `\"5.4\"` increases the rate by 5.4%, `\"-3\"` decreases the rate by 3%. Optional.",
          "type": "string"
        }
      },
      "id": "CarrierRate"
    },
    "Price": {
      "id": "Price",
      "properties": {
        "value": {
          "type": "string",
          "description": "The price represented as a number."
        },
        "currency": {
          "type": "string",
          "description": "The currency of the price."
        }
      },
      "type": "object"
    },
    "AccountAddress": {
      "properties": {
        "streetAddress": {
          "description": "Street-level part of the address. Use `\\n` to add a second line.",
          "type": "string"
        },
        "postalCode": {
          "type": "string",
          "description": "Postal code or ZIP (for example, \"94043\")."
        },
        "locality": {
          "type": "string",
          "description": "City, town or commune. May also include dependent localities or sublocalities (for example, neighborhoods or suburbs)."
        },
        "region": {
          "description": "Top-level administrative subdivision of the country. For example, a state like California (\"CA\") or a province like Quebec (\"QC\").",
          "type": "string"
        },
        "country": {
          "type": "string",
          "description": "CLDR country code (for example, \"US\"). All MCA sub-accounts inherit the country of their parent MCA by default, however the country can be updated for individual sub-accounts."
        }
      },
      "type": "object",
      "id": "AccountAddress"
    },
    "LiaAboutPageSettings": {
      "properties": {
        "status": {
          "description": "The status of the verification process for the About page. Supported values are: - \"`active`\" - \"`inactive`\" - \"`pending`\" ",
          "type": "string"
        },
        "url": {
          "description": "The URL for the About page.",
          "type": "string"
        }
      },
      "type": "object",
      "id": "LiaAboutPageSettings"
    },
    "PriceAmount": {
      "properties": {
        "value": {
          "description": "The price represented as a number.",
          "type": "string"
        },
        "currency": {
          "description": "The currency of the price.",
          "type": "string"
        }
      },
      "type": "object",
      "description": "The price represented as a number and currency.",
      "id": "PriceAmount"
    },
    "AttributionSettings": {
      "id": "AttributionSettings",
      "description": "Represents attribution settings for conversion sources receiving pre-attribution data.",
      "type": "object",
      "properties": {
        "attributionModel": {
          "enumDescriptions": [
            "",
            "Cross-channel Last Click model.",
            "Ads-preferred Last Click model.",
            "Cross-channel Data Driven model.",
            "Cross-channel First Click model.",
            "Cross-channel Linear model.",
            "Cross-channel Position Based model.",
            "Cross-channel Time Decay model."
          ],
          "enum": [
            "ATTRIBUTION_MODEL_UNSPECIFIED",
            "CROSS_CHANNEL_LAST_CLICK",
            "ADS_PREFERRED_LAST_CLICK",
            "CROSS_CHANNEL_DATA_DRIVEN",
            "CROSS_CHANNEL_FIRST_CLICK",
            "CROSS_CHANNEL_LINEAR",
            "CROSS_CHANNEL_POSITION_BASED",
            "CROSS_CHANNEL_TIME_DECAY"
          ],
          "type": "string"
        },
        "attributionLookbackWindowInDays": {
          "description": "Required. Lookback windows (in days) used for attribution in this source. Supported values are 7, 30, 40.",
          "type": "integer",
          "format": "int32"
        },
        "conversionType": {
          "type": "array",
          "description": "Immutable. Unordered list. List of different conversion types a conversion event can be classified as. A standard \"purchase\" type will be automatically created if this list is empty at creation time.",
          "items": {
            "$ref": "AttributionSettingsConversionType"
          }
        }
      }
    },
    "PosStore": {
      "type": "object",
      "properties": {
        "storeCode": {
          "type": "string",
          "description": "Required. A store identifier that is unique for the given merchant."
        },
        "storeName": {
          "description": "The merchant or store name.",
          "type": "string"
        },
        "gcidCategory": {
          "description": "The business type of the store.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posStore`\"",
          "type": "string"
        },
        "matchingStatusHint": {
          "description": "Output only. The hint of why the matching has failed. This is only set when matching_status=failed. Possible values are: - \"`linked-store-not-found`\": There aren't any Google Business Profile stores available for matching. Connect your Merchant Center account with the Google Business Profile account. Or add a new Google Business Profile store corresponding to the POS store. - \"`store-match-not-found`\": The provided POS store couldn't be matched to any of the connected Google Business Profile stores. Merchant Center account is connected correctly and stores are available on Google Business Profile, but POS store location address does not match with Google Business Profile stores' addresses. Update POS store address or Google Business Profile store address to match correctly. - \"`store-match-unverified`\": The provided POS store couldn't be matched to any of the connected Google Business Profile stores, as the matched Google Business Profile store is unverified. Go through the Google Business Profile verification process to match correctly. ",
          "readOnly": true,
          "type": "string"
        },
        "storeAddress": {
          "description": "Required. The street address of the store.",
          "type": "string"
        },
        "phoneNumber": {
          "type": "string",
          "description": "The store phone number."
        },
        "placeId": {
          "type": "string",
          "description": "The Google Place Id of the store location."
        },
        "matchingStatus": {
          "readOnly": true,
          "description": "Output only. The matching status of POS store and Google Business Profile store. Possible values are: - \"`matched`\": The POS store is successfully matched with the Google Business Profile store. - \"`failed`\": The POS store is not matched with the Google Business Profile store. See matching_status_hint for further details. Note that there is up to 48 hours propagation delay for changes in Merchant Center (e.g. creation of new account, accounts linking) and Google Business Profile (e.g. store address update) which may affect the matching status. In such cases, after a delay call [pos.list](https://developers.google.com/shopping-content/reference/rest/v2.1/pos/list) to retrieve the updated matching status. ",
          "type": "string"
        },
        "websiteUrl": {
          "type": "string",
          "description": "The website url for the store or merchant."
        }
      },
      "id": "PosStore",
      "description": "Store resource."
    },
    "LinkService": {
      "id": "LinkService",
      "properties": {
        "service": {
          "type": "string",
          "description": "Service provided to or by the linked account. Acceptable values are: - \"`shoppingActionsOrderManagement`\" - \"`shoppingActionsProductManagement`\" - \"`shoppingAdsProductManagement`\" - \"`paymentProcessing`\" "
        },
        "status": {
          "description": "Status of the link Acceptable values are: - \"`active`\" - \"`inactive`\" - \"`pending`\" ",
          "type": "string"
        }
      },
      "type": "object"
    },
    "RenderAccountIssuesRequestPayload": {
      "description": "The payload for configuring how the content should be rendered.",
      "id": "RenderAccountIssuesRequestPayload",
      "properties": {
        "contentOption": {
          "description": "Optional. How the detailed content should be returned. Default option is to return the content as a pre-rendered HTML text.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Returns the detail of the issue as a pre-rendered HTML text."
          ],
          "enum": [
            "CONTENT_OPTION_UNSPECIFIED",
            "PRE_RENDERED_HTML"
          ],
          "type": "string"
        },
        "userInputActionOption": {
          "type": "string",
          "description": "Optional. How actions with user input form should be handled. If not provided, actions will be returned as links that points merchant to Merchant Center where they can request the action.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Actions that require user input are represented only as links that points merchant to Merchant Center where they can request the action. Provides easier to implement alternative to `BUILT_IN_USER_INPUT_ACTIONS`.",
            "Returns content and input form definition for each complex action. Your application needs to display this content and input form to the merchant before they can request processing of the action. To start the action, your application needs to call the `triggeraction` method."
          ],
          "enum": [
            "USER_INPUT_ACTION_RENDERING_OPTION_UNSPECIFIED",
            "REDIRECT_TO_MERCHANT_CENTER",
            "BUILT_IN_USER_INPUT_ACTIONS"
          ]
        }
      },
      "type": "object"
    },
    "LiaSettings": {
      "type": "object",
      "properties": {
        "accountId": {
          "description": "The ID of the account to which these LIA settings belong. Ignored upon update, always present in get request responses.",
          "type": "string",
          "format": "uint64"
        },
        "countrySettings": {
          "type": "array",
          "description": "The LIA settings for each country.",
          "items": {
            "$ref": "LiaCountrySettings"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liaSettings`\""
        }
      },
      "id": "LiaSettings",
      "description": "Local Inventory ads (LIA) settings. All methods except listposdataproviders require the admin role."
    },
    "AccountstatusesCustomBatchRequestEntry": {
      "description": "A batch entry encoding a single non-batch accountstatuses request.",
      "id": "AccountstatusesCustomBatchRequestEntry",
      "properties": {
        "method": {
          "description": "The method of the batch entry. Acceptable values are: - \"`get`\" ",
          "type": "string"
        },
        "destinations": {
          "type": "array",
          "description": "If set, only issues for the specified destinations are returned, otherwise only issues for the Shopping destination.",
          "items": {
            "type": "string"
          }
        },
        "accountId": {
          "description": "The ID of the (sub-)account whose status to get.",
          "type": "string",
          "format": "uint64"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "An entry ID, unique within the batch request."
        },
        "merchantId": {
          "description": "The ID of the managing account.",
          "type": "string",
          "format": "uint64"
        }
      },
      "type": "object"
    },
    "ListMethodQuotasResponse": {
      "description": "Response message for the ListMethodQuotas method.",
      "id": "ListMethodQuotasResponse",
      "properties": {
        "methodQuotas": {
          "type": "array",
          "description": "The current quota usage and limits per each method.",
          "items": {
            "$ref": "MethodQuota"
          }
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "LocalinventoryCustomBatchRequest": {
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "LocalinventoryCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "LocalinventoryCustomBatchRequest"
    },
    "PosDataProviders": {
      "properties": {
        "country": {
          "description": "Country code.",
          "type": "string"
        },
        "posDataProviders": {
          "type": "array",
          "description": "A list of POS data providers.",
          "items": {
            "$ref": "PosDataProvidersPosDataProvider"
          }
        }
      },
      "type": "object",
      "id": "PosDataProviders"
    },
    "ProductTax": {
      "id": "ProductTax",
      "properties": {
        "rate": {
          "description": "The percentage of tax rate that applies to the item price.",
          "format": "double",
          "type": "number"
        },
        "taxShip": {
          "description": "Should be set to true if tax is charged on shipping.",
          "type": "boolean"
        },
        "locationId": {
          "description": "The numeric ID of a location that the tax rate applies to as defined in the Google Ads API.",
          "format": "int64",
          "type": "string"
        },
        "postalCode": {
          "type": "string",
          "description": "The postal code range that the tax rate applies to, represented by a ZIP code, a ZIP code prefix using * wildcard, a range between two ZIP codes or two ZIP code prefixes of equal length. Examples: 94114, 94*, 94002-95460, 94*-95*."
        },
        "country": {
          "description": "The country within which the item is taxed, specified as a CLDR territory code.",
          "type": "string"
        },
        "region": {
          "type": "string",
          "description": "The geographic region to which the tax rate applies."
        }
      },
      "type": "object"
    },
    "AccountImageImprovementsSettings": {
      "description": "Settings for the Automatic Image Improvements.",
      "id": "AccountImageImprovementsSettings",
      "properties": {
        "allowAutomaticImageImprovements": {
          "description": "Enables automatic image improvements.",
          "type": "boolean"
        }
      },
      "type": "object"
    },
    "CollectionStatusItemLevelIssue": {
      "properties": {
        "description": {
          "type": "string",
          "description": "A short issue description in English."
        },
        "code": {
          "description": "The error code of the issue.",
          "type": "string"
        },
        "detail": {
          "type": "string",
          "description": "A detailed issue description in English."
        },
        "servability": {
          "type": "string",
          "description": "How this issue affects the serving of the collection."
        },
        "destination": {
          "description": "The destination the issue applies to.",
          "type": "string"
        },
        "documentation": {
          "description": "The URL of a web page to help with resolving this issue.",
          "type": "string"
        },
        "attributeName": {
          "type": "string",
          "description": "The attribute's name, if the issue is caused by a single attribute."
        },
        "resolution": {
          "description": "Whether the issue can be resolved by the merchant.",
          "type": "string"
        },
        "applicableCountries": {
          "description": "Country codes (ISO 3166-1 alpha-2) where issue applies to the offer.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Issue associated with the collection.",
      "id": "CollectionStatusItemLevelIssue"
    },
    "WarehouseBasedDeliveryTime": {
      "type": "object",
      "properties": {
        "warehouseName": {
          "description": "The name of the warehouse. Warehouse name need to be matched with name. If warehouseName is set, the below fields will be ignored. The warehouse info will be read from warehouse.",
          "type": "string"
        },
        "originCountry": {
          "description": "Shipping origin's country represented as a [CLDR territory code](https://github.com/unicode-org/cldr/blob/latest/common/main/en.xml).",
          "type": "string"
        },
        "originCity": {
          "type": "string",
          "description": "Shipping origin's city."
        },
        "originPostalCode": {
          "type": "string",
          "description": "Shipping origin."
        },
        "carrier": {
          "description": "Required. Carrier, such as `\"UPS\"` or `\"Fedex\"`. The list of supported carriers can be retrieved through the `listSupportedCarriers` method.",
          "type": "string"
        },
        "originStreetAddress": {
          "type": "string",
          "description": "Shipping origin's street address."
        },
        "carrierService": {
          "type": "string",
          "description": "Required. Carrier service, such as `\"ground\"` or `\"2 days\"`. The list of supported services for a carrier can be retrieved through the `listSupportedCarriers` method. The name of the service must be in the eddSupportedServices list."
        },
        "originAdministrativeArea": {
          "description": "Shipping origin's state.",
          "type": "string"
        }
      },
      "id": "WarehouseBasedDeliveryTime"
    },
    "ListAccountLabelsResponse": {
      "description": "Response message for the `ListAccountLabels` method.",
      "id": "ListAccountLabelsResponse",
      "properties": {
        "accountLabels": {
          "type": "array",
          "description": "The labels from the specified account.",
          "items": {
            "$ref": "AccountLabel"
          }
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "ProductSubscriptionCost": {
      "properties": {
        "period": {
          "type": "string",
          "description": "The type of subscription period. - \"`month`\" - \"`year`\" "
        },
        "periodLength": {
          "description": "The number of subscription periods the buyer has to pay.",
          "type": "string",
          "format": "int64"
        },
        "amount": {
          "description": "The amount the buyer has to pay per subscription period.",
          "$ref": "Price"
        }
      },
      "type": "object",
      "id": "ProductSubscriptionCost"
    },
    "PosCustomBatchRequest": {
      "properties": {
        "entries": {
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "PosCustomBatchRequestEntry"
          },
          "type": "array"
        }
      },
      "type": "object",
      "id": "PosCustomBatchRequest"
    },
    "TransitTable": {
      "id": "TransitTable",
      "properties": {
        "rows": {
          "items": {
            "$ref": "TransitTableTransitTimeRow"
          },
          "type": "array"
        },
        "postalCodeGroupNames": {
          "description": "A list of postal group names. The last value can be `\"all other locations\"`. Example: `[\"zone 1\", \"zone 2\", \"all other locations\"]`. The referred postal code groups must match the delivery country of the service.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "transitTimeLabels": {
          "type": "array",
          "description": "A list of transit time labels. The last value can be `\"all other labels\"`. Example: `[\"food\", \"electronics\", \"all other labels\"]`.",
          "items": {
            "type": "string"
          }
        }
      },
      "type": "object"
    },
    "ShippingsettingsCustomBatchResponseEntry": {
      "properties": {
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "batchId": {
          "format": "uint32",
          "type": "integer",
          "description": "The ID of the request entry to which this entry responds."
        },
        "shippingSettings": {
          "description": "The retrieved or updated account shipping settings.",
          "$ref": "ShippingSettings"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsCustomBatchResponseEntry`\""
        }
      },
      "type": "object",
      "description": "A batch entry encoding a single non-batch shipping settings response.",
      "id": "ShippingsettingsCustomBatchResponseEntry"
    },
    "ReturnPolicyOnlineReturnShippingFee": {
      "type": "object",
      "properties": {
        "type": {
          "type": "string",
          "description": "Type of return shipping fee.",
          "enumDescriptions": [
            "Default value. This value is unused.",
            "The return shipping fee is a fixed value.",
            "Customer will pay the actual return shipping fee."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "FIXED",
            "CUSTOMER_PAYING_ACTUAL_FEE"
          ]
        },
        "fixedFee": {
          "description": "Fixed return shipping fee amount. This value is only applicable when type is FIXED. We will treat the return shipping fee as free if type is FIXED and this value is not set.",
          "$ref": "PriceAmount"
        }
      },
      "id": "ReturnPolicyOnlineReturnShippingFee",
      "description": "The return shipping fee. This can either be a fixed fee or a boolean to indicate that the customer pays the actual shipping cost."
    },
    "AccountIdentityType": {
      "type": "object",
      "properties": {
        "selfIdentified": {
          "description": "Optional. Indicates that the business identifies itself with a given identity type. Setting this field does not automatically mean eligibility for promotions.",
          "type": "boolean"
        }
      },
      "id": "AccountIdentityType",
      "description": "The account identity type used to specify attributes."
    },
    "ProductShipping": {
      "properties": {
        "service": {
          "type": "string",
          "description": "A free-form description of the service class or delivery speed."
        },
        "postalCode": {
          "description": "The postal code range that the shipping rate applies to, represented by a postal code, a postal code prefix followed by a * wildcard, a range between two postal codes or two postal code prefixes of equal length.",
          "type": "string"
        },
        "country": {
          "description": "The CLDR territory code of the country to which an item will ship.",
          "type": "string"
        },
        "price": {
          "description": "Fixed shipping price, represented as a number.",
          "$ref": "Price"
        },
        "locationId": {
          "description": "The numeric ID of a location that the shipping rate applies to as defined in the Google Ads API.",
          "format": "int64",
          "type": "string"
        },
        "minHandlingTime": {
          "type": "string",
          "format": "int64",
          "description": "Minimum handling time (inclusive) between when the order is received and shipped in business days. 0 means that the order is shipped on the same day as it's received if it happens before the cut-off time. minHandlingTime can only be present together with maxHandlingTime; but it's not required if maxHandlingTime is present."
        },
        "maxHandlingTime": {
          "description": "Maximum handling time (inclusive) between when the order is received and shipped in business days. 0 means that the order is shipped on the same day as it's received if it happens before the cut-off time. Both maxHandlingTime and maxTransitTime are required if providing shipping speeds.",
          "type": "string",
          "format": "int64"
        },
        "minTransitTime": {
          "format": "int64",
          "type": "string",
          "description": "Minimum transit time (inclusive) between when the order has shipped and when it's delivered in business days. 0 means that the order is delivered on the same day as it ships. minTransitTime can only be present together with maxTransitTime; but it's not required if maxTransitTime is present."
        },
        "maxTransitTime": {
          "type": "string",
          "format": "int64",
          "description": "Maximum transit time (inclusive) between when the order has shipped and when it's delivered in business days. 0 means that the order is delivered on the same day as it ships. Both maxHandlingTime and maxTransitTime are required if providing shipping speeds."
        },
        "region": {
          "description": "The geographic region to which a shipping rate applies.",
          "type": "string"
        },
        "locationGroupName": {
          "type": "string",
          "description": "The location where the shipping is applicable, represented by a location group name."
        }
      },
      "type": "object",
      "id": "ProductShipping"
    },
    "SearchRequest": {
      "type": "object",
      "properties": {
        "pageSize": {
          "description": "Number of ReportRows to retrieve in a single page. Defaults to 1000. Values above 5000 are coerced to 5000.",
          "type": "integer",
          "format": "int32"
        },
        "pageToken": {
          "description": "Token of the page to retrieve. If not specified, the first page of results is returned. In order to request the next page of results, the value obtained from `next_page_token` in the previous response should be used.",
          "type": "string"
        },
        "query": {
          "description": "Required. Query that defines performance metrics to retrieve and dimensions according to which the metrics are to be segmented. For details on how to construct your query, see the [Query Language guide](https://developers.google.com/shopping-content/guides/reports/query-language/overview).",
          "type": "string"
        }
      },
      "id": "SearchRequest",
      "description": "Request message for the ReportService.Search method."
    },
    "AccounttaxCustomBatchRequest": {
      "type": "object",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The request entries to be processed in the batch.",
          "items": {
            "$ref": "AccounttaxCustomBatchRequestEntry"
          }
        }
      },
      "id": "AccounttaxCustomBatchRequest"
    },
    "PubsubNotificationSettings": {
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#pubsubNotificationSettings`\"",
          "type": "string"
        },
        "cloudTopicName": {
          "type": "string",
          "description": "Cloud pub/sub topic to which notifications are sent (read-only)."
        },
        "registeredEvents": {
          "description": "List of event types. Acceptable values are: - \"`orderPendingShipment`\" ",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object",
      "description": "Settings for Pub/Sub notifications, all methods require that the caller is a direct user of the merchant center account.",
      "id": "PubsubNotificationSettings"
    },
    "InputValueChoiceInputValue": {
      "description": "Value for choice input field.",
      "id": "InputValueChoiceInputValue",
      "properties": {
        "choiceInputOptionId": {
          "description": "Required. Id of the option that was selected by the merchant.",
          "type": "string"
        }
      },
      "type": "object"
    },
    "PosListResponse": {
      "id": "PosListResponse",
      "type": "object",
      "properties": {
        "resources": {
          "type": "array",
          "items": {
            "$ref": "PosStore"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posListResponse`\"."
        }
      }
    },
    "DatafeedstatusesCustomBatchResponse": {
      "id": "DatafeedstatusesCustomBatchResponse",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#datafeedstatusesCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "DatafeedstatusesCustomBatchResponseEntry"
          }
        }
      },
      "type": "object"
    },
    "AccountsLinkResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accountsLinkResponse`\".",
          "type": "string"
        }
      },
      "id": "AccountsLinkResponse"
    },
    "ProductShippingWeight": {
      "id": "ProductShippingWeight",
      "type": "object",
      "properties": {
        "unit": {
          "description": "The unit of value.",
          "type": "string"
        },
        "value": {
          "type": "number",
          "format": "double",
          "description": "The weight of the product used to calculate the shipping cost of the item."
        }
      }
    },
    "DatafeedTarget": {
      "id": "DatafeedTarget",
      "type": "object",
      "properties": {
        "language": {
          "description": "The two-letter ISO 639-1 language of the items in the feed. Must be a valid language for `targets[].country`.",
          "type": "string"
        },
        "includedDestinations": {
          "type": "array",
          "description": "The list of [destinations to include](//support.google.com/merchants/answer/7501026) for this target (corresponds to checked check boxes in Merchant Center). Default destinations are always included unless provided in `excludedDestinations`.",
          "items": {
            "type": "string"
          }
        },
        "country": {
          "type": "string",
          "description": "Deprecated. Use `feedLabel` instead. The country where the items in the feed will be included in the search index, represented as a CLDR territory code."
        },
        "feedLabel": {
          "type": "string",
          "description": "Feed label for the DatafeedTarget. Either `country` or `feedLabel` is required. If both `feedLabel` and `country` is specified, the values must match. Must be less than or equal to 20 uppercase letters (A-Z), numbers (0-9), and dashes (-)."
        },
        "targetCountries": {
          "description": "The countries where the items may be displayed. Represented as a CLDR territory code. Will be ignored for \"product inventory\" feeds.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "excludedDestinations": {
          "description": "The list of [destinations to exclude](//support.google.com/merchants/answer/6324486) for this target (corresponds to cleared check boxes in Merchant Center). Products that are excluded from all destinations for more than 7 days are automatically deleted.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      }
    },
    "PriceCompetitiveness": {
      "type": "object",
      "properties": {
        "benchmarkPriceCurrencyCode": {
          "type": "string",
          "description": "The price benchmark currency (ISO 4217 code)."
        },
        "countryCode": {
          "description": "The country of the price benchmark (ISO 3166 code).",
          "type": "string"
        },
        "benchmarkPriceMicros": {
          "format": "int64",
          "type": "string",
          "description": "The latest available price benchmark in micros (1 millionth of a standard unit, 1 USD = 1000000 micros) for the product's catalog in the benchmark country."
        }
      },
      "id": "PriceCompetitiveness",
      "description": "Price competitiveness fields requested by the merchant in the query. Field values are only set if the merchant queries `PriceCompetitivenessProductView`. https://support.google.com/merchants/answer/9626903"
    },
    "OrderTrackingSignalLineItemDetails": {
      "properties": {
        "productId": {
          "description": "Required. The Content API REST ID of the product, in the form channel:contentLanguage:targetCountry:offerId.",
          "type": "string"
        },
        "productTitle": {
          "type": "string",
          "description": "Plain text title of this product."
        },
        "upc": {
          "type": "string",
          "description": "Universal product code for this item (deprecated: Please use GTIN instead).",
          "deprecated": true
        },
        "productDescription": {
          "deprecated": true,
          "description": "Plain text description of this product (deprecated: Please use product_title instead).",
          "type": "string"
        },
        "quantity": {
          "format": "int64",
          "type": "string",
          "description": "The quantity of the line item in the order."
        },
        "lineItemId": {
          "description": "Required. The ID for this line item.",
          "type": "string"
        },
        "brand": {
          "description": "Brand of the product.",
          "type": "string"
        },
        "mpn": {
          "type": "string",
          "description": "The manufacturer part number."
        },
        "sku": {
          "description": "Merchant SKU for this item (deprecated).",
          "deprecated": true,
          "type": "string"
        },
        "gtin": {
          "type": "string",
          "description": "The Global Trade Item Number."
        }
      },
      "type": "object",
      "description": "The line items of the order.",
      "id": "OrderTrackingSignalLineItemDetails"
    },
    "HolidayCutoff": {
      "properties": {
        "deadlineHour": {
          "description": "Hour of the day on the deadline date until which the order has to be placed to qualify for the delivery guarantee. Possible values are: 0 (midnight), 1, ..., 12 (noon), 13, ..., 23. Required.",
          "type": "integer",
          "format": "uint32"
        },
        "deadlineDate": {
          "description": "Date of the order deadline, in ISO 8601 format. For example, \"2016-11-29\" for 29th November 2016. Required.",
          "type": "string"
        },
        "deadlineTimezone": {
          "description": "Timezone identifier for the deadline hour (for example, \"Europe/Zurich\"). List of identifiers. Required.",
          "type": "string"
        },
        "holidayId": {
          "type": "string",
          "description": "Unique identifier for the holiday. Required."
        },
        "visibleFromDate": {
          "type": "string",
          "description": "Date on which the deadline will become visible to consumers in ISO 8601 format. For example, \"2016-10-31\" for 31st October 2016. Required."
        }
      },
      "type": "object",
      "id": "HolidayCutoff"
    },
    "LiasettingsSetInventoryVerificationContactResponse": {
      "id": "LiasettingsSetInventoryVerificationContactResponse",
      "type": "object",
      "properties": {
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsSetInventoryVerificationContactResponse`\"."
        }
      }
    },
    "ProductStructuredDescription": {
      "description": "Structured description, for algorithmically (AI)-generated descriptions. See [description](https://support.google.com/merchants/answer/6324468#When_to_use) for more information.",
      "id": "ProductStructuredDescription",
      "properties": {
        "digitalSourceType": {
          "type": "string",
          "description": "Optional. The digital source type. Acceptable values are: - \"`trained_algorithmic_media`\" - \"`default`\" "
        },
        "content": {
          "type": "string",
          "description": "Required. The description text. Maximum length is 5000 characters."
        }
      },
      "type": "object"
    },
    "Value": {
      "type": "object",
      "properties": {
        "carrierRateName": {
          "description": "The name of a carrier rate referring to a carrier rate defined in the same rate group. Can only be set if all other fields are not set.",
          "type": "string"
        },
        "noShipping": {
          "description": "If true, then the product can't ship. Must be true when set, can only be set if all other fields are not set.",
          "type": "boolean"
        },
        "subtableName": {
          "type": "string",
          "description": "The name of a subtable. Can only be set in table cells (not for single values), and only if all other fields are not set."
        },
        "pricePercentage": {
          "description": "A percentage of the price represented as a number in decimal notation (for example, `\"5.4\"`). Can only be set if all other fields are not set.",
          "type": "string"
        },
        "flatRate": {
          "description": "A flat rate. Can only be set if all other fields are not set.",
          "$ref": "Price"
        }
      },
      "id": "Value",
      "description": "The single value of a rate group or the value of a rate group table's cell. Exactly one of `noShipping`, `flatRate`, `pricePercentage`, `carrierRateName`, `subtableName` must be set."
    },
    "LocalinventoryCustomBatchResponseEntry": {
      "properties": {
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "format": "uint32",
          "type": "integer"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#localinventoryCustomBatchResponseEntry`\""
        }
      },
      "type": "object",
      "description": "Batch entry encoding a single local inventory update response.",
      "id": "LocalinventoryCustomBatchResponseEntry"
    },
    "TriggerActionPayload": {
      "id": "TriggerActionPayload",
      "description": "The payload for the triggered action.",
      "type": "object",
      "properties": {
        "actionInput": {
          "description": "Required. Input provided by the merchant.",
          "$ref": "ActionInput"
        },
        "actionContext": {
          "type": "string",
          "description": "Required. The context from the selected action. The value is obtained from rendered issues and needs to be sent back to identify the action that is being triggered."
        }
      }
    },
    "PosCustomBatchResponse": {
      "properties": {
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "PosCustomBatchResponseEntry"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#posCustomBatchResponse`\"."
        }
      },
      "type": "object",
      "id": "PosCustomBatchResponse"
    },
    "RegionalinventoryCustomBatchResponse": {
      "id": "RegionalinventoryCustomBatchResponse",
      "properties": {
        "entries": {
          "type": "array",
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "RegionalinventoryCustomBatchResponseEntry"
          }
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#regionalinventoryCustomBatchResponse`\"."
        }
      },
      "type": "object"
    },
    "RecommendationDescription": {
      "properties": {
        "text": {
          "type": "string",
          "description": "Output only. Text of the description.",
          "readOnly": true
        },
        "type": {
          "type": "string",
          "readOnly": true,
          "description": "Output only. Type of the description.",
          "enumDescriptions": [
            "Default value. Will never be provided by the API.",
            "Short description.",
            "Long description."
          ],
          "enum": [
            "DESCRIPTION_TYPE_UNSPECIFIED",
            "SHORT",
            "LONG"
          ]
        }
      },
      "type": "object",
      "description": "Google-provided description for the recommendation.",
      "id": "RecommendationDescription"
    },
    "HolidaysHoliday": {
      "id": "HolidaysHoliday",
      "type": "object",
      "properties": {
        "id": {
          "type": "string",
          "description": "Unique identifier for the holiday to be used when configuring holiday cutoffs. Always present."
        },
        "deliveryGuaranteeHour": {
          "description": "Hour of the day in the delivery location's timezone on the guaranteed delivery date by which the order has to arrive at the customer's. Possible values are: 0 (midnight), 1, ..., 12 (noon), 13, ..., 23. Always present.",
          "type": "string",
          "format": "uint64"
        },
        "countryCode": {
          "type": "string",
          "description": "The CLDR territory code of the country in which the holiday is available. For example, \"US\", \"DE\", \"GB\". A holiday cutoff can only be configured in a shipping settings service with matching delivery country. Always present."
        },
        "date": {
          "type": "string",
          "description": "Date of the holiday, in ISO 8601 format. For example, \"2016-12-25\" for Christmas 2016. Always present."
        },
        "deliveryGuaranteeDate": {
          "type": "string",
          "description": "Date on which the order has to arrive at the customer's, in ISO 8601 format. For example, \"2016-12-24\" for 24th December 2016. Always present."
        },
        "type": {
          "type": "string",
          "description": "The holiday type. Always present. Acceptable values are: - \"`Christmas`\" - \"`Easter`\" - \"`Father's Day`\" - \"`Halloween`\" - \"`Independence Day (USA)`\" - \"`Mother's Day`\" - \"`Thanksgiving`\" - \"`Valentine's Day`\" "
        }
      }
    },
    "ShippingsettingsGetSupportedPickupServicesResponse": {
      "id": "ShippingsettingsGetSupportedPickupServicesResponse",
      "type": "object",
      "properties": {
        "pickupServices": {
          "description": "A list of supported pickup services. May be empty.",
          "items": {
            "$ref": "PickupServicesPickupService"
          },
          "type": "array"
        },
        "kind": {
          "type": "string",
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#shippingsettingsGetSupportedPickupServicesResponse`\"."
        }
      }
    },
    "FreeListingsProgramStatusRegionStatus": {
      "id": "FreeListingsProgramStatusRegionStatus",
      "description": "Status of program and region.",
      "type": "object",
      "properties": {
        "reviewEligibilityStatus": {
          "description": "If a program is eligible for review in a specific region. Only visible if `eligibilityStatus` is `DISAPPROVED`.",
          "enumDescriptions": [
            "Review eligibility state is unknown.",
            "Account is eligible for review for a specified region code.",
            "Account is not eligible for review for a specified region code."
          ],
          "enum": [
            "REVIEW_ELIGIBILITY_UNSPECIFIED",
            "ELIGIBLE",
            "INELIGIBLE"
          ],
          "type": "string"
        },
        "disapprovalDate": {
          "type": "string",
          "description": "Date by which eligibilityStatus will go from `WARNING` to `DISAPPROVED`. Only visible when your eligibilityStatus is WARNING. In [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) format: `YYYY-MM-DD`."
        },
        "reviewIneligibilityReason": {
          "type": "string",
          "description": "Review ineligibility reason if account is not eligible for review.",
          "enumDescriptions": [
            "Requesting a review from Google is not possible.",
            "All onboarding issues needs to be fixed.",
            "Not enough offers uploaded for this country.",
            "Cooldown period applies. Wait until cooldown period ends.",
            "Account is already under review.",
            "No issues available to review.",
            "Account will be automatically reviewed at the end of the grace period.",
            "Account is retired. Should not appear in MC.",
            "Account has already been reviewed. You can't request further reviews."
          ],
          "enum": [
            "REVIEW_INELIGIBILITY_REASON_UNSPECIFIED",
            "ONBOARDING_ISSUES",
            "NOT_ENOUGH_OFFERS",
            "IN_COOLDOWN_PERIOD",
            "ALREADY_UNDER_REVIEW",
            "NO_REVIEW_REQUIRED",
            "WILL_BE_REVIEWED_AUTOMATICALLY",
            "IS_RETIRED",
            "ALREADY_REVIEWED"
          ]
        },
        "reviewIneligibilityReasonDescription": {
          "description": "Reason a program in a specific region isn’t eligible for review. Only visible if `reviewEligibilityStatus` is `INELIGIBLE`.",
          "type": "string"
        },
        "eligibilityStatus": {
          "description": "Eligibility status of the standard free listing program.",
          "enumDescriptions": [
            "State is not known.",
            "If the account has no issues and review is completed successfully.",
            "There are one or more issues that needs to be resolved for account to be active for the program. Detailed list of account issues are available in [accountstatuses](https://developers.google.com/shopping-content/reference/rest/v2.1/accountstatuses) API.",
            "If account has issues but offers are servable. Some of the issue can make account DISAPPROVED after a certain deadline.",
            "Account is under review.",
            "Account is waiting for review to start.",
            "Program is currently onboarding. Upload valid offers to complete onboarding."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "APPROVED",
            "DISAPPROVED",
            "WARNING",
            "UNDER_REVIEW",
            "PENDING_REVIEW",
            "ONBOARDING"
          ],
          "type": "string"
        },
        "reviewIneligibilityReasonDetails": {
          "description": "Additional information for ineligibility. If `reviewIneligibilityReason` is `IN_COOLDOWN_PERIOD`, a timestamp for the end of the cooldown period is provided.",
          "$ref": "FreeListingsProgramStatusReviewIneligibilityReasonDetails"
        },
        "regionCodes": {
          "description": "The two-letter [ISO 3166-1 alpha-2](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) codes for all the regions with the same `eligibilityStatus` and `reviewEligibility`.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "reviewIssues": {
          "description": "Issues evaluated in the review process. Fix all issues before requesting a review.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "onboardingIssues": {
          "type": "array",
          "description": "Issues that must be fixed to be eligible for review.",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "AccounttaxCustomBatchResponseEntry": {
      "description": "A batch entry encoding a single non-batch accounttax response.",
      "id": "AccounttaxCustomBatchResponseEntry",
      "properties": {
        "batchId": {
          "description": "The ID of the request entry this entry responds to.",
          "type": "integer",
          "format": "uint32"
        },
        "accountTax": {
          "description": "The retrieved or updated account tax settings.",
          "$ref": "AccountTax"
        },
        "errors": {
          "description": "A list of errors for failed custombatch entries. *Note:* Schema errors fail the whole request.",
          "$ref": "Errors"
        },
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#accounttaxCustomBatchResponseEntry`\"",
          "type": "string"
        }
      },
      "type": "object"
    },
    "AccountReturnCarrier": {
      "description": " The return carrier information. This service is designed for merchants enrolled in the Buy on Google program. ",
      "id": "AccountReturnCarrier",
      "properties": {
        "carrierAccountNumber": {
          "description": "Number of the carrier account.",
          "type": "string"
        },
        "carrierCode": {
          "type": "string",
          "description": "The carrier code enum. Accepts the values FEDEX or UPS.",
          "enumDescriptions": [
            "Carrier not specified",
            "FedEx carrier",
            "UPS carrier"
          ],
          "enum": [
            "CARRIER_CODE_UNSPECIFIED",
            "FEDEX",
            "UPS"
          ]
        },
        "carrierAccountName": {
          "description": "Name of the carrier account.",
          "type": "string"
        },
        "carrierAccountId": {
          "readOnly": true,
          "description": "Output only. Immutable. The Google-provided unique carrier ID, used to update the resource.",
          "type": "string",
          "format": "int64"
        }
      },
      "type": "object"
    },
    "LiasettingsCustomBatchResponse": {
      "type": "object",
      "properties": {
        "kind": {
          "description": "Identifies what kind of resource this is. Value: the fixed string \"`content#liasettingsCustomBatchResponse`\".",
          "type": "string"
        },
        "entries": {
          "description": "The result of the execution of the batch requests.",
          "items": {
            "$ref": "LiasettingsCustomBatchResponseEntry"
          },
          "type": "array"
        }
      },
      "id": "LiasettingsCustomBatchResponse"
    }
  },
  "ownerName": "Google",
  "protocol": "rest",
  "servicePath": "content/v2.1/",
  "mtlsRootUrl": "https://shoppingcontent.mtls.googleapis.com/",
  "title": "Content API for Shopping",
  "discoveryVersion": "v1",
  "kind": "discovery#restDescription",
  "rootUrl": "https://shoppingcontent.googleapis.com/"
}
