Places API (New) . places

Instance Methods

photos()

Returns the photos Resource.

autocomplete(body=None, x__xgafv=None)

Returns predictions for the given input.

close()

Close httplib2 connections.

get(name, languageCode=None, regionCode=None, sessionToken=None, x__xgafv=None)

Get the details of a place based on its resource name, which is a string in the `places/{place_id}` format.

searchNearby(body=None, x__xgafv=None)

Search for places near locations.

searchText(body=None, x__xgafv=None)

Text query based place search.

searchText_next()

Retrieves the next page of results.

Method Details

autocomplete(body=None, x__xgafv=None)
Returns predictions for the given input.

Args:
  body: object, The request body.
    The object takes the form of:

{ # Request proto for AutocompletePlaces.
  "includePureServiceAreaBusinesses": True or False, # Optional. Include pure service area businesses if the field is set to true. Pure service area business is a business that visits or delivers to customers directly but does not serve customers at their business address. For example, businesses like cleaning services or plumbers. Those businesses do not have a physical address or location on Google Maps. Places will not return fields including `location`, `plus_code`, and other location related fields for these businesses.
  "includeQueryPredictions": True or False, # Optional. If true, the response will include both Place and query predictions. Otherwise the response will only return Place predictions.
  "includedPrimaryTypes": [ # Optional. Included primary Place type (for example, "restaurant" or "gas_station") in Place Types (https://developers.google.com/maps/documentation/places/web-service/place-types), or only `(regions)`, or only `(cities)`. A Place is only returned if its primary type is included in this list. Up to 5 values can be specified. If no types are specified, all Place types are returned.
    "A String",
  ],
  "includedRegionCodes": [ # Optional. Only include results in the specified regions, specified as up to 15 CLDR two-character region codes. An empty set will not restrict the results. If both `location_restriction` and `included_region_codes` are set, the results will be located in the area of intersection.
    "A String",
  ],
  "input": "A String", # Required. The text string on which to search.
  "inputOffset": 42, # Optional. A zero-based Unicode character offset of `input` indicating the cursor position in `input`. The cursor position may influence what predictions are returned. If empty, defaults to the length of `input`.
  "languageCode": "A String", # Optional. The language in which to return results. Defaults to en-US. The results may be in mixed languages if the language used in `input` is different from `language_code` or if the returned Place does not have a translation from the local language to `language_code`.
  "locationBias": { # The region to search. The results may be biased around the specified region. # Optional. Bias results to a specified location. At most one of `location_bias` or `location_restriction` should be set. If neither are set, the results will be biased by IP address, meaning the IP address will be mapped to an imprecise location and used as a biasing signal.
    "circle": { # Circle with a LatLng as center and radius. # A circle defined by a center point and radius.
      "center": { # 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. # Required. Center latitude and longitude. The range of latitude must be within [-90.0, 90.0]. The range of the longitude must be within [-180.0, 180.0].
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "radius": 3.14, # Required. Radius measured in meters. The radius must be within [0.0, 50000.0].
    },
    "rectangle": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A viewport defined by a northeast and a southwest corner.
      "high": { # 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. # Required. The high point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "low": { # 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. # Required. The low point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
    },
  },
  "locationRestriction": { # The region to search. The results will be restricted to the specified region. # Optional. Restrict results to a specified location. At most one of `location_bias` or `location_restriction` should be set. If neither are set, the results will be biased by IP address, meaning the IP address will be mapped to an imprecise location and used as a biasing signal.
    "circle": { # Circle with a LatLng as center and radius. # A circle defined by a center point and radius.
      "center": { # 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. # Required. Center latitude and longitude. The range of latitude must be within [-90.0, 90.0]. The range of the longitude must be within [-180.0, 180.0].
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "radius": 3.14, # Required. Radius measured in meters. The radius must be within [0.0, 50000.0].
    },
    "rectangle": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A viewport defined by a northeast and a southwest corner.
      "high": { # 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. # Required. The high point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "low": { # 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. # Required. The low point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
    },
  },
  "origin": { # 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. # Optional. The origin point from which to calculate geodesic distance to the destination (returned as `distance_meters`). If this value is omitted, geodesic distance will not be returned.
    "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
    "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
  },
  "regionCode": "A String", # Optional. The region code, specified as a CLDR two-character region code. This affects address formatting, result ranking, and may influence what results are returned. This does not restrict results to the specified region. To restrict results to a region, use `region_code_restriction`.
  "sessionToken": "A String", # Optional. A string which identifies an Autocomplete session for billing purposes. Must be a URL and filename safe base64 string with at most 36 ASCII characters in length. Otherwise an INVALID_ARGUMENT error is returned. The session begins when the user starts typing a query, and concludes when they select a place and a call to Place Details or Address Validation is made. Each session can have multiple queries, followed by one Place Details or Address Validation request. The credentials used for each request within a session must belong to the same Google Cloud Console project. Once a session has concluded, the token is no longer valid; your app must generate a fresh token for each session. If the `session_token` parameter is omitted, or if you reuse a session token, the session is charged as if no session token was provided (each request is billed separately). We recommend the following guidelines: * Use session tokens for all Place Autocomplete calls. * Generate a fresh token for each session. Using a version 4 UUID is recommended. * Ensure that the credentials used for all Place Autocomplete, Place Details, and Address Validation requests within a session belong to the same Cloud Console project. * Be sure to pass a unique session token for each new session. Using the same token for more than one session will result in each request being billed individually.
}

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Response proto for AutocompletePlaces.
  "suggestions": [ # Contains a list of suggestions, ordered in descending order of relevance.
    { # An Autocomplete suggestion result.
      "placePrediction": { # Prediction results for a Place Autocomplete prediction. # A prediction for a Place.
        "distanceMeters": 42, # The length of the geodesic in meters from `origin` if `origin` is specified. Certain predictions such as routes may not populate this field.
        "place": "A String", # The resource name of the suggested Place. This name can be used in other APIs that accept Place names.
        "placeId": "A String", # The unique identifier of the suggested Place. This identifier can be used in other APIs that accept Place IDs.
        "structuredFormat": { # Contains a breakdown of a Place or query prediction into main text and secondary text. For Place predictions, the main text contains the specific name of the Place. For query predictions, the main text contains the query. The secondary text contains additional disambiguating features (such as a city or region) to further identify the Place or refine the query. # A breakdown of the Place prediction into main text containing the name of the Place and secondary text containing additional disambiguating features (such as a city or region). `structured_format` is recommended for developers who wish to show two separate, but related, UI elements. Developers who wish to show a single UI element may want to use `text` instead. They are two different ways to represent a Place prediction. Users should not try to parse `structured_format` into `text` or vice versa.
          "mainText": { # Text representing a Place or query prediction. The text may be used as is or formatted. # Represents the name of the Place or query.
            "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
              { # Identifies a substring within a given text.
                "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
                "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
              },
            ],
            "text": "A String", # Text that may be used as is or formatted with `matches`.
          },
          "secondaryText": { # Text representing a Place or query prediction. The text may be used as is or formatted. # Represents additional disambiguating features (such as a city or region) to further identify the Place or refine the query.
            "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
              { # Identifies a substring within a given text.
                "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
                "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
              },
            ],
            "text": "A String", # Text that may be used as is or formatted with `matches`.
          },
        },
        "text": { # Text representing a Place or query prediction. The text may be used as is or formatted. # Contains the human-readable name for the returned result. For establishment results, this is usually the business name and address. `text` is recommended for developers who wish to show a single UI element. Developers who wish to show two separate, but related, UI elements may want to use `structured_format` instead. They are two different ways to represent a Place prediction. Users should not try to parse `structured_format` into `text` or vice versa. This text may be different from the `display_name` returned by GetPlace. May be in mixed languages if the request `input` and `language_code` are in different languages or if the Place does not have a translation from the local language to `language_code`.
          "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
            { # Identifies a substring within a given text.
              "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
              "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
            },
          ],
          "text": "A String", # Text that may be used as is or formatted with `matches`.
        },
        "types": [ # List of types that apply to this Place from Table A or Table B in https://developers.google.com/maps/documentation/places/web-service/place-types. A type is a categorization of a Place. Places with shared types will share similar characteristics.
          "A String",
        ],
      },
      "queryPrediction": { # Prediction results for a Query Autocomplete prediction. # A prediction for a query.
        "structuredFormat": { # Contains a breakdown of a Place or query prediction into main text and secondary text. For Place predictions, the main text contains the specific name of the Place. For query predictions, the main text contains the query. The secondary text contains additional disambiguating features (such as a city or region) to further identify the Place or refine the query. # A breakdown of the query prediction into main text containing the query and secondary text containing additional disambiguating features (such as a city or region). `structured_format` is recommended for developers who wish to show two separate, but related, UI elements. Developers who wish to show a single UI element may want to use `text` instead. They are two different ways to represent a query prediction. Users should not try to parse `structured_format` into `text` or vice versa.
          "mainText": { # Text representing a Place or query prediction. The text may be used as is or formatted. # Represents the name of the Place or query.
            "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
              { # Identifies a substring within a given text.
                "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
                "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
              },
            ],
            "text": "A String", # Text that may be used as is or formatted with `matches`.
          },
          "secondaryText": { # Text representing a Place or query prediction. The text may be used as is or formatted. # Represents additional disambiguating features (such as a city or region) to further identify the Place or refine the query.
            "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
              { # Identifies a substring within a given text.
                "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
                "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
              },
            ],
            "text": "A String", # Text that may be used as is or formatted with `matches`.
          },
        },
        "text": { # Text representing a Place or query prediction. The text may be used as is or formatted. # The predicted text. This text does not represent a Place, but rather a text query that could be used in a search endpoint (for example, Text Search). `text` is recommended for developers who wish to show a single UI element. Developers who wish to show two separate, but related, UI elements may want to use `structured_format` instead. They are two different ways to represent a query prediction. Users should not try to parse `structured_format` into `text` or vice versa. May be in mixed languages if the request `input` and `language_code` are in different languages or if part of the query does not have a translation from the local language to `language_code`.
          "matches": [ # A list of string ranges identifying where the input request matched in `text`. The ranges can be used to format specific parts of `text`. The substrings may not be exact matches of `input` if the matching was determined by criteria other than string matching (for example, spell corrections or transliterations). These values are Unicode character offsets of `text`. The ranges are guaranteed to be ordered in increasing offset values.
            { # Identifies a substring within a given text.
              "endOffset": 42, # Zero-based offset of the last Unicode character (exclusive).
              "startOffset": 42, # Zero-based offset of the first Unicode character of the string (inclusive).
            },
          ],
          "text": "A String", # Text that may be used as is or formatted with `matches`.
        },
      },
    },
  ],
}
close()
Close httplib2 connections.
get(name, languageCode=None, regionCode=None, sessionToken=None, x__xgafv=None)
Get the details of a place based on its resource name, which is a string in the `places/{place_id}` format.

