google-api-ruby-client/generated/google/apis/mybusiness_v3/classes.rb

1865 lines
75 KiB
Ruby

# Copyright 2015 Google Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
require 'date'
require 'google/apis/core/base_service'
require 'google/apis/core/json_representation'
require 'google/apis/core/hashable'
require 'google/apis/errors'
module Google
module Apis
module MybusinessV3
# An account is a container for your business's locations. If you are the only
# user who manages locations for your business, you can use your personal
# Google Account. To share management of locations with multiple users,
# [create a business account]
# (https://support.google.com/business/answer/6085339?hl=en&ref_topic=6085325).
class Account
include Google::Apis::Core::Hashable
# The name of the account. Note: For an account with AccountType `PERSONAL`,
# this is the first
# and last name of the user account.
# Corresponds to the JSON property `accountName`
# @return [String]
attr_accessor :account_name
# The resource name, in the format `accounts/`account_id``.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# Specifies the AccountRole
# the caller has for this account.
# @OutputOnly
# Corresponds to the JSON property `role`
# @return [String]
attr_accessor :role
# Indicates status of the account, such as whether the account
# has been verified by Google.
# Corresponds to the JSON property `state`
# @return [Google::Apis::MybusinessV3::AccountState]
attr_accessor :state
# Specifies the AccountType
# of this account.
# @OutputOnly
# Corresponds to the JSON property `type`
# @return [String]
attr_accessor :type
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@account_name = args[:account_name] if args.key?(:account_name)
@name = args[:name] if args.key?(:name)
@role = args[:role] if args.key?(:role)
@state = args[:state] if args.key?(:state)
@type = args[:type] if args.key?(:type)
end
end
# Indicates status of the account, such as whether the account
# has been verified by Google.
class AccountState
include Google::Apis::Core::Hashable
# If verified, future locations that are created are automatically
# be connected to maps, and have Google+ pages created, without requiring
# moderation.
# Corresponds to the JSON property `status`
# @return [String]
attr_accessor :status
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@status = args[:status] if args.key?(:status)
end
end
# Additional information that is surfaced in AdWords.
class AdWordsLocationExtensions
include Google::Apis::Core::Hashable
# An alternate phone number to display on AdWords location extensions
# instead of the location's primary phone number.
# Corresponds to the JSON property `adPhone`
# @return [String]
attr_accessor :ad_phone
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ad_phone = args[:ad_phone] if args.key?(:ad_phone)
end
end
# Represents the physical location of the business.
# Example addresses:
# address_lines: "1600 Amphitheatre Parkway"
# locality: Mountain View
# administrative_area: CA
# country: US
# postal_code: 94043
# address_lines: "A-205, Natasha Apartments", "2, Inner Ring Road"
# sub_locality: Domlur
# locality: Bangalore
# administrative_area: Karnataka
# country: IN
# postal_code: 560071
class Address
include Google::Apis::Core::Hashable
# The precise address information for the business below the sub-locality
# level. For most countries, the first line should include a street number
# and street name. Suite numbers, floors, building numbers, etc., may also be
# included. Imprecise information like cross-streets and nearby landmarks
# should only be included in regions where the official street address does
# not accurately pinpoint the business's location. Maximum 80 characters.
# Corresponds to the JSON property `addressLines`
# @return [Array<String>]
attr_accessor :address_lines
# The state or province where the business is located. Using the common
# abbreviation is generally preferred, such as CA for California or NSW
# for New South Wales.
# Not all countries require this field. Use the address editor in the
# product to determine whether it is appropriate for an address in a
# particular country.
# Also known as:
# "area" (Hong Kong), "county" (Ireland, Taiwan, United Kingdom),
# "department" (Colombia, Nicaragua), "district" (Indonesia),
# "do/si" (South Korea), "emirate" (United Arab Emirates), "island,"
# "oblast" (Russia, Ukraine), "parish," "prefecture" (Japan).
# Examples:
# California (United States), Ontario (Canada), Uttar Pradesh (India).
# Maximum 80 characters.
# Corresponds to the JSON property `administrativeArea`
# @return [String]
attr_accessor :administrative_area
# The ISO 3166-1 alpha-2 country code where the business is located. Once
# a location is created, the country cannot be changed.
# Corresponds to the JSON property `country`
# @return [String]
attr_accessor :country
# The city or town where the business is located.
# Also known as:
# "district" (Hong Kong, Turkey), "post town" (United Kingdom).
# Examples:
# Chicago (United States), Berlin (Germany), London (United Kingdom).
# Maximum 80 characters.
# Corresponds to the JSON property `locality`
# @return [String]
attr_accessor :locality
# The postal code of the business. If the postal code begins with zero, make
# sure that your formatting does not remove the zero as the first digit.
# Also known as: "zip code" (United States), "PIN code" (India).
# Corresponds to the JSON property `postalCode`
# @return [String]
attr_accessor :postal_code
# The suburb where the business is located. This is the division just smaller
# than a locality (city). Previously referred to in Google My Business
# Locations as "district". Maximum 80 characters.
# Also known as: "district" (South Korea), "neighborhood" (Brazil, Mexico),
# "village / township" (Malaysia).
# Examples:
# Manhattan (United States),
# Centro (Mexico),
# Songpa District (South Korea.)
# Corresponds to the JSON property `subLocality`
# @return [String]
attr_accessor :sub_locality
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@address_lines = args[:address_lines] if args.key?(:address_lines)
@administrative_area = args[:administrative_area] if args.key?(:administrative_area)
@country = args[:country] if args.key?(:country)
@locality = args[:locality] if args.key?(:locality)
@postal_code = args[:postal_code] if args.key?(:postal_code)
@sub_locality = args[:sub_locality] if args.key?(:sub_locality)
end
end
# An administrator of an Account, or a
# Location.
class Admin
include Google::Apis::Core::Hashable
# The name of the admin. When making the initial invitation, this is the
# invitee's email address. On `GET` calls, the user's email address is
# returned if the invitation is still pending. Otherwise, it contains
# the user's first and last names.
# Corresponds to the JSON property `adminName`
# @return [String]
attr_accessor :admin_name
# The resource name. For account admins, this is in the form:
# `accounts/`account_id`/admins/`admin_id``
# For location admins, this is in the form:
# `accounts/`account_id`/locations/`location_id`/admins/`admin_id``
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# Indicates whether this admin has a pending invitation for the specified
# resource.
# @OutputOnly
# Corresponds to the JSON property `pendingInvitation`
# @return [Boolean]
attr_accessor :pending_invitation
alias_method :pending_invitation?, :pending_invitation
# Specifies the AdminRole that this
# admin uses with the specified Account
# or Location resource.
# Corresponds to the JSON property `role`
# @return [String]
attr_accessor :role
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@admin_name = args[:admin_name] if args.key?(:admin_name)
@name = args[:name] if args.key?(:name)
@pending_invitation = args[:pending_invitation] if args.key?(:pending_invitation)
@role = args[:role] if args.key?(:role)
end
end
# Request message for MyBusiness.AssociateLocationRequest to associate a
# location to a place or indicate no match.
class AssociateLocationRequest
include Google::Apis::Core::Hashable
# The association to establish. If not set, it indicates no match.
# Corresponds to the JSON property `placeId`
# @return [String]
attr_accessor :place_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@place_id = args[:place_id] if args.key?(:place_id)
end
end
# A location attribute. Attributes provide additional, information about a
# location. The attributes that can be set on a location may vary based on
# the properties of that location (e.g. category). Available attributes are
# determined by Google and may be added and removed without API changes.
class Attribute
include Google::Apis::Core::Hashable
# The id of the attribute. Attribute ids are provided by Google.
# Corresponds to the JSON property `attributeId`
# @return [String]
attr_accessor :attribute_id
# The type of value that this attribute contains. This should be used to
# determine how to interpret the value.
# @OutputOnly
# Corresponds to the JSON property `valueType`
# @return [String]
attr_accessor :value_type
# The values for this attribute. The type of the values supplied must match
# that expected for that attribute, see AttributeValueType. This is a
# repeated field where multiple attribute values may be provided. Current
# attribute types only support one value, but future types may support
# multiple values.
# Corresponds to the JSON property `values`
# @return [Array<Object>]
attr_accessor :values
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attribute_id = args[:attribute_id] if args.key?(:attribute_id)
@value_type = args[:value_type] if args.key?(:value_type)
@values = args[:values] if args.key?(:values)
end
end
# Metadata for an attribute. Contains display information for the attribute,
# including a localised name and a heading for grouping related attributes
# together.
class AttributeMetadata
include Google::Apis::Core::Hashable
# The id of the attribute.
# Corresponds to the JSON property `attributeId`
# @return [String]
attr_accessor :attribute_id
# The localised display name for the attribute, if available, otherwise
# the English display name.
# Corresponds to the JSON property `displayName`
# @return [String]
attr_accessor :display_name
# The localised display name of the group that contains this attribute, if
# available, otherwise the English group name. Related attributes are
# collected into group and should be displayed together under the heading
# given here.
# Corresponds to the JSON property `groupDisplayName`
# @return [String]
attr_accessor :group_display_name
# If true, the attribute supports multiple values. If false only a single
# value should be provided.
# Corresponds to the JSON property `isRepeatable`
# @return [Boolean]
attr_accessor :is_repeatable
alias_method :is_repeatable?, :is_repeatable
# For some types of attributes (e.g. enums) a list of supported values and
# corresponding display names for those values is provided.
# Corresponds to the JSON property `valueMetadata`
# @return [Array<Google::Apis::MybusinessV3::AttributeValueMetadata>]
attr_accessor :value_metadata
# The value type for the attribute. Values set and retrieved should be
# expected to be of this type.
# Corresponds to the JSON property `valueType`
# @return [String]
attr_accessor :value_type
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attribute_id = args[:attribute_id] if args.key?(:attribute_id)
@display_name = args[:display_name] if args.key?(:display_name)
@group_display_name = args[:group_display_name] if args.key?(:group_display_name)
@is_repeatable = args[:is_repeatable] if args.key?(:is_repeatable)
@value_metadata = args[:value_metadata] if args.key?(:value_metadata)
@value_type = args[:value_type] if args.key?(:value_type)
end
end
# Metadata for supported attribute values
class AttributeValueMetadata
include Google::Apis::Core::Hashable
# The display name for this value, localised where available otherwise in
# English.
# Corresponds to the JSON property `displayName`
# @return [String]
attr_accessor :display_name
# The attribute value
# Corresponds to the JSON property `value`
# @return [Object]
attr_accessor :value
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@display_name = args[:display_name] if args.key?(:display_name)
@value = args[:value] if args.key?(:value)
end
end
#
class BatchGetLocationsRequest
include Google::Apis::Core::Hashable
# A collection of locations to fetch, specified by their names.
# Corresponds to the JSON property `locationNames`
# @return [Array<String>]
attr_accessor :location_names
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@location_names = args[:location_names] if args.key?(:location_names)
end
end
#
class BatchGetLocationsResponse
include Google::Apis::Core::Hashable
# A collection of locations.
# Corresponds to the JSON property `locations`
# @return [Array<Google::Apis::MybusinessV3::Location>]
attr_accessor :locations
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@locations = args[:locations] if args.key?(:locations)
end
end
# Represents the time periods that this location is open for business.
# Holds a collection of TimePeriod
# instances.
class BusinessHours
include Google::Apis::Core::Hashable
# A collection of times that this location is open for business. Each period
# represents a range of hours when the location is open during the week.
# Corresponds to the JSON property `periods`
# @return [Array<Google::Apis::MybusinessV3::TimePeriod>]
attr_accessor :periods
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@periods = args[:periods] if args.key?(:periods)
end
end
# A category describing what this business is (not what it does). For a list of
# valid category IDs, and the mappings to their human readable names, see
# the [category list](/my-business/content/categories).
class Category
include Google::Apis::Core::Hashable
# A stable ID (provided by Google) for this category. While it is possible
# to populate only the `name` field in a category, setting the `category_id`
# field is
# preferred.
# If both fields are populated, the `category_id` takes precedence, and
# the supplied `name` field is ignored, and populated based on the
# value of this field.
# Corresponds to the JSON property `categoryId`
# @return [String]
attr_accessor :category_id
# The human-readable name of the category.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@category_id = args[:category_id] if args.key?(:category_id)
@name = args[:name] if args.key?(:name)
end
end
# Request message for MyBusiness.ClearLocationAssociationRequest to clear
# the association between a location to its place ID.
class ClearLocationAssociationRequest
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Represents a whole calendar date, e.g. date of birth. The time of day and
# time zone are either specified elsewhere or are not significant. The date
# is relative to the Proleptic Gregorian Calendar. The day may be 0 to
# represent a year and month where the day is not significant, e.g. credit card
# expiration date. The year may be 0 to represent a month and day independent
# of year, e.g. anniversary date. Related types are google.type.TimeOfDay
# and `google.protobuf.Timestamp`.
class Date
include Google::Apis::Core::Hashable
# Day of month. Must be from 1 to 31 and valid for the year and month, or 0
# if specifying a year/month where the day is not significant.
# Corresponds to the JSON property `day`
# @return [Fixnum]
attr_accessor :day
# Month of year. Must be from 1 to 12.
# Corresponds to the JSON property `month`
# @return [Fixnum]
attr_accessor :month
# Year of date. Must be from 1 to 9999, or 0 if specifying a date without
# a year.
# Corresponds to the JSON property `year`
# @return [Fixnum]
attr_accessor :year
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@day = args[:day] if args.key?(:day)
@month = args[:month] if args.key?(:month)
@year = args[:year] if args.key?(:year)
end
end
# Information about the location that this location duplicates.
class Duplicate
include Google::Apis::Core::Hashable
# The resource name of the location that this duplicates. Only populated
# if the authenticated user has access rights to that location and that
# location is not deleted.
# Corresponds to the JSON property `locationName`
# @return [String]
attr_accessor :location_name
# Indicates the ownership status between this location and the location
# that it duplicates.
# Corresponds to the JSON property `ownership`
# @return [String]
attr_accessor :ownership
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@location_name = args[:location_name] if args.key?(:location_name)
@ownership = args[:ownership] if args.key?(:ownership)
end
end
# A generic empty message that you can re-use to avoid defining duplicated
# empty messages in your APIs. A typical example is to use it as the request
# or the response type of an API method. For instance:
# service Foo `
# rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
# `
# The JSON representation for `Empty` is empty JSON object ````.
class Empty
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for MyBusiness.FindMatchingLocations.
class FindMatchingLocationsRequest
include Google::Apis::Core::Hashable
# The preferred language for the matching location.
# Corresponds to the JSON property `languageCode`
# @return [String]
attr_accessor :language_code
# Indicates the duration of acceptable cache-age. If omitted, will always
# return the cached data (if available). If the cache is older than the
# provided duration, or if a cached value is not available, results will be
# re-calculated and re-cached.
# Corresponds to the JSON property `maxCacheDuration`
# @return [String]
attr_accessor :max_cache_duration
# The number of matches to return. The default value is 3, with a maximum
# of 10. Note that latency may increase if more are requested. There is no
# pagination. This field is only respected if the cache needs to be updated.
# Corresponds to the JSON property `numResults`
# @return [Fixnum]
attr_accessor :num_results
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@language_code = args[:language_code] if args.key?(:language_code)
@max_cache_duration = args[:max_cache_duration] if args.key?(:max_cache_duration)
@num_results = args[:num_results] if args.key?(:num_results)
end
end
# Response message for MyBusiness.FindMatchingLocations
class FindMatchingLocationsResponse
include Google::Apis::Core::Hashable
# When the matching algorithm was last executed for this location.
# Corresponds to the JSON property `matchTime`
# @return [String]
attr_accessor :match_time
# A collection of locations that are potential matches to the specified
# location, listed in order from best to least match. If there is an exact
# match, it will be in the first position.
# Corresponds to the JSON property `matchedLocations`
# @return [Array<Google::Apis::MybusinessV3::MatchedLocation>]
attr_accessor :matched_locations
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@match_time = args[:match_time] if args.key?(:match_time)
@matched_locations = args[:matched_locations] if args.key?(:matched_locations)
end
end
# Represents a location that was modified by Google.
class GoogleUpdatedLocation
include Google::Apis::Core::Hashable
# The fields that Google updated.
# Corresponds to the JSON property `diffMask`
# @return [String]
attr_accessor :diff_mask
# A location.
# See the [help center article]
# (https://support.google.com/business/answer/3038177) for a detailed
# description of these fields, or the [category
# list](/my-business/content/categories] for a list of valid business
# categories.
# Corresponds to the JSON property `location`
# @return [Google::Apis::MybusinessV3::Location]
attr_accessor :location
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@diff_mask = args[:diff_mask] if args.key?(:diff_mask)
@location = args[:location] if args.key?(:location)
end
end
# An object representing a latitude/longitude pair. This is expressed as a pair
# of doubles representing degrees latitude and degrees longitude. Unless
# specified otherwise, this must conform to the
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
# standard</a>. Values must be within normalized ranges.
# Example of normalization code in Python:
# def NormalizeLongitude(longitude):
# """Wraps decimal degrees longitude to [-180.0, 180.0]."""
# q, r = divmod(longitude, 360.0)
# if r > 180.0 or (r == 180.0 and q <= -1.0):
# return r - 360.0
# return r
# def NormalizeLatLng(latitude, longitude):
# """Wraps decimal degrees latitude and longitude to
# [-90.0, 90.0] and [-180.0, 180.0], respectively."""
# r = latitude % 360.0
# if r <= 90.0:
# return r, NormalizeLongitude(longitude)
# elif r >= 270.0:
# return r - 360, NormalizeLongitude(longitude)
# else:
# return 180 - r, NormalizeLongitude(longitude + 180.0)
# assert 180.0 == NormalizeLongitude(180.0)
# assert -180.0 == NormalizeLongitude(-180.0)
# assert -179.0 == NormalizeLongitude(181.0)
# assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0)
# assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0)
# assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0)
# assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0)
# assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0)
# assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0)
# assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0)
# assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0)
class LatLng
include Google::Apis::Core::Hashable
# The latitude in degrees. It must be in the range [-90.0, +90.0].
# Corresponds to the JSON property `latitude`
# @return [Float]
attr_accessor :latitude
# The longitude in degrees. It must be in the range [-180.0, +180.0].
# Corresponds to the JSON property `longitude`
# @return [Float]
attr_accessor :longitude
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@latitude = args[:latitude] if args.key?(:latitude)
@longitude = args[:longitude] if args.key?(:longitude)
end
end
#
class ListAccountAdminsResponse
include Google::Apis::Core::Hashable
# A collection of Admin instances.
# Corresponds to the JSON property `admins`
# @return [Array<Google::Apis::MybusinessV3::Admin>]
attr_accessor :admins
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@admins = args[:admins] if args.key?(:admins)
end
end
#
class ListAccountsResponse
include Google::Apis::Core::Hashable
# A collection of accounts to which the user has access.
# Corresponds to the JSON property `accounts`
# @return [Array<Google::Apis::MybusinessV3::Account>]
attr_accessor :accounts
# If the number of accounts exceeds the requested page size, this field is
# populated with a token to fetch the next page of accounts on a
# subsequent call to `accounts.list`. If there are no more accounts, this field
# is not present in the response.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@accounts = args[:accounts] if args.key?(:accounts)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
end
end
#
class ListLocationAdminsResponse
include Google::Apis::Core::Hashable
# A collection of Admin instances.
# Corresponds to the JSON property `admins`
# @return [Array<Google::Apis::MybusinessV3::Admin>]
attr_accessor :admins
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@admins = args[:admins] if args.key?(:admins)
end
end
#
class ListLocationAttributeMetadataResponse
include Google::Apis::Core::Hashable
# A collection of attribute metadata for the available attributes.
# Corresponds to the JSON property `attributes`
# @return [Array<Google::Apis::MybusinessV3::AttributeMetadata>]
attr_accessor :attributes
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attributes = args[:attributes] if args.key?(:attributes)
end
end
#
class ListLocationsResponse
include Google::Apis::Core::Hashable
# The locations
# Corresponds to the JSON property `locations`
# @return [Array<Google::Apis::MybusinessV3::Location>]
attr_accessor :locations
# If the number of locations exceeded the requested page size, this field
# is populated with a token to fetch the next page of locations on a
# subsequent call to ListLocations. If there are no more locations, this
# field is not be present in the response.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@locations = args[:locations] if args.key?(:locations)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
end
end
# Response message for MyBusiness.ListReviews.
class ListReviewsResponse
include Google::Apis::Core::Hashable
# The average star rating of all reviews for this location
# on a scale of 1 to 5.
# Corresponds to the JSON property `averageRating`
# @return [Float]
attr_accessor :average_rating
# If the number of reviews exceeded the requested page size, this field
# is populated with a token to fetch the next page of reviews on a
# subsequent call to ListReviews. If there are no more reviews, this
# field is not be present in the response.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# The reviews.
# Corresponds to the JSON property `reviews`
# @return [Array<Google::Apis::MybusinessV3::Review>]
attr_accessor :reviews
# The total number of reviews for this location.
# Corresponds to the JSON property `totalReviewCount`
# @return [Fixnum]
attr_accessor :total_review_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@average_rating = args[:average_rating] if args.key?(:average_rating)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
@reviews = args[:reviews] if args.key?(:reviews)
@total_review_count = args[:total_review_count] if args.key?(:total_review_count)
end
end
# A location.
# See the [help center article]
# (https://support.google.com/business/answer/3038177) for a detailed
# description of these fields, or the [category
# list](/my-business/content/categories] for a list of valid business
# categories.
class Location
include Google::Apis::Core::Hashable
# Additional information that is surfaced in AdWords.
# Corresponds to the JSON property `adWordsLocationExtensions`
# @return [Google::Apis::MybusinessV3::AdWordsLocationExtensions]
attr_accessor :ad_words_location_extensions
# Additional categories to describe your business.
# Categories help your customers find accurate, specific results for services
# they're interested in. In order to keep your business information accurate
# and live, make sure that you use as few categories as possible to describe
# your overall core business.
# Choose categories that are as specific as possible, but representative of
# your main business.
# Corresponds to the JSON property `additionalCategories`
# @return [Array<Google::Apis::MybusinessV3::Category>]
attr_accessor :additional_categories
# Up to two phone numbers (mobile or landline, no fax) at which your business
# can be called, in addition to your primary phone number.
# Corresponds to the JSON property `additionalPhones`
# @return [Array<String>]
attr_accessor :additional_phones
# Represents the physical location of the business.
# Example addresses:
# address_lines: "1600 Amphitheatre Parkway"
# locality: Mountain View
# administrative_area: CA
# country: US
# postal_code: 94043
# address_lines: "A-205, Natasha Apartments", "2, Inner Ring Road"
# sub_locality: Domlur
# locality: Bangalore
# administrative_area: Karnataka
# country: IN
# postal_code: 560071
# Corresponds to the JSON property `address`
# @return [Google::Apis::MybusinessV3::Address]
attr_accessor :address
# Attributes for this location.
# Corresponds to the JSON property `attributes`
# @return [Array<Google::Apis::MybusinessV3::Attribute>]
attr_accessor :attributes
# A collection of free-form strings to allow you to tag your business. These
# labels are NOT user facing, and are only be seen by you.
# Limited to 255 characters (per label).
# Corresponds to the JSON property `labels`
# @return [Array<String>]
attr_accessor :labels
# An object representing a latitude/longitude pair. This is expressed as a pair
# of doubles representing degrees latitude and degrees longitude. Unless
# specified otherwise, this must conform to the
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
# standard</a>. Values must be within normalized ranges.
# Example of normalization code in Python:
# def NormalizeLongitude(longitude):
# """Wraps decimal degrees longitude to [-180.0, 180.0]."""
# q, r = divmod(longitude, 360.0)
# if r > 180.0 or (r == 180.0 and q <= -1.0):
# return r - 360.0
# return r
# def NormalizeLatLng(latitude, longitude):
# """Wraps decimal degrees latitude and longitude to
# [-90.0, 90.0] and [-180.0, 180.0], respectively."""
# r = latitude % 360.0
# if r <= 90.0:
# return r, NormalizeLongitude(longitude)
# elif r >= 270.0:
# return r - 360, NormalizeLongitude(longitude)
# else:
# return 180 - r, NormalizeLongitude(longitude + 180.0)
# assert 180.0 == NormalizeLongitude(180.0)
# assert -180.0 == NormalizeLongitude(-180.0)
# assert -179.0 == NormalizeLongitude(181.0)
# assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0)
# assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0)
# assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0)
# assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0)
# assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0)
# assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0)
# assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0)
# assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0)
# Corresponds to the JSON property `latlng`
# @return [Google::Apis::MybusinessV3::LatLng]
attr_accessor :latlng
# Alternate / surrogate key references for a location.
# Corresponds to the JSON property `locationKey`
# @return [Google::Apis::MybusinessV3::LocationKey]
attr_accessor :location_key
# Location name should reflect your business's real-world name, as used
# consistently on your storefront, website, and stationery, and as known to
# customers.
# Any additional information, when relevant, can be included in other
# fields of the resource (for example, `Address`, `Categories`).
# Do not add unnecessary information to your name (for example, prefer "Google"
# over
# "Google Inc. - Mountain View Corporate Headquarters").
# It is NOT permitted to include marketing taglines, store codes, special
# characters, hours or
# closed/open status, phone numbers, website URLs, service/product
# information, location/address or directions, or containment information
# (for example, "Chase ATM in Duane Reade").
# Corresponds to the JSON property `locationName`
# @return [String]
attr_accessor :location_name
# Contains a set of booleans that reflect the state of a Location.
# Corresponds to the JSON property `locationState`
# @return [Google::Apis::MybusinessV3::LocationState]
attr_accessor :location_state
# Additional non-user-editable information about the location.
# Corresponds to the JSON property `metadata`
# @return [Google::Apis::MybusinessV3::Metadata]
attr_accessor :metadata
# Google identifier for this location in the form:
# `accounts/`account_id`/locations/`location_id``
# In the context of matches, this field will not be populated.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# Indicates whether the location is currently open for business.
# All locations are open by default, unless updated to be closed.
# Corresponds to the JSON property `openInfo`
# @return [Google::Apis::MybusinessV3::OpenInfo]
attr_accessor :open_info
# A collection of photos representing the business, categorized by photo type.
# The URL for each photo should point to a publicly accessible image.
# Photos should be supplied in either JPG or PNG format unless specified
# otherwise. If the photo was added by using Google My Business Locations or
# this API, the user-provided URL is used. If the photo was uploaded via the
# Google My Business Photos App, the photo uses a generated URL hosted by
# Google. Exceptions: `profile_photo_url` and `cover_photo_url` are always
# under a Google domain.
# With the exception of profile_photo_url and cover_photo_url, all photos
# must measure a minimum of 250px on the short edge, with a file size of at
# least 10240 bytes.
# Corresponds to the JSON property `photos`
# @return [Google::Apis::MybusinessV3::Photos]
attr_accessor :photos
# A category describing what this business is (not what it does). For a list of
# valid category IDs, and the mappings to their human readable names, see
# the [category list](/my-business/content/categories).
# Corresponds to the JSON property `primaryCategory`
# @return [Google::Apis::MybusinessV3::Category]
attr_accessor :primary_category
# A phone number that connects to your individual business location
# as directly as possible. Use a local phone number instead of a central,
# call center helpline number whenever possible.
# Corresponds to the JSON property `primaryPhone`
# @return [String]
attr_accessor :primary_phone
# Represents the time periods that this location is open for business.
# Holds a collection of TimePeriod
# instances.
# Corresponds to the JSON property `regularHours`
# @return [Google::Apis::MybusinessV3::BusinessHours]
attr_accessor :regular_hours
# Service area businesses provide their service at the customer's location (for
# example a locksmith or plumber).
# Corresponds to the JSON property `serviceArea`
# @return [Google::Apis::MybusinessV3::ServiceAreaBusiness]
attr_accessor :service_area
# Represents a set of time periods when a location's operational hours differ
# from its normal business hours.
# Corresponds to the JSON property `specialHours`
# @return [Google::Apis::MybusinessV3::SpecialHours]
attr_accessor :special_hours
# External identifier for this location, which must be unique inside a given
# account. This is a means of associating the location with your own records.
# Corresponds to the JSON property `storeCode`
# @return [String]
attr_accessor :store_code
# A URL for this business. If possible, use a URL that represents this
# individual business location instead of a generic website/URL that represents
# all locations, or the brand.
# Corresponds to the JSON property `websiteUrl`
# @return [String]
attr_accessor :website_url
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ad_words_location_extensions = args[:ad_words_location_extensions] if args.key?(:ad_words_location_extensions)
@additional_categories = args[:additional_categories] if args.key?(:additional_categories)
@additional_phones = args[:additional_phones] if args.key?(:additional_phones)
@address = args[:address] if args.key?(:address)
@attributes = args[:attributes] if args.key?(:attributes)
@labels = args[:labels] if args.key?(:labels)
@latlng = args[:latlng] if args.key?(:latlng)
@location_key = args[:location_key] if args.key?(:location_key)
@location_name = args[:location_name] if args.key?(:location_name)
@location_state = args[:location_state] if args.key?(:location_state)
@metadata = args[:metadata] if args.key?(:metadata)
@name = args[:name] if args.key?(:name)
@open_info = args[:open_info] if args.key?(:open_info)
@photos = args[:photos] if args.key?(:photos)
@primary_category = args[:primary_category] if args.key?(:primary_category)
@primary_phone = args[:primary_phone] if args.key?(:primary_phone)
@regular_hours = args[:regular_hours] if args.key?(:regular_hours)
@service_area = args[:service_area] if args.key?(:service_area)
@special_hours = args[:special_hours] if args.key?(:special_hours)
@store_code = args[:store_code] if args.key?(:store_code)
@website_url = args[:website_url] if args.key?(:website_url)
end
end
# Alternate / surrogate key references for a location.
class LocationKey
include Google::Apis::Core::Hashable
# A value of true indicates that an unset place ID is deliberate,
# which is different from no association being made yet.
# @OutputOnly
# Corresponds to the JSON property `explicitNoPlaceId`
# @return [Boolean]
attr_accessor :explicit_no_place_id
alias_method :explicit_no_place_id?, :explicit_no_place_id
# If this location has been verified and is connected to/appears on Google
# Maps, this field is populated with the place ID for the location.
# This ID can be used in various Places APIs.
# If this location is unverified, this field may be populated if the location
# has been associated with a place that appears on Google Maps.
# This field can be set during Create calls, but not for Update.
# The additional explicit_no_place_id bool qualifies whether an unset
# place ID is deliberate or not.
# Corresponds to the JSON property `placeId`
# @return [String]
attr_accessor :place_id
# If this location has a Google+ page associated with it, this is
# populated with the Google+ page ID for this location.
# @OutputOnly
# Corresponds to the JSON property `plusPageId`
# @return [String]
attr_accessor :plus_page_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@explicit_no_place_id = args[:explicit_no_place_id] if args.key?(:explicit_no_place_id)
@place_id = args[:place_id] if args.key?(:place_id)
@plus_page_id = args[:plus_page_id] if args.key?(:plus_page_id)
end
end
# Contains a set of booleans that reflect the state of a Location.
class LocationState
include Google::Apis::Core::Hashable
# Indicates whether the location can be deleted using the Google My Business
# UI.
# @OutputOnly
# Corresponds to the JSON property `canDelete`
# @return [Boolean]
attr_accessor :can_delete
alias_method :can_delete?, :can_delete
# Indicates whether the location can be updated.
# @OutputOnly
# Corresponds to the JSON property `canUpdate`
# @return [Boolean]
attr_accessor :can_update
alias_method :can_update?, :can_update
# Indicates whether the location is a duplicate of another location.
# See metadata.duplicate for more information.
# @OutputOnly
# Corresponds to the JSON property `isDuplicate`
# @return [Boolean]
attr_accessor :is_duplicate
alias_method :is_duplicate?, :is_duplicate
# Indicates whether the place ID associated with this location has updates.
# @OutputOnly
# Corresponds to the JSON property `isGoogleUpdated`
# @return [Boolean]
attr_accessor :is_google_updated
alias_method :is_google_updated?, :is_google_updated
# Indicates whether the location is suspended.
# Suspended locations are not visible to end users in Google products.
# If you believe this was a mistake, see the [help center article]
# (https://support.google.com/business/answer/4569145).
# @OutputOnly
# Corresponds to the JSON property `isSuspended`
# @return [Boolean]
attr_accessor :is_suspended
alias_method :is_suspended?, :is_suspended
# Indicates whether the location is verified.
# @OutputOnly
# Corresponds to the JSON property `isVerified`
# @return [Boolean]
attr_accessor :is_verified
alias_method :is_verified?, :is_verified
# Indicates whether the location requires reverification.
# @OutputOnly
# Corresponds to the JSON property `needsReverification`
# @return [Boolean]
attr_accessor :needs_reverification
alias_method :needs_reverification?, :needs_reverification
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@can_delete = args[:can_delete] if args.key?(:can_delete)
@can_update = args[:can_update] if args.key?(:can_update)
@is_duplicate = args[:is_duplicate] if args.key?(:is_duplicate)
@is_google_updated = args[:is_google_updated] if args.key?(:is_google_updated)
@is_suspended = args[:is_suspended] if args.key?(:is_suspended)
@is_verified = args[:is_verified] if args.key?(:is_verified)
@needs_reverification = args[:needs_reverification] if args.key?(:needs_reverification)
end
end
# Represents a possible match to a location.
class MatchedLocation
include Google::Apis::Core::Hashable
# Is this an exact match?
# Corresponds to the JSON property `isExactMatch`
# @return [Boolean]
attr_accessor :is_exact_match
alias_method :is_exact_match?, :is_exact_match
# A location.
# See the [help center article]
# (https://support.google.com/business/answer/3038177) for a detailed
# description of these fields, or the [category
# list](/my-business/content/categories] for a list of valid business
# categories.
# Corresponds to the JSON property `location`
# @return [Google::Apis::MybusinessV3::Location]
attr_accessor :location
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@is_exact_match = args[:is_exact_match] if args.key?(:is_exact_match)
@location = args[:location] if args.key?(:location)
end
end
# Additional non-user-editable information about the location.
class Metadata
include Google::Apis::Core::Hashable
# Information about the location that this location duplicates.
# Corresponds to the JSON property `duplicate`
# @return [Google::Apis::MybusinessV3::Duplicate]
attr_accessor :duplicate
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@duplicate = args[:duplicate] if args.key?(:duplicate)
end
end
# Indicates whether the location is currently open for business.
# All locations are open by default, unless updated to be closed.
class OpenInfo
include Google::Apis::Core::Hashable
# Indicates the Location OpenForBusiness status.
# Corresponds to the JSON property `status`
# @return [String]
attr_accessor :status
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@status = args[:status] if args.key?(:status)
end
end
# A collection of photos representing the business, categorized by photo type.
# The URL for each photo should point to a publicly accessible image.
# Photos should be supplied in either JPG or PNG format unless specified
# otherwise. If the photo was added by using Google My Business Locations or
# this API, the user-provided URL is used. If the photo was uploaded via the
# Google My Business Photos App, the photo uses a generated URL hosted by
# Google. Exceptions: `profile_photo_url` and `cover_photo_url` are always
# under a Google domain.
# With the exception of profile_photo_url and cover_photo_url, all photos
# must measure a minimum of 250px on the short edge, with a file size of at
# least 10240 bytes.
class Photos
include Google::Apis::Core::Hashable
# Use the additional photos category for images that don't fit in any of the
# other categories.
# Corresponds to the JSON property `additionalPhotoUrls`
# @return [Array<String>]
attr_accessor :additional_photo_urls
# Common area photos show customers the common areas of your business
# location.
# Corresponds to the JSON property `commonAreasPhotoUrls`
# @return [Array<String>]
attr_accessor :common_areas_photo_urls
# The cover photo showcases the personality of your business.
# Cover photos must have a 16:9 aspect ratio, with a minimum size of 480px
# x 270px, and a maximum size of 2120px x 1192px.
# Corresponds to the JSON property `coverPhotoUrl`
# @return [String]
attr_accessor :cover_photo_url
# Exterior photos help customers to recognize your business as they approach
# from different directions.
# Corresponds to the JSON property `exteriorPhotoUrls`
# @return [Array<String>]
attr_accessor :exterior_photo_urls
# Food and drink photos display the food and drink items served by your
# business.
# Corresponds to the JSON property `foodAndDrinkPhotoUrls`
# @return [Array<String>]
attr_accessor :food_and_drink_photo_urls
# Interior photos show customers what your business location looks like
# inside.
# Corresponds to the JSON property `interiorPhotoUrls`
# @return [Array<String>]
attr_accessor :interior_photo_urls
# The logo photo helps customers to recognize your brand. Upon upload, logo
# images are fitted into a square (transparent vertical or horizontal lines
# are added on two sides of the image if the original image is not square).
# Corresponds to the JSON property `logoPhotoUrl`
# @return [String]
attr_accessor :logo_photo_url
# Menu photos show customers what your food menu looks like.
# Corresponds to the JSON property `menuPhotoUrls`
# @return [Array<String>]
attr_accessor :menu_photo_urls
# At work photos show you and your employees serving your customers.
# Corresponds to the JSON property `photosAtWorkUrls`
# @return [Array<String>]
attr_accessor :photos_at_work_urls
# Indicate which photo should be shown first in Google Maps and Search.
# Corresponds to the JSON property `preferredPhoto`
# @return [String]
attr_accessor :preferred_photo
# Product photos showcase the products sold by your business.
# Corresponds to the JSON property `productPhotoUrls`
# @return [Array<String>]
attr_accessor :product_photo_urls
# The profile photo helps people recognize your business across Google.
# Profile photos must be square, with a minimum size of 250px and a maximum
# size of 500px. Allowed formats are JPG, PNG, and GIF.
# Corresponds to the JSON property `profilePhotoUrl`
# @return [String]
attr_accessor :profile_photo_url
# Room photos show customers the inside of your guest rooms.
# Corresponds to the JSON property `roomsPhotoUrls`
# @return [Array<String>]
attr_accessor :rooms_photo_urls
# Team photos show your management team and your employees.
# Corresponds to the JSON property `teamPhotoUrls`
# @return [Array<String>]
attr_accessor :team_photo_urls
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@additional_photo_urls = args[:additional_photo_urls] if args.key?(:additional_photo_urls)
@common_areas_photo_urls = args[:common_areas_photo_urls] if args.key?(:common_areas_photo_urls)
@cover_photo_url = args[:cover_photo_url] if args.key?(:cover_photo_url)
@exterior_photo_urls = args[:exterior_photo_urls] if args.key?(:exterior_photo_urls)
@food_and_drink_photo_urls = args[:food_and_drink_photo_urls] if args.key?(:food_and_drink_photo_urls)
@interior_photo_urls = args[:interior_photo_urls] if args.key?(:interior_photo_urls)
@logo_photo_url = args[:logo_photo_url] if args.key?(:logo_photo_url)
@menu_photo_urls = args[:menu_photo_urls] if args.key?(:menu_photo_urls)
@photos_at_work_urls = args[:photos_at_work_urls] if args.key?(:photos_at_work_urls)
@preferred_photo = args[:preferred_photo] if args.key?(:preferred_photo)
@product_photo_urls = args[:product_photo_urls] if args.key?(:product_photo_urls)
@profile_photo_url = args[:profile_photo_url] if args.key?(:profile_photo_url)
@rooms_photo_urls = args[:rooms_photo_urls] if args.key?(:rooms_photo_urls)
@team_photo_urls = args[:team_photo_urls] if args.key?(:team_photo_urls)
end
end
# Defines an area that's represented by a place ID.
class PlaceInfo
include Google::Apis::Core::Hashable
# The localized name of the place. For example, `Scottsdale, AZ`.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# The ID of the place.
# Corresponds to the JSON property `placeId`
# @return [String]
attr_accessor :place_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@name = args[:name] if args.key?(:name)
@place_id = args[:place_id] if args.key?(:place_id)
end
end
# Defines the union of areas represented by a set of places.
class Places
include Google::Apis::Core::Hashable
# The areas represented by place IDs.
# Corresponds to the JSON property `placeInfos`
# @return [Array<Google::Apis::MybusinessV3::PlaceInfo>]
attr_accessor :place_infos
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@place_infos = args[:place_infos] if args.key?(:place_infos)
end
end
# A radius around a particular point (latitude/longitude).
class PointRadius
include Google::Apis::Core::Hashable
# An object representing a latitude/longitude pair. This is expressed as a pair
# of doubles representing degrees latitude and degrees longitude. Unless
# specified otherwise, this must conform to the
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
# standard</a>. Values must be within normalized ranges.
# Example of normalization code in Python:
# def NormalizeLongitude(longitude):
# """Wraps decimal degrees longitude to [-180.0, 180.0]."""
# q, r = divmod(longitude, 360.0)
# if r > 180.0 or (r == 180.0 and q <= -1.0):
# return r - 360.0
# return r
# def NormalizeLatLng(latitude, longitude):
# """Wraps decimal degrees latitude and longitude to
# [-90.0, 90.0] and [-180.0, 180.0], respectively."""
# r = latitude % 360.0
# if r <= 90.0:
# return r, NormalizeLongitude(longitude)
# elif r >= 270.0:
# return r - 360, NormalizeLongitude(longitude)
# else:
# return 180 - r, NormalizeLongitude(longitude + 180.0)
# assert 180.0 == NormalizeLongitude(180.0)
# assert -180.0 == NormalizeLongitude(-180.0)
# assert -179.0 == NormalizeLongitude(181.0)
# assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0)
# assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0)
# assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0)
# assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0)
# assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0)
# assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0)
# assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0)
# assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0)
# assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0)
# Corresponds to the JSON property `latlng`
# @return [Google::Apis::MybusinessV3::LatLng]
attr_accessor :latlng
# The distance in kilometers of the area around the point.
# Corresponds to the JSON property `radiusKm`
# @return [Float]
attr_accessor :radius_km
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@latlng = args[:latlng] if args.key?(:latlng)
@radius_km = args[:radius_km] if args.key?(:radius_km)
end
end
# Represents a review for a location.
# @OutputOnly
class Review
include Google::Apis::Core::Hashable
# The body of the review as plain text with markups.
# Corresponds to the JSON property `comment`
# @return [String]
attr_accessor :comment
# The timestamp for when the review was written.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# The encrypted unique identifier.
# Corresponds to the JSON property `reviewId`
# @return [String]
attr_accessor :review_id
# Represents the location owner/manager's reply to a review
# Corresponds to the JSON property `reviewReply`
# @return [Google::Apis::MybusinessV3::ReviewReply]
attr_accessor :review_reply
# Represents the author of reviews.
# Corresponds to the JSON property `reviewer`
# @return [Google::Apis::MybusinessV3::Reviewer]
attr_accessor :reviewer
# Star rating of the review.
# Corresponds to the JSON property `starRating`
# @return [String]
attr_accessor :star_rating
# The timestamp for when the review was last modified.
# Corresponds to the JSON property `updateTime`
# @return [String]
attr_accessor :update_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@comment = args[:comment] if args.key?(:comment)
@create_time = args[:create_time] if args.key?(:create_time)
@review_id = args[:review_id] if args.key?(:review_id)
@review_reply = args[:review_reply] if args.key?(:review_reply)
@reviewer = args[:reviewer] if args.key?(:reviewer)
@star_rating = args[:star_rating] if args.key?(:star_rating)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Represents the location owner/manager's reply to a review
class ReviewReply
include Google::Apis::Core::Hashable
# The body of the review as plain text with markups.
# The maximum length is 4096 bytes.
# Corresponds to the JSON property `comment`
# @return [String]
attr_accessor :comment
# The timestamp for when the review was last modified.
# @OutputOnly
# Corresponds to the JSON property `updateTime`
# @return [String]
attr_accessor :update_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@comment = args[:comment] if args.key?(:comment)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Represents the author of reviews.
class Reviewer
include Google::Apis::Core::Hashable
# The name of the reviewer.
# Only populated with the reviewer's real name if is_anonymous is false.
# Corresponds to the JSON property `displayName`
# @return [String]
attr_accessor :display_name
# Indicates whether the reviewer has opted to remain anonymous.
# Corresponds to the JSON property `isAnonymous`
# @return [Boolean]
attr_accessor :is_anonymous
alias_method :is_anonymous?, :is_anonymous
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@display_name = args[:display_name] if args.key?(:display_name)
@is_anonymous = args[:is_anonymous] if args.key?(:is_anonymous)
end
end
# Service area businesses provide their service at the customer's location (for
# example a locksmith or plumber).
class ServiceAreaBusiness
include Google::Apis::Core::Hashable
# Indicates the type of the service area
# business.
# Corresponds to the JSON property `businessType`
# @return [String]
attr_accessor :business_type
# Defines the union of areas represented by a set of places.
# Corresponds to the JSON property `places`
# @return [Google::Apis::MybusinessV3::Places]
attr_accessor :places
# A radius around a particular point (latitude/longitude).
# Corresponds to the JSON property `radius`
# @return [Google::Apis::MybusinessV3::PointRadius]
attr_accessor :radius
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@business_type = args[:business_type] if args.key?(:business_type)
@places = args[:places] if args.key?(:places)
@radius = args[:radius] if args.key?(:radius)
end
end
# Represents a single time period when a location's operational hours differ
# from its normal business hours.
# A special hour period must represent a range of less than 24 hours.
# The `open_time` and `start_date` must predate the `close_time` and `end_date`.
# The `close_time` and `end_date` can extend to 11:59 a.m. on the day after
# the specified `start_date`.
# For example, the following inputs are valid:
# start_date=2015-11-23, open_time=08:00, close_time=18:00
# start_date=2015-11-23, end_date=2015-11-23, open_time=08:00, close_time=18:
# 00
# start_date=2015-11-23, end_date=2015-11-24, open_time=13:00, close_time=11:
# 59
# The following inputs are NOT valid:
# start_date=2015-11-23, open_time=13:00, close_time=11:59
# start_date=2015-11-23, end_date=2015-11-24, open_time=13:00, close_time=12:
# 00
# start_date=2015-11-23, end_date=2015-11-25, open_time=08:00, close_time=18:
# 00
class SpecialHourPeriod
include Google::Apis::Core::Hashable
# The wall time on end_date when a location closes, expressed in
# 24hr ISO 8601 extended format. (hh:mm) Valid values are 00:00-24:00,
# where 24:00 represents midnight at the end of the specified day field.
# Must be specified if is_closed is false.
# Corresponds to the JSON property `closeTime`
# @return [String]
attr_accessor :close_time
# Represents a whole calendar date, e.g. date of birth. The time of day and
# time zone are either specified elsewhere or are not significant. The date
# is relative to the Proleptic Gregorian Calendar. The day may be 0 to
# represent a year and month where the day is not significant, e.g. credit card
# expiration date. The year may be 0 to represent a month and day independent
# of year, e.g. anniversary date. Related types are google.type.TimeOfDay
# and `google.protobuf.Timestamp`.
# Corresponds to the JSON property `endDate`
# @return [Google::Apis::MybusinessV3::Date]
attr_accessor :end_date
# If true, end_date, open_time, and close_time are ignored,
# and the date specified in start_date is treated as the location being
# closed for the entire day.
# Corresponds to the JSON property `isClosed`
# @return [Boolean]
attr_accessor :is_closed
alias_method :is_closed?, :is_closed
# The wall time on `start_date` when a location opens, expressed in
# 24hr ISO 8601 extended format. (hh:mm) Valid values are 00:00-24:00,
# where 24:00 represents midnight at the end of the specified day field.
# Must be specified if `is_closed` is false.
# Corresponds to the JSON property `openTime`
# @return [String]
attr_accessor :open_time
# Represents a whole calendar date, e.g. date of birth. The time of day and
# time zone are either specified elsewhere or are not significant. The date
# is relative to the Proleptic Gregorian Calendar. The day may be 0 to
# represent a year and month where the day is not significant, e.g. credit card
# expiration date. The year may be 0 to represent a month and day independent
# of year, e.g. anniversary date. Related types are google.type.TimeOfDay
# and `google.protobuf.Timestamp`.
# Corresponds to the JSON property `startDate`
# @return [Google::Apis::MybusinessV3::Date]
attr_accessor :start_date
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@close_time = args[:close_time] if args.key?(:close_time)
@end_date = args[:end_date] if args.key?(:end_date)
@is_closed = args[:is_closed] if args.key?(:is_closed)
@open_time = args[:open_time] if args.key?(:open_time)
@start_date = args[:start_date] if args.key?(:start_date)
end
end
# Represents a set of time periods when a location's operational hours differ
# from its normal business hours.
class SpecialHours
include Google::Apis::Core::Hashable
# A list of exceptions to the business's regular hours.
# Corresponds to the JSON property `specialHourPeriods`
# @return [Array<Google::Apis::MybusinessV3::SpecialHourPeriod>]
attr_accessor :special_hour_periods
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@special_hour_periods = args[:special_hour_periods] if args.key?(:special_hour_periods)
end
end
# Represents a span of time that the business is open, starting on the
# specified open
# day/time and closing on the specified close day/time.
# The closing time must occur after the opening time, for example later in the
# same day, or on a subsequent day.
class TimePeriod
include Google::Apis::Core::Hashable
# Indicates the day of the week this period ends
# on.
# Corresponds to the JSON property `closeDay`
# @return [String]
attr_accessor :close_day
# Time in 24hr ISO 8601 extended format (hh:mm). Valid values are
# 00:00-24:00, where 24:00 represents midnight at the end of the specified day
# field.
# Corresponds to the JSON property `closeTime`
# @return [String]
attr_accessor :close_time
# Indicates the day of the week this period starts
# on.
# Corresponds to the JSON property `openDay`
# @return [String]
attr_accessor :open_day
# Time in 24hr ISO 8601 extended format (hh:mm). Valid values are 00:00-24:00,
# where 24:00 represents midnight at the end of the specified day field.
# Corresponds to the JSON property `openTime`
# @return [String]
attr_accessor :open_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@close_day = args[:close_day] if args.key?(:close_day)
@close_time = args[:close_time] if args.key?(:close_time)
@open_day = args[:open_day] if args.key?(:open_day)
@open_time = args[:open_time] if args.key?(:open_time)
end
end
# Request message for MyBusiness.TransferLocation to transfer a location from
# its current account to another.
class TransferLocationRequest
include Google::Apis::Core::Hashable
# Name of the account resource to transfer the location to (e.g.
# "accounts/8675309")
# Corresponds to the JSON property `toAccount`
# @return [String]
attr_accessor :to_account
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@to_account = args[:to_account] if args.key?(:to_account)
end
end
end
end
end