{
  "servicePath": "",
  "mtlsRootUrl": "https://travelpartner.mtls.googleapis.com/",
  "fullyEncodeReservedExpansion": true,
  "documentationLink": "https://developers.google.com/hotels/hotel-prices/api-reference",
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "title": "Travel Partner API",
  "id": "travelpartner:v3",
  "parameters": {
    "quotaUser": {
      "type": "string",
      "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.",
      "location": "query"
    },
    "upload_protocol": {
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "location": "query"
    },
    "key": {
      "type": "string",
      "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.",
      "location": "query"
    },
    "access_token": {
      "type": "string",
      "description": "OAuth access token.",
      "location": "query"
    },
    "alt": {
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "type": "string",
      "description": "Data format for response.",
      "default": "json",
      "location": "query"
    },
    "$.xgafv": {
      "location": "query",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "type": "string",
      "description": "V1 error format."
    },
    "callback": {
      "type": "string",
      "description": "JSONP",
      "location": "query"
    },
    "uploadType": {
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "location": "query"
    },
    "oauth_token": {
      "type": "string",
      "description": "OAuth 2.0 token for the current user.",
      "location": "query"
    },
    "fields": {
      "type": "string",
      "description": "Selector specifying which fields to include in a partial response.",
      "location": "query"
    },
    "prettyPrint": {
      "type": "boolean",
      "description": "Returns response with indentations and line breaks.",
      "location": "query",
      "default": "true"
    }
  },
  "baseUrl": "https://travelpartner.googleapis.com/",
  "basePath": "",
  "discoveryVersion": "v1",
  "canonicalName": "TravelPartner",
  "kind": "discovery#restDescription",
  "batchPath": "batch",
  "version": "v3",
  "resources": {
    "accounts": {
      "resources": {
        "hotels": {
          "methods": {
            "setLiveOnGoogle": {
              "httpMethod": "POST",
              "parameterOrder": [
                "account"
              ],
              "response": {
                "$ref": "SetLiveOnGoogleResponse"
              },
              "id": "travelpartner.accounts.hotels.setLiveOnGoogle",
              "parameters": {
                "account": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the account. The format is accounts/{account_id}.",
                  "type": "string"
                }
              },
              "request": {
                "$ref": "SetLiveOnGoogleRequest"
              },
              "flatPath": "v3/accounts/{accountsId}/hotels:setLiveOnGoogle",
              "path": "v3/{+account}/hotels:setLiveOnGoogle",
              "description": "Collection-level custom method to update the Live on Google status for multiple properties. Each call can turn on or off multiple hotels. To turn some hotels on and turn some hotels off, you will have to make multiple calls."
            }
          }
        },
        "hotelViews": {
          "methods": {
            "list": {
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListHotelViewsResponse"
              },
              "path": "v3/{+parent}/hotelViews",
              "description": "Returns the list of hotel views.",
              "flatPath": "v3/accounts/{accountsId}/hotelViews",
              "id": "travelpartner.accounts.hotelViews.list",
              "httpMethod": "GET",
              "parameters": {
                "pageToken": {
                  "description": "Token of the page to retrieve.",
                  "location": "query",
                  "type": "string"
                },
                "filter": {
                  "description": "Optional. The conditions (fields and expressions) used to filter HotelViews. The syntax requires spaces surrounding the `in` operator. Otherwise, spaces can be omitted. Conditions cannot be joined. The `hotelId` field can be used to select specific hotels. The `liveOnGoogle` field can select properties that Google shows, or properties that are omitted in google search results. A value of 'TRUE' includes properties that are conditionally active, e.g. LIVE_ON_GOOGLE_STATUS_ACTIVE_OUTSIDE_DSA_REGION. The `matchStatus` field can be used to filter the list of HotelViews returned for the account. Examples of valid conditions and their syntax are as follows: * `hotelId = 'hotel_ABC'` * `hotelId in ('hotel_ABC', 'hotel_XYZ')` * `liveOnGoogle = 'TRUE'` * `liveOnGoogle = 'FALSE'` * `matchStatus = 'NOT_MATCHED'` * `matchStatus in ('NOT_MATCHED', 'MATCHED', 'MAP_OVERLAP')`",
                  "location": "query",
                  "type": "string"
                },
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                },
                "pageSize": {
                  "description": "Number of elements to retrieve in a single page.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                }
              }
            },
            "summarize": {
              "id": "travelpartner.accounts.hotelViews.summarize",
              "httpMethod": "GET",
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "flatPath": "v3/accounts/{accountsId}/hotelViews:summarize",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "SummarizeHotelViewsResponse"
              },
              "path": "v3/{+parent}/hotelViews:summarize",
              "description": "Returns summarized information about hotels."
            }
          }
        },
        "priceAccuracyViews": {
          "methods": {
            "list": {
              "path": "v3/{+parent}/priceAccuracyViews",
              "description": "Lists the available price accuracy views.",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListPriceAccuracyViewsResponse"
              },
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "id": "travelpartner.accounts.priceAccuracyViews.list",
              "httpMethod": "GET",
              "flatPath": "v3/accounts/{accountsId}/priceAccuracyViews"
            },
            "get": {
              "flatPath": "v3/accounts/{accountsId}/priceAccuracyViews/{priceAccuracyViewsId}",
              "id": "travelpartner.accounts.priceAccuracyViews.get",
              "httpMethod": "GET",
              "parameters": {
                "includePixels": {
                  "description": "Set to true if pixel signals are to be added into the report.",
                  "location": "query",
                  "type": "boolean"
                },
                "includeMatchedPrices": {
                  "description": "Set to true if matched prices are to be added into the report.",
                  "location": "query",
                  "type": "boolean"
                },
                "includeNonScoring": {
                  "description": "Set to true if non-scoring rows are to be added into the report.",
                  "location": "query",
                  "type": "boolean"
                },
                "name": {
                  "description": "The resource name of price accuracy view that is being queried.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/priceAccuracyViews/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "PriceAccuracyView"
              },
              "path": "v3/{+name}",
              "description": "Returns the requested price accuracy view in full detail."
            },
            "summarize": {
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "SummarizePriceAccuracyResponse"
              },
              "path": "v3/{+parent}/priceAccuracyViews:summarize",
              "description": "Returns the price accuracy summary.",
              "id": "travelpartner.accounts.priceAccuracyViews.summarize",
              "httpMethod": "GET",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account that is being queried. The format is `accounts/{account_id}`.",
                  "type": "string"
                }
              },
              "flatPath": "v3/accounts/{accountsId}/priceAccuracyViews:summarize"
            }
          }
        },
        "propertyPerformanceReportViews": {
          "methods": {
            "query": {
              "flatPath": "v3/accounts/{accountsId}/propertyPerformanceReportViews:query",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account being queried. Format: accounts/{account_id}",
                  "type": "string"
                },
                "aggregateBy": {
                  "description": "Specifies how to segment the metrics returned by the query. For example, if `userRegionCode` is specified, the `PropertyPerformanceResult` will provide metrics aggregated by user region. The string value is a comma-separated list of fields. Valid fields are: `advanceBookingWindow`, `brand`, `date`, `deviceType`, `highIntentUsers`, `lengthOfStay`, `propertyRegionCode`, `occupancy`, `partnerPropertyId`, `partnerPropertyDisplayName`, and `userRegionCode`. Only fields specified here are included in the PropertyPerformanceResult. **Important**: Using the `aggregateBy` parameter with `partnerHotelId` or more than two values can result in an error. Filtering with `partnerHotelId` and `date` to reduce the number of rows can prevent the occurrence of errors.",
                  "location": "query",
                  "type": "string"
                },
                "filter": {
                  "description": "The conditions (fields and expressions) used to filter the property performance metrics for the account being queried. The syntax requires spaces surrounding the `in` operator. Otherwise, spaces can be omitted. Conditions can be joined using the `AND` operator. **Important:** The correct syntax to add multiple conditions is: `\"?filter==%20AND%20=...\"` The `date` field is required. All other fields are optional. The `date` field values are inclusive and must be in YYYY-MM-DD format. The earliest acceptable date is 2021-03-09; earlier date values will be coerced to 2021-03-09. Values for `partnerPropertyDisplayName` and `brand` are matched case-insensitively. Examples of valid conditions are as follows: * `advanceBookingWindow = 'ADVANCE_BOOKING_WINDOW_SAME_DAY'` * `advanceBookingWindow in ('ADVANCE_BOOKING_WINDOW_SAME_DAY', 'ADVANCE_BOOKING_WINDOW_DAYS_61_TO_90')` * `brand = 'Brand A'` * `brand in ('Brand A', 'brand B')` * `date = '2021-12-03'` * `date between '2021-12-03' and '2021-12-08'` * `deviceType = 'TABLET'` * `deviceType in ('MOBILE', 'TABLET')` * `highIntentUsers = 'TRUE'` * `highIntentUsers = 'FALSE'` * `lengthOfStay = 'LENGTH_OF_STAY_NIGHTS_2'` * `lengthOfStay in ('LENGTH_OF_STAY_NIGHTS_2', 'LENGTH_OF_STAY_NIGHTS_4_TO_7')` * `propertyRegionCode = 'US'` * `propertyRegionCode in ('US', 'CA')` * `occupancy = 'OCCUPANCY_2'` * `occupancy in ('OCCUPANCY_2', 'OCCUPANCY_OVER_4')` * `partnerPropertyId = 'AAA'` * `partnerPropertyId in ('AAA', 'BBB')` * `partnerPropertyDisplayName = 'hotel A'` * `partnerPropertyDisplayName in ('Hotel A', 'HOTEL b')` * `userRegionCode = 'US'` * `userRegionCode in ('US', 'CA')`",
                  "location": "query",
                  "type": "string"
                },
                "pageSize": {
                  "description": "The maximum number of participation results to return. The service may return fewer than this value. If unspecified, at most 10,000 results will be returned. The maximum value is 10,000; values above 10,000 will be coerced to 10,000.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                },
                "pageToken": {
                  "description": "A page token, received from a previous QueryParticipationReport request. Provide this to receive the subsequent page. When paginating, all other parameters provided to QueryParticipationReport must match the call that provided the page token.",
                  "location": "query",
                  "type": "string"
                }
              },
              "id": "travelpartner.accounts.propertyPerformanceReportViews.query",
              "httpMethod": "GET",
              "path": "v3/{+name}/propertyPerformanceReportViews:query",
              "description": "Provides the ability to query (get, filter, and segment) a free booking links report for a specific account. This new version returns impressions and clicks, as well as a much larger superset of filters/aggregations.",
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "QueryPropertyPerformanceReportResponse"
              }
            }
          }
        },
        "priceViews": {
          "methods": {
            "get": {
              "parameters": {
                "name": {
                  "description": "The resource name of price view being queried. The format is `accounts/{account_id}/priceViews/{partner_hotel_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/priceViews/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "id": "travelpartner.accounts.priceViews.get",
              "httpMethod": "GET",
              "flatPath": "v3/accounts/{accountsId}/priceViews/{priceViewsId}",
              "path": "v3/{+name}",
              "description": "Returns the requested price view in full detail.",
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "PriceView"
              }
            }
          }
        },
        "priceCoverageViews": {
          "methods": {
            "getLatest": {
              "flatPath": "v3/accounts/{accountsId}/priceCoverageViews:latest",
              "id": "travelpartner.accounts.priceCoverageViews.getLatest",
              "httpMethod": "GET",
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "PriceCoverageView"
              },
              "path": "v3/{+parent}/priceCoverageViews:latest",
              "description": "Returns the latest price coverage view in full detail."
            },
            "list": {
              "path": "v3/{+parent}/priceCoverageViews",
              "description": "Returns the entire price coverage history.",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListPriceCoverageViewsResponse"
              },
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "id": "travelpartner.accounts.priceCoverageViews.list",
              "httpMethod": "GET",
              "flatPath": "v3/accounts/{accountsId}/priceCoverageViews"
            }
          }
        },
        "freeBookingLinksReportViews": {
          "deprecated": true,
          "methods": {
            "query": {
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "QueryFreeBookingLinksReportResponse"
              },
              "deprecated": true,
              "httpMethod": "GET",
              "path": "v3/{+name}/freeBookingLinksReportViews:query",
              "description": "**DEPRECATED:** Use PropertyPerformanceReportService.QueryPropertyPerformanceReport, which also has impression reporting, instead. Provides the ability to query (get, filter, and segment) a free booking links report for a specific account.",
              "flatPath": "v3/accounts/{accountsId}/freeBookingLinksReportViews:query",
              "parameters": {
                "aggregateBy": {
                  "description": "Specifies how to segment the metrics returned by the query. For example, if `userRegionCode` is specified, the `freeBookingLinksResult` will provide metrics aggregated by user region. The string value is a comma-separated list of fields. Valid fields are: `date`, `userRegionCode`, `deviceType`, `partnerHotelId`, and `partnerHotelDisplayName`. Only fields specified here are included in the FreeBookingLinksResult.",
                  "location": "query",
                  "type": "string"
                },
                "name": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account being queried. Format: accounts/{account_id}",
                  "type": "string"
                },
                "pageToken": {
                  "description": "A page token, received from a previous QueryParticipationReport request. Provide this to receive the subsequent page. When paginating, all other parameters provided to QueryParticipationReport must match the call that provided the page token.",
                  "location": "query",
                  "type": "string"
                },
                "filter": {
                  "description": "The conditions (fields and expressions) used to filter the free booking link metrics for the account being queried. The syntax requires spaces surrounding the `in` operator. Otherwise, spaces can be omitted. Conditions can be joined using the `and` operator. The `date` field is required. All other fields are optional. The `date` field values are inclusive and must be in YYYY-MM-DD format. The earliest acceptable date is 2021-03-09; earlier date values will be coerced to 2021-03-09. Values for `partnerHotelDisplayName` are matched case-insensitively. Examples of valid conditions are as follows: * `date = '2021-12-03'` * `date between '2021-12-03' and '2021-12-08'` * `deviceType = 'TABLET'` * `deviceType in ('MOBILE', 'TABLET')` * `partnerHotelId = 'AAA'` * `partnerHotelId in ('AAA', 'BBB')` * `partnerHotelDisplayName = 'hotel A'` * `partnerHotelDisplayName in ('Hotel A', 'HOTEL b')` * `userRegionCode = 'US'` * `userRegionCode in ('US', 'CA')`",
                  "location": "query",
                  "type": "string"
                },
                "pageSize": {
                  "description": "The maximum number of participation results to return. The service may return fewer than this value. If unspecified, at most 10,000 results will be returned. The maximum value is 10,000; values above 10,000 will be coerced to 10,000.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                }
              },
              "id": "travelpartner.accounts.freeBookingLinksReportViews.query"
            }
          }
        },
        "icons": {
          "methods": {
            "list": {
              "flatPath": "v3/accounts/{accountsId}/icons",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the queried partner account. The format is `accounts/{account_id}`.",
                  "type": "string"
                }
              },
              "id": "travelpartner.accounts.icons.list",
              "httpMethod": "GET",
              "path": "v3/{+parent}/icons",
              "description": "Returns the `Icon`s for a partner account.",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListIconsResponse"
              }
            },
            "get": {
              "parameters": {
                "name": {
                  "description": "Required. The icon's resource name. The format is `accounts/{account_id}/icons/{icon_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/icons/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "id": "travelpartner.accounts.icons.get",
              "httpMethod": "GET",
              "flatPath": "v3/accounts/{accountsId}/icons/{iconsId}",
              "path": "v3/{+name}",
              "description": "Returns the `Icon` instance associated with an icon resource name specified in the request URI. To get icon resource names, use the `list` method.",
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "Icon"
              }
            },
            "create": {
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the partner account owning the icon. The format is `accounts/{account_id}`.",
                  "type": "string"
                }
              },
              "request": {
                "$ref": "Icon"
              },
              "id": "travelpartner.accounts.icons.create",
              "flatPath": "v3/accounts/{accountsId}/icons",
              "path": "v3/{+parent}/icons",
              "description": "Uploads a new icon and starts its review process. Generates an `icon_id` and includes it in the icon's resource name, which is the format `accounts/{account_id}/icons/{icon_id}` Returns HTTP status 400 and doesn't trigger the review process if the icon has any of these conditions: * Image is not in PNG format, or not convertible to PNG format. * Size less than 72 pixels * Size greater than 1200 pixels * Aspect ratio other than 1:1",
              "httpMethod": "POST",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "Icon"
              }
            }
          }
        },
        "accountLinks": {
          "methods": {
            "delete": {
              "flatPath": "v3/accounts/{accountsId}/accountLinks/{accountLinksId}",
              "id": "travelpartner.accounts.accountLinks.delete",
              "httpMethod": "DELETE",
              "parameters": {
                "name": {
                  "description": "Required. The resource name of the account link being deleted. The format is `accounts/{account_id}/accountLinks/{account_link_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/accountLinks/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "Empty"
              },
              "path": "v3/{+name}",
              "description": "Deletes an account link."
            },
            "patch": {
              "path": "v3/{+name}",
              "description": "Updates the account link target of an account link.",
              "flatPath": "v3/accounts/{accountsId}/accountLinks/{accountLinksId}",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/accountLinks/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name for the account link in the format `accounts/{account_id}/accountLinks/{account_link_id}`.",
                  "type": "string"
                },
                "updateMask": {
                  "description": "Required. The field to update. Only the `accountLinkTarget` field can be updated. Use the syntax shown in the example URL below and provide the new value in the request body. Example request URL and request body: ``` PATCH https://travelpartner.googleapis.com/v3/accounts/123456789/ accountLinks/0123456789?update_mask=account_link.account_link_target ``` ``` { \"account_link_target\": { \"hotel_list\": { \"partner_hotel_ids\": [\"1234\", \"4321\"] } } } ``` The response body will only include the `name` field of an `AccountLink`. The information above is sufficient for forming the URL and request body. The sentence below is auto-generated, supplemental information about the `FieldMask` format in general.",
                  "location": "query",
                  "type": "string",
                  "format": "google-fieldmask"
                }
              },
              "request": {
                "$ref": "AccountLink"
              },
              "id": "travelpartner.accounts.accountLinks.patch",
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "AccountLink"
              },
              "httpMethod": "PATCH"
            },
            "list": {
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListAccountLinksResponse"
              },
              "path": "v3/{+parent}/accountLinks",
              "description": "Returns the account links for a Hotel Center account.",
              "flatPath": "v3/accounts/{accountsId}/accountLinks",
              "id": "travelpartner.accounts.accountLinks.list",
              "httpMethod": "GET",
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              }
            },
            "get": {
              "flatPath": "v3/accounts/{accountsId}/accountLinks/{accountLinksId}",
              "id": "travelpartner.accounts.accountLinks.get",
              "httpMethod": "GET",
              "parameters": {
                "name": {
                  "description": "The resource name of an account link. The format is `accounts/{account_id}/accountLinks/{account_link_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/accountLinks/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "AccountLink"
              },
              "path": "v3/{+name}",
              "description": "Returns the `AccountLink` instance associated with the account link resource name specified in the request URL. To get account link resource names, use the `list` method."
            },
            "create": {
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "AccountLink"
              },
              "httpMethod": "POST",
              "path": "v3/{+parent}/accountLinks",
              "description": "Creates a new account link between a Hotel Center account and a Google Ads account.",
              "parameters": {
                "parent": {
                  "description": "The resource name of the Hotel Center account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "request": {
                "$ref": "AccountLink"
              },
              "id": "travelpartner.accounts.accountLinks.create",
              "flatPath": "v3/accounts/{accountsId}/accountLinks"
            }
          }
        },
        "participationReportViews": {
          "methods": {
            "query": {
              "flatPath": "v3/accounts/{accountsId}/participationReportViews:query",
              "id": "travelpartner.accounts.participationReportViews.query",
              "httpMethod": "GET",
              "parameters": {
                "pageToken": {
                  "description": "A page token, received from a previous QueryParticipationReport request. Provide this to receive the subsequent page. When paginating, all other parameters provided to QueryParticipationReport must match the call that provided the page token.",
                  "location": "query",
                  "type": "string"
                },
                "filter": {
                  "description": "The conditions (fields and expressions) used to filter the participation metrics for the account being queried. The syntax requires spaces surrounding the `in` operator. Otherwise, spaces can be omitted. Conditions can be joined using the `AND` operator. **Important:** The correct syntax to add multiple conditions is: `\"?filter==%20AND%20=...\"` The `date` field is required. All other fields are optional. Examples of valid conditions are as follows: * `advanceBookingWindow = 2` * `advanceBookingWindow \u003e= 0` * `advanceBookingWindow \u003c= 5` * `checkinDate = '2020-10-01'` * `checkinDate \u003e= '2020-10-01'` * `checkinDate \u003c= '2020-10-01'` * `checkinDate between '2020-10-01' and '2020-10-05'` * `date = '2020-02-04'` * `date between '2020-02-04' and '2020-02-09'` * `deviceType = 'TABLET'` * `deviceType in ('MOBILE', 'TABLET')` * `hotelRegionCode = 'US'` * `hotelRegionCode in ('US', 'CA')` * `lengthOfStayDays = 2` * `lengthOfStayDays \u003e= 0` * `lengthOfStayDays \u003c= 5` * `occupancy = 2` * `occupancy \u003e= 0` * `occupancy \u003c= 5` * `occupancy between 1 and 5` * `partnerHotelId = 'AAA'` * `partnerHotelId in ('AAA', 'BBB')` * `userRegionCode = 'US'` * `userRegionCode in ('US', 'CA')`",
                  "location": "query",
                  "type": "string"
                },
                "pageSize": {
                  "description": "The maximum number of participation results to return. The service may return fewer than this value. If unspecified, at most 10,000 results will be returned. The maximum value is 10,000; values above 10,000 will be coerced to 10,000.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                },
                "aggregateBy": {
                  "description": "Specifies how to segment the metrics returned by the query. For example, if `userRegionCode` is specified as the `aggregate_by` value, the `participationResult` will provide metrics aggregated by user region. The string value is a comma-separated list of fields. Valid fields are: `date`, `userRegionCode`, `deviceType`, `partnerHotelId`, `hotelRegionCode`, `advanceBookingWindow`, `lengthOfStayDays`, `checkinDate`, and `occupancy`. Fields that are not specified are not included in the ParticipationResult. **Important**: Using the `aggregateBy` parameter with `partnerHotelId` or more than two values can result in an error. Filtering with `partnerHotelId` and `date` to reduce the number of rows can prevent the occurrence of errors.",
                  "location": "query",
                  "type": "string"
                },
                "name": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string"
                }
              },
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "QueryParticipationReportResponse"
              },
              "path": "v3/{+name}/participationReportViews:query",
              "description": "Provides the ability to query (get, filter, and segment) a participation report for a particular account."
            }
          }
        },
        "reconciliationReports": {
          "methods": {
            "list": {
              "path": "v3/{+parent}/reconciliationReports",
              "description": "Returns a list of the names of created reconciliation reports.",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListReconciliationReportsResponse"
              },
              "flatPath": "v3/accounts/{accountsId}/reconciliationReports",
              "parameters": {
                "endDate": {
                  "description": "End of date range to fetch files for. Format is yyyy-mm-dd[THH[:MM[:SS]]]. If empty, reports until the end of time are fetched.",
                  "location": "query",
                  "type": "string"
                },
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string"
                },
                "startDate": {
                  "description": "Beginning of date range to fetch files for. Format is yyyy-MM-dd[THH[:mm[:SS]]]. If empty, reports from the beginning of time onwards are fetched.",
                  "location": "query",
                  "type": "string"
                }
              },
              "id": "travelpartner.accounts.reconciliationReports.list",
              "httpMethod": "GET"
            },
            "get": {
              "flatPath": "v3/accounts/{accountsId}/reconciliationReports/{reconciliationReportsId}",
              "id": "travelpartner.accounts.reconciliationReports.get",
              "httpMethod": "GET",
              "parameters": {
                "name": {
                  "description": "The resource name of the reconciliation report to fetch. The format is `accounts/{account_id}/reconciliationReports/{datetime}~{filename}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/reconciliationReports/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "ReconciliationReport"
              },
              "path": "v3/{+name}",
              "description": "Returns a reconciliation report."
            },
            "create": {
              "path": "v3/{+parent}/reconciliationReports",
              "description": "Creates a reconciliation report and uploads it to Google.",
              "flatPath": "v3/accounts/{accountsId}/reconciliationReports",
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "request": {
                "$ref": "ReconciliationReport"
              },
              "id": "travelpartner.accounts.reconciliationReports.create",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "CreateReconciliationReportResponse"
              },
              "httpMethod": "POST"
            },
            "validate": {
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ValidateReconciliationReportResponse"
              },
              "httpMethod": "POST",
              "path": "v3/{+parent}/reconciliationReports:validate",
              "description": "Validates a reconciliation report.",
              "flatPath": "v3/accounts/{accountsId}/reconciliationReports:validate",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string"
                }
              },
              "request": {
                "$ref": "ReconciliationReport"
              },
              "id": "travelpartner.accounts.reconciliationReports.validate"
            }
          }
        },
        "listings": {
          "methods": {
            "verify": {
              "id": "travelpartner.accounts.listings.verify",
              "parameters": {
                "parent": {
                  "description": "The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                }
              },
              "request": {
                "$ref": "VerifyListingsRequest"
              },
              "flatPath": "v3/accounts/{accountsId}/listings:verify",
              "path": "v3/{+parent}/listings:verify",
              "description": "Returns verified listings with data issues and serving eligibilities for VR partners only.",
              "httpMethod": "POST",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "VerifyListingsResponse"
              }
            }
          }
        },
        "brands": {
          "methods": {
            "list": {
              "id": "travelpartner.accounts.brands.list",
              "httpMethod": "GET",
              "parameters": {
                "pageToken": {
                  "description": "Optional. Page token, received from a previous `ListBrands` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListBrands` (except `page_size` and `page_token`) must match the call that provided the page token.",
                  "location": "query",
                  "type": "string"
                },
                "parent": {
                  "description": "Required. The resource name of the account being queried. The format is `accounts/{account_id}`.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true
                },
                "pageSize": {
                  "description": "Optional. The maximum number of brands to return. The service may return fewer than this value. If unspecified, at most 10,000 brands will be returned. The maximum value is 10,000; values above 10,000 will be coerced to 10,000.",
                  "location": "query",
                  "type": "integer",
                  "format": "int32"
                }
              },
              "flatPath": "v3/accounts/{accountsId}/brands",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "ListBrandsResponse"
              },
              "path": "v3/{+parent}/brands",
              "description": "Returns the brands for a partner account."
            },
            "get": {
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "Brand"
              },
              "path": "v3/{+name}",
              "description": "Returns the `Brand` instance associated with the request URI's brand resource name.",
              "id": "travelpartner.accounts.brands.get",
              "httpMethod": "GET",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/brands/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The brand's resource name. The format is `accounts/{account_id}/brands/{brand_id}`.",
                  "type": "string"
                }
              },
              "flatPath": "v3/accounts/{accountsId}/brands/{brandsId}"
            },
            "create": {
              "flatPath": "v3/accounts/{accountsId}/brands",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the Hotel Center account being queried. The format is `accounts/{account_id}`.",
                  "type": "string"
                },
                "brandId": {
                  "description": "Required. The partner-determined brand identifier.",
                  "location": "query",
                  "type": "string"
                }
              },
              "request": {
                "$ref": "Brand"
              },
              "id": "travelpartner.accounts.brands.create",
              "path": "v3/{+parent}/brands",
              "description": "Creates a new brand. Because Google detects brands from your existing properties, you only need this operation when you want to configure a brand before you send its properties to Google. Note that it might take a couple of days after your listing feed first provides a brand for the brand to appear.",
              "httpMethod": "POST",
              "parameterOrder": [
                "parent"
              ],
              "response": {
                "$ref": "Brand"
              }
            },
            "patch": {
              "path": "v3/{+name}",
              "description": "Updates a brand.",
              "id": "travelpartner.accounts.brands.patch",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/brands/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Output only. The resource name for the brand in the format `accounts/{account_id}/brands/{brand_id}`. The `brand_id` corresponds to the partner's brand identifier used for landing page matching and the property-level brand identifier. A default brand is applied to properties that do not have a brand. The `brand_id` of the default brand is `NO_BRAND_ID`. It can be fetched and updated like any configured brand.",
                  "type": "string"
                },
                "updateMask": {
                  "description": "Required. The field to update. Only the `display_names` and `icon` fields can be updated. Use the syntax shown in the example URI below and provide the new value in the request body. Example request URI and request body: ``` PATCH https://travelpartner.googleapis.com/v3/accounts/123456789/ brands/my-brand?update_mask=brand.display_names ``` ``` { \"display_names\": [{ \"language\": \"en\" \"text\": \"Gilles' Gites\" }] } ``` The information above is sufficient for forming the URI and request body. The sentence below is auto-generated, supplemental information about the `FieldMask` format in general.",
                  "location": "query",
                  "type": "string",
                  "format": "google-fieldmask"
                },
                "allowMissing": {
                  "description": "When true, and the Brand is not found, a new Brand will be created. In this situation, `update_mask` is ignored.",
                  "location": "query",
                  "type": "boolean"
                }
              },
              "request": {
                "$ref": "Brand"
              },
              "flatPath": "v3/accounts/{accountsId}/brands/{brandsId}",
              "parameterOrder": [
                "name"
              ],
              "response": {
                "$ref": "Brand"
              },
              "httpMethod": "PATCH"
            }
          }
        }
      }
    }
  },
  "version_module": true,
  "ownerDomain": "google.com",
  "rootUrl": "https://travelpartner.googleapis.com/",
  "revision": "20260406",
  "name": "travelpartner",
  "ownerName": "Google",
  "schemas": {
    "QueryFreeBookingLinksReportResponse": {
      "id": "QueryFreeBookingLinksReportResponse",
      "deprecated": true,
      "description": "**DEPRECATED:** Use `QueryPropertyPerformanceReportResponse` with `PropertyPerformanceReportService` instead. Response message for FreeBookingLinksReportService.QueryFreeBookingLinksReport.",
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "Pagination token used to retrieve the next page of results. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "results": {
          "description": "The list of results that match the query.",
          "type": "array",
          "items": {
            "$ref": "FreeBookingLinksResult"
          }
        }
      }
    },
    "HotelView": {
      "description": "A hotel view.",
      "type": "object",
      "id": "HotelView",
      "properties": {
        "partnerHotelId": {
          "description": "The unique ID of the hotel that the partner provides in their Hotel List Feed.",
          "type": "string"
        },
        "overclusteredPartnerHotelIds": {
          "description": "Other hotels with which the hotel is overclustered. If your feed contains overclustered hotels, update the feed and resubmit it. To do this, you can use the manual match tool.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "propertyDetails": {
          "description": "Optional. A URL to the property on Google. Only available for properties that are listed.",
          "type": "string"
        },
        "matchFailureReasons": {
          "description": "The reasons why a hotel failed to match to a property on Maps.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "googleHotelId": {
          "description": "Google's canonical ID for the hotel.",
          "type": "string",
          "format": "uint64"
        },
        "googleClusterId": {
          "description": "The Google Maps identifier for the hotel.",
          "type": "string",
          "format": "uint64"
        },
        "primaryOverclusteredPartnerHotelId": {
          "description": "The primary hotel in the overclustered set.",
          "type": "string"
        },
        "dataIssueDetail": {
          "items": {
            "$ref": "DataIssueDetail"
          },
          "description": "The type and severity of each data quality issue in the feed. If your feed contains data issues, update the feed and resubmit it. For more information, refer to this article.",
          "type": "array"
        },
        "googleHotelDisplayName": {
          "description": "Google's hotel name.",
          "type": "string"
        },
        "partnerHotelDisplayName": {
          "description": "Partner's hotel name.",
          "type": "string"
        },
        "liveOnGoogleStatus": {
          "enumDescriptions": [
            "Not specified.",
            "The property will show on Google unconditionally.",
            "The property will not show on Google.",
            "The property will show on Google for users outside of DSA regions. Current regions include: EU."
          ],
          "enum": [
            "LIVE_ON_GOOGLE_STATUS_UNSPECIFIED",
            "LIVE_ON_GOOGLE_STATUS_ACTIVE",
            "LIVE_ON_GOOGLE_STATUS_INACTIVE",
            "LIVE_ON_GOOGLE_STATUS_ACTIVE_OUTSIDE_DSA_REGION"
          ],
          "description": "Optional. Whether the hotel appears in Google's hotel booking links. Declaration & behavior to get detection of presence/absence in JSON conversion.",
          "type": "string"
        },
        "matchStatus": {
          "description": "Current matching status of the hotel.",
          "type": "string",
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "This hotel does not correspond to a hotel on Google Maps.",
            "This hotel corresponds to a hotel on Google Maps.",
            "More than one of your hotels match this hotel on Google Maps."
          ],
          "enum": [
            "MATCH_STATUS_UNSPECIFIED",
            "MATCH_STATUS_UNKNOWN",
            "NOT_MATCHED",
            "MATCHED",
            "MAP_OVERLAP"
          ]
        },
        "liveOnGoogle": {
          "description": "Optional. DEPRECATED. Prefer live_on_google_status. Whether the hotel appears in Google's hotel booking links. Declaration & behavior to get detection of presence/absence in JSON conversion.",
          "type": "boolean",
          "deprecated": true
        },
        "dataIssues": {
          "items": {
            "type": "string",
            "enumDeprecated": [
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              true,
              false,
              false,
              true,
              false,
              false,
              false,
              true,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false
            ],
            "enumDescriptions": [
              "Not specified.",
              "The value is unknown in this version.",
              "No data issues found.",
              "The address is the same as another property in the Hotel List Feed.",
              "The provided address appears to contain a postal box instead of a physical street address.",
              "The address does not appear to contain a street name.",
              "The address does not appear to contain a street number.",
              "The address does not appear to contain a street number, street name, or supported country code.",
              "An invalid but recognized country code was provided.",
              "The address contains an invalid postal code.",
              "The address contains an invalid postal code suffix.",
              "The address contains a postal code suffix when unsupported by the country's postal code system.",
              "The address contains a postal code when unsupported by the country's postal code system.",
              "The name and value at 'listing.content.attributes.attr' is either unsupported or has an invalid value.",
              "The email at 'listing.content.attributes.attr[name='email']' is not a valid email address.",
              "The latitude/longitude pair is the same as another property in the Hotel List Feed.",
              "The latitude/longitude pair provided for the address is more than 500 meters away from the Google latitude/longitude generated from the address.",
              "A valid pair of latitude/longitude fields is missing and Google latitude/longitude generation is disabled.",
              "A valid pair of latitude/longitude fields is missing and Google could not generate them from the address.",
              "No hotel name is provided.",
              "An empty or whitespace only name is provided, but no valid name.",
              "An invalid name is provided, but no valid name.",
              "The hotel name exceeds 200 characters.",
              "Google encountered an error while importing your Hotel List Feed.",
              "Google encountered an unknown error while importing your Hotel List Feed.",
              "The phone number you provided for this property is the same as the phone number for another property. More than one listing in the Hotel List Feed cannot have the same phone number.",
              "No valid phone number for this property found.",
              "Only invalid or fax phone numbers found.",
              "The phone number format is not valid.",
              "The phone number is not valid.",
              "The country code of the phone number is not valid.",
              "The phone number contains too many digits.",
              "The phone number contains has too few digits.",
              "The specified `content.attributes.attr[name='website']` element is not a valid URL.",
              "The category or `content.attributes.client_attr[name='hotel_brand']` element exceeds 70 Unicode characters, and/or `content.attributes.client_attr[name='custom_*']` exceeds 100 Unicode characters.",
              "Contact your account manager for details.",
              "Vacation rental properties must have at least five feed images. Eight or more images are strongly recommended; having fewer than 8 may impact performance (such as impressions and clicks).",
              "The images for this vacation rental property are still being processed.",
              "The images for this property cannot be fetched. Please check that the image URLs are valid (e.g. do not give a 404 error) and that the domain hosting the image URLs does not block crawling of these images in its robots.txt file or X-Robots-Tag HTTP Header.",
              "The images provided for this property do not meet Google's requirements due to dimensions, size, or automated quality signals. Please ensure that the images are less than 10 MB large, less than 4K pixels wide, and less than 4K pixels tall. Please check additional guidance outlined at the [Property listing image requirements](/hotels/vacation-rentals/dev-guide/onboarding#property_listing_image_requirements)",
              "Deprecated Issue Vacation rental raw listing is missing a language field.",
              "Vacation rental listing has been characterized as a hotel and not a vacation rental.",
              "Vacation rental listing is missing a required attribute.",
              "Vacation rental listing is missing a name.",
              "Vacation rental listing name is missing a language field.",
              "Vacation rental listing name is too long.",
              "Vacation rental listing's name or description is verfied to contain content that violates Google's content policy.",
              "Vacation rental listing is a test property.",
              "Please use NON_VR_ACCOMMODATION_TYPE instead.",
              "Listing that is sent as a vacation rental is suspected to be a non-vacation rental accommodation type, such as a hotel, hostel, etc.",
              "Vacation rental listing brand name is too long.",
              "Google no longer requires brand names; this issue no longer occurs.",
              "This listing has a review that is missing a visit timestamp and the timestamp is required in the listing's country. The review should include \"servicedate\" if using XML markup or \"contentReferenceTime\" if using schema.org.",
              "An address should be added to this listing.",
              "The provided address is invalid. Review address requirements on the [dev guide](/hotels/vacation-rentals/dev-guide/vr-attributes). Debugging suggestions: 1. Confirm the address does not contain redundant information such as the country in both addr1 and country_code. 2. Use Google Maps to confirm if the address is formatted correctly for its region. 3. Use a [plus code](https://plus.codes) if the address continues to be invalid.",
              "Deprecated: Replaced with more specifc errors or VR_ADDRESS_INVALID. Google detected that the provided address for this listing is incomplete. For example, it may be missing a unit number.",
              "The provided address is missing a street name.",
              "The provided address is missing a street number.",
              "The provided address is missing a unit number.",
              "The provided address and lat/long data for this listing doesn't match.",
              "Vacation rental listing has an invalid review rating.",
              "Vacation rental listing has an invalid check-in format.",
              "Vacation rental listing has an invalid check-out format.",
              "This listing is in an internal blocklist. Contact your account manager for help.",
              "The \"Live on Google\" setting for this Vacation Rental is set to false. Note: once \"Live on Google\" is set to true, it will take a few days for this error to disappear.",
              "This listing's XML failed to parse. Please fix the XML associated with this listing.",
              "A listing that indicates the that feed ZIP file is corrupt. Please ensure the ZIP file is valid.",
              "Vacation rental listing is undergoing initial processing.",
              "Vacation rental listing has a website link that is blocked by a robots.txt",
              "Vacation rental listing has a website link that is still undergoing crawling.",
              "Vacation rental listing has a website link with a crawling error.",
              "The brand of this vacation rental property doesn't have a landing page. Contact your account manager for details.",
              "The room type is invalid. Private rooms and shared rooms are part of shared accommodations, which are not currently supported on the platform."
            ],
            "enum": [
              "FEED_DATA_ISSUE_UNSPECIFIED",
              "FEED_DATA_ISSUE_UNKNOWN",
              "NO_DATA_ISSUE",
              "DUPLICATE_ADDRESS",
              "MISSING_PHYSICAL_STREET_ADDRESS",
              "MISSING_STREET_NAME",
              "MISSING_STREET_NUMBER",
              "MISSING_ADDRESS",
              "MISSING_COUNTRY",
              "INVALID_POSTAL_CODE",
              "INVALID_POSTAL_CODE_SUFFIX",
              "UNEXPECTED_POSTAL_CODE_SUFFIX",
              "UNEXPECTED_POSTAL_CODE",
              "INVALID_AMENITIES",
              "INVALID_EMAIL_ADDRESS",
              "DUPLICATE_LATLONG",
              "LATLONG_INCONSISTENT_WITH_ADDRESS",
              "MISSING_LATLONG",
              "COULD_NOT_GEOCODE",
              "MISSING_HOTEL_NAME",
              "HOTEL_NAME_EMPTY",
              "INVALID_HOTEL_NAME",
              "HOTEL_NAME_TOO_LONG",
              "PARSE_ERROR_IN_XML",
              "UNEXPECTED_ATTRIBUTE_IN_XML",
              "DUPLICATE_PHONE_NUMBER",
              "MISSING_PHONE_NUMBER",
              "MISSING_VOICE_PHONE_NUMBER",
              "INVALID_PHONE_NUMBER_FORMAT",
              "INVALID_PHONE_NUMBER",
              "INVALID_PHONE_NUMBER_COUNTRY_CODE",
              "PHONE_NUMBER_TOO_LONG",
              "PHONE_NUMBER_TOO_SHORT",
              "INVALID_WEBSITE_URL",
              "ADWORDS_ATTRIBUTE_TOO_LONG",
              "FLAGGED_DUE_TO_SUSPICIOUS_METADATA",
              "NOT_ENOUGH_IMAGES_PROVIDED",
              "IMAGE_PROCESSING_IN_PROGRESS",
              "CANNOT_FETCH_IMAGES",
              "INCOMPATIBLE_IMAGE_SIZE_OR_LOW_QUALITY",
              "MISSING_LANG_IN_RAW_LISTING",
              "IS_HOTEL",
              "MISSING_REQ_ATTR",
              "MISSING_NAME",
              "MISSING_LANG_IN_NAME",
              "VR_NAME_TOO_LONG",
              "NAME_AND_DESCRIPTION_ABUSE_VERIFIED",
              "TEST_PROPERTY",
              "NON_VR_ACCOMMODATION_TYPE_BASED_ON_LISTING_NAME",
              "NON_VR_ACCOMMODATION_TYPE",
              "BRAND_NAME_TOO_LONG",
              "MISSING_BRAND_NAME",
              "REVIEW_MISSING_VISIT_TIMESTAMP",
              "VR_ADDRESS_MISSING",
              "VR_ADDRESS_INVALID",
              "VR_ADDRESS_INCOMPLETE",
              "VR_ADDRESS_INCOMPLETE_NO_STREET_NAME",
              "VR_ADDRESS_INCOMPLETE_NO_STREET_NUMBER",
              "VR_ADDRESS_INCOMPLETE_NO_UNIT_NUMBER",
              "VR_ADDRESS_LATLONG_MISMATCH",
              "INVALID_REVIEW_RATING",
              "INVALID_CHECKIN_FORMAT",
              "INVALID_CHECKOUT_FORMAT",
              "INTERNAL_BLOCKLIST",
              "VR_LIVE_ON_GOOGLE_INACTIVE_ERROR",
              "VR_XML_FAILED_PARSING",
              "VR_ZIP_FILE_CORRUPT",
              "VR_PENDING_INITIAL_PROCESSING",
              "VR_WEBSITE_LINK_ROBOTED",
              "VR_PENDING_WEBSITE_CRAWLING",
              "VR_WEBSITE_LINK_WITH_CRAWLING_ERROR",
              "VR_BRAND_MISSING_LANDING_PAGE",
              "VR_INVALID_ROOM_TYPE"
            ]
          },
          "description": "DEPRECATED. Indicates that the hotel has data quality issues. The value of this field indicates the type of error. This has been replaced with the data_issue_detail field. If your feed contains data issues, update the feed and resubmit it. For more information, refer to this article.",
          "type": "array"
        }
      }
    },
    "PriceRecord": {
      "description": "A price record.",
      "type": "object",
      "properties": {
        "currencyCode": {
          "description": "ISO 4217 currency code.",
          "type": "string"
        },
        "taxesAndFees": {
          "description": "Taxes and fees.",
          "type": "number",
          "format": "float"
        },
        "basePrice": {
          "description": "Base price.",
          "type": "number",
          "format": "float"
        },
        "time": {
          "description": "Timestamp of this price record.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "id": "PriceRecord"
    },
    "SetLiveOnGoogleRequest": {
      "properties": {
        "liveOnGoogle": {
          "description": "Optional. DEPRECATED. Whether the property will show on Google. When true, Google will show the properties if their integration is complete and the property is available. When false, Google will never show the properties. Superseded by `live_on_google_status`. Only one of `live_on_google` or `live_on_google_status` should be set; if both are set, `live_on_google_status` will be used.",
          "type": "boolean",
          "deprecated": true
        },
        "partnerHotelIds": {
          "description": "Required. Identifies the properties to update with the liveOnGoogle setting.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "liveOnGoogleStatus": {
          "description": "Optional. Whether the property will show on Google, with more granular controls than the original `live_on_google` boolean field. Only one of `live_on_google` or `live_on_google_status` should be set; if both are set, `live_on_google_status` will be used. **Note:** This field should be enclosed in quotes. For example, `\"LIVE_ON_GOOGLE_STATUS_INACTIVE\"`.",
          "type": "string",
          "enumDescriptions": [
            "Not specified.",
            "The property will show on Google unconditionally.",
            "The property will not show on Google.",
            "The property will show on Google for users outside of DSA regions. Current regions include: EU."
          ],
          "enum": [
            "LIVE_ON_GOOGLE_STATUS_UNSPECIFIED",
            "LIVE_ON_GOOGLE_STATUS_ACTIVE",
            "LIVE_ON_GOOGLE_STATUS_INACTIVE",
            "LIVE_ON_GOOGLE_STATUS_ACTIVE_OUTSIDE_DSA_REGION"
          ]
        }
      },
      "id": "SetLiveOnGoogleRequest",
      "description": "Request message for HotelService.SetLiveOnGoogle.",
      "type": "object"
    },
    "SummarizePriceAccuracyResponse": {
      "id": "SummarizePriceAccuracyResponse",
      "properties": {
        "currentWebsiteScore": {
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "description": "The current website price accuracy score.",
          "type": "string"
        },
        "currentScore": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "description": "The current price accuracy score. Contains the same value as `current_website_score`. For clarity, use either `current_website_score` or 'current_overall_score` depending upon which is needed.",
          "type": "string",
          "deprecated": true
        },
        "predictedOverallScore": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "description": "The predicted price accuracy score combining both website and Book on Google scores.",
          "type": "string"
        },
        "predictedScore": {
          "deprecated": true,
          "description": "The predicted price accuracy score. Contains the same value as `predicted_website_score`. For clarity, use either `predicted_website_score` or 'predicted_overall_score` depending upon which is needed.",
          "type": "string",
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ]
        },
        "predictedBookOnGoogleScore": {
          "description": "The predicted Book on Google price accuracy score.",
          "type": "string",
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ]
        },
        "currentOverallScore": {
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "description": "The current price accuracy score combining both website and Book on Google scores.",
          "type": "string"
        },
        "predictedWebsiteScore": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "description": "The predicted website price accuracy score.",
          "type": "string"
        },
        "currentBookOnGoogleScore": {
          "enum": [
            "PRICE_ACCURACY_STATE_UNSPECIFIED",
            "PRICE_ACCURACY_STATE_UNKNOWN",
            "EXCELLENT",
            "GOOD",
            "POOR",
            "AT_RISK",
            "FAILED"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Average score exceeds the positioning threshold.",
            "Average score is slightly below the positioning threshold. “Good” has been renamed to “Fair” in Hotel Center.",
            "Average score is well below the positioning threshold.",
            "Average score is close to the account suspension threshold.",
            "Average score is below the account suspension threshold."
          ],
          "description": "The current Book on Google price accuracy score.",
          "type": "string"
        },
        "updateTime": {
          "description": "The update timestamp for the current score.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "description": "Response message for PriceAccuracyViewService.SummarizePriceAccuracy.",
      "type": "object"
    },
    "PropertyPerformanceResult": {
      "id": "PropertyPerformanceResult",
      "properties": {
        "adsImpressionCount": {
          "description": "The total number of ad impressions that were recorded for this result.",
          "type": "string",
          "format": "int64"
        },
        "date": {
          "description": "A date within the requested date range. Only present if `date` is specified in `aggregateBy` in the request.",
          "$ref": "Date"
        },
        "highIntentUsers": {
          "description": "Whether the user’s query indicated a strong interest in booking. Only present if `highIntentUsers` is specified in `aggregateBy` in the request.",
          "type": "boolean"
        },
        "partnerPropertyId": {
          "description": "Partner's property ID. Only present if `partnerPropertyId` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "impressionCount": {
          "description": "The total number of free booking link impressions that were recorded for this result. This value is rounded to preserve user privacy.",
          "type": "string",
          "format": "int64"
        },
        "occupancy": {
          "description": "Requested number of people staying at the property. Only present if `partnerPropertyId` is specified in `aggregateBy` in the request.",
          "type": "string",
          "enum": [
            "OCCUPANCY_UNSPECIFIED",
            "OCCUPANCY_1",
            "OCCUPANCY_2",
            "OCCUPANCY_3",
            "OCCUPANCY_4",
            "OCCUPANCY_OVER_4"
          ],
          "enumDescriptions": [
            "Not specified.",
            "Single person.",
            "Two people.",
            "Three people.",
            "Four people.",
            "Over 4 people."
          ]
        },
        "deviceType": {
          "enum": [
            "DEVICE_UNSPECIFIED",
            "DEVICE_UNKNOWN",
            "DESKTOP",
            "MOBILE",
            "TABLET"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Computers.",
            "Mobile devices with full browsers.",
            "Tablets with full browsers."
          ],
          "description": "The user’s device type. Only present if `deviceType` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "brand": {
          "description": "Partner-specified brand for the property. Only present if `brand` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "clickCount": {
          "description": "The total number of free booking link clicks that were recorded for this result.",
          "type": "string",
          "format": "int64"
        },
        "partnerPropertyDisplayName": {
          "description": "Partner's property name. Only present if `partnerPropertyDisplayName` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "clickthroughRate": {
          "description": "Equal to `click_count` divided by `impression_count`.",
          "type": "number",
          "format": "double"
        },
        "adsClickCount": {
          "description": "The total number of ad clicks that were recorded for this result.",
          "type": "string",
          "format": "int64"
        },
        "vrWebsiteButtonClicks": {
          "description": "The total number of clicks on the \"Website\" button on Google for vacation rentals.",
          "type": "string",
          "format": "int64"
        },
        "lengthOfStay": {
          "enumDescriptions": [
            "Not specified.",
            "Single night stay.",
            "Stay of 2 nights.",
            "Stay of 3 nights.",
            "Stay of 4-7 nights.",
            "Stay of 8-14 nights.",
            "Stay of 15-21 nights.",
            "Stay of 22-30 nights.",
            "Stay of over 30 nights."
          ],
          "enum": [
            "LENGTH_OF_STAY_UNSPECIFIED",
            "LENGTH_OF_STAY_NIGHTS_1",
            "LENGTH_OF_STAY_NIGHTS_2",
            "LENGTH_OF_STAY_NIGHTS_3",
            "LENGTH_OF_STAY_NIGHTS_4_TO_7",
            "LENGTH_OF_STAY_NIGHTS_8_TO_14",
            "LENGTH_OF_STAY_NIGHTS_15_TO_21",
            "LENGTH_OF_STAY_NIGHTS_22_TO_30",
            "LENGTH_OF_STAY_NIGHTS_OVER_30"
          ],
          "description": "Number of nights between check-in and check-out dates specified by user. Only present if `lengthOfStay` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "propertyRegionCode": {
          "description": "ISO 3116 region code of the country/region of the property. Only present if `propertyRegionCode` is specified in `aggregateBy` in the request",
          "type": "string"
        },
        "advanceBookingWindow": {
          "enumDescriptions": [
            "Not specified.",
            "Check-in date was same as query date.",
            "Check-in date was next day after query date.",
            "Check-in date was 2-7 days after query date.",
            "Check-in date was 8-14 days after query date.",
            "Check-in date was 15-30 days after query date.",
            "Check-in date was 31-60 days after query date.",
            "Check-in date was 61-90 days after query date.",
            "Check-in date was 91-120 days after query date.",
            "Check-in date was 121-150 days after query date.",
            "Check-in date was 151-180 days after query date.",
            "Check-in date was over 180 days after query date."
          ],
          "enum": [
            "ADVANCE_BOOKING_WINDOW_UNSPECIFIED",
            "ADVANCE_BOOKING_WINDOW_SAME_DAY",
            "ADVANCE_BOOKING_WINDOW_NEXT_DAY",
            "ADVANCE_BOOKING_WINDOW_DAYS_2_TO_7",
            "ADVANCE_BOOKING_WINDOW_DAYS_8_TO_14",
            "ADVANCE_BOOKING_WINDOW_DAYS_15_TO_30",
            "ADVANCE_BOOKING_WINDOW_DAYS_31_TO_60",
            "ADVANCE_BOOKING_WINDOW_DAYS_61_TO_90",
            "ADVANCE_BOOKING_WINDOW_DAYS_91_TO_120",
            "ADVANCE_BOOKING_WINDOW_DAYS_121_TO_150",
            "ADVANCE_BOOKING_WINDOW_DAYS_151_TO_180",
            "ADVANCE_BOOKING_WINDOW_DAYS_OVER_180"
          ],
          "description": "Difference in days between query date and check-in date in property's local timezone. Only present if `advanceBookingWindow` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "adsClickthroughRate": {
          "description": "Equal to `ads_click_count` divided by `ads_impression_count`.",
          "type": "number",
          "format": "double"
        },
        "userRegionCode": {
          "description": "ISO 3116 region code of the country/region of the user. Only present if `userRegionCode` is specified in `aggregateBy` in the request",
          "type": "string"
        }
      },
      "description": "Represents a result from querying for the property performance report for an account.",
      "type": "object"
    },
    "Empty": {
      "id": "Empty",
      "properties": {},
      "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }",
      "type": "object"
    },
    "SummarizeHotelViewsResponse": {
      "description": "Response message for HotelViewService.SummarizeHotelViews.",
      "type": "object",
      "id": "SummarizeHotelViewsResponse",
      "properties": {
        "overclusteredPropertyCount": {
          "description": "The number of hotels that are considered overclustered.",
          "type": "string",
          "format": "int64"
        },
        "unmatchedPropertyWithErrorsCount": {
          "description": "The number of unmatched properties that have data-related errors.",
          "type": "string",
          "format": "int64"
        },
        "overclusteredPropertyWithErrorsCount": {
          "description": "The number of overclustered properties that have data-related errors.",
          "type": "string",
          "format": "int64"
        },
        "unmatchedPropertyCount": {
          "description": "The number of properties that are considered unmatched.",
          "type": "string",
          "format": "int64"
        },
        "lastManifestUpdateTime": {
          "description": "Timestamp of the last hotel manifest update.",
          "type": "string",
          "format": "google-datetime"
        },
        "matchedPropertyCount": {
          "description": "The number of properties that match Google's manifest.",
          "type": "string",
          "format": "int64"
        },
        "lastFeedSubmissionTime": {
          "description": "Timestamp of the last hotel feed submission.",
          "type": "string",
          "format": "google-datetime"
        },
        "liveOnGooglePropertyCount": {
          "description": "The number of properties that are Live on Google. This includes properties that are conditionally active, e.g. LIVE_ON_GOOGLE_STATUS_ACTIVE_OUTSIDE_DSA_REGION.",
          "type": "string",
          "format": "int64"
        }
      }
    },
    "QueryParticipationReportResponse": {
      "properties": {
        "results": {
          "items": {
            "$ref": "ParticipationResult"
          },
          "description": "The list of results that matches the query.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "Pagination token used to retrieve the next page of results.",
          "type": "string"
        }
      },
      "id": "QueryParticipationReportResponse",
      "description": "Response message for ParticipationReportService.QueryParticipationReport.",
      "type": "object"
    },
    "ListPriceAccuracyViewsResponse": {
      "id": "ListPriceAccuracyViewsResponse",
      "properties": {
        "priceAccuracyViews": {
          "description": "The list of rows that match the query.",
          "type": "array",
          "items": {
            "$ref": "PriceAccuracyView"
          }
        }
      },
      "description": "Response message for PriceAccuracyViewService.ListPriceAccuracyViews.",
      "type": "object"
    },
    "DisplayNameDisapprovalReason": {
      "description": "Disapproval reason of the display name in a specific language.",
      "type": "object",
      "properties": {
        "languageCode": {
          "description": "Language of the disapproved display name.",
          "type": "string"
        },
        "disapprovalReason": {
          "description": "Disapproval reason.",
          "type": "string",
          "enumDescriptions": [
            "Not specified.",
            "The display name has bad formatting and/or contains punctuation.",
            "The display name contains marketing language.",
            "The display name does not match the landing page.",
            "The display name does not appear to be a brand."
          ],
          "enum": [
            "DISAPPROVAL_REASON_UNSPECIFIED",
            "PUNCTUATION",
            "MARKETING_LANGUAGE",
            "LANDING_PAGE_NOT_MATCHED",
            "NOT_BRAND_NAME"
          ]
        }
      },
      "id": "DisplayNameDisapprovalReason"
    },
    "Image": {
      "description": "A single image in a VR Listing. Title and gallery URL are stored per locale. NEXT ID: 4",
      "type": "object",
      "properties": {
        "title": {
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "Title of the image.",
          "type": "array"
        },
        "galleryUri": {
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "URL that is deeplink to the image in a gallery (or a webpage).",
          "type": "array"
        },
        "uri": {
          "description": "URL that points to the binary image content directly.",
          "type": "string"
        }
      },
      "id": "Image"
    },
    "PriceUnavailableCountDetails": {
      "description": "The reasons that contributed to the price unavailable count and the total count for each reason.",
      "type": "object",
      "id": "PriceUnavailableCountDetails",
      "properties": {
        "participationNotLikelyCount": {
          "description": "No price was cached for this itinerary, and no live query was done because your server usually tells us the hotel is unavailable or sold out.",
          "type": "string",
          "format": "int64"
        },
        "priceUnavailableCount": {
          "description": "Hotel did not participate because it wasn't available for the itinerary dates.",
          "type": "string",
          "format": "int64"
        }
      }
    },
    "PriceView": {
      "description": "A price view. Covers the Prices functionality in pre-v3.0 API versions.",
      "type": "object",
      "properties": {
        "name": {
          "description": "Resource name in the format `accounts/{account_id}/priceViews/{partner_hotel_id}`.",
          "type": "string"
        },
        "perItineraryPrices": {
          "description": "Price for each itinerary.",
          "type": "array",
          "items": {
            "$ref": "HotelPricePerItinerary"
          }
        }
      },
      "id": "PriceView"
    },
    "ReconciliationReportValidationIssue": {
      "properties": {
        "description": {
          "description": "Text description of the issue, typically including what was seen and why it was invalid.",
          "type": "string"
        },
        "lineNum": {
          "description": "The line number on which the issue was detected. If this field is 0, the issue applies to the whole file.",
          "type": "integer",
          "format": "int32"
        },
        "fieldName": {
          "description": "Name of the invalid field. If no field name is given, this issue applies to the whole line (or file).",
          "type": "string"
        }
      },
      "id": "ReconciliationReportValidationIssue",
      "description": "Represents an issue encountered when validating a reconciliation report.",
      "type": "object"
    },
    "Review": {
      "description": "A single review in a VR Listing. NEXT ID: 10",
      "type": "object",
      "properties": {
        "visitTime": {
          "description": "Unix timestamp (in seconds) of when the stay was, in UTC+0.",
          "type": "string",
          "format": "google-datetime"
        },
        "body": {
          "description": "The body of the review.",
          "type": "string"
        },
        "languageCode": {
          "description": "Language of the review in ISO639 format, such as \"en\", \"de\", etc.",
          "type": "string"
        },
        "title": {
          "description": "The title of the review, for example: Great three bedrooms.",
          "type": "string"
        },
        "reviewTime": {
          "description": "Unix timestamp (in seconds) of the review, in UTC+0.",
          "type": "string",
          "format": "google-datetime"
        },
        "author": {
          "description": "The author of the review.",
          "type": "string"
        },
        "link": {
          "description": "The url of the review.",
          "type": "string"
        },
        "rating": {
          "description": "Any ratings associated with this review. This is repeated because reviews can include ratings on different aspects of a listing, e.g. location, cleanliness, etc.",
          "type": "array",
          "items": {
            "$ref": "Rating"
          }
        },
        "type": {
          "enum": [
            "UNKNOWN",
            "EDITORIAL",
            "USER"
          ],
          "enumDescriptions": [
            "Review type is unknown.",
            "Review is of editorial type.",
            "Review is of user type."
          ],
          "description": "The type of the review.",
          "type": "string"
        }
      },
      "id": "Review"
    },
    "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",
      "type": "object",
      "properties": {
        "year": {
          "description": "Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.",
          "type": "integer",
          "format": "int32"
        },
        "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.",
          "type": "integer",
          "format": "int32"
        },
        "month": {
          "description": "Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "Date"
    },
    "Rating": {
      "description": "A rating for a vacation rentals listing. NEXT ID: 4",
      "type": "object",
      "id": "Rating",
      "properties": {
        "score": {
          "description": "The rating score. (e.g. 8.5)",
          "type": "number",
          "format": "float"
        },
        "ratingScale": {
          "description": "Maximum rating possible.",
          "type": "integer",
          "format": "int32"
        },
        "type": {
          "description": "The type of the rating.",
          "type": "string",
          "enum": [
            "TYPE_UNSPECIFIED",
            "OVERALL"
          ],
          "enumDescriptions": [
            "Rating type is unspecified.",
            "Rating is of overall type."
          ]
        }
      }
    },
    "PriceCoverageBucket": {
      "properties": {
        "advanceBookingWindowRange": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Represents advance booking window between 0 and 30 days.",
            "Represents advance booking window between 31 and 60 days.",
            "Represents advance booking window between 61 and 90 days.",
            "Represents advance booking window between 91 and 120 days.",
            "Represents advance booking window between 121 and 150 days.",
            "Represents advance booking window between 151 and 180 days.",
            "Represents advance booking window between 181 and 210 days.",
            "Represents advance booking window between 211 and 240 days.",
            "Represents advance booking window between 241 and 270 days.",
            "Represents advance booking window between 271 and 300 days.",
            "Represents advance booking window between 301 and 330 days."
          ],
          "enum": [
            "ADVANCE_BOOKING_WINDOW_RANGE_UNSPECIFIED",
            "ADVANCE_BOOKING_WINDOW_RANGE_UNKNOWN",
            "DAYS_0_TO_30",
            "DAYS_31_TO_60",
            "DAYS_61_TO_90",
            "DAYS_91_TO_120",
            "DAYS_121_TO_150",
            "DAYS_151_TO_180",
            "DAYS_181_TO_210",
            "DAYS_211_TO_240",
            "DAYS_241_TO_270",
            "DAYS_271_TO_300",
            "DAYS_301_TO_330"
          ],
          "description": "Advance booking window range.",
          "type": "string"
        },
        "lengthOfStayRange": {
          "enum": [
            "LENGTH_OF_STAY_RANGE_UNSPECIFIED",
            "LENGTH_OF_STAY_RANGE_UNKNOWN",
            "LENGTH_OF_STAY_1_TO_7",
            "LENGTH_OF_STAY_8_TO_14",
            "LENGTH_OF_STAY_15_TO_30"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Represents length of stay from 1 to 7 nights.",
            "Represents length of stay from 8 to 14 nights.",
            "Represents length of stay from 15 to 30 nights."
          ],
          "description": "Length of stay range.",
          "type": "string"
        },
        "priceCoveragePercent": {
          "description": "The percent of itineraries for which you have coverage for this advance booking window bucket and length of stay bucket.",
          "type": "number",
          "format": "double"
        },
        "availablePriceCount": {
          "description": "Number of prices for this advance booking window bucket and length of stay bucket.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "PriceCoverageBucket",
      "description": "Coverage stats for one combination of advance booking window and length of stay.",
      "type": "object"
    },
    "ListIconsResponse": {
      "id": "ListIconsResponse",
      "properties": {
        "icons": {
          "description": "A list of all icons associated with the queried partner account.",
          "type": "array",
          "items": {
            "$ref": "Icon"
          }
        }
      },
      "description": "Response message for IconService.ListIcons.",
      "type": "object"
    },
    "DataIssueDetail": {
      "description": "Details on a data issue in the listing.",
      "type": "object",
      "id": "DataIssueDetail",
      "properties": {
        "isSelfResolving": {
          "description": "Whether or not the issue is self-resolving. If true, the issue is expected to resolve itself. If false or not set, action is needed to resolve the issue. Refer to documentation on the data issue’s type for further information.",
          "type": "boolean"
        },
        "dataIssueType": {
          "enumDeprecated": [
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            true,
            false,
            false,
            true,
            false,
            false,
            false,
            true,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false
          ],
          "enum": [
            "FEED_DATA_ISSUE_UNSPECIFIED",
            "FEED_DATA_ISSUE_UNKNOWN",
            "NO_DATA_ISSUE",
            "DUPLICATE_ADDRESS",
            "MISSING_PHYSICAL_STREET_ADDRESS",
            "MISSING_STREET_NAME",
            "MISSING_STREET_NUMBER",
            "MISSING_ADDRESS",
            "MISSING_COUNTRY",
            "INVALID_POSTAL_CODE",
            "INVALID_POSTAL_CODE_SUFFIX",
            "UNEXPECTED_POSTAL_CODE_SUFFIX",
            "UNEXPECTED_POSTAL_CODE",
            "INVALID_AMENITIES",
            "INVALID_EMAIL_ADDRESS",
            "DUPLICATE_LATLONG",
            "LATLONG_INCONSISTENT_WITH_ADDRESS",
            "MISSING_LATLONG",
            "COULD_NOT_GEOCODE",
            "MISSING_HOTEL_NAME",
            "HOTEL_NAME_EMPTY",
            "INVALID_HOTEL_NAME",
            "HOTEL_NAME_TOO_LONG",
            "PARSE_ERROR_IN_XML",
            "UNEXPECTED_ATTRIBUTE_IN_XML",
            "DUPLICATE_PHONE_NUMBER",
            "MISSING_PHONE_NUMBER",
            "MISSING_VOICE_PHONE_NUMBER",
            "INVALID_PHONE_NUMBER_FORMAT",
            "INVALID_PHONE_NUMBER",
            "INVALID_PHONE_NUMBER_COUNTRY_CODE",
            "PHONE_NUMBER_TOO_LONG",
            "PHONE_NUMBER_TOO_SHORT",
            "INVALID_WEBSITE_URL",
            "ADWORDS_ATTRIBUTE_TOO_LONG",
            "FLAGGED_DUE_TO_SUSPICIOUS_METADATA",
            "NOT_ENOUGH_IMAGES_PROVIDED",
            "IMAGE_PROCESSING_IN_PROGRESS",
            "CANNOT_FETCH_IMAGES",
            "INCOMPATIBLE_IMAGE_SIZE_OR_LOW_QUALITY",
            "MISSING_LANG_IN_RAW_LISTING",
            "IS_HOTEL",
            "MISSING_REQ_ATTR",
            "MISSING_NAME",
            "MISSING_LANG_IN_NAME",
            "VR_NAME_TOO_LONG",
            "NAME_AND_DESCRIPTION_ABUSE_VERIFIED",
            "TEST_PROPERTY",
            "NON_VR_ACCOMMODATION_TYPE_BASED_ON_LISTING_NAME",
            "NON_VR_ACCOMMODATION_TYPE",
            "BRAND_NAME_TOO_LONG",
            "MISSING_BRAND_NAME",
            "REVIEW_MISSING_VISIT_TIMESTAMP",
            "VR_ADDRESS_MISSING",
            "VR_ADDRESS_INVALID",
            "VR_ADDRESS_INCOMPLETE",
            "VR_ADDRESS_INCOMPLETE_NO_STREET_NAME",
            "VR_ADDRESS_INCOMPLETE_NO_STREET_NUMBER",
            "VR_ADDRESS_INCOMPLETE_NO_UNIT_NUMBER",
            "VR_ADDRESS_LATLONG_MISMATCH",
            "INVALID_REVIEW_RATING",
            "INVALID_CHECKIN_FORMAT",
            "INVALID_CHECKOUT_FORMAT",
            "INTERNAL_BLOCKLIST",
            "VR_LIVE_ON_GOOGLE_INACTIVE_ERROR",
            "VR_XML_FAILED_PARSING",
            "VR_ZIP_FILE_CORRUPT",
            "VR_PENDING_INITIAL_PROCESSING",
            "VR_WEBSITE_LINK_ROBOTED",
            "VR_PENDING_WEBSITE_CRAWLING",
            "VR_WEBSITE_LINK_WITH_CRAWLING_ERROR",
            "VR_BRAND_MISSING_LANDING_PAGE",
            "VR_INVALID_ROOM_TYPE"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "No data issues found.",
            "The address is the same as another property in the Hotel List Feed.",
            "The provided address appears to contain a postal box instead of a physical street address.",
            "The address does not appear to contain a street name.",
            "The address does not appear to contain a street number.",
            "The address does not appear to contain a street number, street name, or supported country code.",
            "An invalid but recognized country code was provided.",
            "The address contains an invalid postal code.",
            "The address contains an invalid postal code suffix.",
            "The address contains a postal code suffix when unsupported by the country's postal code system.",
            "The address contains a postal code when unsupported by the country's postal code system.",
            "The name and value at 'listing.content.attributes.attr' is either unsupported or has an invalid value.",
            "The email at 'listing.content.attributes.attr[name='email']' is not a valid email address.",
            "The latitude/longitude pair is the same as another property in the Hotel List Feed.",
            "The latitude/longitude pair provided for the address is more than 500 meters away from the Google latitude/longitude generated from the address.",
            "A valid pair of latitude/longitude fields is missing and Google latitude/longitude generation is disabled.",
            "A valid pair of latitude/longitude fields is missing and Google could not generate them from the address.",
            "No hotel name is provided.",
            "An empty or whitespace only name is provided, but no valid name.",
            "An invalid name is provided, but no valid name.",
            "The hotel name exceeds 200 characters.",
            "Google encountered an error while importing your Hotel List Feed.",
            "Google encountered an unknown error while importing your Hotel List Feed.",
            "The phone number you provided for this property is the same as the phone number for another property. More than one listing in the Hotel List Feed cannot have the same phone number.",
            "No valid phone number for this property found.",
            "Only invalid or fax phone numbers found.",
            "The phone number format is not valid.",
            "The phone number is not valid.",
            "The country code of the phone number is not valid.",
            "The phone number contains too many digits.",
            "The phone number contains has too few digits.",
            "The specified `content.attributes.attr[name='website']` element is not a valid URL.",
            "The category or `content.attributes.client_attr[name='hotel_brand']` element exceeds 70 Unicode characters, and/or `content.attributes.client_attr[name='custom_*']` exceeds 100 Unicode characters.",
            "Contact your account manager for details.",
            "Vacation rental properties must have at least five feed images. Eight or more images are strongly recommended; having fewer than 8 may impact performance (such as impressions and clicks).",
            "The images for this vacation rental property are still being processed.",
            "The images for this property cannot be fetched. Please check that the image URLs are valid (e.g. do not give a 404 error) and that the domain hosting the image URLs does not block crawling of these images in its robots.txt file or X-Robots-Tag HTTP Header.",
            "The images provided for this property do not meet Google's requirements due to dimensions, size, or automated quality signals. Please ensure that the images are less than 10 MB large, less than 4K pixels wide, and less than 4K pixels tall. Please check additional guidance outlined at the [Property listing image requirements](/hotels/vacation-rentals/dev-guide/onboarding#property_listing_image_requirements)",
            "Deprecated Issue Vacation rental raw listing is missing a language field.",
            "Vacation rental listing has been characterized as a hotel and not a vacation rental.",
            "Vacation rental listing is missing a required attribute.",
            "Vacation rental listing is missing a name.",
            "Vacation rental listing name is missing a language field.",
            "Vacation rental listing name is too long.",
            "Vacation rental listing's name or description is verfied to contain content that violates Google's content policy.",
            "Vacation rental listing is a test property.",
            "Please use NON_VR_ACCOMMODATION_TYPE instead.",
            "Listing that is sent as a vacation rental is suspected to be a non-vacation rental accommodation type, such as a hotel, hostel, etc.",
            "Vacation rental listing brand name is too long.",
            "Google no longer requires brand names; this issue no longer occurs.",
            "This listing has a review that is missing a visit timestamp and the timestamp is required in the listing's country. The review should include \"servicedate\" if using XML markup or \"contentReferenceTime\" if using schema.org.",
            "An address should be added to this listing.",
            "The provided address is invalid. Review address requirements on the [dev guide](/hotels/vacation-rentals/dev-guide/vr-attributes). Debugging suggestions: 1. Confirm the address does not contain redundant information such as the country in both addr1 and country_code. 2. Use Google Maps to confirm if the address is formatted correctly for its region. 3. Use a [plus code](https://plus.codes) if the address continues to be invalid.",
            "Deprecated: Replaced with more specifc errors or VR_ADDRESS_INVALID. Google detected that the provided address for this listing is incomplete. For example, it may be missing a unit number.",
            "The provided address is missing a street name.",
            "The provided address is missing a street number.",
            "The provided address is missing a unit number.",
            "The provided address and lat/long data for this listing doesn't match.",
            "Vacation rental listing has an invalid review rating.",
            "Vacation rental listing has an invalid check-in format.",
            "Vacation rental listing has an invalid check-out format.",
            "This listing is in an internal blocklist. Contact your account manager for help.",
            "The \"Live on Google\" setting for this Vacation Rental is set to false. Note: once \"Live on Google\" is set to true, it will take a few days for this error to disappear.",
            "This listing's XML failed to parse. Please fix the XML associated with this listing.",
            "A listing that indicates the that feed ZIP file is corrupt. Please ensure the ZIP file is valid.",
            "Vacation rental listing is undergoing initial processing.",
            "Vacation rental listing has a website link that is blocked by a robots.txt",
            "Vacation rental listing has a website link that is still undergoing crawling.",
            "Vacation rental listing has a website link with a crawling error.",
            "The brand of this vacation rental property doesn't have a landing page. Contact your account manager for details.",
            "The room type is invalid. Private rooms and shared rooms are part of shared accommodations, which are not currently supported on the platform."
          ],
          "description": "The type of the data issue.",
          "type": "string"
        },
        "dataIssueSeverity": {
          "description": "The severity of the data issue.",
          "type": "string",
          "enumDescriptions": [
            "The severity of the issue is unknown.",
            "The data issue will make the listing ineligible for serving.",
            "The listing will still be eligible for serving, but the data issue may have an adverse effect on the content shown.",
            "The data issue is for informational purposes."
          ],
          "enum": [
            "DATA_ISSUE_SEVERITY_UNSPECIFIED",
            "ERROR",
            "WARNING",
            "INFO"
          ]
        }
      }
    },
    "ListHotelViewsResponse": {
      "description": "Response message for HotelViewService.ListHotelViews.",
      "type": "object",
      "id": "ListHotelViewsResponse",
      "properties": {
        "hotelViews": {
          "description": "The list of rows that match the query.",
          "type": "array",
          "items": {
            "$ref": "HotelView"
          }
        },
        "nextPageToken": {
          "description": "Pagination token used to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "PriceProblemCountDetails": {
      "id": "PriceProblemCountDetails",
      "properties": {
        "priceAccuracyIssueCount": {
          "description": "Price accuracy issue.",
          "type": "string",
          "format": "int64"
        },
        "hotelSuspendedCount": {
          "description": "The hotel was suspended. This may be due to persistent problems in areas such as incorrect taxes and fees.",
          "type": "string",
          "format": "int64"
        },
        "taxesAndFeesMissingCount": {
          "description": "Taxes and fees were missing from pricing.",
          "type": "string",
          "format": "int64"
        },
        "basePriceViolationsCount": {
          "description": "Base price too low relative to total price.",
          "type": "string",
          "format": "int64"
        },
        "priceUnusuallyHighCount": {
          "description": "The price given for this itinerary seemed oddly high compared to regional trends.",
          "type": "string",
          "format": "int64"
        },
        "priceUnusuallyLowCount": {
          "description": "The price given for this itinerary seemed oddly low compared to regional trends.",
          "type": "string",
          "format": "int64"
        }
      },
      "description": "The reasons that contributed to the price problem count and the total count for each reason.",
      "type": "object"
    },
    "PriceAccuracyRow": {
      "description": "A price accuracy row.",
      "type": "object",
      "properties": {
        "cachedPriceRecord": {
          "description": "Price as advertised.",
          "$ref": "PriceRecord"
        },
        "fetchedPriceRecord": {
          "description": "Price as read from the partner website.",
          "$ref": "PriceRecord"
        },
        "lengthOfStayDays": {
          "description": "Length of stay.",
          "type": "integer",
          "format": "int32"
        },
        "userRegionCode": {
          "description": "The user's region.",
          "type": "string"
        },
        "signalSource": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "The price is read directly from the partner's website.",
            "The price is provided by the partner via a price accuracy pixel."
          ],
          "enum": [
            "SIGNAL_SOURCE_UNSPECIFIED",
            "SIGNAL_SOURCE_UNKNOWN",
            "FETCHED",
            "PIXEL"
          ],
          "description": "Source of the price accuracy signal.",
          "type": "string"
        },
        "hotelCountryCode": {
          "description": "The country of the hotel (based on address).",
          "type": "string"
        },
        "hotel": {
          "description": "Partner-defined hotel ID.",
          "type": "string"
        },
        "mismatchReason": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Tax mismatch.",
            "Room unavailable.",
            "Site error.",
            "Price feed delayed.",
            "Discount missing.",
            "Incorrect discount value.",
            "Wrong itinerary."
          ],
          "enum": [
            "MISMATCH_REASON_UNSPECIFIED",
            "MISMATCH_REASON_UNKNOWN",
            "TAX_MISMATCH",
            "ROOM_UNAVAILABLE",
            "SITE_ERROR",
            "PRICE_FEED_DELAYED",
            "DISCOUNT_MISSING",
            "INCORRECT_DISCOUNT_VALUE",
            "WRONG_ITINERARY"
          ],
          "description": "The reason why the fetched price didn't match the cached price.",
          "type": "string"
        },
        "affectsScore": {
          "description": "True if this row affects the overall price accuracy score.",
          "type": "boolean"
        },
        "url": {
          "description": "Initial URL visited on the partner website.",
          "type": "string"
        },
        "childOccupancy": {
          "description": "The number of children in the occupancy details of the validation query.",
          "type": "integer",
          "format": "int32"
        },
        "adultOccupancy": {
          "description": "The number of adults in the occupancy details of the validation query.",
          "type": "integer",
          "format": "int32"
        },
        "rateRuleId": {
          "description": "The rate rule of the advertised price for non-public rates.",
          "type": "string"
        },
        "correctionTime": {
          "description": "Time at which an incorrect price is updated to a correct price.",
          "type": "string",
          "format": "google-datetime"
        },
        "deviceType": {
          "enum": [
            "DEVICE_UNSPECIFIED",
            "DEVICE_UNKNOWN",
            "DESKTOP",
            "MOBILE",
            "TABLET"
          ],
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Computers.",
            "Mobile devices with full browsers.",
            "Tablets with full browsers."
          ],
          "description": "The user's device type.",
          "type": "string"
        },
        "checkinDate": {
          "description": "Check-in date.",
          "$ref": "Date"
        },
        "finalDomain": {
          "description": "The domain of the final page from which prices are read.",
          "type": "string"
        }
      },
      "id": "PriceAccuracyRow"
    },
    "Key": {
      "id": "Key",
      "properties": {
        "deviceType": {
          "description": "The user’s device type. If `deviceType` is not a value of the `aggregateBy` parameter in the request call, then the `deviceType` field is not returned in the `Key`.",
          "type": "string",
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Computers.",
            "Mobile devices with full browsers.",
            "Tablets with full browsers."
          ],
          "enum": [
            "DEVICE_UNSPECIFIED",
            "DEVICE_UNKNOWN",
            "DESKTOP",
            "MOBILE",
            "TABLET"
          ]
        },
        "advanceBookingWindow": {
          "description": "The number of days in advance the user wants to book the itinerary. If `advanceBookingWindow` is not a value of the `aggregateBy` parameter in the request call, then the `advanceBookingWindow` field is not returned in the `Key`.",
          "type": "integer",
          "format": "int32"
        },
        "checkinDate": {
          "description": "The check-in date of the itinerary. If `checkinDate` is not a value of the `aggregateBy` parameter in the request call, then the `checkinDate` field is not returned in the `Key`.",
          "$ref": "Date"
        },
        "occupancy": {
          "description": "The total occupancy of the itinerary. If `occupancy` is not a value of the `aggregateBy` parameter in the request call, then the `occupancy` field is not returned in the `Key`.",
          "type": "integer",
          "format": "int32"
        },
        "userRegionCode": {
          "description": "ISO 3116 region code of the country/region of the user. If `userRegionCode` is not a value of the `aggregateBy` parameter in the request call, then the `userRegionCode` field is not returned in the `Key`.",
          "type": "string"
        },
        "lengthOfStayDays": {
          "description": "The number of nights for the itinerary. If `lengthOfStayDays` is not a value of the `aggregateBy` parameter in the request call, then the `lengthOfStayDays` field is not returned in the `Key`.",
          "type": "integer",
          "format": "int32"
        },
        "date": {
          "description": "The date for which you are requesting metrics. If `date` is not a value of the `aggregateBy` parameter in the request call, then the `date` field is not returned in the `Key`.",
          "$ref": "Date"
        },
        "partnerHotelId": {
          "description": "Partner's hotel ID. If `partnerHotelId` is not a value of the `aggregateBy` parameter in the request call, then the `partnerHotelId` field is not returned in the `Key`.",
          "type": "string"
        },
        "hotelRegionCode": {
          "description": "CLDR region code of the country/region of the hotel. If `hotelRegionCode` is not a value of the `aggregateBy` parameter in the request call, then the `hotelRegionCode` field is not returned in the `Key`.",
          "type": "string"
        }
      },
      "description": "Key of a result.",
      "type": "object"
    },
    "PriceCoverageView": {
      "description": "A price coverage view. Covers the `price_coverage_stats` Scorecard functionality in pre-v3.0 API versions. For more information, refer to Price Coverage for Push and Hint partners.",
      "type": "object",
      "id": "PriceCoverageView",
      "properties": {
        "matchedPropertyCount": {
          "description": "The total number of properties that have prices for the given itineraries.",
          "type": "integer",
          "format": "int32"
        },
        "priceCoverageBuckets": {
          "items": {
            "$ref": "PriceCoverageBucket"
          },
          "description": "Price coverage stats for combinations of advance booking window and length of stay ranges.",
          "type": "array"
        },
        "calculationDate": {
          "description": "The date on which the calculations were made.",
          "$ref": "Date"
        },
        "priceCoverageBinaryPercent": {
          "description": "The ratio between the number of hotels which have at least one price for the calculation period and `matched_property_count`.",
          "type": "number",
          "format": "double"
        },
        "priceCoveragePercent": {
          "description": "The overall price coverage for an account. This value is the ratio between the number of hotel prices for the calculation booking window and length of stay range divided by the number of all possible prices, which is `matched_property_count` times 330 (for advance book window) times 30 (for length of stay).",
          "type": "number",
          "format": "double"
        }
      }
    },
    "Brand": {
      "description": "Brand-level icon and display name configuration. Once approved, the icon and display name appear in the search results for properties that the partner has assigned to this brand.",
      "type": "object",
      "properties": {
        "displayNameState": {
          "readOnly": true,
          "description": "Output only. The brand's display names review state, which applies to all display name language entries. If there are both submitted and active display names, this refers to the submitted display names.",
          "type": "string",
          "enum": [
            "REVIEW_STATE_UNSPECIFIED",
            "REVIEW_STATE_NEW",
            "APPROVED",
            "REJECTED"
          ],
          "enumDescriptions": [
            "Default value.",
            "Google is reviewing the icon or display name.",
            "The icon or display name is approved and ready for public display.",
            "The icon or display name is rejected. Google won't display it."
          ]
        },
        "icon": {
          "description": "Input only. The brand's [accounts.icon](/hotels/hotel-prices/api-reference/rest/v3/accounts.icons#resource:-iconresource) identifying the brand's icon. The value refers to the icons's resource name in the format `accounts/{account_id}/icons/{icon_id}`.",
          "type": "string"
        },
        "displayNames": {
          "description": "Input only. The name Google displays for the brand's properties. Setting the display names is only necessary if you want to override the landing page display name or account-level display name for the brand. Google reviews the display names for appropriate content. When there are multiple languages, Google will only show the display names once Google approves all the languages.",
          "type": "array",
          "items": {
            "$ref": "LocalizedText"
          }
        },
        "name": {
          "description": "Output only. The resource name for the brand in the format `accounts/{account_id}/brands/{brand_id}`. The `brand_id` corresponds to the partner's brand identifier used for landing page matching and the property-level brand identifier. A default brand is applied to properties that do not have a brand. The `brand_id` of the default brand is `NO_BRAND_ID`. It can be fetched and updated like any configured brand.",
          "type": "string",
          "readOnly": true
        },
        "iconState": {
          "readOnly": true,
          "description": "Output only. The brand's icon's review state. If there are both submitted and active icons, this refers to the submitted icon.",
          "type": "string",
          "enumDescriptions": [
            "Default value.",
            "Google is reviewing the icon or display name.",
            "The icon or display name is approved and ready for public display.",
            "The icon or display name is rejected. Google won't display it."
          ],
          "enum": [
            "REVIEW_STATE_UNSPECIFIED",
            "REVIEW_STATE_NEW",
            "APPROVED",
            "REJECTED"
          ]
        },
        "activeIconUri": {
          "readOnly": true,
          "description": "Output only. URL of the active icon, only present when the icon has been approved.",
          "type": "string"
        },
        "activeDisplayNames": {
          "description": "Output only. The brand's active display names in all provided languages, only present if the display name is approved for all provided languages.",
          "type": "array",
          "items": {
            "$ref": "LocalizedText"
          },
          "readOnly": true
        },
        "submittedIcon": {
          "description": "Output only. The brand's submitted [accounts.icon](/hotels/hotel-prices/api-reference/rest/v3/accounts.icons#resource:-iconresource). The value refers to the icons's resource name in the format `accounts/{account_id}/icons/{icon_id}`. A submitted icon is one that is new or rejected.",
          "type": "string",
          "readOnly": true
        },
        "activeIcon": {
          "description": "Output only. The brand's active [accounts.icon](/hotels/hotel-prices/api-reference/rest/v3/accounts.icons#resource:-iconresource). The value refers to the icons's resource name in the format `accounts/{account_id}/icons/{icon_id}`. An active icon is one that has been approved.",
          "type": "string",
          "readOnly": true
        },
        "displayNameDisapprovalReason": {
          "items": {
            "$ref": "DisplayNameDisapprovalReason"
          },
          "description": "Output only. Display name's disapproval reason. Only applies to display names with the review state 'REJECTED'.",
          "type": "array",
          "readOnly": true
        },
        "submittedDisplayNames": {
          "readOnly": true,
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "Output only. The brand's submitted display names in all provided languages, only present if the display name is new or rejected for any language.",
          "type": "array"
        },
        "iconDisapprovalReasons": {
          "readOnly": true,
          "description": "Output only. The icon's disapproval reason(s). Only applies to submitted icons with `REJECTED` state.",
          "type": "array",
          "items": {
            "enum": [
              "IMAGE_DISAPPROVAL_REASON_UNSPECIFIED",
              "NOT_LIKE_SITE",
              "OFFENSIVE",
              "LOW_QUALITY",
              "ANIMATED",
              "BAD_BACKGROUND",
              "TEXT_TOO_SMALL"
            ],
            "enumDescriptions": [
              "Not specified.",
              "Icon image does not match the favicon or artwork on the advertiser’s final URL.",
              "Icon image contains offensive content.",
              "Icon image is low quality.",
              "Icon image is animated.",
              "Icon image does not have a transparent or non-white background.",
              "Icon image contains text that is too small."
            ],
            "type": "string"
          }
        },
        "propertyCount": {
          "readOnly": true,
          "description": "Output only. The number of properties with the corresponding brand ID.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "Brand"
    },
    "ListReconciliationReportsResponse": {
      "id": "ListReconciliationReportsResponse",
      "properties": {
        "reconciliationReports": {
          "items": {
            "$ref": "ReconciliationReport"
          },
          "description": "The list of names of reconciliation reports. Note that the `contents` and `fileName` fields of each `ReconciliationReport` object are not returned by this call.",
          "type": "array"
        }
      },
      "description": "Response message for ReconciliationReportService.ListReconciliationReports.",
      "type": "object"
    },
    "AccountLink": {
      "description": "An account link. Represents the link between a Google Ads customer and a Hotel Ads (Hotel Center) account. An account link defines the set of hotels under the Hotel Center account that is linked to the Google Ads customer.",
      "type": "object",
      "id": "AccountLink",
      "properties": {
        "googleAdsCustomerName": {
          "description": "Required for CREATE requests. The value representing the Google Ads customer ID in the format `customers/{google_ads_customer_id}`. For example: `customers/0123456789`. Note that the `googleAdsCustomerName` field is not returned in responses to GET requests.",
          "type": "string"
        },
        "accountLinkTarget": {
          "description": "Required for CREATE requests. The properties in the Hotel Center account that can be managed using the linked Google Ads account.",
          "$ref": "AccountLinkTarget"
        },
        "name": {
          "description": "The resource name for the account link in the format `accounts/{account_id}/accountLinks/{account_link_id}`.",
          "type": "string"
        },
        "status": {
          "description": "The current status of the account link.",
          "type": "string",
          "enum": [
            "ACCOUNT_LINK_STATUS_UNSPECIFIED",
            "ACCOUNT_LINK_STATUS_UNKNOWN",
            "REQUESTED_FROM_HOTEL_CENTER",
            "REQUESTED_FROM_GOOGLE_ADS",
            "APPROVED"
          ],
          "enumDescriptions": [
            "Default value.",
            "The account link status is not recognized by this API version.",
            "The account link was initiated through Hotel Center and has not yet been approved in Google Ads.",
            "The account link was initiated through Google Ads and has not yet been approved in Hotel Center.",
            "The account link has been approved."
          ]
        }
      }
    },
    "VerifyListingsRequest": {
      "description": "Request message for VRPartnerListingVerificationService.VerifyPartnerListings.",
      "type": "object",
      "id": "VerifyListingsRequest",
      "properties": {
        "xmlListing": {
          "description": "A listing that follows the XML format specified in https://developers.google.com/hotels/hotel-prices/xml-reference/hotel-list-feed.",
          "type": "string"
        }
      }
    },
    "HotelList": {
      "description": "The properties in the Hotel Center account that can be managed with the Google Ads account.",
      "type": "object",
      "id": "HotelList",
      "properties": {
        "partnerHotelIds": {
          "items": {
            "type": "string"
          },
          "description": "Hotel IDs.",
          "type": "array"
        }
      }
    },
    "HotelPricePerItinerary": {
      "properties": {
        "fees": {
          "description": "Fees for this itinerary.",
          "type": "number",
          "format": "float"
        },
        "price": {
          "description": "Hotel price for this itinerary.",
          "type": "number",
          "format": "float"
        },
        "taxes": {
          "description": "Taxes for this itinerary.",
          "type": "number",
          "format": "float"
        },
        "currencyCode": {
          "description": "Currency for `price`, `taxes`, and `fees`.",
          "type": "string"
        },
        "updateTime": {
          "description": "Update timestamp for this hotel price.",
          "type": "string",
          "format": "google-datetime"
        },
        "checkinDate": {
          "description": "Check-in date.",
          "$ref": "Date"
        },
        "lengthOfStayDays": {
          "description": "Number of nights for the itinerary.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "HotelPricePerItinerary",
      "description": "Hotel price for a given itinerary.",
      "type": "object"
    },
    "FreeBookingLinksResult": {
      "properties": {
        "date": {
          "description": "A date within the requested date range. Only present if `date` is specified in `aggregateBy` in the request.",
          "$ref": "Date"
        },
        "deviceType": {
          "enumDescriptions": [
            "Not specified.",
            "The value is unknown in this version.",
            "Computers.",
            "Mobile devices with full browsers.",
            "Tablets with full browsers."
          ],
          "enum": [
            "DEVICE_UNSPECIFIED",
            "DEVICE_UNKNOWN",
            "DESKTOP",
            "MOBILE",
            "TABLET"
          ],
          "description": "The user’s device type. Only present if `deviceType` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "partnerHotelDisplayName": {
          "description": "Partner's hotel name. Only present if `partnerHotelDisplayName` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "userRegionCode": {
          "description": "ISO 3116 region code of the country/region of the user. Only present if `userRegionCode` is specified in `aggregateBy` in the request",
          "type": "string"
        },
        "partnerHotelId": {
          "description": "Partner's hotel ID. Only present if `partnerHotelId` is specified in `aggregateBy` in the request.",
          "type": "string"
        },
        "clickCount": {
          "description": "The total number of clicks that were recorded for this result.",
          "type": "string",
          "format": "int64"
        }
      },
      "deprecated": true,
      "description": "**DEPRECATED:** Use `PropertyPerformanceResult` with `PropertyPerformanceReportService` instead. Represents a result from querying for free booking link stats for an account.",
      "type": "object",
      "id": "FreeBookingLinksResult"
    },
    "SetLiveOnGoogleResponse": {
      "properties": {
        "updatedHotelIds": {
          "items": {
            "type": "string"
          },
          "description": "Identifies the updated properties.",
          "type": "array"
        },
        "failedHotelIds": {
          "items": {
            "type": "string"
          },
          "description": "Identifies properties that Google could not update.",
          "type": "array"
        }
      },
      "id": "SetLiveOnGoogleResponse",
      "description": "Response message for HotelService.SetLiveOnGoogle.",
      "type": "object"
    },
    "ReconciliationReport": {
      "description": "Reconciliation report (Hotel Ads only). Covers the Reconciliation Reports functionality in pre-v3.0 API versions. Lets you see the status, validate, and upload your Commissions reconciliation reports. This only applies if you are in the Google Hotel Ads Commissions Program (GHACP). For more information about working with reconciliation reports in Hotel Center, refer to [Reconciliation reports](//support.google.com/hotelprices/answer/7019060#sending).",
      "type": "object",
      "id": "ReconciliationReport",
      "properties": {
        "name": {
          "description": "Resource name in the format `accounts/{account_id}/reconciliationReports/{datetime}~{filename}`. The value for `{datetime}` must be from 0001-01-01T00:00:00 to 9999-12-31T23:59:59 inclusive.",
          "type": "string"
        },
        "contents": {
          "description": "Required. The contents of the commission report. Report contents must conform to the requirements specified in [Reconciliation reports] (//support.google.com/hotelprices/answer/7019060#creating).",
          "type": "string"
        },
        "fileName": {
          "description": "Required. Desired filename of the reconciliation report.",
          "type": "string"
        }
      }
    },
    "ParsedListing": {
      "description": "A parsed listing",
      "type": "object",
      "id": "ParsedListing",
      "properties": {
        "dataIssueDetail": {
          "description": "Data issues about this listing",
          "type": "array",
          "items": {
            "$ref": "DataIssueDetail"
          }
        },
        "regionCode": {
          "description": "The country code where the listing is located.",
          "type": "string"
        },
        "image": {
          "items": {
            "$ref": "Image"
          },
          "description": "Images associated with this listing, localized.",
          "type": "array"
        },
        "imprecisionRadiusMeters": {
          "description": "Represents the accuracy of the location. The listing can be anywhere within the defined circular area.",
          "type": "integer",
          "format": "int32"
        },
        "location": {
          "description": "Location of listing using latitude and longitude (degrees).",
          "$ref": "LatLng"
        },
        "review": {
          "description": "Reviews associated with this listing. Each review has a single language attached to it.",
          "type": "array",
          "items": {
            "$ref": "Review"
          }
        },
        "partnerListId": {
          "description": "The list ID on partner LEC feed, provided by partner.",
          "type": "string"
        },
        "brand": {
          "description": "If not empty, it indicates that this listing belongs to a brand of the feed.",
          "type": "string"
        },
        "description": {
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "Description of the property.",
          "type": "array"
        },
        "isServed": {
          "description": "Whether the listing can be served based on non image data alone.",
          "type": "boolean"
        },
        "listingName": {
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "List of localized names.",
          "type": "array"
        },
        "unitAttributes": {
          "description": "VR List attribute.",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        },
        "category": {
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "The partner provided category (accommodation type) of the property.",
          "type": "array"
        }
      }
    },
    "Icon": {
      "properties": {
        "imageData": {
          "description": "Required. Input only. The icon contents, which must be in PNG format, or convertible to PNG.",
          "type": "string",
          "format": "byte"
        },
        "name": {
          "readOnly": true,
          "description": "Required. Output only. The resource name for the icon in the format `accounts/{account_id}/icons/{icon_id}`. Google generates the `icon_id` during the `create` operation. Use the `icon_id` to associate the icon with a brand using the [accounts.brands](/hotels/hotel-prices/api-reference/rest/v3/accounts.brands#resource:-brand) API.",
          "type": "string"
        },
        "state": {
          "description": "Output only. The icon's current state.",
          "type": "string",
          "enumDescriptions": [
            "Default value.",
            "Google has received the icon and is reviewing its contents.",
            "The icon is approved and is ready for public display. You can link APPROVED icons to brands.",
            "The icon is rejected. Google won't display this icon."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "NEW",
            "APPROVED",
            "REJECTED"
          ],
          "readOnly": true
        },
        "disapprovalReasons": {
          "readOnly": true,
          "description": "Output only. The icon's disapproval reason(s). Only applies to icons with `REJECTED` state.",
          "type": "array",
          "items": {
            "type": "string",
            "enum": [
              "IMAGE_DISAPPROVAL_REASON_UNSPECIFIED",
              "NOT_LIKE_SITE",
              "OFFENSIVE",
              "LOW_QUALITY",
              "ANIMATED",
              "BAD_BACKGROUND",
              "TEXT_TOO_SMALL"
            ],
            "enumDescriptions": [
              "Not specified.",
              "Icon image does not match the favicon or artwork on the advertiser’s final URL.",
              "Icon image contains offensive content.",
              "Icon image is low quality.",
              "Icon image is animated.",
              "Icon image does not have a transparent or non-white background.",
              "Icon image contains text that is too small."
            ]
          }
        },
        "iconUri": {
          "readOnly": true,
          "description": "Output only. The approved icon's Google-hosted URI. Only applies to icons with `APPROVED` state.",
          "type": "string"
        },
        "reference": {
          "description": "Optional. Value for tracking the icon. It could be the primary key to your icon in your system, or the icon's filename. Google does not use this value.",
          "type": "string"
        }
      },
      "id": "Icon",
      "description": "Information about a partner's icon.",
      "type": "object"
    },
    "PriceMissingCountDetails": {
      "description": "The reasons that contributed to the price missing count and the total count for each reason.",
      "type": "object",
      "properties": {
        "livePricingNotSetupCount": {
          "description": "No price was cached for this itinerary, and live query was not configured for this account.",
          "type": "string",
          "format": "int64"
        },
        "bandwidthDepletedCount": {
          "description": "No price was cached for this itinerary, and there was no live query quota remaining.",
          "type": "string",
          "format": "int64"
        },
        "livePricingErrorCount": {
          "description": "No price was cached for this itinerary. A live query did not time out, but your system returned an error.",
          "type": "string",
          "format": "int64"
        },
        "cacheRateMissingCount": {
          "description": "No price exists in the cache for this itinerary. A live query was not done due to page constraints.",
          "type": "string",
          "format": "int64"
        },
        "itineraryBlockedCount": {
          "description": "The itinerary was outside of your basic parameters, so no price was pulled for the itinerary from either live query or cache fill.",
          "type": "string",
          "format": "int64"
        },
        "livePricingTimeoutCount": {
          "description": "No price was cached for this itinerary, and a live query sent to your system timed out.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "PriceMissingCountDetails"
    },
    "ParticipationResult": {
      "description": "Represents a result from querying for participation stats for an account.",
      "type": "object",
      "properties": {
        "opportunityCount": {
          "description": "For a specific hotel, the total number of opportunities that were available. Opportunities are the total number of instances when a hotel ad could have been displayed to a user.",
          "type": "string",
          "format": "int64"
        },
        "participationPercent": {
          "description": "The percentage rate of participation where the number of successfully participated opportunities is divided by the total number of opportunities. For example, if a property was eligible to enter the Google Ads auction 90 times out of 100 opportunities, the participation rate is 90%.",
          "type": "number",
          "format": "double"
        },
        "key": {
          "description": "Key of the result.",
          "$ref": "Key"
        },
        "participationCount": {
          "description": "The total number of opportunities for which you were eligible to enter in the Google Ads auction process.",
          "type": "string",
          "format": "int64"
        },
        "missedParticipationCountDetails": {
          "description": "The reasons that contributed to the missed participation count (for example, no availability) and a total count for each reason.",
          "$ref": "MissedParticipationCountDetails"
        },
        "partnerHotelDisplayName": {
          "description": "Partner's hotel display name. This field is only populated when the result is aggregated by `partnerHotelId`.",
          "type": "string"
        },
        "missedParticipationCount": {
          "description": "The total number of opportunities **not** eligible for the Google Ads auction process. Comprised of the following: * Landing page missing * Price missing * Price problem * Price unavailable * Other",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "ParticipationResult"
    },
    "LatLng": {
      "id": "LatLng",
      "properties": {
        "latitude": {
          "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].",
          "type": "number",
          "format": "double"
        },
        "longitude": {
          "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].",
          "type": "number",
          "format": "double"
        }
      },
      "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.",
      "type": "object"
    },
    "QueryPropertyPerformanceReportResponse": {
      "description": "Response message for PropertyPerformanceReportService.QueryPropertyPerformanceReport.",
      "type": "object",
      "id": "QueryPropertyPerformanceReportResponse",
      "properties": {
        "results": {
          "items": {
            "$ref": "PropertyPerformanceResult"
          },
          "description": "The list of results that match the query.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "Pagination token used to retrieve the next page of results. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      }
    },
    "MissedParticipationCountDetails": {
      "description": "Missed participation count broken down by reason.",
      "type": "object",
      "id": "MissedParticipationCountDetails",
      "properties": {
        "noPriceCountDetails": {
          "description": "The reasons that contributed to the no price count (for example, live pricing not available) and the total count for each reason.",
          "$ref": "NoPriceCountDetails",
          "deprecated": true
        },
        "noPriceCount": {
          "description": "The total number of missed participations due to a price not being offered for the requested itinerary.",
          "type": "string",
          "format": "int64",
          "deprecated": true
        },
        "priceUnavailableCount": {
          "description": "The total number of missed participation due to price listed as unavailable (-1) for the requested itinerary. Comprised of the following: * Price unavailable * Participation not likely * Other",
          "type": "string",
          "format": "int64"
        },
        "priceProblemCount": {
          "description": "The total number of missed participation due to an issue with the accuracy of the price provided for the itinerary. Comprised of the following: * Hotel suspended * Price unusually high * Price unusually low * Taxes and feeds missing",
          "type": "string",
          "format": "int64"
        },
        "priceUnavailableCountDetails": {
          "description": "The reasons that contributed to the price unavailable count.",
          "$ref": "PriceUnavailableCountDetails"
        },
        "hotelSuspendedCount": {
          "description": "The total number of missed participations due to one or more of your hotels being suspended due to price accuracy violations.",
          "type": "string",
          "format": "int64",
          "deprecated": true
        },
        "noTaxBreakdownCount": {
          "description": "The total number of missed participation due to one or more of your hotels not specifying taxes and fees separately.",
          "type": "string",
          "format": "int64",
          "deprecated": true
        },
        "priceMissingCount": {
          "description": "The total number of missed participations due to either a price not being present in Google's cache or failing to successfully respond to live pricing. Comprised of the following: * Bandwidth depleted * Cache rate missing * Itinerary blocked * Live pricing not set up * Live pricing timeout * Live pricing error",
          "type": "string",
          "format": "int64"
        },
        "otherReasonCount": {
          "description": "Hotel did not participate for an unknown reason.",
          "type": "string",
          "format": "int64"
        },
        "priceMissingCountDetails": {
          "description": "The reasons that contributed to the price missing count.",
          "$ref": "PriceMissingCountDetails"
        },
        "noLandingPageCount": {
          "description": "No landing page matched the user.",
          "type": "string",
          "format": "int64"
        },
        "noAvailabilityCount": {
          "description": "The total number of missed participation due to the hotel/itinerary combination being unavailable, or the traveler was ineligible for the rates. To participate in these auctions, you may need to provide more pricing information.",
          "type": "string",
          "format": "int64",
          "deprecated": true
        },
        "priceProblemCountDetails": {
          "description": "The reasons that contributed to the price problem count.",
          "$ref": "PriceProblemCountDetails"
        }
      }
    },
    "ListPriceCoverageViewsResponse": {
      "properties": {
        "priceCoverageViews": {
          "description": "Hotel price coverage stats.",
          "type": "array",
          "items": {
            "$ref": "PriceCoverageView"
          }
        }
      },
      "id": "ListPriceCoverageViewsResponse",
      "description": "Response message for PriceCoverageViewService.ListPriceCoverageViews.",
      "type": "object"
    },
    "ValidateReconciliationReportResponse": {
      "properties": {
        "issues": {
          "items": {
            "$ref": "ReconciliationReportValidationIssue"
          },
          "description": "Issues that were encountered when validating the file.",
          "type": "array"
        },
        "successfulRecordCount": {
          "description": "The number of commission records that were successfully validated.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "ValidateReconciliationReportResponse",
      "description": "Response message for ReconciliationReportService.ValidateReconciliationReport.",
      "type": "object"
    },
    "VerifyListingsResponse": {
      "id": "VerifyListingsResponse",
      "properties": {
        "parsedListing": {
          "description": "The parsed listing output.",
          "$ref": "ParsedListing"
        }
      },
      "description": "Response message for VRPartnerListingVerificationService.VerifyPartnerListings.",
      "type": "object"
    },
    "CreateReconciliationReportResponse": {
      "properties": {
        "reconciliationReport": {
          "description": "Resource name of the new reconciliation report. The format is `accounts/{account_id}`.",
          "$ref": "ReconciliationReport"
        },
        "successfulRecordCount": {
          "description": "The number of commission records that were successfully saved.",
          "type": "integer",
          "format": "int32"
        },
        "issues": {
          "items": {
            "$ref": "ReconciliationReportValidationIssue"
          },
          "description": "Issues that were encountered when validating the file.",
          "type": "array"
        }
      },
      "id": "CreateReconciliationReportResponse",
      "description": "Response message for ReconciliationReportService.CreateReconciliationReport.",
      "type": "object"
    },
    "LocalizedText": {
      "id": "LocalizedText",
      "properties": {
        "languageCode": {
          "description": "The text's BCP-47 language code, such as \"en-US\" or \"sr-Latn\". For more information, see http://www.unicode.org/reports/tr35/#Unicode_locale_identifier.",
          "type": "string"
        },
        "text": {
          "description": "Localized string in the language corresponding to language_code below.",
          "type": "string"
        }
      },
      "description": "Localized variant of a text in a particular language.",
      "type": "object"
    },
    "ListAccountLinksResponse": {
      "description": "Response message for AccountLinkService.ListAccountLinks.",
      "type": "object",
      "properties": {
        "accountLinks": {
          "description": "A list of all account links associated with the Hotel Center account being queried.",
          "type": "array",
          "items": {
            "$ref": "AccountLink"
          }
        }
      },
      "id": "ListAccountLinksResponse"
    },
    "ListBrandsResponse": {
      "description": "Response message for BrandService.ListBrands.",
      "type": "object",
      "properties": {
        "brands": {
          "items": {
            "$ref": "Brand"
          },
          "description": "A list of brands for the current page associated with the Hotel Center account being queried.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "Token that can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "id": "ListBrandsResponse"
    },
    "NoPriceCountDetails": {
      "description": "The reasons that contributed to the no price count and the total count for each reason.",
      "type": "object",
      "properties": {
        "livePricingNotTriggeredCount": {
          "description": "The total number of missed participation due to live pricing not being triggered for any of the following reasons: * You didn't set a bid. * You didn't have a valid landing page. * There weren't enough prices in the cache.",
          "type": "string",
          "format": "int64"
        },
        "livePricingOtherReasonCount": {
          "description": "The number of missed participations due to other issues with live pricing.",
          "type": "string",
          "format": "int64"
        },
        "livePricingConfigIssueCount": {
          "description": "The total number of missed participation due to live pricing not being triggered for any of the following reasons: * You didn't have live pricing configured for these searches. * You restricted Google from accessing the hotel itinerary in question.",
          "type": "string",
          "format": "int64"
        },
        "livePricingNotAvailableCount": {
          "description": "The total number of missed participation due to live pricing being unavailable. Live pricing will not be triggered for certain default itineraries or UIs. In this scenario, partners will need a cached price to participate.",
          "type": "string",
          "format": "int64"
        },
        "livePricingTechnicalIssueCount": {
          "description": "The total number of missed participation due to technical issues with live pricing for any of the following reasons: * You didn’t respond quickly enough and exceeded the response deadline (around 4000 milliseconds). * You returned an error. * Your response was malformed.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "NoPriceCountDetails"
    },
    "PriceAccuracyView": {
      "properties": {
        "name": {
          "description": "Resource name should be in the format `accounts/{account_id}/priceAccuracyViews/{report_date}`.",
          "type": "string"
        },
        "results": {
          "items": {
            "$ref": "PriceAccuracyRow"
          },
          "description": "The list of rows that match the query.",
          "type": "array"
        }
      },
      "id": "PriceAccuracyView",
      "description": "A price accuracy view. Covers the price accuracy reports functionality in pre-v3.0 API versions. For more information, refer to [Price Accuracy report](https://support.google.com/hotelprices/answer/6318506).",
      "type": "object"
    },
    "AccountLinkTarget": {
      "properties": {
        "hotelList": {
          "description": "List of properties that is made available to the account link.",
          "$ref": "HotelList"
        },
        "allHotels": {
          "description": "True if all properties under the Hotel Center account are made available to the account link. The default is `false`.",
          "type": "boolean"
        }
      },
      "id": "AccountLinkTarget",
      "description": "Defines whether all properties or a subset of properties in the Hotel Center account can be managed with the linked Google Ads account. If a subset, the specific properties are specified.",
      "type": "object"
    }
  },
  "protocol": "rest",
  "description": "The Travel Partner API provides you with a RESTful interface to the Google Hotel Center platform. It enables an app to efficiently retrieve and change Hotel Center data, and is thus suitable for managing large or complex accounts."
}