Args:
  name: string, Required. The resource name of a place, in the `places/{place_id}` format. (required)
  languageCode: string, Optional. Place details will be displayed with the preferred language if available. Current list of supported languages: https://developers.google.com/maps/faq#languagesupport.
  regionCode: string, Optional. The Unicode country/region code (CLDR) of the location where the request is coming from. This parameter is used to display the place details, like region-specific place name, if available. The parameter can affect results based on applicable law. For more information, see https://www.unicode.org/cldr/charts/latest/supplemental/territory_language_information.html. Note that 3-digit region codes are not currently supported.
  sessionToken: string, Optional. A string which identifies an Autocomplete session for billing purposes. Must be a URL and filename safe base64 string with at most 36 ASCII characters in length. Otherwise an INVALID_ARGUMENT error is returned. The session begins when the user starts typing a query, and concludes when they select a place and a call to Place Details or Address Validation is made. Each session can have multiple queries, followed by one Place Details or Address Validation request. The credentials used for each request within a session must belong to the same Google Cloud Console project. Once a session has concluded, the token is no longer valid; your app must generate a fresh token for each session. If the `session_token` parameter is omitted, or if you reuse a session token, the session is charged as if no session token was provided (each request is billed separately). We recommend the following guidelines: * Use session tokens for all Place Autocomplete calls. * Generate a fresh token for each session. Using a version 4 UUID is recommended. * Ensure that the credentials used for all Place Autocomplete, Place Details, and Address Validation requests within a session belong to the same Cloud Console project. * Be sure to pass a unique session token for each new session. Using the same token for more than one session will result in each request being billed individually.
  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # All the information representing a Place.
  "accessibilityOptions": { # Information about the accessibility options a place offers. # Information about the accessibility options a place offers.
    "wheelchairAccessibleEntrance": True or False, # Places has wheelchair accessible entrance.
    "wheelchairAccessibleParking": True or False, # Place offers wheelchair accessible parking.
    "wheelchairAccessibleRestroom": True or False, # Place has wheelchair accessible restroom.
    "wheelchairAccessibleSeating": True or False, # Place has wheelchair accessible seating.
  },
  "addressComponents": [ # Repeated components for each locality level. Note the following facts about the address_components[] array: - The array of address components may contain more components than the formatted_address. - The array does not necessarily include all the political entities that contain an address, apart from those included in the formatted_address. To retrieve all the political entities that contain a specific address, you should use reverse geocoding, passing the latitude/longitude of the address as a parameter to the request. - The format of the response is not guaranteed to remain the same between requests. In particular, the number of address_components varies based on the address requested and can change over time for the same address. A component can change position in the array. The type of the component can change. A particular component may be missing in a later response.
    { # The structured components that form the formatted address, if this information is available.
      "languageCode": "A String", # The language used to format this components, in CLDR notation.
      "longText": "A String", # The full text description or name of the address component. For example, an address component for the country Australia may have a long_name of "Australia".
      "shortText": "A String", # An abbreviated textual name for the address component, if available. For example, an address component for the country of Australia may have a short_name of "AU".
      "types": [ # An array indicating the type(s) of the address component.
        "A String",
      ],
    },
  ],
  "addressDescriptor": { # A relational description of a location. Includes a ranked set of nearby landmarks and precise containing areas and their relationship to the target location. # The address descriptor of the place. Address descriptors include additional information that help describe a location using landmarks and areas. See address descriptor regional coverage in https://developers.google.com/maps/documentation/geocoding/address-descriptors/coverage.
    "areas": [ # A ranked list of containing or adjacent areas. The most recognizable and precise areas are ranked first.
      { # Area information and the area's relationship with the target location. Areas includes precise sublocality, neighborhoods, and large compounds that are useful for describing a location.
        "containment": "A String", # Defines the spatial relationship between the target location and the area.
        "displayName": { # Localized variant of a text in a particular language. # The area's display name.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "name": "A String", # The area's resource name.
        "placeId": "A String", # The area's place id.
      },
    ],
    "landmarks": [ # A ranked list of nearby landmarks. The most recognizable and nearby landmarks are ranked first.
      { # Basic landmark information and the landmark's relationship with the target location. Landmarks are prominent places that can be used to describe a location.
        "displayName": { # Localized variant of a text in a particular language. # The landmark's display name.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "name": "A String", # The landmark's resource name.
        "placeId": "A String", # The landmark's place id.
        "spatialRelationship": "A String", # Defines the spatial relationship between the target location and the landmark.
        "straightLineDistanceMeters": 3.14, # The straight line distance, in meters, between the center point of the target and the center point of the landmark. In some situations, this value can be longer than `travel_distance_meters`.
        "travelDistanceMeters": 3.14, # The travel distance, in meters, along the road network from the target to the landmark, if known. This value does not take into account the mode of transportation, such as walking, driving, or biking.
        "types": [ # A set of type tags for this landmark. For a complete list of possible values, see https://developers.google.com/maps/documentation/places/web-service/place-types.
          "A String",
        ],
      },
    ],
  },
  "adrFormatAddress": "A String", # The place's address in adr microformat: http://microformats.org/wiki/adr.
  "allowsDogs": True or False, # Place allows dogs.
  "areaSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in.
    "contentBlocks": [ # Content blocks that compose the area summary. Each block has a separate topic about the area.
      { # A block of content that can be served individually.
        "content": { # Localized variant of a text in a particular language. # Content related to the topic.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. References that are related to this block of content.
          "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
            "A String",
          ],
          "reviews": [ # Reviews that serve as references.
            { # Information about a review of a place.
              "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                "displayName": "A String", # Name of the author of the Photo or Review.
                "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                "uri": "A String", # URI of the author of the Photo or Review.
              },
              "flagContentUri": "A String", # A link where users can flag a problem with the review.
              "googleMapsUri": "A String", # A link to show the review on Google Maps.
              "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
              "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
              "publishTime": "A String", # Timestamp for the review.
              "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
              "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
              "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
            },
          ],
        },
        "topic": "A String", # The topic of the content, for example "overview" or "restaurant".
      },
    ],
    "flagContentUri": "A String", # A link where users can flag a problem with the summary.
  },
  "attributions": [ # A set of data provider that must be shown with this result.
    { # Information about data providers of this place.
      "provider": "A String", # Name of the Place's data provider.
      "providerUri": "A String", # URI to the Place's data provider.
    },
  ],
  "businessStatus": "A String", # The business status for the place.
  "containingPlaces": [ # List of places in which the current place is located.
    { # Info about the place in which this place is located.
      "id": "A String", # The place id of the place in which this place is located.
      "name": "A String", # The resource name of the place in which this place is located.
    },
  ],
  "curbsidePickup": True or False, # Specifies if the business supports curbside pickup.
  "currentOpeningHours": { # Information about business hour of the place. # The hours of operation for the next seven days (including today). The time period starts at midnight on the date of the request and ends at 11:59 pm six days later. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
    "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
    "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
    "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
    "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
      { # A period the place remains in open_now status.
        "close": { # Status changing points. # The time that the place starts to be closed.
          "date": { # 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 # Date in the local timezone for the place.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
          "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
          "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
          "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
          "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
        },
        "open": { # Status changing points. # The time that the place starts to be open.
          "date": { # 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 # Date in the local timezone for the place.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
          "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
          "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
          "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
          "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
        },
      },
    ],
    "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
    "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
      { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
        "date": { # 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 # The date of this special day.
          "day": 42, # 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.
          "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
          "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
        },
      },
    ],
    "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
      "A String",
    ],
  },
  "currentSecondaryOpeningHours": [ # Contains an array of entries for the next seven days including information about secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
    { # Information about business hour of the place.
      "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
      "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
      "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
      "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
        { # A period the place remains in open_now status.
          "close": { # Status changing points. # The time that the place starts to be closed.
            "date": { # 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 # Date in the local timezone for the place.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
            "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
            "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
            "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
            "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
          },
          "open": { # Status changing points. # The time that the place starts to be open.
            "date": { # 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 # Date in the local timezone for the place.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
            "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
            "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
            "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
            "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
          },
        },
      ],
      "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
      "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
        { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
          "date": { # 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 # The date of this special day.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
        },
      ],
      "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
        "A String",
      ],
    },
  ],
  "delivery": True or False, # Specifies if the business supports delivery.
  "dineIn": True or False, # Specifies if the business supports indoor or outdoor seating options.
  "displayName": { # Localized variant of a text in a particular language. # The localized name of the place, suitable as a short human-readable description. For example, "Google Sydney", "Starbucks", "Pyrmont", etc.
    "languageCode": "A String", # 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.
    "text": "A String", # Localized string in the language corresponding to language_code below.
  },
  "editorialSummary": { # Localized variant of a text in a particular language. # Contains a summary of the place. A summary is comprised of a textual overview, and also includes the language code for these if applicable. Summary text must be presented as-is and can not be modified or altered.
    "languageCode": "A String", # 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.
    "text": "A String", # Localized string in the language corresponding to language_code below.
  },
  "evChargeOptions": { # Information about the EV Charge Station hosted in Place. Terminology follows https://afdc.energy.gov/fuels/electricity_infrastructure.html One port could charge one car at a time. One port has one or more connectors. One station has one or more ports. # Information of ev charging options.
    "connectorAggregation": [ # A list of EV charging connector aggregations that contain connectors of the same type and same charge rate.
      { # EV charging information grouped by [type, max_charge_rate_kw]. Shows EV charge aggregation of connectors that have the same type and max charge rate in kw.
        "availabilityLastUpdateTime": "A String", # The timestamp when the connector availability information in this aggregation was last updated.
        "availableCount": 42, # Number of connectors in this aggregation that are currently available.
        "count": 42, # Number of connectors in this aggregation.
        "maxChargeRateKw": 3.14, # The static max charging rate in kw of each connector in the aggregation.
        "outOfServiceCount": 42, # Number of connectors in this aggregation that are currently out of service.
        "type": "A String", # The connector type of this aggregation.
      },
    ],
    "connectorCount": 42, # Number of connectors at this station. However, because some ports can have multiple connectors but only be able to charge one car at a time (e.g.) the number of connectors may be greater than the total number of cars which can charge simultaneously.
  },
  "formattedAddress": "A String", # A full, human-readable address for this place.
  "fuelOptions": { # The most recent information about fuel options in a gas station. This information is updated regularly. # The most recent information about fuel options in a gas station. This information is updated regularly.
    "fuelPrices": [ # The last known fuel price for each type of fuel this station has. There is one entry per fuel type this station has. Order is not important.
      { # Fuel price information for a given type.
        "price": { # Represents an amount of money with its currency type. # The price of the fuel.
          "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
          "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
          "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
        },
        "type": "A String", # The type of fuel.
        "updateTime": "A String", # The time the fuel price was last updated.
      },
    ],
  },
  "generativeSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place.
    "description": { # Localized variant of a text in a particular language. # The detailed description of the place.
      "languageCode": "A String", # 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.
      "text": "A String", # Localized string in the language corresponding to language_code below.
    },
    "descriptionFlagContentUri": "A String", # A link where users can flag a problem with the description summary.
    "overview": { # Localized variant of a text in a particular language. # The overview of the place.
      "languageCode": "A String", # 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.
      "text": "A String", # Localized string in the language corresponding to language_code below.
    },
    "overviewFlagContentUri": "A String", # A link where users can flag a problem with the overview summary.
    "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # References that are used to generate the summary description.
      "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
        "A String",
      ],
      "reviews": [ # Reviews that serve as references.
        { # Information about a review of a place.
          "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
            "displayName": "A String", # Name of the author of the Photo or Review.
            "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
            "uri": "A String", # URI of the author of the Photo or Review.
          },
          "flagContentUri": "A String", # A link where users can flag a problem with the review.
          "googleMapsUri": "A String", # A link to show the review on Google Maps.
          "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
          "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
          "publishTime": "A String", # Timestamp for the review.
          "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
          "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
          "text": { # Localized variant of a text in a particular language. # The localized text of the review.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
        },
      ],
    },
  },
  "goodForChildren": True or False, # Place is good for children.
  "goodForGroups": True or False, # Place accommodates groups.
  "goodForWatchingSports": True or False, # Place is suitable for watching sports.
  "googleMapsLinks": { # Links to trigger different Google Maps actions. # Links to trigger different Google Maps actions.
    "directionsUri": "A String", # A link to show the directions to the place. The link only populates the destination location and uses the default travel mode `DRIVE`.
    "photosUri": "A String", # A link to show photos of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
    "placeUri": "A String", # A link to show this place.
    "reviewsUri": "A String", # A link to show reviews of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
    "writeAReviewUri": "A String", # A link to write a review for this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
  },
  "googleMapsUri": "A String", # A URL providing more information about this place.
  "iconBackgroundColor": "A String", # Background color for icon_mask in hex format, e.g. #909CE1.
  "iconMaskBaseUri": "A String", # A truncated URL to an icon mask. User can access different icon type by appending type suffix to the end (eg, ".svg" or ".png").
  "id": "A String", # The unique identifier of a place.
  "internationalPhoneNumber": "A String", # A human-readable phone number for the place, in international format.
  "liveMusic": True or False, # Place provides live music.
  "location": { # 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. # The position of this place.
    "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
    "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
  },
  "menuForChildren": True or False, # Place has a children's menu.
  "name": "A String", # This Place's resource name, in `places/{place_id}` format. Can be used to look up the Place.
  "nationalPhoneNumber": "A String", # A human-readable phone number for the place, in national format.
  "outdoorSeating": True or False, # Place provides outdoor seating.
  "parkingOptions": { # Information about parking options for the place. A parking lot could support more than one option at the same time. # Options of parking provided by the place.
    "freeGarageParking": True or False, # Place offers free garage parking.
    "freeParkingLot": True or False, # Place offers free parking lots.
    "freeStreetParking": True or False, # Place offers free street parking.
    "paidGarageParking": True or False, # Place offers paid garage parking.
    "paidParkingLot": True or False, # Place offers paid parking lots.
    "paidStreetParking": True or False, # Place offers paid street parking.
    "valetParking": True or False, # Place offers valet parking.
  },
  "paymentOptions": { # Payment options the place accepts. # Payment options the place accepts. If a payment option data is not available, the payment option field will be unset.
    "acceptsCashOnly": True or False, # Place accepts cash only as payment. Places with this attribute may still accept other payment methods.
    "acceptsCreditCards": True or False, # Place accepts credit cards as payment.
    "acceptsDebitCards": True or False, # Place accepts debit cards as payment.
    "acceptsNfc": True or False, # Place accepts NFC payments.
  },
  "photos": [ # Information (including references) about photos of this place. A maximum of 10 photos can be returned.
    { # Information about a photo of a place.
      "authorAttributions": [ # This photo's authors.
        { # Information about the author of the UGC data. Used in Photo, and Review.
          "displayName": "A String", # Name of the author of the Photo or Review.
          "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
          "uri": "A String", # URI of the author of the Photo or Review.
        },
      ],
      "flagContentUri": "A String", # A link where users can flag a problem with the photo.
      "googleMapsUri": "A String", # A link to show the photo on Google Maps.
      "heightPx": 42, # The maximum available height, in pixels.
      "name": "A String", # Identifier. A reference representing this place photo which may be used to look up this place photo again (also called the API "resource" name: `places/{place_id}/photos/{photo}`).
      "widthPx": 42, # The maximum available width, in pixels.
    },
  ],
  "plusCode": { # Plus code (http://plus.codes) is a location reference with two formats: global code defining a 14mx14m (1/8000th of a degree) or smaller rectangle, and compound code, replacing the prefix with a reference location. # Plus code of the place location lat/long.
    "compoundCode": "A String", # Place's compound code, such as "33GV+HQ, Ramberg, Norway", containing the suffix of the global code and replacing the prefix with a formatted name of a reference entity.
    "globalCode": "A String", # Place's global (full) code, such as "9FWM33GV+HQ", representing an 1/8000 by 1/8000 degree area (~14 by 14 meters).
  },
  "priceLevel": "A String", # Price level of the place.
  "priceRange": { # The price range associated with a Place. `end_price` could be unset, which indicates a range without upper bound (e.g. "More than $100"). # The price range associated with a Place.
    "endPrice": { # Represents an amount of money with its currency type. # The high end of the price range (exclusive). Price should be lower than this amount.
      "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
      "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
      "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
    },
    "startPrice": { # Represents an amount of money with its currency type. # The low end of the price range (inclusive). Price should be at or above this amount.
      "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
      "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
      "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
    },
  },
  "primaryType": "A String", # The primary type of the given result. This type must one of the Places API supported types. For example, "restaurant", "cafe", "airport", etc. A place can only have a single primary type. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
  "primaryTypeDisplayName": { # Localized variant of a text in a particular language. # The display name of the primary type, localized to the request language if applicable. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
    "languageCode": "A String", # 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.
    "text": "A String", # Localized string in the language corresponding to language_code below.
  },
  "pureServiceAreaBusiness": True or False, # Indicates whether the place is a pure service area business. Pure service area business is a business that visits or delivers to customers directly but does not serve customers at their business address. For example, businesses like cleaning services or plumbers. Those businesses may not have a physical address or location on Google Maps.
  "rating": 3.14, # A rating between 1.0 and 5.0, based on user reviews of this place.
  "regularOpeningHours": { # Information about business hour of the place. # The regular hours of operation.
    "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
    "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
    "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
    "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
      { # A period the place remains in open_now status.
        "close": { # Status changing points. # The time that the place starts to be closed.
          "date": { # 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 # Date in the local timezone for the place.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
          "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
          "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
          "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
          "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
        },
        "open": { # Status changing points. # The time that the place starts to be open.
          "date": { # 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 # Date in the local timezone for the place.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
          "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
          "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
          "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
          "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
        },
      },
    ],
    "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
    "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
      { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
        "date": { # 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 # The date of this special day.
          "day": 42, # 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.
          "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
          "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
        },
      },
    ],
    "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
      "A String",
    ],
  },
  "regularSecondaryOpeningHours": [ # Contains an array of entries for information about regular secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place.
    { # Information about business hour of the place.
      "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
      "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
      "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
      "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
        { # A period the place remains in open_now status.
          "close": { # Status changing points. # The time that the place starts to be closed.
            "date": { # 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 # Date in the local timezone for the place.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
            "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
            "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
            "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
            "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
          },
          "open": { # Status changing points. # The time that the place starts to be open.
            "date": { # 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 # Date in the local timezone for the place.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
            "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
            "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
            "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
            "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
          },
        },
      ],
      "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
      "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
        { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
          "date": { # 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 # The date of this special day.
            "day": 42, # 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.
            "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
            "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
          },
        },
      ],
      "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
        "A String",
      ],
    },
  ],
  "reservable": True or False, # Specifies if the place supports reservations.
  "restroom": True or False, # Place has restroom.
  "reviews": [ # List of reviews about this place, sorted by relevance. A maximum of 5 reviews can be returned.
    { # Information about a review of a place.
      "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
        "displayName": "A String", # Name of the author of the Photo or Review.
        "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
        "uri": "A String", # URI of the author of the Photo or Review.
      },
      "flagContentUri": "A String", # A link where users can flag a problem with the review.
      "googleMapsUri": "A String", # A link to show the review on Google Maps.
      "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
      "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "publishTime": "A String", # Timestamp for the review.
      "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
      "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
      "text": { # Localized variant of a text in a particular language. # The localized text of the review.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
    },
  ],
  "servesBeer": True or False, # Specifies if the place serves beer.
  "servesBreakfast": True or False, # Specifies if the place serves breakfast.
  "servesBrunch": True or False, # Specifies if the place serves brunch.
  "servesCocktails": True or False, # Place serves cocktails.
  "servesCoffee": True or False, # Place serves coffee.
  "servesDessert": True or False, # Place serves dessert.
  "servesDinner": True or False, # Specifies if the place serves dinner.
  "servesLunch": True or False, # Specifies if the place serves lunch.
  "servesVegetarianFood": True or False, # Specifies if the place serves vegetarian food.
  "servesWine": True or False, # Specifies if the place serves wine.
  "shortFormattedAddress": "A String", # A short, human-readable address for this place.
  "subDestinations": [ # A list of sub destinations related to the place.
    { # Place resource name and id of sub destinations that relate to the place. For example, different terminals are different destinations of an airport.
      "id": "A String", # The place id of the sub destination.
      "name": "A String", # The resource name of the sub destination.
    },
  ],
  "takeout": True or False, # Specifies if the business supports takeout.
  "types": [ # A set of type tags for this result. For example, "political" and "locality". For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
    "A String",
  ],
  "userRatingCount": 42, # The total number of reviews (with or without text) for this place.
  "utcOffsetMinutes": 42, # Number of minutes this place's timezone is currently offset from UTC. This is expressed in minutes to support timezones that are offset by fractions of an hour, e.g. X hours and 15 minutes.
  "viewport": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A viewport suitable for displaying the place on an average-sized map. This viewport should not be used as the physical boundary or the service area of the business.
    "high": { # 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. # Required. The high point of the viewport.
      "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
      "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
    },
    "low": { # 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. # Required. The low point of the viewport.
      "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
      "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
    },
  },
  "websiteUri": "A String", # The authoritative website for this place, e.g. a business' homepage. Note that for places that are part of a chain (e.g. an IKEA store), this will usually be the website for the individual store, not the overall chain.
}
searchNearby(body=None, x__xgafv=None)
Search for places near locations.

Args:
  body: object, The request body.
    The object takes the form of:

{ # Request proto for Search Nearby.
  "excludedPrimaryTypes": [ # Excluded primary Place type (e.g. "restaurant" or "gas_station") from https://developers.google.com/maps/documentation/places/web-service/place-types. Up to 50 types from [Table A](https://developers.google.com/maps/documentation/places/web-service/place-types#table-a) may be specified. If there are any conflicting primary types, i.e. a type appears in both included_primary_types and excluded_primary_types, an INVALID_ARGUMENT error is returned. If a Place type is specified with multiple type restrictions, only places that satisfy all of the restrictions are returned. For example, if we have {included_types = ["restaurant"], excluded_primary_types = ["restaurant"]}, the returned places provide "restaurant" related services but do not operate primarily as "restaurants".
    "A String",
  ],
  "excludedTypes": [ # Excluded Place type (eg, "restaurant" or "gas_station") from https://developers.google.com/maps/documentation/places/web-service/place-types. Up to 50 types from [Table A](https://developers.google.com/maps/documentation/places/web-service/place-types#table-a) may be specified. If the client provides both included_types (e.g. restaurant) and excluded_types (e.g. cafe), then the response should include places that are restaurant but not cafe. The response includes places that match at least one of the included_types and none of the excluded_types. If there are any conflicting types, i.e. a type appears in both included_types and excluded_types, an INVALID_ARGUMENT error is returned. If a Place type is specified with multiple type restrictions, only places that satisfy all of the restrictions are returned. For example, if we have {included_types = ["restaurant"], excluded_primary_types = ["restaurant"]}, the returned places provide "restaurant" related services but do not operate primarily as "restaurants".
    "A String",
  ],
  "includedPrimaryTypes": [ # Included primary Place type (e.g. "restaurant" or "gas_station") from https://developers.google.com/maps/documentation/places/web-service/place-types. A place can only have a single primary type from the supported types table associated with it. Up to 50 types from [Table A](https://developers.google.com/maps/documentation/places/web-service/place-types#table-a) may be specified. If there are any conflicting primary types, i.e. a type appears in both included_primary_types and excluded_primary_types, an INVALID_ARGUMENT error is returned. If a Place type is specified with multiple type restrictions, only places that satisfy all of the restrictions are returned. For example, if we have {included_types = ["restaurant"], excluded_primary_types = ["restaurant"]}, the returned places provide "restaurant" related services but do not operate primarily as "restaurants".
    "A String",
  ],
  "includedTypes": [ # Included Place type (eg, "restaurant" or "gas_station") from https://developers.google.com/maps/documentation/places/web-service/place-types. Up to 50 types from [Table A](https://developers.google.com/maps/documentation/places/web-service/place-types#table-a) may be specified. If there are any conflicting types, i.e. a type appears in both included_types and excluded_types, an INVALID_ARGUMENT error is returned. If a Place type is specified with multiple type restrictions, only places that satisfy all of the restrictions are returned. For example, if we have {included_types = ["restaurant"], excluded_primary_types = ["restaurant"]}, the returned places provide "restaurant" related services but do not operate primarily as "restaurants".
    "A String",
  ],
  "languageCode": "A String", # Place details will be displayed with the preferred language if available. If the language code is unspecified or unrecognized, place details of any language may be returned, with a preference for English if such details exist. Current list of supported languages: https://developers.google.com/maps/faq#languagesupport.
  "locationRestriction": { # The region to search. # Required. The region to search.
    "circle": { # Circle with a LatLng as center and radius. # A circle defined by center point and radius.
      "center": { # 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. # Required. Center latitude and longitude. The range of latitude must be within [-90.0, 90.0]. The range of the longitude must be within [-180.0, 180.0].
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "radius": 3.14, # Required. Radius measured in meters. The radius must be within [0.0, 50000.0].
    },
  },
  "maxResultCount": 42, # Maximum number of results to return. It must be between 1 and 20 (default), inclusively. If the number is unset, it falls back to the upper limit. If the number is set to negative or exceeds the upper limit, an INVALID_ARGUMENT error is returned.
  "rankPreference": "A String", # How results will be ranked in the response.
  "regionCode": "A String", # The Unicode country/region code (CLDR) of the location where the request is coming from. This parameter is used to display the place details, like region-specific place name, if available. The parameter can affect results based on applicable law. For more information, see https://www.unicode.org/cldr/charts/latest/supplemental/territory_language_information.html. Note that 3-digit region codes are not currently supported.
  "routingParameters": { # Parameters to configure the routing calculations to the places in the response, both along a route (where result ranking will be influenced) and for calculating travel times on results. # Optional. Parameters that affect the routing to the search results.
    "origin": { # 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. # Optional. An explicit routing origin that overrides the origin defined in the polyline. By default, the polyline origin is used.
      "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
      "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
    },
    "routeModifiers": { # Encapsulates a set of optional conditions to satisfy when calculating the routes. # Optional. The route modifiers.
      "avoidFerries": True or False, # Optional. When set to true, avoids ferries where reasonable, giving preference to routes not containing ferries. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
      "avoidHighways": True or False, # Optional. When set to true, avoids highways where reasonable, giving preference to routes not containing highways. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
      "avoidIndoor": True or False, # Optional. When set to true, avoids navigating indoors where reasonable, giving preference to routes not containing indoor navigation. Applies only to the `WALK` `TravelMode`.
      "avoidTolls": True or False, # Optional. When set to true, avoids toll roads where reasonable, giving preference to routes not containing toll roads. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
    },
    "routingPreference": "A String", # Optional. Specifies how to compute the routing summaries. The server attempts to use the selected routing preference to compute the route. The traffic aware routing preference is only available for the `DRIVE` or `TWO_WHEELER` `travelMode`.
    "travelMode": "A String", # Optional. The travel mode.
  },
}

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Response proto for Search Nearby.
  "places": [ # A list of places that meets user's requirements like places types, number of places and specific location restriction.
    { # All the information representing a Place.
      "accessibilityOptions": { # Information about the accessibility options a place offers. # Information about the accessibility options a place offers.
        "wheelchairAccessibleEntrance": True or False, # Places has wheelchair accessible entrance.
        "wheelchairAccessibleParking": True or False, # Place offers wheelchair accessible parking.
        "wheelchairAccessibleRestroom": True or False, # Place has wheelchair accessible restroom.
        "wheelchairAccessibleSeating": True or False, # Place has wheelchair accessible seating.
      },
      "addressComponents": [ # Repeated components for each locality level. Note the following facts about the address_components[] array: - The array of address components may contain more components than the formatted_address. - The array does not necessarily include all the political entities that contain an address, apart from those included in the formatted_address. To retrieve all the political entities that contain a specific address, you should use reverse geocoding, passing the latitude/longitude of the address as a parameter to the request. - The format of the response is not guaranteed to remain the same between requests. In particular, the number of address_components varies based on the address requested and can change over time for the same address. A component can change position in the array. The type of the component can change. A particular component may be missing in a later response.
        { # The structured components that form the formatted address, if this information is available.
          "languageCode": "A String", # The language used to format this components, in CLDR notation.
          "longText": "A String", # The full text description or name of the address component. For example, an address component for the country Australia may have a long_name of "Australia".
          "shortText": "A String", # An abbreviated textual name for the address component, if available. For example, an address component for the country of Australia may have a short_name of "AU".
          "types": [ # An array indicating the type(s) of the address component.
            "A String",
          ],
        },
      ],
      "addressDescriptor": { # A relational description of a location. Includes a ranked set of nearby landmarks and precise containing areas and their relationship to the target location. # The address descriptor of the place. Address descriptors include additional information that help describe a location using landmarks and areas. See address descriptor regional coverage in https://developers.google.com/maps/documentation/geocoding/address-descriptors/coverage.
        "areas": [ # A ranked list of containing or adjacent areas. The most recognizable and precise areas are ranked first.
          { # Area information and the area's relationship with the target location. Areas includes precise sublocality, neighborhoods, and large compounds that are useful for describing a location.
            "containment": "A String", # Defines the spatial relationship between the target location and the area.
            "displayName": { # Localized variant of a text in a particular language. # The area's display name.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "name": "A String", # The area's resource name.
            "placeId": "A String", # The area's place id.
          },
        ],
        "landmarks": [ # A ranked list of nearby landmarks. The most recognizable and nearby landmarks are ranked first.
          { # Basic landmark information and the landmark's relationship with the target location. Landmarks are prominent places that can be used to describe a location.
            "displayName": { # Localized variant of a text in a particular language. # The landmark's display name.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "name": "A String", # The landmark's resource name.
            "placeId": "A String", # The landmark's place id.
            "spatialRelationship": "A String", # Defines the spatial relationship between the target location and the landmark.
            "straightLineDistanceMeters": 3.14, # The straight line distance, in meters, between the center point of the target and the center point of the landmark. In some situations, this value can be longer than `travel_distance_meters`.
            "travelDistanceMeters": 3.14, # The travel distance, in meters, along the road network from the target to the landmark, if known. This value does not take into account the mode of transportation, such as walking, driving, or biking.
            "types": [ # A set of type tags for this landmark. For a complete list of possible values, see https://developers.google.com/maps/documentation/places/web-service/place-types.
              "A String",
            ],
          },
        ],
      },
      "adrFormatAddress": "A String", # The place's address in adr microformat: http://microformats.org/wiki/adr.
      "allowsDogs": True or False, # Place allows dogs.
      "areaSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in.
        "contentBlocks": [ # Content blocks that compose the area summary. Each block has a separate topic about the area.
          { # A block of content that can be served individually.
            "content": { # Localized variant of a text in a particular language. # Content related to the topic.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. References that are related to this block of content.
              "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
                "A String",
              ],
              "reviews": [ # Reviews that serve as references.
                { # Information about a review of a place.
                  "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                    "displayName": "A String", # Name of the author of the Photo or Review.
                    "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                    "uri": "A String", # URI of the author of the Photo or Review.
                  },
                  "flagContentUri": "A String", # A link where users can flag a problem with the review.
                  "googleMapsUri": "A String", # A link to show the review on Google Maps.
                  "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
                  "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                    "languageCode": "A String", # 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.
                    "text": "A String", # Localized string in the language corresponding to language_code below.
                  },
                  "publishTime": "A String", # Timestamp for the review.
                  "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
                  "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
                  "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                    "languageCode": "A String", # 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.
                    "text": "A String", # Localized string in the language corresponding to language_code below.
                  },
                },
              ],
            },
            "topic": "A String", # The topic of the content, for example "overview" or "restaurant".
          },
        ],
        "flagContentUri": "A String", # A link where users can flag a problem with the summary.
      },
      "attributions": [ # A set of data provider that must be shown with this result.
        { # Information about data providers of this place.
          "provider": "A String", # Name of the Place's data provider.
          "providerUri": "A String", # URI to the Place's data provider.
        },
      ],
      "businessStatus": "A String", # The business status for the place.
      "containingPlaces": [ # List of places in which the current place is located.
        { # Info about the place in which this place is located.
          "id": "A String", # The place id of the place in which this place is located.
          "name": "A String", # The resource name of the place in which this place is located.
        },
      ],
      "curbsidePickup": True or False, # Specifies if the business supports curbside pickup.
      "currentOpeningHours": { # Information about business hour of the place. # The hours of operation for the next seven days (including today). The time period starts at midnight on the date of the request and ends at 11:59 pm six days later. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
        "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
        "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
        "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
        "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
          { # A period the place remains in open_now status.
            "close": { # Status changing points. # The time that the place starts to be closed.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
            "open": { # Status changing points. # The time that the place starts to be open.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
          },
        ],
        "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
        "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
          { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
            "date": { # 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 # The date of this special day.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
          },
        ],
        "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
          "A String",
        ],
      },
      "currentSecondaryOpeningHours": [ # Contains an array of entries for the next seven days including information about secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
        { # Information about business hour of the place.
          "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
          "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
          "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
          "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
            { # A period the place remains in open_now status.
              "close": { # Status changing points. # The time that the place starts to be closed.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
              "open": { # Status changing points. # The time that the place starts to be open.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
            },
          ],
          "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
          "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
            { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
              "date": { # 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 # The date of this special day.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
            },
          ],
          "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
            "A String",
          ],
        },
      ],
      "delivery": True or False, # Specifies if the business supports delivery.
      "dineIn": True or False, # Specifies if the business supports indoor or outdoor seating options.
      "displayName": { # Localized variant of a text in a particular language. # The localized name of the place, suitable as a short human-readable description. For example, "Google Sydney", "Starbucks", "Pyrmont", etc.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "editorialSummary": { # Localized variant of a text in a particular language. # Contains a summary of the place. A summary is comprised of a textual overview, and also includes the language code for these if applicable. Summary text must be presented as-is and can not be modified or altered.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "evChargeOptions": { # Information about the EV Charge Station hosted in Place. Terminology follows https://afdc.energy.gov/fuels/electricity_infrastructure.html One port could charge one car at a time. One port has one or more connectors. One station has one or more ports. # Information of ev charging options.
        "connectorAggregation": [ # A list of EV charging connector aggregations that contain connectors of the same type and same charge rate.
          { # EV charging information grouped by [type, max_charge_rate_kw]. Shows EV charge aggregation of connectors that have the same type and max charge rate in kw.
            "availabilityLastUpdateTime": "A String", # The timestamp when the connector availability information in this aggregation was last updated.
            "availableCount": 42, # Number of connectors in this aggregation that are currently available.
            "count": 42, # Number of connectors in this aggregation.
            "maxChargeRateKw": 3.14, # The static max charging rate in kw of each connector in the aggregation.
            "outOfServiceCount": 42, # Number of connectors in this aggregation that are currently out of service.
            "type": "A String", # The connector type of this aggregation.
          },
        ],
        "connectorCount": 42, # Number of connectors at this station. However, because some ports can have multiple connectors but only be able to charge one car at a time (e.g.) the number of connectors may be greater than the total number of cars which can charge simultaneously.
      },
      "formattedAddress": "A String", # A full, human-readable address for this place.
      "fuelOptions": { # The most recent information about fuel options in a gas station. This information is updated regularly. # The most recent information about fuel options in a gas station. This information is updated regularly.
        "fuelPrices": [ # The last known fuel price for each type of fuel this station has. There is one entry per fuel type this station has. Order is not important.
          { # Fuel price information for a given type.
            "price": { # Represents an amount of money with its currency type. # The price of the fuel.
              "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
              "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
              "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
            },
            "type": "A String", # The type of fuel.
            "updateTime": "A String", # The time the fuel price was last updated.
          },
        ],
      },
      "generativeSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place.
        "description": { # Localized variant of a text in a particular language. # The detailed description of the place.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "descriptionFlagContentUri": "A String", # A link where users can flag a problem with the description summary.
        "overview": { # Localized variant of a text in a particular language. # The overview of the place.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "overviewFlagContentUri": "A String", # A link where users can flag a problem with the overview summary.
        "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # References that are used to generate the summary description.
          "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
            "A String",
          ],
          "reviews": [ # Reviews that serve as references.
            { # Information about a review of a place.
              "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                "displayName": "A String", # Name of the author of the Photo or Review.
                "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                "uri": "A String", # URI of the author of the Photo or Review.
              },
              "flagContentUri": "A String", # A link where users can flag a problem with the review.
              "googleMapsUri": "A String", # A link to show the review on Google Maps.
              "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
              "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
              "publishTime": "A String", # Timestamp for the review.
              "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
              "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
              "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
            },
          ],
        },
      },
      "goodForChildren": True or False, # Place is good for children.
      "goodForGroups": True or False, # Place accommodates groups.
      "goodForWatchingSports": True or False, # Place is suitable for watching sports.
      "googleMapsLinks": { # Links to trigger different Google Maps actions. # Links to trigger different Google Maps actions.
        "directionsUri": "A String", # A link to show the directions to the place. The link only populates the destination location and uses the default travel mode `DRIVE`.
        "photosUri": "A String", # A link to show photos of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
        "placeUri": "A String", # A link to show this place.
        "reviewsUri": "A String", # A link to show reviews of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
        "writeAReviewUri": "A String", # A link to write a review for this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
      },
      "googleMapsUri": "A String", # A URL providing more information about this place.
      "iconBackgroundColor": "A String", # Background color for icon_mask in hex format, e.g. #909CE1.
      "iconMaskBaseUri": "A String", # A truncated URL to an icon mask. User can access different icon type by appending type suffix to the end (eg, ".svg" or ".png").
      "id": "A String", # The unique identifier of a place.
      "internationalPhoneNumber": "A String", # A human-readable phone number for the place, in international format.
      "liveMusic": True or False, # Place provides live music.
      "location": { # 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. # The position of this place.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "menuForChildren": True or False, # Place has a children's menu.
      "name": "A String", # This Place's resource name, in `places/{place_id}` format. Can be used to look up the Place.
      "nationalPhoneNumber": "A String", # A human-readable phone number for the place, in national format.
      "outdoorSeating": True or False, # Place provides outdoor seating.
      "parkingOptions": { # Information about parking options for the place. A parking lot could support more than one option at the same time. # Options of parking provided by the place.
        "freeGarageParking": True or False, # Place offers free garage parking.
        "freeParkingLot": True or False, # Place offers free parking lots.
        "freeStreetParking": True or False, # Place offers free street parking.
        "paidGarageParking": True or False, # Place offers paid garage parking.
        "paidParkingLot": True or False, # Place offers paid parking lots.
        "paidStreetParking": True or False, # Place offers paid street parking.
        "valetParking": True or False, # Place offers valet parking.
      },
      "paymentOptions": { # Payment options the place accepts. # Payment options the place accepts. If a payment option data is not available, the payment option field will be unset.
        "acceptsCashOnly": True or False, # Place accepts cash only as payment. Places with this attribute may still accept other payment methods.
        "acceptsCreditCards": True or False, # Place accepts credit cards as payment.
        "acceptsDebitCards": True or False, # Place accepts debit cards as payment.
        "acceptsNfc": True or False, # Place accepts NFC payments.
      },
      "photos": [ # Information (including references) about photos of this place. A maximum of 10 photos can be returned.
        { # Information about a photo of a place.
          "authorAttributions": [ # This photo's authors.
            { # Information about the author of the UGC data. Used in Photo, and Review.
              "displayName": "A String", # Name of the author of the Photo or Review.
              "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
              "uri": "A String", # URI of the author of the Photo or Review.
            },
          ],
          "flagContentUri": "A String", # A link where users can flag a problem with the photo.
          "googleMapsUri": "A String", # A link to show the photo on Google Maps.
          "heightPx": 42, # The maximum available height, in pixels.
          "name": "A String", # Identifier. A reference representing this place photo which may be used to look up this place photo again (also called the API "resource" name: `places/{place_id}/photos/{photo}`).
          "widthPx": 42, # The maximum available width, in pixels.
        },
      ],
      "plusCode": { # Plus code (http://plus.codes) is a location reference with two formats: global code defining a 14mx14m (1/8000th of a degree) or smaller rectangle, and compound code, replacing the prefix with a reference location. # Plus code of the place location lat/long.
        "compoundCode": "A String", # Place's compound code, such as "33GV+HQ, Ramberg, Norway", containing the suffix of the global code and replacing the prefix with a formatted name of a reference entity.
        "globalCode": "A String", # Place's global (full) code, such as "9FWM33GV+HQ", representing an 1/8000 by 1/8000 degree area (~14 by 14 meters).
      },
      "priceLevel": "A String", # Price level of the place.
      "priceRange": { # The price range associated with a Place. `end_price` could be unset, which indicates a range without upper bound (e.g. "More than $100"). # The price range associated with a Place.
        "endPrice": { # Represents an amount of money with its currency type. # The high end of the price range (exclusive). Price should be lower than this amount.
          "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
          "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
          "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
        },
        "startPrice": { # Represents an amount of money with its currency type. # The low end of the price range (inclusive). Price should be at or above this amount.
          "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
          "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
          "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
        },
      },
      "primaryType": "A String", # The primary type of the given result. This type must one of the Places API supported types. For example, "restaurant", "cafe", "airport", etc. A place can only have a single primary type. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
      "primaryTypeDisplayName": { # Localized variant of a text in a particular language. # The display name of the primary type, localized to the request language if applicable. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "pureServiceAreaBusiness": True or False, # Indicates whether the place is a pure service area business. Pure service area business is a business that visits or delivers to customers directly but does not serve customers at their business address. For example, businesses like cleaning services or plumbers. Those businesses may not have a physical address or location on Google Maps.
      "rating": 3.14, # A rating between 1.0 and 5.0, based on user reviews of this place.
      "regularOpeningHours": { # Information about business hour of the place. # The regular hours of operation.
        "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
        "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
        "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
        "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
          { # A period the place remains in open_now status.
            "close": { # Status changing points. # The time that the place starts to be closed.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
            "open": { # Status changing points. # The time that the place starts to be open.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
          },
        ],
        "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
        "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
          { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
            "date": { # 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 # The date of this special day.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
          },
        ],
        "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
          "A String",
        ],
      },
      "regularSecondaryOpeningHours": [ # Contains an array of entries for information about regular secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place.
        { # Information about business hour of the place.
          "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
          "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
          "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
          "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
            { # A period the place remains in open_now status.
              "close": { # Status changing points. # The time that the place starts to be closed.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
              "open": { # Status changing points. # The time that the place starts to be open.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
            },
          ],
          "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
          "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
            { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
              "date": { # 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 # The date of this special day.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
            },
          ],
          "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
            "A String",
          ],
        },
      ],
      "reservable": True or False, # Specifies if the place supports reservations.
      "restroom": True or False, # Place has restroom.
      "reviews": [ # List of reviews about this place, sorted by relevance. A maximum of 5 reviews can be returned.
        { # Information about a review of a place.
          "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
            "displayName": "A String", # Name of the author of the Photo or Review.
            "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
            "uri": "A String", # URI of the author of the Photo or Review.
          },
          "flagContentUri": "A String", # A link where users can flag a problem with the review.
          "googleMapsUri": "A String", # A link to show the review on Google Maps.
          "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
          "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
          "publishTime": "A String", # Timestamp for the review.
          "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
          "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
          "text": { # Localized variant of a text in a particular language. # The localized text of the review.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
        },
      ],
      "servesBeer": True or False, # Specifies if the place serves beer.
      "servesBreakfast": True or False, # Specifies if the place serves breakfast.
      "servesBrunch": True or False, # Specifies if the place serves brunch.
      "servesCocktails": True or False, # Place serves cocktails.
      "servesCoffee": True or False, # Place serves coffee.
      "servesDessert": True or False, # Place serves dessert.
      "servesDinner": True or False, # Specifies if the place serves dinner.
      "servesLunch": True or False, # Specifies if the place serves lunch.
      "servesVegetarianFood": True or False, # Specifies if the place serves vegetarian food.
      "servesWine": True or False, # Specifies if the place serves wine.
      "shortFormattedAddress": "A String", # A short, human-readable address for this place.
      "subDestinations": [ # A list of sub destinations related to the place.
        { # Place resource name and id of sub destinations that relate to the place. For example, different terminals are different destinations of an airport.
          "id": "A String", # The place id of the sub destination.
          "name": "A String", # The resource name of the sub destination.
        },
      ],
      "takeout": True or False, # Specifies if the business supports takeout.
      "types": [ # A set of type tags for this result. For example, "political" and "locality". For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
        "A String",
      ],
      "userRatingCount": 42, # The total number of reviews (with or without text) for this place.
      "utcOffsetMinutes": 42, # Number of minutes this place's timezone is currently offset from UTC. This is expressed in minutes to support timezones that are offset by fractions of an hour, e.g. X hours and 15 minutes.
      "viewport": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A viewport suitable for displaying the place on an average-sized map. This viewport should not be used as the physical boundary or the service area of the business.
        "high": { # 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. # Required. The high point of the viewport.
          "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
          "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
        },
        "low": { # 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. # Required. The low point of the viewport.
          "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
          "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
        },
      },
      "websiteUri": "A String", # The authoritative website for this place, e.g. a business' homepage. Note that for places that are part of a chain (e.g. an IKEA store), this will usually be the website for the individual store, not the overall chain.
    },
  ],
  "routingSummaries": [ # A list of routing summaries where each entry associates to the corresponding place in the same index in the `places` field. If the routing summary is not available for one of the places, it will contain an empty entry. This list should have as many entries as the list of places if requested.
    { # The duration and distance from the routing origin to a place in the response, and a second leg from that place to the destination, if requested. **Note:** Adding `routingSummaries` in the field mask without also including either the `routingParameters.origin` parameter or the `searchAlongRouteParameters.polyline.encodedPolyline` parameter in the request causes an error.
      "directionsUri": "A String", # A link to show directions on Google Maps using the waypoints from the given routing summary. The route generated by this link is not guaranteed to be the same as the route used to generate the routing summary. The link uses information provided in the request, from fields including `routingParameters` and `searchAlongRouteParameters` when applicable, to generate the directions link.
      "legs": [ # The legs of the trip. When you calculate travel duration and distance from a set origin, `legs` contains a single leg containing the duration and distance from the origin to the destination. When you do a search along route, `legs` contains two legs: one from the origin to place, and one from the place to the destination.
        { # A leg is a single portion of a journey from one location to another.
          "distanceMeters": 42, # The distance of this leg of the trip.
          "duration": "A String", # The time it takes to complete this leg of the trip.
        },
      ],
    },
  ],
}
searchText(body=None, x__xgafv=None)
Text query based place search.

Args:
  body: object, The request body.
    The object takes the form of:

{ # Request proto for SearchText.
  "evOptions": { # Searchable EV options of a place search request. # Optional. Set the searchable EV options of a place search request.
    "connectorTypes": [ # Optional. The list of preferred EV connector types. A place that does not support any of the listed connector types is filtered out.
      "A String",
    ],
    "minimumChargingRateKw": 3.14, # Optional. Minimum required charging rate in kilowatts. A place with a charging rate less than the specified rate is filtered out.
  },
  "includePureServiceAreaBusinesses": True or False, # Optional. Include pure service area businesses if the field is set to true. Pure service area business is a business that visits or delivers to customers directly but does not serve customers at their business address. For example, businesses like cleaning services or plumbers. Those businesses do not have a physical address or location on Google Maps. Places will not return fields including `location`, `plus_code`, and other location related fields for these businesses.
  "includedType": "A String", # The requested place type. Full list of types supported: https://developers.google.com/maps/documentation/places/web-service/place-types. Only support one included type.
  "languageCode": "A String", # Place details will be displayed with the preferred language if available. If the language code is unspecified or unrecognized, place details of any language may be returned, with a preference for English if such details exist. Current list of supported languages: https://developers.google.com/maps/faq#languagesupport.
  "locationBias": { # The region to search. This location serves as a bias which means results around given location might be returned. # The region to search. This location serves as a bias which means results around given location might be returned. Cannot be set along with location_restriction.
    "circle": { # Circle with a LatLng as center and radius. # A circle defined by center point and radius.
      "center": { # 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. # Required. Center latitude and longitude. The range of latitude must be within [-90.0, 90.0]. The range of the longitude must be within [-180.0, 180.0].
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "radius": 3.14, # Required. Radius measured in meters. The radius must be within [0.0, 50000.0].
    },
    "rectangle": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A rectangle box defined by northeast and southwest corner. `rectangle.high()` must be the northeast point of the rectangle viewport. `rectangle.low()` must be the southwest point of the rectangle viewport. `rectangle.low().latitude()` cannot be greater than `rectangle.high().latitude()`. This will result in an empty latitude range. A rectangle viewport cannot be wider than 180 degrees.
      "high": { # 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. # Required. The high point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "low": { # 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. # Required. The low point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
    },
  },
  "locationRestriction": { # The region to search. This location serves as a restriction which means results outside given location will not be returned. # The region to search. This location serves as a restriction which means results outside given location will not be returned. Cannot be set along with location_bias.
    "rectangle": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A rectangle box defined by northeast and southwest corner. `rectangle.high()` must be the northeast point of the rectangle viewport. `rectangle.low()` must be the southwest point of the rectangle viewport. `rectangle.low().latitude()` cannot be greater than `rectangle.high().latitude()`. This will result in an empty latitude range. A rectangle viewport cannot be wider than 180 degrees.
      "high": { # 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. # Required. The high point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "low": { # 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. # Required. The low point of the viewport.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
    },
  },
  "maxResultCount": 42, # Deprecated: Use `page_size` instead. The maximum number of results per page that can be returned. If the number of available results is larger than `max_result_count`, a `next_page_token` is returned which can be passed to `page_token` to get the next page of results in subsequent requests. If 0 or no value is provided, a default of 20 is used. The maximum value is 20; values above 20 will be coerced to 20. Negative values will return an INVALID_ARGUMENT error. If both `max_result_count` and `page_size` are specified, `max_result_count` will be ignored.
  "minRating": 3.14, # Filter out results whose average user rating is strictly less than this limit. A valid value must be a float between 0 and 5 (inclusively) at a 0.5 cadence i.e. [0, 0.5, 1.0, ... , 5.0] inclusively. The input rating will round up to the nearest 0.5(ceiling). For instance, a rating of 0.6 will eliminate all results with a less than 1.0 rating.
  "openNow": True or False, # Used to restrict the search to places that are currently open. The default is false.
  "pageSize": 42, # Optional. The maximum number of results per page that can be returned. If the number of available results is larger than `page_size`, a `next_page_token` is returned which can be passed to `page_token` to get the next page of results in subsequent requests. If 0 or no value is provided, a default of 20 is used. The maximum value is 20; values above 20 will be set to 20. Negative values will return an INVALID_ARGUMENT error. If both `max_result_count` and `page_size` are specified, `max_result_count` will be ignored.
  "pageToken": "A String", # Optional. A page token, received from a previous TextSearch call. Provide this to retrieve the subsequent page. When paginating, all parameters other than `page_token`, `page_size`, and `max_result_count` provided to TextSearch must match the initial call that provided the page token. Otherwise an INVALID_ARGUMENT error is returned.
  "priceLevels": [ # Used to restrict the search to places that are marked as certain price levels. Users can choose any combinations of price levels. Default to select all price levels.
    "A String",
  ],
  "rankPreference": "A String", # How results will be ranked in the response.
  "regionCode": "A String", # The Unicode country/region code (CLDR) of the location where the request is coming from. This parameter is used to display the place details, like region-specific place name, if available. The parameter can affect results based on applicable law. For more information, see https://www.unicode.org/cldr/charts/latest/supplemental/territory_language_information.html. Note that 3-digit region codes are not currently supported.
  "routingParameters": { # Parameters to configure the routing calculations to the places in the response, both along a route (where result ranking will be influenced) and for calculating travel times on results. # Optional. Additional parameters for routing to results.
    "origin": { # 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. # Optional. An explicit routing origin that overrides the origin defined in the polyline. By default, the polyline origin is used.
      "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
      "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
    },
    "routeModifiers": { # Encapsulates a set of optional conditions to satisfy when calculating the routes. # Optional. The route modifiers.
      "avoidFerries": True or False, # Optional. When set to true, avoids ferries where reasonable, giving preference to routes not containing ferries. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
      "avoidHighways": True or False, # Optional. When set to true, avoids highways where reasonable, giving preference to routes not containing highways. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
      "avoidIndoor": True or False, # Optional. When set to true, avoids navigating indoors where reasonable, giving preference to routes not containing indoor navigation. Applies only to the `WALK` `TravelMode`.
      "avoidTolls": True or False, # Optional. When set to true, avoids toll roads where reasonable, giving preference to routes not containing toll roads. Applies only to the `DRIVE` and `TWO_WHEELER` `TravelMode`.
    },
    "routingPreference": "A String", # Optional. Specifies how to compute the routing summaries. The server attempts to use the selected routing preference to compute the route. The traffic aware routing preference is only available for the `DRIVE` or `TWO_WHEELER` `travelMode`.
    "travelMode": "A String", # Optional. The travel mode.
  },
  "searchAlongRouteParameters": { # Specifies a precalculated polyline from the [Routes API](https://developers.google.com/maps/documentation/routes) defining the route to search. Searching along a route is similar to using the `locationBias` or `locationRestriction` request option to bias the search results. However, while the `locationBias` and `locationRestriction` options let you specify a region to bias the search results, this option lets you bias the results along a trip route. Results are not guaranteed to be along the route provided, but rather are ranked within the search area defined by the polyline and, optionally, by the `locationBias` or `locationRestriction` based on minimal detour times from origin to destination. The results might be along an alternate route, especially if the provided polyline does not define an optimal route from origin to destination. # Optional. Additional parameters proto for searching along a route.
    "polyline": { # A route polyline. Only supports an [encoded polyline](https://developers.google.com/maps/documentation/utilities/polylinealgorithm), which can be passed as a string and includes compression with minimal lossiness. This is the Routes API default output. # Required. The route polyline.
      "encodedPolyline": "A String", # An [encoded polyline](https://developers.google.com/maps/documentation/utilities/polylinealgorithm), as returned by the [Routes API by default](https://developers.google.com/maps/documentation/routes/reference/rest/v2/TopLevel/computeRoutes#polylineencoding). See the [encoder](https://developers.google.com/maps/documentation/utilities/polylineutility) and [decoder](https://developers.google.com/maps/documentation/routes/polylinedecoder) tools.
    },
  },
  "strictTypeFiltering": True or False, # Used to set strict type filtering for included_type. If set to true, only results of the same type will be returned. Default to false.
  "textQuery": "A String", # Required. The text query for textual search.
}

  x__xgafv: string, V1 error format.
    Allowed values
      1 - v1 error format
      2 - v2 error format

Returns:
  An object of the form:

    { # Response proto for SearchText.
  "contextualContents": [ # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. A list of contextual contents where each entry associates to the corresponding place in the same index in the places field. The contents that are relevant to the `text_query` in the request are preferred. If the contextual content is not available for one of the places, it will return non-contextual content. It will be empty only when the content is unavailable for this place. This list will have as many entries as the list of places if requested.
    { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Content that is contextual to the place query.
      "justifications": [ # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Justifications for the place.
        { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Justifications for the place. Justifications answers the question of why a place could interest an end user.
          "businessAvailabilityAttributesJustification": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. BusinessAvailabilityAttributes justifications. This shows some attributes a business has that could interest an end user. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details.
            "delivery": True or False, # If a place provides delivery.
            "dineIn": True or False, # If a place provides dine-in.
            "takeout": True or False, # If a place provides takeout.
          },
          "reviewJustification": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. User review justifications. This highlights a section of the user review that would interest an end user. For instance, if the search query is "firewood pizza", the review justification highlights the text relevant to the search query. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details.
            "highlightedText": { # The text highlighted by the justification. This is a subset of the review itself. The exact word to highlight is marked by the HighlightedTextRange. There could be several words in the text being highlighted.
              "highlightedTextRanges": [ # The list of the ranges of the highlighted text.
                { # The range of highlighted text.
                  "endIndex": 42,
                  "startIndex": 42,
                },
              ],
              "text": "A String",
            },
            "review": { # Information about a review of a place. # The review that the highlighted text is generated from.
              "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                "displayName": "A String", # Name of the author of the Photo or Review.
                "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                "uri": "A String", # URI of the author of the Photo or Review.
              },
              "flagContentUri": "A String", # A link where users can flag a problem with the review.
              "googleMapsUri": "A String", # A link to show the review on Google Maps.
              "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
              "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
              "publishTime": "A String", # Timestamp for the review.
              "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
              "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
              "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
            },
          },
        },
      ],
      "photos": [ # Information (including references) about photos of this place, contexual to the place query.
        { # Information about a photo of a place.
          "authorAttributions": [ # This photo's authors.
            { # Information about the author of the UGC data. Used in Photo, and Review.
              "displayName": "A String", # Name of the author of the Photo or Review.
              "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
              "uri": "A String", # URI of the author of the Photo or Review.
            },
          ],
          "flagContentUri": "A String", # A link where users can flag a problem with the photo.
          "googleMapsUri": "A String", # A link to show the photo on Google Maps.
          "heightPx": 42, # The maximum available height, in pixels.
          "name": "A String", # Identifier. A reference representing this place photo which may be used to look up this place photo again (also called the API "resource" name: `places/{place_id}/photos/{photo}`).
          "widthPx": 42, # The maximum available width, in pixels.
        },
      ],
      "reviews": [ # List of reviews about this place, contexual to the place query.
        { # Information about a review of a place.
          "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
            "displayName": "A String", # Name of the author of the Photo or Review.
            "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
            "uri": "A String", # URI of the author of the Photo or Review.
          },
          "flagContentUri": "A String", # A link where users can flag a problem with the review.
          "googleMapsUri": "A String", # A link to show the review on Google Maps.
          "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
          "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
          "publishTime": "A String", # Timestamp for the review.
          "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
          "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
          "text": { # Localized variant of a text in a particular language. # The localized text of the review.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
        },
      ],
    },
  ],
  "nextPageToken": "A String", # A token that can be sent as `page_token` to retrieve the next page. If this field is omitted or empty, there are no subsequent pages.
  "places": [ # A list of places that meet the user's text search criteria.
    { # All the information representing a Place.
      "accessibilityOptions": { # Information about the accessibility options a place offers. # Information about the accessibility options a place offers.
        "wheelchairAccessibleEntrance": True or False, # Places has wheelchair accessible entrance.
        "wheelchairAccessibleParking": True or False, # Place offers wheelchair accessible parking.
        "wheelchairAccessibleRestroom": True or False, # Place has wheelchair accessible restroom.
        "wheelchairAccessibleSeating": True or False, # Place has wheelchair accessible seating.
      },
      "addressComponents": [ # Repeated components for each locality level. Note the following facts about the address_components[] array: - The array of address components may contain more components than the formatted_address. - The array does not necessarily include all the political entities that contain an address, apart from those included in the formatted_address. To retrieve all the political entities that contain a specific address, you should use reverse geocoding, passing the latitude/longitude of the address as a parameter to the request. - The format of the response is not guaranteed to remain the same between requests. In particular, the number of address_components varies based on the address requested and can change over time for the same address. A component can change position in the array. The type of the component can change. A particular component may be missing in a later response.
        { # The structured components that form the formatted address, if this information is available.
          "languageCode": "A String", # The language used to format this components, in CLDR notation.
          "longText": "A String", # The full text description or name of the address component. For example, an address component for the country Australia may have a long_name of "Australia".
          "shortText": "A String", # An abbreviated textual name for the address component, if available. For example, an address component for the country of Australia may have a short_name of "AU".
          "types": [ # An array indicating the type(s) of the address component.
            "A String",
          ],
        },
      ],
      "addressDescriptor": { # A relational description of a location. Includes a ranked set of nearby landmarks and precise containing areas and their relationship to the target location. # The address descriptor of the place. Address descriptors include additional information that help describe a location using landmarks and areas. See address descriptor regional coverage in https://developers.google.com/maps/documentation/geocoding/address-descriptors/coverage.
        "areas": [ # A ranked list of containing or adjacent areas. The most recognizable and precise areas are ranked first.
          { # Area information and the area's relationship with the target location. Areas includes precise sublocality, neighborhoods, and large compounds that are useful for describing a location.
            "containment": "A String", # Defines the spatial relationship between the target location and the area.
            "displayName": { # Localized variant of a text in a particular language. # The area's display name.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "name": "A String", # The area's resource name.
            "placeId": "A String", # The area's place id.
          },
        ],
        "landmarks": [ # A ranked list of nearby landmarks. The most recognizable and nearby landmarks are ranked first.
          { # Basic landmark information and the landmark's relationship with the target location. Landmarks are prominent places that can be used to describe a location.
            "displayName": { # Localized variant of a text in a particular language. # The landmark's display name.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "name": "A String", # The landmark's resource name.
            "placeId": "A String", # The landmark's place id.
            "spatialRelationship": "A String", # Defines the spatial relationship between the target location and the landmark.
            "straightLineDistanceMeters": 3.14, # The straight line distance, in meters, between the center point of the target and the center point of the landmark. In some situations, this value can be longer than `travel_distance_meters`.
            "travelDistanceMeters": 3.14, # The travel distance, in meters, along the road network from the target to the landmark, if known. This value does not take into account the mode of transportation, such as walking, driving, or biking.
            "types": [ # A set of type tags for this landmark. For a complete list of possible values, see https://developers.google.com/maps/documentation/places/web-service/place-types.
              "A String",
            ],
          },
        ],
      },
      "adrFormatAddress": "A String", # The place's address in adr microformat: http://microformats.org/wiki/adr.
      "allowsDogs": True or False, # Place allows dogs.
      "areaSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the area that the place is in.
        "contentBlocks": [ # Content blocks that compose the area summary. Each block has a separate topic about the area.
          { # A block of content that can be served individually.
            "content": { # Localized variant of a text in a particular language. # Content related to the topic.
              "languageCode": "A String", # 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.
              "text": "A String", # Localized string in the language corresponding to language_code below.
            },
            "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. References that are related to this block of content.
              "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
                "A String",
              ],
              "reviews": [ # Reviews that serve as references.
                { # Information about a review of a place.
                  "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                    "displayName": "A String", # Name of the author of the Photo or Review.
                    "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                    "uri": "A String", # URI of the author of the Photo or Review.
                  },
                  "flagContentUri": "A String", # A link where users can flag a problem with the review.
                  "googleMapsUri": "A String", # A link to show the review on Google Maps.
                  "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
                  "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                    "languageCode": "A String", # 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.
                    "text": "A String", # Localized string in the language corresponding to language_code below.
                  },
                  "publishTime": "A String", # Timestamp for the review.
                  "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
                  "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
                  "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                    "languageCode": "A String", # 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.
                    "text": "A String", # Localized string in the language corresponding to language_code below.
                  },
                },
              ],
            },
            "topic": "A String", # The topic of the content, for example "overview" or "restaurant".
          },
        ],
        "flagContentUri": "A String", # A link where users can flag a problem with the summary.
      },
      "attributions": [ # A set of data provider that must be shown with this result.
        { # Information about data providers of this place.
          "provider": "A String", # Name of the Place's data provider.
          "providerUri": "A String", # URI to the Place's data provider.
        },
      ],
      "businessStatus": "A String", # The business status for the place.
      "containingPlaces": [ # List of places in which the current place is located.
        { # Info about the place in which this place is located.
          "id": "A String", # The place id of the place in which this place is located.
          "name": "A String", # The resource name of the place in which this place is located.
        },
      ],
      "curbsidePickup": True or False, # Specifies if the business supports curbside pickup.
      "currentOpeningHours": { # Information about business hour of the place. # The hours of operation for the next seven days (including today). The time period starts at midnight on the date of the request and ends at 11:59 pm six days later. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
        "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
        "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
        "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
        "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
          { # A period the place remains in open_now status.
            "close": { # Status changing points. # The time that the place starts to be closed.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
            "open": { # Status changing points. # The time that the place starts to be open.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
          },
        ],
        "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
        "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
          { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
            "date": { # 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 # The date of this special day.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
          },
        ],
        "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
          "A String",
        ],
      },
      "currentSecondaryOpeningHours": [ # Contains an array of entries for the next seven days including information about secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place. This field includes the special_days subfield of all hours, set for dates that have exceptional hours.
        { # Information about business hour of the place.
          "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
          "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
          "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
          "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
            { # A period the place remains in open_now status.
              "close": { # Status changing points. # The time that the place starts to be closed.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
              "open": { # Status changing points. # The time that the place starts to be open.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
            },
          ],
          "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
          "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
            { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
              "date": { # 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 # The date of this special day.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
            },
          ],
          "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
            "A String",
          ],
        },
      ],
      "delivery": True or False, # Specifies if the business supports delivery.
      "dineIn": True or False, # Specifies if the business supports indoor or outdoor seating options.
      "displayName": { # Localized variant of a text in a particular language. # The localized name of the place, suitable as a short human-readable description. For example, "Google Sydney", "Starbucks", "Pyrmont", etc.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "editorialSummary": { # Localized variant of a text in a particular language. # Contains a summary of the place. A summary is comprised of a textual overview, and also includes the language code for these if applicable. Summary text must be presented as-is and can not be modified or altered.
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "evChargeOptions": { # Information about the EV Charge Station hosted in Place. Terminology follows https://afdc.energy.gov/fuels/electricity_infrastructure.html One port could charge one car at a time. One port has one or more connectors. One station has one or more ports. # Information of ev charging options.
        "connectorAggregation": [ # A list of EV charging connector aggregations that contain connectors of the same type and same charge rate.
          { # EV charging information grouped by [type, max_charge_rate_kw]. Shows EV charge aggregation of connectors that have the same type and max charge rate in kw.
            "availabilityLastUpdateTime": "A String", # The timestamp when the connector availability information in this aggregation was last updated.
            "availableCount": 42, # Number of connectors in this aggregation that are currently available.
            "count": 42, # Number of connectors in this aggregation.
            "maxChargeRateKw": 3.14, # The static max charging rate in kw of each connector in the aggregation.
            "outOfServiceCount": 42, # Number of connectors in this aggregation that are currently out of service.
            "type": "A String", # The connector type of this aggregation.
          },
        ],
        "connectorCount": 42, # Number of connectors at this station. However, because some ports can have multiple connectors but only be able to charge one car at a time (e.g.) the number of connectors may be greater than the total number of cars which can charge simultaneously.
      },
      "formattedAddress": "A String", # A full, human-readable address for this place.
      "fuelOptions": { # The most recent information about fuel options in a gas station. This information is updated regularly. # The most recent information about fuel options in a gas station. This information is updated regularly.
        "fuelPrices": [ # The last known fuel price for each type of fuel this station has. There is one entry per fuel type this station has. Order is not important.
          { # Fuel price information for a given type.
            "price": { # Represents an amount of money with its currency type. # The price of the fuel.
              "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
              "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
              "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
            },
            "type": "A String", # The type of fuel.
            "updateTime": "A String", # The time the fuel price was last updated.
          },
        ],
      },
      "generativeSummary": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place. # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. AI-generated summary of the place.
        "description": { # Localized variant of a text in a particular language. # The detailed description of the place.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "descriptionFlagContentUri": "A String", # A link where users can flag a problem with the description summary.
        "overview": { # Localized variant of a text in a particular language. # The overview of the place.
          "languageCode": "A String", # 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.
          "text": "A String", # Localized string in the language corresponding to language_code below.
        },
        "overviewFlagContentUri": "A String", # A link where users can flag a problem with the overview summary.
        "references": { # Experimental: See https://developers.google.com/maps/documentation/places/web-service/experimental/places-generative for more details. Reference that the generative content is related to. # References that are used to generate the summary description.
          "places": [ # The list of resource names of the referenced places. This name can be used in other APIs that accept Place resource names.
            "A String",
          ],
          "reviews": [ # Reviews that serve as references.
            { # Information about a review of a place.
              "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
                "displayName": "A String", # Name of the author of the Photo or Review.
                "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
                "uri": "A String", # URI of the author of the Photo or Review.
              },
              "flagContentUri": "A String", # A link where users can flag a problem with the review.
              "googleMapsUri": "A String", # A link to show the review on Google Maps.
              "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
              "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
              "publishTime": "A String", # Timestamp for the review.
              "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
              "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
              "text": { # Localized variant of a text in a particular language. # The localized text of the review.
                "languageCode": "A String", # 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.
                "text": "A String", # Localized string in the language corresponding to language_code below.
              },
            },
          ],
        },
      },
      "goodForChildren": True or False, # Place is good for children.
      "goodForGroups": True or False, # Place accommodates groups.
      "goodForWatchingSports": True or False, # Place is suitable for watching sports.
      "googleMapsLinks": { # Links to trigger different Google Maps actions. # Links to trigger different Google Maps actions.
        "directionsUri": "A String", # A link to show the directions to the place. The link only populates the destination location and uses the default travel mode `DRIVE`.
        "photosUri": "A String", # A link to show photos of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
        "placeUri": "A String", # A link to show this place.
        "reviewsUri": "A String", # A link to show reviews of this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
        "writeAReviewUri": "A String", # A link to write a review for this place. This link is currently not supported on Google Maps Mobile and only works on the web version of Google Maps.
      },
      "googleMapsUri": "A String", # A URL providing more information about this place.
      "iconBackgroundColor": "A String", # Background color for icon_mask in hex format, e.g. #909CE1.
      "iconMaskBaseUri": "A String", # A truncated URL to an icon mask. User can access different icon type by appending type suffix to the end (eg, ".svg" or ".png").
      "id": "A String", # The unique identifier of a place.
      "internationalPhoneNumber": "A String", # A human-readable phone number for the place, in international format.
      "liveMusic": True or False, # Place provides live music.
      "location": { # 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. # The position of this place.
        "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
        "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
      },
      "menuForChildren": True or False, # Place has a children's menu.
      "name": "A String", # This Place's resource name, in `places/{place_id}` format. Can be used to look up the Place.
      "nationalPhoneNumber": "A String", # A human-readable phone number for the place, in national format.
      "outdoorSeating": True or False, # Place provides outdoor seating.
      "parkingOptions": { # Information about parking options for the place. A parking lot could support more than one option at the same time. # Options of parking provided by the place.
        "freeGarageParking": True or False, # Place offers free garage parking.
        "freeParkingLot": True or False, # Place offers free parking lots.
        "freeStreetParking": True or False, # Place offers free street parking.
        "paidGarageParking": True or False, # Place offers paid garage parking.
        "paidParkingLot": True or False, # Place offers paid parking lots.
        "paidStreetParking": True or False, # Place offers paid street parking.
        "valetParking": True or False, # Place offers valet parking.
      },
      "paymentOptions": { # Payment options the place accepts. # Payment options the place accepts. If a payment option data is not available, the payment option field will be unset.
        "acceptsCashOnly": True or False, # Place accepts cash only as payment. Places with this attribute may still accept other payment methods.
        "acceptsCreditCards": True or False, # Place accepts credit cards as payment.
        "acceptsDebitCards": True or False, # Place accepts debit cards as payment.
        "acceptsNfc": True or False, # Place accepts NFC payments.
      },
      "photos": [ # Information (including references) about photos of this place. A maximum of 10 photos can be returned.
        { # Information about a photo of a place.
          "authorAttributions": [ # This photo's authors.
            { # Information about the author of the UGC data. Used in Photo, and Review.
              "displayName": "A String", # Name of the author of the Photo or Review.
              "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
              "uri": "A String", # URI of the author of the Photo or Review.
            },
          ],
          "flagContentUri": "A String", # A link where users can flag a problem with the photo.
          "googleMapsUri": "A String", # A link to show the photo on Google Maps.
          "heightPx": 42, # The maximum available height, in pixels.
          "name": "A String", # Identifier. A reference representing this place photo which may be used to look up this place photo again (also called the API "resource" name: `places/{place_id}/photos/{photo}`).
          "widthPx": 42, # The maximum available width, in pixels.
        },
      ],
      "plusCode": { # Plus code (http://plus.codes) is a location reference with two formats: global code defining a 14mx14m (1/8000th of a degree) or smaller rectangle, and compound code, replacing the prefix with a reference location. # Plus code of the place location lat/long.
        "compoundCode": "A String", # Place's compound code, such as "33GV+HQ, Ramberg, Norway", containing the suffix of the global code and replacing the prefix with a formatted name of a reference entity.
        "globalCode": "A String", # Place's global (full) code, such as "9FWM33GV+HQ", representing an 1/8000 by 1/8000 degree area (~14 by 14 meters).
      },
      "priceLevel": "A String", # Price level of the place.
      "priceRange": { # The price range associated with a Place. `end_price` could be unset, which indicates a range without upper bound (e.g. "More than $100"). # The price range associated with a Place.
        "endPrice": { # Represents an amount of money with its currency type. # The high end of the price range (exclusive). Price should be lower than this amount.
          "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
          "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
          "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
        },
        "startPrice": { # Represents an amount of money with its currency type. # The low end of the price range (inclusive). Price should be at or above this amount.
          "currencyCode": "A String", # The three-letter currency code defined in ISO 4217.
          "nanos": 42, # Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000.
          "units": "A String", # The whole units of the amount. For example if `currencyCode` is `"USD"`, then 1 unit is one US dollar.
        },
      },
      "primaryType": "A String", # The primary type of the given result. This type must one of the Places API supported types. For example, "restaurant", "cafe", "airport", etc. A place can only have a single primary type. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
      "primaryTypeDisplayName": { # Localized variant of a text in a particular language. # The display name of the primary type, localized to the request language if applicable. For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
        "languageCode": "A String", # 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.
        "text": "A String", # Localized string in the language corresponding to language_code below.
      },
      "pureServiceAreaBusiness": True or False, # Indicates whether the place is a pure service area business. Pure service area business is a business that visits or delivers to customers directly but does not serve customers at their business address. For example, businesses like cleaning services or plumbers. Those businesses may not have a physical address or location on Google Maps.
      "rating": 3.14, # A rating between 1.0 and 5.0, based on user reviews of this place.
      "regularOpeningHours": { # Information about business hour of the place. # The regular hours of operation.
        "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
        "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
        "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
        "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
          { # A period the place remains in open_now status.
            "close": { # Status changing points. # The time that the place starts to be closed.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
            "open": { # Status changing points. # The time that the place starts to be open.
              "date": { # 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 # Date in the local timezone for the place.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
              "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
              "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
              "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
              "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
            },
          },
        ],
        "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
        "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
          { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
            "date": { # 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 # The date of this special day.
              "day": 42, # 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.
              "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
              "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
            },
          },
        ],
        "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
          "A String",
        ],
      },
      "regularSecondaryOpeningHours": [ # Contains an array of entries for information about regular secondary hours of a business. Secondary hours are different from a business's main hours. For example, a restaurant can specify drive through hours or delivery hours as its secondary hours. This field populates the type subfield, which draws from a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP, or TAKEOUT) based on the types of the place.
        { # Information about business hour of the place.
          "nextCloseTime": "A String", # The next time the current opening hours period ends up to 7 days in the future. This field is only populated if the opening hours period is active at the time of serving the request.
          "nextOpenTime": "A String", # The next time the current opening hours period starts up to 7 days in the future. This field is only populated if the opening hours period is not active at the time of serving the request.
          "openNow": True or False, # Whether the opening hours period is currently active. For regular opening hours and current opening hours, this field means whether the place is open. For secondary opening hours and current secondary opening hours, this field means whether the secondary hours of this place is active.
          "periods": [ # The periods that this place is open during the week. The periods are in chronological order, starting with Sunday in the place-local timezone. An empty (but not absent) value indicates a place that is never open, e.g. because it is closed temporarily for renovations.
            { # A period the place remains in open_now status.
              "close": { # Status changing points. # The time that the place starts to be closed.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
              "open": { # Status changing points. # The time that the place starts to be open.
                "date": { # 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 # Date in the local timezone for the place.
                  "day": 42, # 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.
                  "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                  "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
                },
                "day": 42, # A day of the week, as an integer in the range 0-6. 0 is Sunday, 1 is Monday, etc.
                "hour": 42, # The hour in 2 digits. Ranges from 00 to 23.
                "minute": 42, # The minute in 2 digits. Ranges from 00 to 59.
                "truncated": True or False, # Whether or not this endpoint was truncated. Truncation occurs when the real hours are outside the times we are willing to return hours between, so we truncate the hours back to these boundaries. This ensures that at most 24 * 7 hours from midnight of the day of the request are returned.
              },
            },
          ],
          "secondaryHoursType": "A String", # A type string used to identify the type of secondary hours.
          "specialDays": [ # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day. Set for current_opening_hours and current_secondary_opening_hours if there are exceptional hours.
            { # Structured information for special days that fall within the period that the returned opening hours cover. Special days are days that could impact the business hours of a place, e.g. Christmas day.
              "date": { # 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 # The date of this special day.
                "day": 42, # 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.
                "month": 42, # Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.
                "year": 42, # Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.
              },
            },
          ],
          "weekdayDescriptions": [ # Localized strings describing the opening hours of this place, one string for each day of the week. Will be empty if the hours are unknown or could not be converted to localized text. Example: "Sun: 18:00–06:00"
            "A String",
          ],
        },
      ],
      "reservable": True or False, # Specifies if the place supports reservations.
      "restroom": True or False, # Place has restroom.
      "reviews": [ # List of reviews about this place, sorted by relevance. A maximum of 5 reviews can be returned.
        { # Information about a review of a place.
          "authorAttribution": { # Information about the author of the UGC data. Used in Photo, and Review. # This review's author.
            "displayName": "A String", # Name of the author of the Photo or Review.
            "photoUri": "A String", # Profile photo URI of the author of the Photo or Review.
            "uri": "A String", # URI of the author of the Photo or Review.
          },
          "flagContentUri": "A String", # A link where users can flag a problem with the review.
          "googleMapsUri": "A String", # A link to show the review on Google Maps.
          "name": "A String", # A reference representing this place review which may be used to look up this place review again (also called the API "resource" name: `places/{place_id}/reviews/{review}`).
          "originalText": { # Localized variant of a text in a particular language. # The review text in its original language.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
          "publishTime": "A String", # Timestamp for the review.
          "rating": 3.14, # A number between 1.0 and 5.0, also called the number of stars.
          "relativePublishTimeDescription": "A String", # A string of formatted recent time, expressing the review time relative to the current time in a form appropriate for the language and country.
          "text": { # Localized variant of a text in a particular language. # The localized text of the review.
            "languageCode": "A String", # 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.
            "text": "A String", # Localized string in the language corresponding to language_code below.
          },
        },
      ],
      "servesBeer": True or False, # Specifies if the place serves beer.
      "servesBreakfast": True or False, # Specifies if the place serves breakfast.
      "servesBrunch": True or False, # Specifies if the place serves brunch.
      "servesCocktails": True or False, # Place serves cocktails.
      "servesCoffee": True or False, # Place serves coffee.
      "servesDessert": True or False, # Place serves dessert.
      "servesDinner": True or False, # Specifies if the place serves dinner.
      "servesLunch": True or False, # Specifies if the place serves lunch.
      "servesVegetarianFood": True or False, # Specifies if the place serves vegetarian food.
      "servesWine": True or False, # Specifies if the place serves wine.
      "shortFormattedAddress": "A String", # A short, human-readable address for this place.
      "subDestinations": [ # A list of sub destinations related to the place.
        { # Place resource name and id of sub destinations that relate to the place. For example, different terminals are different destinations of an airport.
          "id": "A String", # The place id of the sub destination.
          "name": "A String", # The resource name of the sub destination.
        },
      ],
      "takeout": True or False, # Specifies if the business supports takeout.
      "types": [ # A set of type tags for this result. For example, "political" and "locality". For the complete list of possible values, see Table A and Table B at https://developers.google.com/maps/documentation/places/web-service/place-types
        "A String",
      ],
      "userRatingCount": 42, # The total number of reviews (with or without text) for this place.
      "utcOffsetMinutes": 42, # Number of minutes this place's timezone is currently offset from UTC. This is expressed in minutes to support timezones that are offset by fractions of an hour, e.g. X hours and 15 minutes.
      "viewport": { # A latitude-longitude viewport, represented as two diagonally opposite `low` and `high` points. A viewport is considered a closed region, i.e. it includes its boundary. The latitude bounds must range between -90 to 90 degrees inclusive, and the longitude bounds must range between -180 to 180 degrees inclusive. Various cases include: - If `low` = `high`, the viewport consists of that single point. - If `low.longitude` > `high.longitude`, the longitude range is inverted (the viewport crosses the 180 degree longitude line). - If `low.longitude` = -180 degrees and `high.longitude` = 180 degrees, the viewport includes all longitudes. - If `low.longitude` = 180 degrees and `high.longitude` = -180 degrees, the longitude range is empty. - If `low.latitude` > `high.latitude`, the latitude range is empty. Both `low` and `high` must be populated, and the represented box cannot be empty (as specified by the definitions above). An empty viewport will result in an error. For example, this viewport fully encloses New York City: { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } # A viewport suitable for displaying the place on an average-sized map. This viewport should not be used as the physical boundary or the service area of the business.
        "high": { # 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. # Required. The high point of the viewport.
          "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
          "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
        },
        "low": { # 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. # Required. The low point of the viewport.
          "latitude": 3.14, # The latitude in degrees. It must be in the range [-90.0, +90.0].
          "longitude": 3.14, # The longitude in degrees. It must be in the range [-180.0, +180.0].
        },
      },
      "websiteUri": "A String", # The authoritative website for this place, e.g. a business' homepage. Note that for places that are part of a chain (e.g. an IKEA store), this will usually be the website for the individual store, not the overall chain.
    },
  ],
  "routingSummaries": [ # A list of routing summaries where each entry associates to the corresponding place in the same index in the `places` field. If the routing summary is not available for one of the places, it will contain an empty entry. This list will have as many entries as the list of places if requested.
    { # The duration and distance from the routing origin to a place in the response, and a second leg from that place to the destination, if requested. **Note:** Adding `routingSummaries` in the field mask without also including either the `routingParameters.origin` parameter or the `searchAlongRouteParameters.polyline.encodedPolyline` parameter in the request causes an error.
      "directionsUri": "A String", # A link to show directions on Google Maps using the waypoints from the given routing summary. The route generated by this link is not guaranteed to be the same as the route used to generate the routing summary. The link uses information provided in the request, from fields including `routingParameters` and `searchAlongRouteParameters` when applicable, to generate the directions link.
      "legs": [ # The legs of the trip. When you calculate travel duration and distance from a set origin, `legs` contains a single leg containing the duration and distance from the origin to the destination. When you do a search along route, `legs` contains two legs: one from the origin to place, and one from the place to the destination.
        { # A leg is a single portion of a journey from one location to another.
          "distanceMeters": 42, # The distance of this leg of the trip.
          "duration": "A String", # The time it takes to complete this leg of the trip.
        },
      ],
    },
  ],
  "searchUri": "A String", # A link allows the user to search with the same text query as specified in the request on Google Maps.
}
searchText_next()
Retrieves the next page of results.

        Args:
          previous_request: The request for the previous page. (required)
          previous_response: The response from the request for the previous page. (required)

        Returns:
          A request object that you can call 'execute()' on to request the next
          page. Returns None if there are no more items in the collection.