google-api-ruby-client/generated/google-apis-retail_v2/lib/google/apis/retail_v2/classes.rb

4970 lines
223 KiB
Ruby
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Copyright 2020 Google LLC
#
# 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 RetailV2
# Message that represents an arbitrary HTTP body. It should only be used for
# payload formats that can't be represented as JSON, such as raw binary or an
# HTML page. This message can be used both in streaming and non-streaming API
# methods in the request as well as the response. It can be used as a top-level
# request field, which is convenient if one wants to extract parameters from
# either the URL or HTTP template into the request fields and also want access
# to the raw HTTP body. Example: message GetResourceRequest ` // A unique
# request id. string request_id = 1; // The raw HTTP body is bound to this field.
# google.api.HttpBody http_body = 2; ` service ResourceService ` rpc
# GetResource(GetResourceRequest) returns (google.api.HttpBody); rpc
# UpdateResource(google.api.HttpBody) returns (google.protobuf.Empty); ` Example
# with streaming methods: service CaldavService ` rpc GetCalendar(stream google.
# api.HttpBody) returns (stream google.api.HttpBody); rpc UpdateCalendar(stream
# google.api.HttpBody) returns (stream google.api.HttpBody); ` Use of this type
# only changes how the request and response bodies are handled, all other
# features will continue to work unchanged.
class GoogleApiHttpBody
include Google::Apis::Core::Hashable
# The HTTP Content-Type header value specifying the content type of the body.
# Corresponds to the JSON property `contentType`
# @return [String]
attr_accessor :content_type
# The HTTP request/response body as raw binary.
# Corresponds to the JSON property `data`
# NOTE: Values are automatically base64 encoded/decoded in the client library.
# @return [String]
attr_accessor :data
# Application specific response metadata. Must be set in the first response for
# streaming APIs.
# Corresponds to the JSON property `extensions`
# @return [Array<Hash<String,Object>>]
attr_accessor :extensions
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@content_type = args[:content_type] if args.key?(:content_type)
@data = args[:data] if args.key?(:data)
@extensions = args[:extensions] if args.key?(:extensions)
end
end
# A description of the context in which an error occurred.
class GoogleCloudRetailLoggingErrorContext
include Google::Apis::Core::Hashable
# HTTP request data that is related to a reported error.
# Corresponds to the JSON property `httpRequest`
# @return [Google::Apis::RetailV2::GoogleCloudRetailLoggingHttpRequestContext]
attr_accessor :http_request
# Indicates a location in the source code of the service for which errors are
# reported.
# Corresponds to the JSON property `reportLocation`
# @return [Google::Apis::RetailV2::GoogleCloudRetailLoggingSourceLocation]
attr_accessor :report_location
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@http_request = args[:http_request] if args.key?(:http_request)
@report_location = args[:report_location] if args.key?(:report_location)
end
end
# An error log which is reported to the Error Reporting system. This proto a
# superset of google.devtools.clouderrorreporting.v1beta1.ReportedErrorEvent.
class GoogleCloudRetailLoggingErrorLog
include Google::Apis::Core::Hashable
# A description of the context in which an error occurred.
# Corresponds to the JSON property `context`
# @return [Google::Apis::RetailV2::GoogleCloudRetailLoggingErrorContext]
attr_accessor :context
# The error payload that is populated on LRO import APIs. Including: "google.
# cloud.retail.v2.ProductService.ImportProducts" "google.cloud.retail.v2.
# EventService.ImportUserEvents"
# Corresponds to the JSON property `importPayload`
# @return [Google::Apis::RetailV2::GoogleCloudRetailLoggingImportErrorContext]
attr_accessor :import_payload
# A message describing the error.
# Corresponds to the JSON property `message`
# @return [String]
attr_accessor :message
# The API request payload, represented as a protocol buffer. Most API request
# types are supported. For example: "type.googleapis.com/google.cloud.retail.v2.
# ProductService.CreateProductRequest" "type.googleapis.com/google.cloud.retail.
# v2.UserEventService.WriteUserEventRequest"
# Corresponds to the JSON property `requestPayload`
# @return [Hash<String,Object>]
attr_accessor :request_payload
# The API response payload, represented as a protocol buffer. This is used to
# log some "soft errors", where the response is valid but we consider there are
# some quality issues like unjoined events. The following API responses are
# supported and no PII is included: "google.cloud.retail.v2.PredictionService.
# Predict" "google.cloud.retail.v2.UserEventService.WriteUserEvent" "google.
# cloud.retail.v2.UserEventService.CollectUserEvent"
# Corresponds to the JSON property `responsePayload`
# @return [Hash<String,Object>]
attr_accessor :response_payload
# Describes a running service that sends errors.
# Corresponds to the JSON property `serviceContext`
# @return [Google::Apis::RetailV2::GoogleCloudRetailLoggingServiceContext]
attr_accessor :service_context
# The `Status` type defines a logical error model that is suitable for different
# programming environments, including REST APIs and RPC APIs. It is used by [
# gRPC](https://github.com/grpc). Each `Status` message contains three pieces of
# data: error code, error message, and error details. You can find out more
# about this error model and how to work with it in the [API Design Guide](https:
# //cloud.google.com/apis/design/errors).
# Corresponds to the JSON property `status`
# @return [Google::Apis::RetailV2::GoogleRpcStatus]
attr_accessor :status
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@context = args[:context] if args.key?(:context)
@import_payload = args[:import_payload] if args.key?(:import_payload)
@message = args[:message] if args.key?(:message)
@request_payload = args[:request_payload] if args.key?(:request_payload)
@response_payload = args[:response_payload] if args.key?(:response_payload)
@service_context = args[:service_context] if args.key?(:service_context)
@status = args[:status] if args.key?(:status)
end
end
# HTTP request data that is related to a reported error.
class GoogleCloudRetailLoggingHttpRequestContext
include Google::Apis::Core::Hashable
# The HTTP response status code for the request.
# Corresponds to the JSON property `responseStatusCode`
# @return [Fixnum]
attr_accessor :response_status_code
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@response_status_code = args[:response_status_code] if args.key?(:response_status_code)
end
end
# The error payload that is populated on LRO import APIs. Including: "google.
# cloud.retail.v2.ProductService.ImportProducts" "google.cloud.retail.v2.
# EventService.ImportUserEvents"
class GoogleCloudRetailLoggingImportErrorContext
include Google::Apis::Core::Hashable
# The detailed content which caused the error on importing a catalog item.
# Corresponds to the JSON property `catalogItem`
# @return [String]
attr_accessor :catalog_item
# Cloud Storage file path of the import source. Can be set for batch operation
# error.
# Corresponds to the JSON property `gcsPath`
# @return [String]
attr_accessor :gcs_path
# Line number of the content in file. Should be empty for permission or batch
# operation error.
# Corresponds to the JSON property `lineNumber`
# @return [String]
attr_accessor :line_number
# The operation resource name of the LRO.
# Corresponds to the JSON property `operationName`
# @return [String]
attr_accessor :operation_name
# The detailed content which caused the error on importing a product.
# Corresponds to the JSON property `product`
# @return [String]
attr_accessor :product
# The detailed content which caused the error on importing a user event.
# Corresponds to the JSON property `userEvent`
# @return [String]
attr_accessor :user_event
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@catalog_item = args[:catalog_item] if args.key?(:catalog_item)
@gcs_path = args[:gcs_path] if args.key?(:gcs_path)
@line_number = args[:line_number] if args.key?(:line_number)
@operation_name = args[:operation_name] if args.key?(:operation_name)
@product = args[:product] if args.key?(:product)
@user_event = args[:user_event] if args.key?(:user_event)
end
end
# Describes a running service that sends errors.
class GoogleCloudRetailLoggingServiceContext
include Google::Apis::Core::Hashable
# An identifier of the service. For example, "retail.googleapis.com".
# Corresponds to the JSON property `service`
# @return [String]
attr_accessor :service
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@service = args[:service] if args.key?(:service)
end
end
# Indicates a location in the source code of the service for which errors are
# reported.
class GoogleCloudRetailLoggingSourceLocation
include Google::Apis::Core::Hashable
# Human-readable name of a function or method. For example, "google.cloud.retail.
# v2.UserEventService.ImportUserEvents".
# Corresponds to the JSON property `functionName`
# @return [String]
attr_accessor :function_name
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@function_name = args[:function_name] if args.key?(:function_name)
end
end
# Metadata related to the progress of the AddFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# AddFulfillmentPlaces method.
class GoogleCloudRetailV2AddFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for AddFulfillmentPlaces method.
class GoogleCloudRetailV2AddFulfillmentPlacesRequest
include Google::Apis::Core::Hashable
# The time when the fulfillment updates are issued, used to prevent out-of-order
# updates on fulfillment information. If not provided, the internal system time
# will be used.
# Corresponds to the JSON property `addTime`
# @return [String]
attr_accessor :add_time
# If set to true, and the Product is not found, the fulfillment information will
# still be processed and retained for at most 1 day and processed once the
# Product is created. If set to false, a NOT_FOUND error is returned if the
# Product is not found.
# Corresponds to the JSON property `allowMissing`
# @return [Boolean]
attr_accessor :allow_missing
alias_method :allow_missing?, :allow_missing
# Required. The IDs for this type, such as the store IDs for "pickup-in-store"
# or the region IDs for "same-day-delivery" to be added for this type. Duplicate
# IDs will be automatically ignored. At least 1 value is required, and a maximum
# of 2000 values are allowed. Each value must be a string with a length limit of
# 10 characters, matching the pattern `[a-zA-Z0-9_-]+`, such as "store1" or "
# REGION-2". Otherwise, an INVALID_ARGUMENT error is returned. If the total
# number of place IDs exceeds 2000 for this type after adding, then the update
# will be rejected.
# Corresponds to the JSON property `placeIds`
# @return [Array<String>]
attr_accessor :place_ids
# Required. The fulfillment type, including commonly used types (such as pickup
# in store and same day delivery), and custom types. Supported values: * "pickup-
# in-store" * "ship-to-store" * "same-day-delivery" * "next-day-delivery" * "
# custom-type-1" * "custom-type-2" * "custom-type-3" * "custom-type-4" * "custom-
# type-5" If this field is set to an invalid value other than these, an
# INVALID_ARGUMENT error is returned. This field directly corresponds to Product.
# fulfillment_info.type.
# 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)
@add_time = args[:add_time] if args.key?(:add_time)
@allow_missing = args[:allow_missing] if args.key?(:allow_missing)
@place_ids = args[:place_ids] if args.key?(:place_ids)
@type = args[:type] if args.key?(:type)
end
end
# Response of the AddFulfillmentPlacesRequest. Currently empty because there is
# no meaningful response populated from the AddFulfillmentPlaces method.
class GoogleCloudRetailV2AddFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the AddLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# AddLocalInventories method.
class GoogleCloudRetailV2AddLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for AddLocalInventories method.
class GoogleCloudRetailV2AddLocalInventoriesRequest
include Google::Apis::Core::Hashable
# Indicates which inventory fields in the provided list of LocalInventory to
# update. The field is updated to the provided value. If a field is set while
# the place does not have a previous local inventory, the local inventory at
# that store is created. If a field is set while the value of that field is not
# provided, the original field value, if it exists, is deleted. If the mask is
# not set or set with empty paths, all inventory fields will be updated. If an
# unsupported or unknown field is provided, an INVALID_ARGUMENT error is
# returned and the entire update will be ignored.
# Corresponds to the JSON property `addMask`
# @return [String]
attr_accessor :add_mask
# The time when the inventory updates are issued. Used to prevent out-of-order
# updates on local inventory fields. If not provided, the internal system time
# will be used.
# Corresponds to the JSON property `addTime`
# @return [String]
attr_accessor :add_time
# If set to true, and the Product is not found, the local inventory will still
# be processed and retained for at most 1 day and processed once the Product is
# created. If set to false, a NOT_FOUND error is returned if the Product is not
# found.
# Corresponds to the JSON property `allowMissing`
# @return [Boolean]
attr_accessor :allow_missing
alias_method :allow_missing?, :allow_missing
# Required. A list of inventory information at difference places. Each place is
# identified by its place ID. At most 3000 inventories are allowed per request.
# Corresponds to the JSON property `localInventories`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2LocalInventory>]
attr_accessor :local_inventories
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@add_mask = args[:add_mask] if args.key?(:add_mask)
@add_time = args[:add_time] if args.key?(:add_time)
@allow_missing = args[:allow_missing] if args.key?(:allow_missing)
@local_inventories = args[:local_inventories] if args.key?(:local_inventories)
end
end
# Response of the AddLocalInventories API. Currently empty because there is no
# meaningful response populated from the AddLocalInventories method.
class GoogleCloudRetailV2AddLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# An intended audience of the Product for whom it's sold.
class GoogleCloudRetailV2Audience
include Google::Apis::Core::Hashable
# The age groups of the audience. Strongly encouraged to use the standard values:
# "newborn" (up to 3 months old), "infant" (312 months old), "toddler" (15
# years old), "kids" (513 years old), "adult" (typically teens or older). At
# most 5 values are allowed. Each value must be a UTF-8 encoded string with a
# length limit of 128 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. Google Merchant Center property [age_group](https://support.google.
# com/merchants/answer/6324463). Schema.org property [Product.audience.
# suggestedMinAge](https://schema.org/suggestedMinAge) and [Product.audience.
# suggestedMaxAge](https://schema.org/suggestedMaxAge).
# Corresponds to the JSON property `ageGroups`
# @return [Array<String>]
attr_accessor :age_groups
# The genders of the audience. Strongly encouraged to use the standard values: "
# male", "female", "unisex". At most 5 values are allowed. Each value must be a
# UTF-8 encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned. Google Merchant Center property [gender](
# https://support.google.com/merchants/answer/6324479). Schema.org property [
# Product.audience.suggestedGender](https://schema.org/suggestedGender).
# Corresponds to the JSON property `genders`
# @return [Array<String>]
attr_accessor :genders
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@age_groups = args[:age_groups] if args.key?(:age_groups)
@genders = args[:genders] if args.key?(:genders)
end
end
# BigQuery source import data from.
class GoogleCloudRetailV2BigQuerySource
include Google::Apis::Core::Hashable
# The schema to use when parsing the data from the source. Supported values for
# product imports: * `product` (default): One JSON Product per line. Each
# product must have a valid Product.id. * `product_merchant_center`: See [
# Importing catalog data from Merchant Center](https://cloud.google.com/retail/
# recommendations-ai/docs/upload-catalog#mc). Supported values for user events
# imports: * `user_event` (default): One JSON UserEvent per line. * `
# user_event_ga360`: The schema is available here: https://support.google.com/
# analytics/answer/3437719. * `user_event_ga4`: This feature is in private
# preview. Please contact the support team for importing Google Analytics 4
# events. The schema is available here: https://support.google.com/analytics/
# answer/7029846. Supported values for auto-completion imports: * `suggestions` (
# default): One JSON completion suggestion per line. * `denylist`: One JSON deny
# suggestion per line. * `allowlist`: One JSON allow suggestion per line.
# Corresponds to the JSON property `dataSchema`
# @return [String]
attr_accessor :data_schema
# Required. The BigQuery data set to copy the data from with a length limit of 1,
# 024 characters.
# Corresponds to the JSON property `datasetId`
# @return [String]
attr_accessor :dataset_id
# Intermediate Cloud Storage directory used for the import with a length limit
# of 2,000 characters. Can be specified if one wants to have the BigQuery export
# to a specific Cloud Storage directory.
# Corresponds to the JSON property `gcsStagingDir`
# @return [String]
attr_accessor :gcs_staging_dir
# 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
# Corresponds to the JSON property `partitionDate`
# @return [Google::Apis::RetailV2::GoogleTypeDate]
attr_accessor :partition_date
# The project ID (can be project # or ID) that the BigQuery source is in with a
# length limit of 128 characters. If not specified, inherits the project ID from
# the parent request.
# Corresponds to the JSON property `projectId`
# @return [String]
attr_accessor :project_id
# Required. The BigQuery table to copy the data from with a length limit of 1,
# 024 characters.
# Corresponds to the JSON property `tableId`
# @return [String]
attr_accessor :table_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@data_schema = args[:data_schema] if args.key?(:data_schema)
@dataset_id = args[:dataset_id] if args.key?(:dataset_id)
@gcs_staging_dir = args[:gcs_staging_dir] if args.key?(:gcs_staging_dir)
@partition_date = args[:partition_date] if args.key?(:partition_date)
@project_id = args[:project_id] if args.key?(:project_id)
@table_id = args[:table_id] if args.key?(:table_id)
end
end
# The catalog configuration.
class GoogleCloudRetailV2Catalog
include Google::Apis::Core::Hashable
# Required. Immutable. The catalog display name. This field must be a UTF-8
# encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `displayName`
# @return [String]
attr_accessor :display_name
# Required. Immutable. The fully qualified resource name of the catalog.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# Configures what level the product should be uploaded with regards to how users
# will be send events and how predictions will be made.
# Corresponds to the JSON property `productLevelConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ProductLevelConfig]
attr_accessor :product_level_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@display_name = args[:display_name] if args.key?(:display_name)
@name = args[:name] if args.key?(:name)
@product_level_config = args[:product_level_config] if args.key?(:product_level_config)
end
end
# The color information of a Product.
class GoogleCloudRetailV2ColorInfo
include Google::Apis::Core::Hashable
# The standard color families. Strongly recommended to use the following
# standard color groups: "Red", "Pink", "Orange", "Yellow", "Purple", "Green", "
# Cyan", "Blue", "Brown", "White", "Gray", "Black" and "Mixed". Normally it is
# expected to have only 1 color family. May consider using single "Mixed"
# instead of multiple values. A maximum of 5 values are allowed. Each value must
# be a UTF-8 encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned. Google Merchant Center property [color](
# https://support.google.com/merchants/answer/6324487). Schema.org property [
# Product.color](https://schema.org/color).
# Corresponds to the JSON property `colorFamilies`
# @return [Array<String>]
attr_accessor :color_families
# The color display names, which may be different from standard color family
# names, such as the color aliases used in the website frontend. Normally it is
# expected to have only 1 color. May consider using single "Mixed" instead of
# multiple values. A maximum of 25 colors are allowed. Each value must be a UTF-
# 8 encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned. Google Merchant Center property [color](
# https://support.google.com/merchants/answer/6324487). Schema.org property [
# Product.color](https://schema.org/color).
# Corresponds to the JSON property `colors`
# @return [Array<String>]
attr_accessor :colors
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@color_families = args[:color_families] if args.key?(:color_families)
@colors = args[:colors] if args.key?(:colors)
end
end
# Response of the auto-complete query.
class GoogleCloudRetailV2CompleteQueryResponse
include Google::Apis::Core::Hashable
# A unique complete token. This should be included in the UserEvent.
# completion_detail for search events resulting from this completion, which
# enables accurate attribution of complete model performance.
# Corresponds to the JSON property `attributionToken`
# @return [String]
attr_accessor :attribution_token
# Results of the matching suggestions. The result list is ordered and the first
# result is top suggestion.
# Corresponds to the JSON property `completionResults`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2CompleteQueryResponseCompletionResult>]
attr_accessor :completion_results
# Matched recent searches of this user. The maximum number of recent searches is
# 10. This field is a restricted feature. Contact Retail Search support team if
# you are interested in enabling it. This feature is only available when
# CompleteQueryRequest.visitor_id field is set and UserEvent is imported. The
# recent searches satisfy the follow rules: * They are ordered from latest to
# oldest. * They are matched with CompleteQueryRequest.query case insensitively.
# * They are transformed to lower cases. * They are UTF-8 safe. Recent searches
# are deduplicated. More recent searches will be reserved when duplication
# happens.
# Corresponds to the JSON property `recentSearchResults`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2CompleteQueryResponseRecentSearchResult>]
attr_accessor :recent_search_results
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attribution_token = args[:attribution_token] if args.key?(:attribution_token)
@completion_results = args[:completion_results] if args.key?(:completion_results)
@recent_search_results = args[:recent_search_results] if args.key?(:recent_search_results)
end
end
# Resource that represents completion results.
class GoogleCloudRetailV2CompleteQueryResponseCompletionResult
include Google::Apis::Core::Hashable
# Custom attributes for the suggestion term. * For "user-data", the attributes
# are additional custom attributes ingested through BigQuery. * For "cloud-
# retail", the attributes are product attributes generated by Cloud Retail.
# Corresponds to the JSON property `attributes`
# @return [Hash<String,Google::Apis::RetailV2::GoogleCloudRetailV2CustomAttribute>]
attr_accessor :attributes
# The suggestion for the query.
# Corresponds to the JSON property `suggestion`
# @return [String]
attr_accessor :suggestion
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attributes = args[:attributes] if args.key?(:attributes)
@suggestion = args[:suggestion] if args.key?(:suggestion)
end
end
# Recent search of this user.
class GoogleCloudRetailV2CompleteQueryResponseRecentSearchResult
include Google::Apis::Core::Hashable
# The recent search query.
# Corresponds to the JSON property `recentSearch`
# @return [String]
attr_accessor :recent_search
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@recent_search = args[:recent_search] if args.key?(:recent_search)
end
end
# The input config source for completion data.
class GoogleCloudRetailV2CompletionDataInputConfig
include Google::Apis::Core::Hashable
# BigQuery source import data from.
# Corresponds to the JSON property `bigQuerySource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2BigQuerySource]
attr_accessor :big_query_source
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@big_query_source = args[:big_query_source] if args.key?(:big_query_source)
end
end
# Detailed completion information including completion attribution token and
# clicked completion info.
class GoogleCloudRetailV2CompletionDetail
include Google::Apis::Core::Hashable
# Completion attribution token in CompleteQueryResponse.attribution_token.
# Corresponds to the JSON property `completionAttributionToken`
# @return [String]
attr_accessor :completion_attribution_token
# End user selected CompleteQueryResponse.CompletionResult.suggestion position,
# starting from 0.
# Corresponds to the JSON property `selectedPosition`
# @return [Fixnum]
attr_accessor :selected_position
# End user selected CompleteQueryResponse.CompletionResult.suggestion.
# Corresponds to the JSON property `selectedSuggestion`
# @return [String]
attr_accessor :selected_suggestion
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@completion_attribution_token = args[:completion_attribution_token] if args.key?(:completion_attribution_token)
@selected_position = args[:selected_position] if args.key?(:selected_position)
@selected_suggestion = args[:selected_suggestion] if args.key?(:selected_suggestion)
end
end
# A custom attribute that is not explicitly modeled in Product.
class GoogleCloudRetailV2CustomAttribute
include Google::Apis::Core::Hashable
# This field will only be used when AttributesConfig.attribute_config_level of
# the Catalog is 'PRODUCT_LEVEL_ATTRIBUTE_CONFIG', if true, custom attribute
# values are indexed, so that it can be filtered, faceted or boosted in
# SearchService.Search. This field is ignored in a UserEvent. See SearchRequest.
# filter, SearchRequest.facet_specs and SearchRequest.boost_spec for more
# details.
# Corresponds to the JSON property `indexable`
# @return [Boolean]
attr_accessor :indexable
alias_method :indexable?, :indexable
# The numerical values of this custom attribute. For example, `[2.3, 15.4]` when
# the key is "lengths_cm". Exactly one of text or numbers should be set.
# Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `numbers`
# @return [Array<Float>]
attr_accessor :numbers
# This field will only be used when AttributesConfig.attribute_config_level of
# the Catalog is 'PRODUCT_LEVEL_ATTRIBUTE_CONFIG', if true, custom attribute
# values are searchable by text queries in SearchService.Search. This field is
# ignored in a UserEvent. Only set if type text is set. Otherwise, a
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `searchable`
# @return [Boolean]
attr_accessor :searchable
alias_method :searchable?, :searchable
# The textual values of this custom attribute. For example, `["yellow", "green"]`
# when the key is "color". Empty string is not allowed. Otherwise, an
# INVALID_ARGUMENT error is returned. Exactly one of text or numbers should be
# set. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `text`
# @return [Array<String>]
attr_accessor :text
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@indexable = args[:indexable] if args.key?(:indexable)
@numbers = args[:numbers] if args.key?(:numbers)
@searchable = args[:searchable] if args.key?(:searchable)
@text = args[:text] if args.key?(:text)
end
end
# Fulfillment information, such as the store IDs for in-store pickup or region
# IDs for different shipping methods.
class GoogleCloudRetailV2FulfillmentInfo
include Google::Apis::Core::Hashable
# The IDs for this type, such as the store IDs for FulfillmentInfo.type.pickup-
# in-store or the region IDs for FulfillmentInfo.type.same-day-delivery. A
# maximum of 3000 values are allowed. Each value must be a string with a length
# limit of 30 characters, matching the pattern `[a-zA-Z0-9_-]+`, such as "store1"
# or "REGION-2". Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `placeIds`
# @return [Array<String>]
attr_accessor :place_ids
# The fulfillment type, including commonly used types (such as pickup in store
# and same day delivery), and custom types. Customers have to map custom types
# to their display names before rendering UI. Supported values: * "pickup-in-
# store" * "ship-to-store" * "same-day-delivery" * "next-day-delivery" * "custom-
# type-1" * "custom-type-2" * "custom-type-3" * "custom-type-4" * "custom-type-5"
# If this field is set to an invalid value other than these, an
# INVALID_ARGUMENT error is returned.
# 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)
@place_ids = args[:place_ids] if args.key?(:place_ids)
@type = args[:type] if args.key?(:type)
end
end
# Google Cloud Storage location for input content. format.
class GoogleCloudRetailV2GcsSource
include Google::Apis::Core::Hashable
# The schema to use when parsing the data from the source. Supported values for
# product imports: * `product` (default): One JSON Product per line. Each
# product must have a valid Product.id. * `product_merchant_center`: See [
# Importing catalog data from Merchant Center](https://cloud.google.com/retail/
# recommendations-ai/docs/upload-catalog#mc). Supported values for user events
# imports: * `user_event` (default): One JSON UserEvent per line. * `
# user_event_ga360`: Using https://support.google.com/analytics/answer/3437719.
# Supported values for control imports: * 'control' (default): One JSON Control
# per line. Supported values for catalog attribute imports: * 'catalog_attribute'
# (default): One CSV CatalogAttribute per line.
# Corresponds to the JSON property `dataSchema`
# @return [String]
attr_accessor :data_schema
# Required. Google Cloud Storage URIs to input files. URI can be up to 2000
# characters long. URIs can match the full object path (for example, `gs://
# bucket/directory/object.json`) or a pattern matching one or more files, such
# as `gs://bucket/directory/*.json`. A request can contain at most 100 files,
# and each file can be up to 2 GB. See [Importing product information](https://
# cloud.google.com/retail/recommendations-ai/docs/upload-catalog) for the
# expected file format and setup instructions.
# Corresponds to the JSON property `inputUris`
# @return [Array<String>]
attr_accessor :input_uris
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@data_schema = args[:data_schema] if args.key?(:data_schema)
@input_uris = args[:input_uris] if args.key?(:input_uris)
end
end
# Response message of CatalogService.GetDefaultBranch.
class GoogleCloudRetailV2GetDefaultBranchResponse
include Google::Apis::Core::Hashable
# Full resource name of the branch id currently set as default branch.
# Corresponds to the JSON property `branch`
# @return [String]
attr_accessor :branch
# This corresponds to SetDefaultBranchRequest.note field, when this branch was
# set as default.
# Corresponds to the JSON property `note`
# @return [String]
attr_accessor :note
# The time when this branch is set to default.
# Corresponds to the JSON property `setTime`
# @return [String]
attr_accessor :set_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@branch = args[:branch] if args.key?(:branch)
@note = args[:note] if args.key?(:note)
@set_time = args[:set_time] if args.key?(:set_time)
end
end
# Product image. Recommendations AI and Retail Search do not use product images
# to improve prediction and search results. However, product images can be
# returned in results, and are shown in prediction or search previews in the
# console.
class GoogleCloudRetailV2Image
include Google::Apis::Core::Hashable
# Height of the image in number of pixels. This field must be nonnegative.
# Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `height`
# @return [Fixnum]
attr_accessor :height
# Required. URI of the image. This field must be a valid UTF-8 encoded URI with
# a length limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. Google Merchant Center property [image_link](https://support.google.
# com/merchants/answer/6324350). Schema.org property [Product.image](https://
# schema.org/image).
# Corresponds to the JSON property `uri`
# @return [String]
attr_accessor :uri
# Width of the image in number of pixels. This field must be nonnegative.
# Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `width`
# @return [Fixnum]
attr_accessor :width
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@height = args[:height] if args.key?(:height)
@uri = args[:uri] if args.key?(:uri)
@width = args[:width] if args.key?(:width)
end
end
# Request message for ImportCompletionData methods.
class GoogleCloudRetailV2ImportCompletionDataRequest
include Google::Apis::Core::Hashable
# The input config source for completion data.
# Corresponds to the JSON property `inputConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2CompletionDataInputConfig]
attr_accessor :input_config
# Pub/Sub topic for receiving notification. If this field is set, when the
# import is finished, a notification will be sent to specified Pub/Sub topic.
# The message data will be JSON string of a Operation. Format of the Pub/Sub
# topic is `projects/`project`/topics/`topic``.
# Corresponds to the JSON property `notificationPubsubTopic`
# @return [String]
attr_accessor :notification_pubsub_topic
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@input_config = args[:input_config] if args.key?(:input_config)
@notification_pubsub_topic = args[:notification_pubsub_topic] if args.key?(:notification_pubsub_topic)
end
end
# Response of the ImportCompletionDataRequest. If the long running operation is
# done, this message is returned by the google.longrunning.Operations.response
# field if the operation is successful.
class GoogleCloudRetailV2ImportCompletionDataResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
end
end
# Configuration of destination for Import related errors.
class GoogleCloudRetailV2ImportErrorsConfig
include Google::Apis::Core::Hashable
# Google Cloud Storage prefix for import errors. This must be an empty, existing
# Cloud Storage directory. Import errors will be written to sharded files in
# this directory, one per line, as a JSON-encoded `google.rpc.Status` message.
# Corresponds to the JSON property `gcsPrefix`
# @return [String]
attr_accessor :gcs_prefix
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@gcs_prefix = args[:gcs_prefix] if args.key?(:gcs_prefix)
end
end
# Metadata related to the progress of the Import operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2ImportMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Count of entries that encountered errors while processing.
# Corresponds to the JSON property `failureCount`
# @return [Fixnum]
attr_accessor :failure_count
# Pub/Sub topic for receiving notification. If this field is set, when the
# import is finished, a notification will be sent to specified Pub/Sub topic.
# The message data will be JSON string of a Operation. Format of the Pub/Sub
# topic is `projects/`project`/topics/`topic``.
# Corresponds to the JSON property `notificationPubsubTopic`
# @return [String]
attr_accessor :notification_pubsub_topic
# Deprecated. This field is never set.
# Corresponds to the JSON property `requestId`
# @return [String]
attr_accessor :request_id
# Count of entries that were processed successfully.
# Corresponds to the JSON property `successCount`
# @return [Fixnum]
attr_accessor :success_count
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@failure_count = args[:failure_count] if args.key?(:failure_count)
@notification_pubsub_topic = args[:notification_pubsub_topic] if args.key?(:notification_pubsub_topic)
@request_id = args[:request_id] if args.key?(:request_id)
@success_count = args[:success_count] if args.key?(:success_count)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Request message for Import methods.
class GoogleCloudRetailV2ImportProductsRequest
include Google::Apis::Core::Hashable
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ImportErrorsConfig]
attr_accessor :errors_config
# The input config source for products.
# Corresponds to the JSON property `inputConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ProductInputConfig]
attr_accessor :input_config
# Pub/Sub topic for receiving notification. If this field is set, when the
# import is finished, a notification will be sent to specified Pub/Sub topic.
# The message data will be JSON string of a Operation. Format of the Pub/Sub
# topic is `projects/`project`/topics/`topic``. Only supported when
# ImportProductsRequest.reconciliation_mode is set to `FULL`.
# Corresponds to the JSON property `notificationPubsubTopic`
# @return [String]
attr_accessor :notification_pubsub_topic
# The mode of reconciliation between existing products and the products to be
# imported. Defaults to ReconciliationMode.INCREMENTAL.
# Corresponds to the JSON property `reconciliationMode`
# @return [String]
attr_accessor :reconciliation_mode
# Deprecated. This field has no effect.
# Corresponds to the JSON property `requestId`
# @return [String]
attr_accessor :request_id
# Indicates which fields in the provided imported 'products' to update. If not
# set, will by default update all fields.
# Corresponds to the JSON property `updateMask`
# @return [String]
attr_accessor :update_mask
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@errors_config = args[:errors_config] if args.key?(:errors_config)
@input_config = args[:input_config] if args.key?(:input_config)
@notification_pubsub_topic = args[:notification_pubsub_topic] if args.key?(:notification_pubsub_topic)
@reconciliation_mode = args[:reconciliation_mode] if args.key?(:reconciliation_mode)
@request_id = args[:request_id] if args.key?(:request_id)
@update_mask = args[:update_mask] if args.key?(:update_mask)
end
end
# Response of the ImportProductsRequest. If the long running operation is done,
# then this message is returned by the google.longrunning.Operations.response
# field if the operation was successful.
class GoogleCloudRetailV2ImportProductsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ImportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Request message for the ImportUserEvents request.
class GoogleCloudRetailV2ImportUserEventsRequest
include Google::Apis::Core::Hashable
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ImportErrorsConfig]
attr_accessor :errors_config
# The input config source for user events.
# Corresponds to the JSON property `inputConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserEventInputConfig]
attr_accessor :input_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@errors_config = args[:errors_config] if args.key?(:errors_config)
@input_config = args[:input_config] if args.key?(:input_config)
end
end
# Response of the ImportUserEventsRequest. If the long running operation was
# successful, then this message is returned by the google.longrunning.Operations.
# response field if the operation was successful.
class GoogleCloudRetailV2ImportUserEventsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ImportErrorsConfig]
attr_accessor :errors_config
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
# Corresponds to the JSON property `importSummary`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserEventImportSummary]
attr_accessor :import_summary
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
@import_summary = args[:import_summary] if args.key?(:import_summary)
end
end
# A floating point interval.
class GoogleCloudRetailV2Interval
include Google::Apis::Core::Hashable
# Exclusive upper bound.
# Corresponds to the JSON property `exclusiveMaximum`
# @return [Float]
attr_accessor :exclusive_maximum
# Exclusive lower bound.
# Corresponds to the JSON property `exclusiveMinimum`
# @return [Float]
attr_accessor :exclusive_minimum
# Inclusive upper bound.
# Corresponds to the JSON property `maximum`
# @return [Float]
attr_accessor :maximum
# Inclusive lower bound.
# Corresponds to the JSON property `minimum`
# @return [Float]
attr_accessor :minimum
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@exclusive_maximum = args[:exclusive_maximum] if args.key?(:exclusive_maximum)
@exclusive_minimum = args[:exclusive_minimum] if args.key?(:exclusive_minimum)
@maximum = args[:maximum] if args.key?(:maximum)
@minimum = args[:minimum] if args.key?(:minimum)
end
end
# Response for CatalogService.ListCatalogs method.
class GoogleCloudRetailV2ListCatalogsResponse
include Google::Apis::Core::Hashable
# All the customer's Catalogs.
# Corresponds to the JSON property `catalogs`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Catalog>]
attr_accessor :catalogs
# A token that can be sent as ListCatalogsRequest.page_token to retrieve the
# next page. If this field is omitted, there are no subsequent pages.
# 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)
@catalogs = args[:catalogs] if args.key?(:catalogs)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
end
end
# Response message for ProductService.ListProducts method.
class GoogleCloudRetailV2ListProductsResponse
include Google::Apis::Core::Hashable
# A token that can be sent as ListProductsRequest.page_token to retrieve the
# next page. If this field is omitted, there are no subsequent pages.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# The Products.
# Corresponds to the JSON property `products`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Product>]
attr_accessor :products
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
@products = args[:products] if args.key?(:products)
end
end
# The inventory information at a place (e.g. a store) identified by a place ID.
class GoogleCloudRetailV2LocalInventory
include Google::Apis::Core::Hashable
# Additional local inventory attributes, for example, store name, promotion tags,
# etc. This field needs to pass all below criteria, otherwise an
# INVALID_ARGUMENT error is returned: * At most 30 attributes are allowed. * The
# key must be a UTF-8 encoded string with a length limit of 32 characters. * The
# key must match the pattern: `a-zA-Z0-9*`. For example, key0LikeThis or
# KEY_1_LIKE_THIS. * The attribute values must be of the same type (text or
# number). * Only 1 value is allowed for each attribute. * For text values, the
# length limit is 256 UTF-8 characters. * The attribute does not support search.
# The `searchable` field should be unset or set to false. * The max summed total
# bytes of custom attribute keys and values per product is 5MiB.
# Corresponds to the JSON property `attributes`
# @return [Hash<String,Google::Apis::RetailV2::GoogleCloudRetailV2CustomAttribute>]
attr_accessor :attributes
# Input only. Supported fulfillment types. Valid fulfillment type values include
# commonly used types (such as pickup in store and same day delivery), and
# custom types. Customers have to map custom types to their display names before
# rendering UI. Supported values: * "pickup-in-store" * "ship-to-store" * "same-
# day-delivery" * "next-day-delivery" * "custom-type-1" * "custom-type-2" * "
# custom-type-3" * "custom-type-4" * "custom-type-5" If this field is set to an
# invalid value other than these, an INVALID_ARGUMENT error is returned. All the
# elements must be distinct. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `fulfillmentTypes`
# @return [Array<String>]
attr_accessor :fulfillment_types
# The place ID for the current set of inventory information.
# Corresponds to the JSON property `placeId`
# @return [String]
attr_accessor :place_id
# The price information of a Product.
# Corresponds to the JSON property `priceInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2PriceInfo]
attr_accessor :price_info
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attributes = args[:attributes] if args.key?(:attributes)
@fulfillment_types = args[:fulfillment_types] if args.key?(:fulfillment_types)
@place_id = args[:place_id] if args.key?(:place_id)
@price_info = args[:price_info] if args.key?(:price_info)
end
end
# Request message for Predict method.
class GoogleCloudRetailV2PredictRequest
include Google::Apis::Core::Hashable
# Filter for restricting prediction results with a length limit of 5,000
# characters. Accepts values for tags and the `filterOutOfStockItems` flag. *
# Tag expressions. Restricts predictions to products that match all of the
# specified tags. Boolean operators `OR` and `NOT` are supported if the
# expression is enclosed in parentheses, and must be separated from the tag
# values by a space. `-"tagA"` is also supported and is equivalent to `NOT "tagA"
# `. Tag values must be double quoted UTF-8 encoded strings with a size limit of
# 1,000 characters. Note: "Recently viewed" models don't support tag filtering
# at the moment. * filterOutOfStockItems. Restricts predictions to products that
# do not have a stockState value of OUT_OF_STOCK. Examples: * tag=("Red" OR "
# Blue") tag="New-Arrival" tag=(NOT "promotional") * filterOutOfStockItems tag=(-
# "promotional") * filterOutOfStockItems If your filter blocks all prediction
# results, the API will return generic (unfiltered) popular products. If you
# only want results strictly matching the filters, set `strictFiltering` to True
# in `PredictRequest.params` to receive empty results instead. Note that the API
# will never return items with storageStatus of "EXPIRED" or "DELETED"
# regardless of filter choices.
# Corresponds to the JSON property `filter`
# @return [String]
attr_accessor :filter
# The labels applied to a resource must meet the following requirements: * Each
# resource can have multiple labels, up to a maximum of 64. * Each label must be
# a key-value pair. * Keys have a minimum length of 1 character and a maximum
# length of 63 characters, and cannot be empty. Values can be empty, and have a
# maximum length of 63 characters. * Keys and values can contain only lowercase
# letters, numeric characters, underscores, and dashes. All characters must use
# UTF-8 encoding, and international characters are allowed. * The key portion of
# a label must be unique. However, you can use the same key with multiple
# resources. * Keys must start with a lowercase letter or international
# character. See [Google Cloud Document](https://cloud.google.com/resource-
# manager/docs/creating-managing-labels#requirements) for more details.
# Corresponds to the JSON property `labels`
# @return [Hash<String,String>]
attr_accessor :labels
# Maximum number of results to return per page. Set this property to the number
# of prediction results needed. If zero, the service will choose a reasonable
# default. The maximum allowed value is 100. Values above 100 will be coerced to
# 100.
# Corresponds to the JSON property `pageSize`
# @return [Fixnum]
attr_accessor :page_size
# The previous PredictResponse.next_page_token.
# Corresponds to the JSON property `pageToken`
# @return [String]
attr_accessor :page_token
# Additional domain specific parameters for the predictions. Allowed values: * `
# returnProduct`: Boolean. If set to true, the associated product object will be
# returned in the `results.metadata` field in the prediction response. * `
# returnScore`: Boolean. If set to true, the prediction 'score' corresponding to
# each returned product will be set in the `results.metadata` field in the
# prediction response. The given 'score' indicates the probability of an product
# being clicked/purchased given the user's context and history. * `
# strictFiltering`: Boolean. True by default. If set to false, the service will
# return generic (unfiltered) popular products instead of empty if your filter
# blocks all prediction results. * `priceRerankLevel`: String. Default empty. If
# set to be non-empty, then it needs to be one of `'no-price-reranking', 'low-
# price-reranking', 'medium-price-reranking', 'high-price-reranking'`. This
# gives request-level control and adjusts prediction results based on product
# price. * `diversityLevel`: String. Default empty. If set to be non-empty, then
# it needs to be one of `'no-diversity', 'low-diversity', 'medium-diversity', '
# high-diversity', 'auto-diversity'`. This gives request-level control and
# adjusts prediction results based on product category.
# Corresponds to the JSON property `params`
# @return [Hash<String,Object>]
attr_accessor :params
# UserEvent captures all metadata information Retail API needs to know about how
# end users interact with customers' website.
# Corresponds to the JSON property `userEvent`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserEvent]
attr_accessor :user_event
# Use validate only mode for this prediction query. If set to true, a dummy
# model will be used that returns arbitrary products. Note that the validate
# only mode should only be used for testing the API, or if the model is not
# ready.
# Corresponds to the JSON property `validateOnly`
# @return [Boolean]
attr_accessor :validate_only
alias_method :validate_only?, :validate_only
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@filter = args[:filter] if args.key?(:filter)
@labels = args[:labels] if args.key?(:labels)
@page_size = args[:page_size] if args.key?(:page_size)
@page_token = args[:page_token] if args.key?(:page_token)
@params = args[:params] if args.key?(:params)
@user_event = args[:user_event] if args.key?(:user_event)
@validate_only = args[:validate_only] if args.key?(:validate_only)
end
end
# Response message for predict method.
class GoogleCloudRetailV2PredictResponse
include Google::Apis::Core::Hashable
# A unique attribution token. This should be included in the UserEvent logs
# resulting from this recommendation, which enables accurate attribution of
# recommendation model performance.
# Corresponds to the JSON property `attributionToken`
# @return [String]
attr_accessor :attribution_token
# IDs of products in the request that were missing from the inventory.
# Corresponds to the JSON property `missingIds`
# @return [Array<String>]
attr_accessor :missing_ids
# A list of recommended products. The order represents the ranking (from the
# most relevant product to the least).
# Corresponds to the JSON property `results`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2PredictResponsePredictionResult>]
attr_accessor :results
# True if the validateOnly property was set in the request.
# Corresponds to the JSON property `validateOnly`
# @return [Boolean]
attr_accessor :validate_only
alias_method :validate_only?, :validate_only
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attribution_token = args[:attribution_token] if args.key?(:attribution_token)
@missing_ids = args[:missing_ids] if args.key?(:missing_ids)
@results = args[:results] if args.key?(:results)
@validate_only = args[:validate_only] if args.key?(:validate_only)
end
end
# PredictionResult represents the recommendation prediction results.
class GoogleCloudRetailV2PredictResponsePredictionResult
include Google::Apis::Core::Hashable
# ID of the recommended product
# Corresponds to the JSON property `id`
# @return [String]
attr_accessor :id
# Additional product metadata / annotations. Possible values: * `product`: JSON
# representation of the product. Will be set if `returnProduct` is set to true
# in `PredictRequest.params`. * `score`: Prediction score in double value. Will
# be set if `returnScore` is set to true in `PredictRequest.params`.
# Corresponds to the JSON property `metadata`
# @return [Hash<String,Object>]
attr_accessor :metadata
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@id = args[:id] if args.key?(:id)
@metadata = args[:metadata] if args.key?(:metadata)
end
end
# The price information of a Product.
class GoogleCloudRetailV2PriceInfo
include Google::Apis::Core::Hashable
# The costs associated with the sale of a particular product. Used for gross
# profit reporting. * Profit = price - cost Google Merchant Center property [
# cost_of_goods_sold](https://support.google.com/merchants/answer/9017895).
# Corresponds to the JSON property `cost`
# @return [Float]
attr_accessor :cost
# The 3-letter currency code defined in [ISO 4217](https://www.iso.org/iso-4217-
# currency-codes.html). If this field is an unrecognizable currency code, an
# INVALID_ARGUMENT error is returned. The Product.Type.VARIANT Products with the
# same Product.primary_product_id must share the same currency_code. Otherwise,
# a FAILED_PRECONDITION error is returned.
# Corresponds to the JSON property `currencyCode`
# @return [String]
attr_accessor :currency_code
# Price of the product without any discount. If zero, by default set to be the
# price.
# Corresponds to the JSON property `originalPrice`
# @return [Float]
attr_accessor :original_price
# Price of the product. Google Merchant Center property [price](https://support.
# google.com/merchants/answer/6324371). Schema.org property [Offer.price](https:/
# /schema.org/price).
# Corresponds to the JSON property `price`
# @return [Float]
attr_accessor :price
# The timestamp when the price starts to be effective. This can be set as a
# future timestamp, and the price is only used for search after
# price_effective_time. If so, the original_price must be set and original_price
# is used before price_effective_time. Do not set if price is always effective
# because it will cause additional latency during search.
# Corresponds to the JSON property `priceEffectiveTime`
# @return [String]
attr_accessor :price_effective_time
# The timestamp when the price stops to be effective. The price is used for
# search before price_expire_time. If this field is set, the original_price must
# be set and original_price is used after price_expire_time. Do not set if price
# is always effective because it will cause additional latency during search.
# Corresponds to the JSON property `priceExpireTime`
# @return [String]
attr_accessor :price_expire_time
# The price range of all variant Product having the same Product.
# primary_product_id.
# Corresponds to the JSON property `priceRange`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2PriceInfoPriceRange]
attr_accessor :price_range
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@cost = args[:cost] if args.key?(:cost)
@currency_code = args[:currency_code] if args.key?(:currency_code)
@original_price = args[:original_price] if args.key?(:original_price)
@price = args[:price] if args.key?(:price)
@price_effective_time = args[:price_effective_time] if args.key?(:price_effective_time)
@price_expire_time = args[:price_expire_time] if args.key?(:price_expire_time)
@price_range = args[:price_range] if args.key?(:price_range)
end
end
# The price range of all variant Product having the same Product.
# primary_product_id.
class GoogleCloudRetailV2PriceInfoPriceRange
include Google::Apis::Core::Hashable
# A floating point interval.
# Corresponds to the JSON property `originalPrice`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Interval]
attr_accessor :original_price
# A floating point interval.
# Corresponds to the JSON property `price`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Interval]
attr_accessor :price
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@original_price = args[:original_price] if args.key?(:original_price)
@price = args[:price] if args.key?(:price)
end
end
# Product captures all metadata information of items to be recommended or
# searched.
class GoogleCloudRetailV2Product
include Google::Apis::Core::Hashable
# Highly encouraged. Extra product attributes to be included. For example, for
# products, this could include the store name, vendor, style, color, etc. These
# are very strong signals for recommendation model, thus we highly recommend
# providing the attributes here. Features that can take on one of a limited
# number of possible values. Two types of features can be set are: Textual
# features. some examples would be the brand/maker of a product, or country of a
# customer. Numerical features. Some examples would be the height/weight of a
# product, or age of a customer. For example: `` "vendor": `"text": ["vendor123",
# "vendor456"]`, "lengths_cm": `"numbers":[2.3, 15.4]`, "heights_cm": `"numbers"
# :[8.1, 6.4]` ``. This field needs to pass all below criteria, otherwise an
# INVALID_ARGUMENT error is returned: * Max entries count: 200. * The key must
# be a UTF-8 encoded string with a length limit of 128 characters. * For
# indexable attribute, the key must match the pattern: `a-zA-Z0-9*`. For example,
# `key0LikeThis` or `KEY_1_LIKE_THIS`. * For text attributes, at most 400
# values are allowed. Empty values are not allowed. Each value must be a non-
# empty UTF-8 encoded string with a length limit of 256 characters. * For number
# attributes, at most 400 values are allowed.
# Corresponds to the JSON property `attributes`
# @return [Hash<String,Google::Apis::RetailV2::GoogleCloudRetailV2CustomAttribute>]
attr_accessor :attributes
# An intended audience of the Product for whom it's sold.
# Corresponds to the JSON property `audience`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Audience]
attr_accessor :audience
# The online availability of the Product. Default to Availability.IN_STOCK.
# Corresponding properties: Google Merchant Center property [availability](https:
# //support.google.com/merchants/answer/6324448). Schema.org property [Offer.
# availability](https://schema.org/availability).
# Corresponds to the JSON property `availability`
# @return [String]
attr_accessor :availability
# The available quantity of the item.
# Corresponds to the JSON property `availableQuantity`
# @return [Fixnum]
attr_accessor :available_quantity
# The timestamp when this Product becomes available for SearchService.Search.
# Corresponds to the JSON property `availableTime`
# @return [String]
attr_accessor :available_time
# The brands of the product. A maximum of 30 brands are allowed. Each brand must
# be a UTF-8 encoded string with a length limit of 1,000 characters. Otherwise,
# an INVALID_ARGUMENT error is returned. Corresponding properties: Google
# Merchant Center property [brand](https://support.google.com/merchants/answer/
# 6324351). Schema.org property [Product.brand](https://schema.org/brand).
# Corresponds to the JSON property `brands`
# @return [Array<String>]
attr_accessor :brands
# Product categories. This field is repeated for supporting one product
# belonging to several parallel categories. Strongly recommended using the full
# path for better search / recommendation quality. To represent full path of
# category, use '>' sign to separate different hierarchies. If '>' is part of
# the category name, please replace it with other character(s). For example, if
# a shoes product belongs to both ["Shoes & Accessories" -> "Shoes"] and ["
# Sports & Fitness" -> "Athletic Clothing" -> "Shoes"], it could be represented
# as: "categories": [ "Shoes & Accessories > Shoes", "Sports & Fitness >
# Athletic Clothing > Shoes" ] Must be set for Type.PRIMARY Product otherwise an
# INVALID_ARGUMENT error is returned. At most 250 values are allowed per Product.
# Empty values are not allowed. Each value must be a UTF-8 encoded string with
# a length limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. Corresponding properties: Google Merchant Center property
# google_product_category. Schema.org property [Product.category] (https://
# schema.org/category). [mc_google_product_category]: https://support.google.com/
# merchants/answer/6324436
# Corresponds to the JSON property `categories`
# @return [Array<String>]
attr_accessor :categories
# The id of the collection members when type is Type.COLLECTION. Non-existent
# product ids are allowed. The type of the members must be either Type.PRIMARY
# or Type.VARIANT otherwise and INVALID_ARGUMENT error is thrown. Should not set
# it for other types. A maximum of 1000 values are allowed. Otherwise, an
# INVALID_ARGUMENT error is return.
# Corresponds to the JSON property `collectionMemberIds`
# @return [Array<String>]
attr_accessor :collection_member_ids
# The color information of a Product.
# Corresponds to the JSON property `colorInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ColorInfo]
attr_accessor :color_info
# The condition of the product. Strongly encouraged to use the standard values: "
# new", "refurbished", "used". A maximum of 1 value is allowed per Product. Each
# value must be a UTF-8 encoded string with a length limit of 128 characters.
# Otherwise, an INVALID_ARGUMENT error is returned. Corresponding properties:
# Google Merchant Center property [condition](https://support.google.com/
# merchants/answer/6324469). Schema.org property [Offer.itemCondition](https://
# schema.org/itemCondition).
# Corresponds to the JSON property `conditions`
# @return [Array<String>]
attr_accessor :conditions
# Product description. This field must be a UTF-8 encoded string with a length
# limit of 5,000 characters. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponding properties: Google Merchant Center property [description](https:/
# /support.google.com/merchants/answer/6324468). Schema.org property [Product.
# description](https://schema.org/description).
# Corresponds to the JSON property `description`
# @return [String]
attr_accessor :description
# The timestamp when this product becomes unavailable for SearchService.Search.
# If it is set, the Product is not available for SearchService.Search after
# expire_time. However, the product can still be retrieved by ProductService.
# GetProduct and ProductService.ListProducts. expire_time must be later than
# available_time and publish_time, otherwise an INVALID_ARGUMENT error is thrown.
# Corresponding properties: Google Merchant Center property [expiration_date](
# https://support.google.com/merchants/answer/6324499).
# Corresponds to the JSON property `expireTime`
# @return [String]
attr_accessor :expire_time
# Fulfillment information, such as the store IDs for in-store pickup or region
# IDs for different shipping methods. All the elements must have distinct
# FulfillmentInfo.type. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `fulfillmentInfo`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2FulfillmentInfo>]
attr_accessor :fulfillment_info
# The Global Trade Item Number (GTIN) of the product. This field must be a UTF-8
# encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned. This field must be a Unigram. Otherwise,
# an INVALID_ARGUMENT error is returned. Corresponding properties: Google
# Merchant Center property [gtin](https://support.google.com/merchants/answer/
# 6324461). Schema.org property [Product.isbn](https://schema.org/isbn), [
# Product.gtin8](https://schema.org/gtin8), [Product.gtin12](https://schema.org/
# gtin12), [Product.gtin13](https://schema.org/gtin13), or [Product.gtin14](
# https://schema.org/gtin14). If the value is not a valid GTIN, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `gtin`
# @return [String]
attr_accessor :gtin
# Immutable. Product identifier, which is the final component of name. For
# example, this field is "id_1", if name is `projects/*/locations/global/
# catalogs/default_catalog/branches/default_branch/products/id_1`. This field
# must be a UTF-8 encoded string with a length limit of 128 characters.
# Otherwise, an INVALID_ARGUMENT error is returned. Corresponding properties:
# Google Merchant Center property [id](https://support.google.com/merchants/
# answer/6324405). Schema.org property [Product.sku](https://schema.org/sku).
# Corresponds to the JSON property `id`
# @return [String]
attr_accessor :id
# Product images for the product. We highly recommend putting the main image
# first. A maximum of 300 images are allowed. Corresponding properties: Google
# Merchant Center property [image_link](https://support.google.com/merchants/
# answer/6324350). Schema.org property [Product.image](https://schema.org/image).
# Corresponds to the JSON property `images`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Image>]
attr_accessor :images
# Language of the title/description and other string attributes. Use language
# tags defined by [BCP 47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt). For
# product prediction, this field is ignored and the model automatically detects
# the text language. The Product can include text in different languages, but
# duplicating Products to provide text in multiple languages can result in
# degraded model performance. For product search this field is in use. It
# defaults to "en-US" if unset.
# Corresponds to the JSON property `languageCode`
# @return [String]
attr_accessor :language_code
# The material of the product. For example, "leather", "wooden". A maximum of 20
# values are allowed. Each value must be a UTF-8 encoded string with a length
# limit of 200 characters. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponding properties: Google Merchant Center property [material](https://
# support.google.com/merchants/answer/6324410). Schema.org property [Product.
# material](https://schema.org/material).
# Corresponds to the JSON property `materials`
# @return [Array<String>]
attr_accessor :materials
# Immutable. Full resource name of the product, such as `projects/*/locations/
# global/catalogs/default_catalog/branches/default_branch/products/product_id`.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# The pattern or graphic print of the product. For example, "striped", "polka
# dot", "paisley". A maximum of 20 values are allowed per Product. Each value
# must be a UTF-8 encoded string with a length limit of 128 characters.
# Otherwise, an INVALID_ARGUMENT error is returned. Corresponding properties:
# Google Merchant Center property [pattern](https://support.google.com/merchants/
# answer/6324483). Schema.org property [Product.pattern](https://schema.org/
# pattern).
# Corresponds to the JSON property `patterns`
# @return [Array<String>]
attr_accessor :patterns
# The price information of a Product.
# Corresponds to the JSON property `priceInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2PriceInfo]
attr_accessor :price_info
# Variant group identifier. Must be an id, with the same parent branch with this
# product. Otherwise, an error is thrown. For Type.PRIMARY Products, this field
# can only be empty or set to the same value as id. For VARIANT Products, this
# field cannot be empty. A maximum of 2,000 products are allowed to share the
# same Type.PRIMARY Product. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponding properties: Google Merchant Center property [item_group_id](
# https://support.google.com/merchants/answer/6324507). Schema.org property [
# Product.inProductGroupWithID](https://schema.org/inProductGroupWithID).
# Corresponds to the JSON property `primaryProductId`
# @return [String]
attr_accessor :primary_product_id
# The promotions applied to the product. A maximum of 10 values are allowed per
# Product. Only Promotion.promotion_id will be used, other fields will be
# ignored if set.
# Corresponds to the JSON property `promotions`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Promotion>]
attr_accessor :promotions
# The timestamp when the product is published by the retailer for the first time,
# which indicates the freshness of the products. Note that this field is
# different from available_time, given it purely describes product freshness
# regardless of when it is available on search and recommendation.
# Corresponds to the JSON property `publishTime`
# @return [String]
attr_accessor :publish_time
# The rating of a Product.
# Corresponds to the JSON property `rating`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Rating]
attr_accessor :rating
# Indicates which fields in the Products are returned in SearchResponse.
# Supported fields for all types: * audience * availability * brands *
# color_info * conditions * gtin * materials * name * patterns * price_info *
# rating * sizes * title * uri Supported fields only for Type.PRIMARY and Type.
# COLLECTION: * categories * description * images Supported fields only for Type.
# VARIANT: * Only the first image in images To mark attributes as retrievable,
# include paths of the form "attributes.key" where "key" is the key of a custom
# attribute, as specified in attributes. For Type.PRIMARY and Type.COLLECTION,
# the following fields are always returned in SearchResponse by default: * name
# For Type.VARIANT, the following fields are always returned in by default: *
# name * color_info Maximum number of paths is 30. Otherwise, an
# INVALID_ARGUMENT error is returned. Note: Returning more fields in
# SearchResponse may increase response payload size and serving latency.
# Corresponds to the JSON property `retrievableFields`
# @return [String]
attr_accessor :retrievable_fields
# The size of the product. To represent different size systems or size types,
# consider using this format: [[[size_system:]size_type:]size_value]. For
# example, in "US:MENS:M", "US" represents size system; "MENS" represents size
# type; "M" represents size value. In "GIRLS:27", size system is empty; "GIRLS"
# represents size type; "27" represents size value. In "32 inches", both size
# system and size type are empty, while size value is "32 inches". A maximum of
# 20 values are allowed per Product. Each value must be a UTF-8 encoded string
# with a length limit of 128 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. Corresponding properties: Google Merchant Center property [size](
# https://support.google.com/merchants/answer/6324492), [size_type](https://
# support.google.com/merchants/answer/6324497), and [size_system](https://
# support.google.com/merchants/answer/6324502). Schema.org property [Product.
# size](https://schema.org/size).
# Corresponds to the JSON property `sizes`
# @return [Array<String>]
attr_accessor :sizes
# Custom tags associated with the product. At most 250 values are allowed per
# Product. This value must be a UTF-8 encoded string with a length limit of 1,
# 000 characters. Otherwise, an INVALID_ARGUMENT error is returned. This tag can
# be used for filtering recommendation results by passing the tag as part of the
# PredictRequest.filter. Corresponding properties: Google Merchant Center
# property [custom_label_04](https://support.google.com/merchants/answer/
# 6324473).
# Corresponds to the JSON property `tags`
# @return [Array<String>]
attr_accessor :tags
# Required. Product title. This field must be a UTF-8 encoded string with a
# length limit of 1,000 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. Corresponding properties: Google Merchant Center property [title](
# https://support.google.com/merchants/answer/6324415). Schema.org property [
# Product.name](https://schema.org/name).
# Corresponds to the JSON property `title`
# @return [String]
attr_accessor :title
# Input only. The TTL (time to live) of the product. If it is set, it must be a
# non-negative value, and expire_time is set as current timestamp plus ttl. The
# derived expire_time is returned in the output and ttl is left blank when
# retrieving the Product. If it is set, the product is not available for
# SearchService.Search after current timestamp plus ttl. However, the product
# can still be retrieved by ProductService.GetProduct and ProductService.
# ListProducts.
# Corresponds to the JSON property `ttl`
# @return [String]
attr_accessor :ttl
# Immutable. The type of the product. Default to Catalog.product_level_config.
# ingestion_product_type if unset.
# Corresponds to the JSON property `type`
# @return [String]
attr_accessor :type
# Canonical URL directly linking to the product detail page. It is strongly
# recommended to provide a valid uri for the product, otherwise the service
# performance could be significantly degraded. This field must be a UTF-8
# encoded string with a length limit of 5,000 characters. Otherwise, an
# INVALID_ARGUMENT error is returned. Corresponding properties: Google Merchant
# Center property [link](https://support.google.com/merchants/answer/6324416).
# Schema.org property [Offer.url](https://schema.org/url).
# Corresponds to the JSON property `uri`
# @return [String]
attr_accessor :uri
# Output only. Product variants grouped together on primary product which share
# similar product attributes. It's automatically grouped by primary_product_id
# for all the product variants. Only populated for Type.PRIMARY Products. Note:
# This field is OUTPUT_ONLY for ProductService.GetProduct. Do not set this field
# in API requests.
# Corresponds to the JSON property `variants`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Product>]
attr_accessor :variants
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attributes = args[:attributes] if args.key?(:attributes)
@audience = args[:audience] if args.key?(:audience)
@availability = args[:availability] if args.key?(:availability)
@available_quantity = args[:available_quantity] if args.key?(:available_quantity)
@available_time = args[:available_time] if args.key?(:available_time)
@brands = args[:brands] if args.key?(:brands)
@categories = args[:categories] if args.key?(:categories)
@collection_member_ids = args[:collection_member_ids] if args.key?(:collection_member_ids)
@color_info = args[:color_info] if args.key?(:color_info)
@conditions = args[:conditions] if args.key?(:conditions)
@description = args[:description] if args.key?(:description)
@expire_time = args[:expire_time] if args.key?(:expire_time)
@fulfillment_info = args[:fulfillment_info] if args.key?(:fulfillment_info)
@gtin = args[:gtin] if args.key?(:gtin)
@id = args[:id] if args.key?(:id)
@images = args[:images] if args.key?(:images)
@language_code = args[:language_code] if args.key?(:language_code)
@materials = args[:materials] if args.key?(:materials)
@name = args[:name] if args.key?(:name)
@patterns = args[:patterns] if args.key?(:patterns)
@price_info = args[:price_info] if args.key?(:price_info)
@primary_product_id = args[:primary_product_id] if args.key?(:primary_product_id)
@promotions = args[:promotions] if args.key?(:promotions)
@publish_time = args[:publish_time] if args.key?(:publish_time)
@rating = args[:rating] if args.key?(:rating)
@retrievable_fields = args[:retrievable_fields] if args.key?(:retrievable_fields)
@sizes = args[:sizes] if args.key?(:sizes)
@tags = args[:tags] if args.key?(:tags)
@title = args[:title] if args.key?(:title)
@ttl = args[:ttl] if args.key?(:ttl)
@type = args[:type] if args.key?(:type)
@uri = args[:uri] if args.key?(:uri)
@variants = args[:variants] if args.key?(:variants)
end
end
# Detailed product information associated with a user event.
class GoogleCloudRetailV2ProductDetail
include Google::Apis::Core::Hashable
# Product captures all metadata information of items to be recommended or
# searched.
# Corresponds to the JSON property `product`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Product]
attr_accessor :product
# Quantity of the product associated with the user event. For example, this
# field will be 2 if two products are added to the shopping cart for `purchase-
# complete` event. Required for `add-to-cart` and `purchase-complete` event
# types.
# Corresponds to the JSON property `quantity`
# @return [Fixnum]
attr_accessor :quantity
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@product = args[:product] if args.key?(:product)
@quantity = args[:quantity] if args.key?(:quantity)
end
end
# The inline source for the input config for ImportProducts method.
class GoogleCloudRetailV2ProductInlineSource
include Google::Apis::Core::Hashable
# Required. A list of products to update/create. Each product must have a valid
# Product.id. Recommended max of 100 items.
# Corresponds to the JSON property `products`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Product>]
attr_accessor :products
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@products = args[:products] if args.key?(:products)
end
end
# The input config source for products.
class GoogleCloudRetailV2ProductInputConfig
include Google::Apis::Core::Hashable
# BigQuery source import data from.
# Corresponds to the JSON property `bigQuerySource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2BigQuerySource]
attr_accessor :big_query_source
# Google Cloud Storage location for input content. format.
# Corresponds to the JSON property `gcsSource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2GcsSource]
attr_accessor :gcs_source
# The inline source for the input config for ImportProducts method.
# Corresponds to the JSON property `productInlineSource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2ProductInlineSource]
attr_accessor :product_inline_source
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@big_query_source = args[:big_query_source] if args.key?(:big_query_source)
@gcs_source = args[:gcs_source] if args.key?(:gcs_source)
@product_inline_source = args[:product_inline_source] if args.key?(:product_inline_source)
end
end
# Configures what level the product should be uploaded with regards to how users
# will be send events and how predictions will be made.
class GoogleCloudRetailV2ProductLevelConfig
include Google::Apis::Core::Hashable
# The type of Products allowed to be ingested into the catalog. Acceptable
# values are: * `primary` (default): You can ingest Products of all types. When
# ingesting a Product, its type will default to Product.Type.PRIMARY if unset. *
# `variant`: You can only ingest Product.Type.VARIANT Products. This means
# Product.primary_product_id cannot be empty. If this field is set to an invalid
# value other than these, an INVALID_ARGUMENT error is returned. If this field
# is `variant` and merchant_center_product_id_field is `itemGroupId`, an
# INVALID_ARGUMENT error is returned. See [Using product levels](https://cloud.
# google.com/retail/recommendations-ai/docs/catalog#product-levels) for more
# details.
# Corresponds to the JSON property `ingestionProductType`
# @return [String]
attr_accessor :ingestion_product_type
# Which field of [Merchant Center Product](/bigquery-transfer/docs/merchant-
# center-products-schema) should be imported as Product.id. Acceptable values
# are: * `offerId` (default): Import `offerId` as the product ID. * `itemGroupId`
# : Import `itemGroupId` as the product ID. Notice that Retail API will choose
# one item from the ones with the same `itemGroupId`, and use it to represent
# the item group. If this field is set to an invalid value other than these, an
# INVALID_ARGUMENT error is returned. If this field is `itemGroupId` and
# ingestion_product_type is `variant`, an INVALID_ARGUMENT error is returned.
# See [Using product levels](https://cloud.google.com/retail/recommendations-ai/
# docs/catalog#product-levels) for more details.
# Corresponds to the JSON property `merchantCenterProductIdField`
# @return [String]
attr_accessor :merchant_center_product_id_field
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@ingestion_product_type = args[:ingestion_product_type] if args.key?(:ingestion_product_type)
@merchant_center_product_id_field = args[:merchant_center_product_id_field] if args.key?(:merchant_center_product_id_field)
end
end
# Promotion information.
class GoogleCloudRetailV2Promotion
include Google::Apis::Core::Hashable
# ID of the promotion. For example, "free gift". The value must be a UTF-8
# encoded string with a length limit of 128 characters, and match the pattern: `
# a-zA-Z*`. For example, id0LikeThis or ID_1_LIKE_THIS. Otherwise, an
# INVALID_ARGUMENT error is returned. Google Merchant Center property [promotion]
# (https://support.google.com/merchants/answer/7050148).
# Corresponds to the JSON property `promotionId`
# @return [String]
attr_accessor :promotion_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@promotion_id = args[:promotion_id] if args.key?(:promotion_id)
end
end
# A transaction represents the entire purchase transaction.
class GoogleCloudRetailV2PurchaseTransaction
include Google::Apis::Core::Hashable
# All the costs associated with the products. These can be manufacturing costs,
# shipping expenses not borne by the end user, or any other costs, such that: *
# Profit = revenue - tax - cost
# Corresponds to the JSON property `cost`
# @return [Float]
attr_accessor :cost
# Required. Currency code. Use three-character ISO-4217 code.
# Corresponds to the JSON property `currencyCode`
# @return [String]
attr_accessor :currency_code
# The transaction ID with a length limit of 128 characters.
# Corresponds to the JSON property `id`
# @return [String]
attr_accessor :id
# Required. Total non-zero revenue or grand total associated with the
# transaction. This value include shipping, tax, or other adjustments to total
# revenue that you want to include as part of your revenue calculations.
# Corresponds to the JSON property `revenue`
# @return [Float]
attr_accessor :revenue
# All the taxes associated with the transaction.
# Corresponds to the JSON property `tax`
# @return [Float]
attr_accessor :tax
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@cost = args[:cost] if args.key?(:cost)
@currency_code = args[:currency_code] if args.key?(:currency_code)
@id = args[:id] if args.key?(:id)
@revenue = args[:revenue] if args.key?(:revenue)
@tax = args[:tax] if args.key?(:tax)
end
end
# Metadata related to the progress of the Purge operation. This will be returned
# by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2PurgeMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for PurgeUserEvents method.
class GoogleCloudRetailV2PurgeUserEventsRequest
include Google::Apis::Core::Hashable
# Required. The filter string to specify the events to be deleted with a length
# limit of 5,000 characters. Empty string filter is not allowed. The eligible
# fields for filtering are: * `eventType`: Double quoted UserEvent.event_type
# string. * `eventTime`: in ISO 8601 "zulu" format. * `visitorId`: Double quoted
# string. Specifying this will delete all events associated with a visitor. * `
# userId`: Double quoted string. Specifying this will delete all events
# associated with a user. Examples: * Deleting all events in a time range: `
# eventTime > "2012-04-23T18:25:43.511Z" eventTime < "2012-04-23T18:30:43.511Z"`
# * Deleting specific eventType in time range: `eventTime > "2012-04-23T18:25:43.
# 511Z" eventType = "detail-page-view"` * Deleting all events for a specific
# visitor: `visitorId = "visitor1024"` The filtering fields are assumed to have
# an implicit AND.
# Corresponds to the JSON property `filter`
# @return [String]
attr_accessor :filter
# Actually perform the purge. If `force` is set to false, the method will return
# the expected purge count without deleting any user events.
# Corresponds to the JSON property `force`
# @return [Boolean]
attr_accessor :force
alias_method :force?, :force
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@filter = args[:filter] if args.key?(:filter)
@force = args[:force] if args.key?(:force)
end
end
# Response of the PurgeUserEventsRequest. If the long running operation is
# successfully done, then this message is returned by the google.longrunning.
# Operations.response field.
class GoogleCloudRetailV2PurgeUserEventsResponse
include Google::Apis::Core::Hashable
# The total count of events purged as a result of the operation.
# Corresponds to the JSON property `purgedEventsCount`
# @return [Fixnum]
attr_accessor :purged_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@purged_events_count = args[:purged_events_count] if args.key?(:purged_events_count)
end
end
# The rating of a Product.
class GoogleCloudRetailV2Rating
include Google::Apis::Core::Hashable
# The average rating of the Product. The rating is scaled at 1-5. Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `averageRating`
# @return [Float]
attr_accessor :average_rating
# The total number of ratings. This value is independent of the value of
# rating_histogram. This value must be nonnegative. Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `ratingCount`
# @return [Fixnum]
attr_accessor :rating_count
# List of rating counts per rating value (index = rating - 1). The list is empty
# if there is no rating. If the list is non-empty, its size is always 5.
# Otherwise, an INVALID_ARGUMENT error is returned. For example, [41, 14, 13, 47,
# 303]. It means that the Product got 41 ratings with 1 star, 14 ratings with 2
# star, and so on.
# Corresponds to the JSON property `ratingHistogram`
# @return [Array<Fixnum>]
attr_accessor :rating_histogram
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@average_rating = args[:average_rating] if args.key?(:average_rating)
@rating_count = args[:rating_count] if args.key?(:rating_count)
@rating_histogram = args[:rating_histogram] if args.key?(:rating_histogram)
end
end
# Metadata for RejoinUserEvents method.
class GoogleCloudRetailV2RejoinUserEventsMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for RejoinUserEvents method.
class GoogleCloudRetailV2RejoinUserEventsRequest
include Google::Apis::Core::Hashable
# The type of the user event rejoin to define the scope and range of the user
# events to be rejoined with the latest product catalog. Defaults to
# USER_EVENT_REJOIN_SCOPE_UNSPECIFIED if this field is not set, or set to an
# invalid integer value.
# Corresponds to the JSON property `userEventRejoinScope`
# @return [String]
attr_accessor :user_event_rejoin_scope
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@user_event_rejoin_scope = args[:user_event_rejoin_scope] if args.key?(:user_event_rejoin_scope)
end
end
# Response message for RejoinUserEvents method.
class GoogleCloudRetailV2RejoinUserEventsResponse
include Google::Apis::Core::Hashable
# Number of user events that were joined with latest product catalog.
# Corresponds to the JSON property `rejoinedUserEventsCount`
# @return [Fixnum]
attr_accessor :rejoined_user_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@rejoined_user_events_count = args[:rejoined_user_events_count] if args.key?(:rejoined_user_events_count)
end
end
# Metadata related to the progress of the RemoveFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2RemoveFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2RemoveFulfillmentPlacesRequest
include Google::Apis::Core::Hashable
# If set to true, and the Product is not found, the fulfillment information will
# still be processed and retained for at most 1 day and processed once the
# Product is created. If set to false, a NOT_FOUND error is returned if the
# Product is not found.
# Corresponds to the JSON property `allowMissing`
# @return [Boolean]
attr_accessor :allow_missing
alias_method :allow_missing?, :allow_missing
# Required. The IDs for this type, such as the store IDs for "pickup-in-store"
# or the region IDs for "same-day-delivery", to be removed for this type. At
# least 1 value is required, and a maximum of 2000 values are allowed. Each
# value must be a string with a length limit of 10 characters, matching the
# pattern `[a-zA-Z0-9_-]+`, such as "store1" or "REGION-2". Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `placeIds`
# @return [Array<String>]
attr_accessor :place_ids
# The time when the fulfillment updates are issued, used to prevent out-of-order
# updates on fulfillment information. If not provided, the internal system time
# will be used.
# Corresponds to the JSON property `removeTime`
# @return [String]
attr_accessor :remove_time
# Required. The fulfillment type, including commonly used types (such as pickup
# in store and same day delivery), and custom types. Supported values: * "pickup-
# in-store" * "ship-to-store" * "same-day-delivery" * "next-day-delivery" * "
# custom-type-1" * "custom-type-2" * "custom-type-3" * "custom-type-4" * "custom-
# type-5" If this field is set to an invalid value other than these, an
# INVALID_ARGUMENT error is returned. This field directly corresponds to Product.
# fulfillment_info.type.
# 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)
@allow_missing = args[:allow_missing] if args.key?(:allow_missing)
@place_ids = args[:place_ids] if args.key?(:place_ids)
@remove_time = args[:remove_time] if args.key?(:remove_time)
@type = args[:type] if args.key?(:type)
end
end
# Response of the RemoveFulfillmentPlacesRequest. Currently empty because there
# is no meaningful response populated from the RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2RemoveFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the RemoveLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveLocalInventories method.
class GoogleCloudRetailV2RemoveLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for RemoveLocalInventories method.
class GoogleCloudRetailV2RemoveLocalInventoriesRequest
include Google::Apis::Core::Hashable
# If set to true, and the Product is not found, the local inventory removal
# request will still be processed and retained for at most 1 day and processed
# once the Product is created. If set to false, a NOT_FOUND error is returned if
# the Product is not found.
# Corresponds to the JSON property `allowMissing`
# @return [Boolean]
attr_accessor :allow_missing
alias_method :allow_missing?, :allow_missing
# Required. A list of place IDs to have their inventory deleted. At most 3000
# place IDs are allowed per request.
# Corresponds to the JSON property `placeIds`
# @return [Array<String>]
attr_accessor :place_ids
# The time when the inventory deletions are issued. Used to prevent out-of-order
# updates and deletions on local inventory fields. If not provided, the internal
# system time will be used.
# Corresponds to the JSON property `removeTime`
# @return [String]
attr_accessor :remove_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@allow_missing = args[:allow_missing] if args.key?(:allow_missing)
@place_ids = args[:place_ids] if args.key?(:place_ids)
@remove_time = args[:remove_time] if args.key?(:remove_time)
end
end
# Response of the RemoveLocalInventories API. Currently empty because there is
# no meaningful response populated from the RemoveLocalInventories method.
class GoogleCloudRetailV2RemoveLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for SearchService.Search method.
class GoogleCloudRetailV2SearchRequest
include Google::Apis::Core::Hashable
# Boost specification to boost certain items.
# Corresponds to the JSON property `boostSpec`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestBoostSpec]
attr_accessor :boost_spec
# The branch resource name, such as `projects/*/locations/global/catalogs/
# default_catalog/branches/0`. Use "default_branch" as the branch ID or leave
# this field empty, to search products under the default branch.
# Corresponds to the JSON property `branch`
# @return [String]
attr_accessor :branch
# The default filter that is applied when a user performs a search without
# checking any filters on the search page. The filter applied to every search
# request when quality improvement such as query expansion is needed. For
# example, if a query does not have enough results, an expanded query with
# SearchRequest.canonical_filter will be returned as a supplement of the
# original query. This field is strongly recommended to achieve high search
# quality. See SearchRequest.filter for more details about filter syntax.
# Corresponds to the JSON property `canonicalFilter`
# @return [String]
attr_accessor :canonical_filter
# The specifications of dynamically generated facets.
# Corresponds to the JSON property `dynamicFacetSpec`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestDynamicFacetSpec]
attr_accessor :dynamic_facet_spec
# Facet specifications for faceted search. If empty, no facets are returned. A
# maximum of 100 values are allowed. Otherwise, an INVALID_ARGUMENT error is
# returned.
# Corresponds to the JSON property `facetSpecs`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestFacetSpec>]
attr_accessor :facet_specs
# The filter syntax consists of an expression language for constructing a
# predicate from one or more fields of the products being filtered. Filter
# expression is case-sensitive. See more details at this [user guide](https://
# cloud.google.com/retail/docs/filter-and-order#filter). If this field is
# unrecognizable, an INVALID_ARGUMENT is returned.
# Corresponds to the JSON property `filter`
# @return [String]
attr_accessor :filter
# A 0-indexed integer that specifies the current offset (that is, starting
# result location, amongst the Products deemed by the API as relevant) in search
# results. This field is only considered if page_token is unset. If this field
# is negative, an INVALID_ARGUMENT is returned.
# Corresponds to the JSON property `offset`
# @return [Fixnum]
attr_accessor :offset
# The order in which products are returned. Products can be ordered by a field
# in an Product object. Leave it unset if ordered by relevance. OrderBy
# expression is case-sensitive. See more details at this [user guide](https://
# cloud.google.com/retail/docs/filter-and-order#order). If this field is
# unrecognizable, an INVALID_ARGUMENT is returned.
# Corresponds to the JSON property `orderBy`
# @return [String]
attr_accessor :order_by
# The categories associated with a category page. Required for category
# navigation queries to achieve good search quality. The format should be the
# same as UserEvent.page_categories; To represent full path of category, use '>'
# sign to separate different hierarchies. If '>' is part of the category name,
# please replace it with other character(s). Category pages include special
# pages such as sales or promotions. For instance, a special sale page may have
# the category hierarchy: "pageCategories" : ["Sales > 2017 Black Friday Deals"].
# Corresponds to the JSON property `pageCategories`
# @return [Array<String>]
attr_accessor :page_categories
# Maximum number of Products to return. If unspecified, defaults to a reasonable
# value. The maximum allowed value is 120. Values above 120 will be coerced to
# 120. If this field is negative, an INVALID_ARGUMENT is returned.
# Corresponds to the JSON property `pageSize`
# @return [Fixnum]
attr_accessor :page_size
# A page token SearchResponse.next_page_token, received from a previous
# SearchService.Search call. Provide this to retrieve the subsequent page. When
# paginating, all other parameters provided to SearchService.Search must match
# the call that provided the page token. Otherwise, an INVALID_ARGUMENT error is
# returned.
# Corresponds to the JSON property `pageToken`
# @return [String]
attr_accessor :page_token
# The specification for personalization.
# Corresponds to the JSON property `personalizationSpec`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestPersonalizationSpec]
attr_accessor :personalization_spec
# Raw search query.
# Corresponds to the JSON property `query`
# @return [String]
attr_accessor :query
# Specification to determine under which conditions query expansion should occur.
# Corresponds to the JSON property `queryExpansionSpec`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestQueryExpansionSpec]
attr_accessor :query_expansion_spec
# The search mode of the search request. If not specified, a single search
# request triggers both product search and faceted search.
# Corresponds to the JSON property `searchMode`
# @return [String]
attr_accessor :search_mode
# Information of an end user.
# Corresponds to the JSON property `userInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserInfo]
attr_accessor :user_info
# The keys to fetch and rollup the matching variant Products attributes,
# FulfillmentInfo or LocalInventorys attributes. The attributes from all the
# matching variant Products or LocalInventorys are merged and de-duplicated.
# Notice that rollup attributes will lead to extra query latency. Maximum number
# of keys is 30. For FulfillmentInfo, a fulfillment type and a fulfillment ID
# must be provided in the format of "fulfillmentType.fulfillmentId". E.g., in "
# pickupInStore.store123", "pickupInStore" is fulfillment type and "store123" is
# the store ID. Supported keys are: * colorFamilies * price * originalPrice *
# discount * variantId * inventory(place_id,price) * inventory(place_id,
# original_price) * inventory(place_id,attributes.key), where key is any key in
# the Product.inventories.attributes map. * attributes.key, where key is any key
# in the Product.attributes map. * pickupInStore.id, where id is any
# FulfillmentInfo.place_ids for FulfillmentInfo.type "pickup-in-store". *
# shipToStore.id, where id is any FulfillmentInfo.place_ids for FulfillmentInfo.
# type "ship-to-store". * sameDayDelivery.id, where id is any FulfillmentInfo.
# place_ids for FulfillmentInfo.type "same-day-delivery". * nextDayDelivery.id,
# where id is any FulfillmentInfo.place_ids for FulfillmentInfo.type "next-day-
# delivery". * customFulfillment1.id, where id is any FulfillmentInfo.place_ids
# for FulfillmentInfo.type "custom-type-1". * customFulfillment2.id, where id is
# any FulfillmentInfo.place_ids for FulfillmentInfo.type "custom-type-2". *
# customFulfillment3.id, where id is any FulfillmentInfo.place_ids for
# FulfillmentInfo.type "custom-type-3". * customFulfillment4.id, where id is any
# FulfillmentInfo.place_ids for FulfillmentInfo.type "custom-type-4". *
# customFulfillment5.id, where id is any FulfillmentInfo.place_ids for
# FulfillmentInfo.type "custom-type-5". If this field is set to an invalid value
# other than these, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `variantRollupKeys`
# @return [Array<String>]
attr_accessor :variant_rollup_keys
# Required. A unique identifier for tracking visitors. For example, this could
# be implemented with an HTTP cookie, which should be able to uniquely identify
# a visitor on a single device. This unique identifier should not change if the
# visitor logs in or out of the website. This should be the same identifier as
# UserEvent.visitor_id. The field must be a UTF-8 encoded string with a length
# limit of 128 characters. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `visitorId`
# @return [String]
attr_accessor :visitor_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@boost_spec = args[:boost_spec] if args.key?(:boost_spec)
@branch = args[:branch] if args.key?(:branch)
@canonical_filter = args[:canonical_filter] if args.key?(:canonical_filter)
@dynamic_facet_spec = args[:dynamic_facet_spec] if args.key?(:dynamic_facet_spec)
@facet_specs = args[:facet_specs] if args.key?(:facet_specs)
@filter = args[:filter] if args.key?(:filter)
@offset = args[:offset] if args.key?(:offset)
@order_by = args[:order_by] if args.key?(:order_by)
@page_categories = args[:page_categories] if args.key?(:page_categories)
@page_size = args[:page_size] if args.key?(:page_size)
@page_token = args[:page_token] if args.key?(:page_token)
@personalization_spec = args[:personalization_spec] if args.key?(:personalization_spec)
@query = args[:query] if args.key?(:query)
@query_expansion_spec = args[:query_expansion_spec] if args.key?(:query_expansion_spec)
@search_mode = args[:search_mode] if args.key?(:search_mode)
@user_info = args[:user_info] if args.key?(:user_info)
@variant_rollup_keys = args[:variant_rollup_keys] if args.key?(:variant_rollup_keys)
@visitor_id = args[:visitor_id] if args.key?(:visitor_id)
end
end
# Boost specification to boost certain items.
class GoogleCloudRetailV2SearchRequestBoostSpec
include Google::Apis::Core::Hashable
# Condition boost specifications. If a product matches multiple conditions in
# the specifictions, boost scores from these specifications are all applied and
# combined in a non-linear way. Maximum number of specifications is 10.
# Corresponds to the JSON property `conditionBoostSpecs`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestBoostSpecConditionBoostSpec>]
attr_accessor :condition_boost_specs
# Whether to skip boostspec validation. If this field is set to true, invalid
# BoostSpec.condition_boost_specs will be ignored and valid BoostSpec.
# condition_boost_specs will still be applied.
# Corresponds to the JSON property `skipBoostSpecValidation`
# @return [Boolean]
attr_accessor :skip_boost_spec_validation
alias_method :skip_boost_spec_validation?, :skip_boost_spec_validation
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@condition_boost_specs = args[:condition_boost_specs] if args.key?(:condition_boost_specs)
@skip_boost_spec_validation = args[:skip_boost_spec_validation] if args.key?(:skip_boost_spec_validation)
end
end
# Boost applies to products which match a condition.
class GoogleCloudRetailV2SearchRequestBoostSpecConditionBoostSpec
include Google::Apis::Core::Hashable
# Strength of the condition boost, which should be in [-1, 1]. Negative boost
# means demotion. Default is 0.0. Setting to 1.0 gives the item a big promotion.
# However, it does not necessarily mean that the boosted item will be the top
# result at all times, nor that other items will be excluded. Results could
# still be shown even when none of them matches the condition. And results that
# are significantly more relevant to the search query can still trump your
# heavily favored but irrelevant items. Setting to -1.0 gives the item a big
# demotion. However, results that are deeply relevant might still be shown. The
# item will have an upstream battle to get a fairly high ranking, but it is not
# blocked out completely. Setting to 0.0 means no boost applied. The boosting
# condition is ignored.
# Corresponds to the JSON property `boost`
# @return [Float]
attr_accessor :boost
# An expression which specifies a boost condition. The syntax and supported
# fields are the same as a filter expression. See SearchRequest.filter for
# detail syntax and limitations. Examples: * To boost products with product ID "
# product_1" or "product_2", and color "Red" or "Blue": * (id: ANY("product_1", "
# product_2")) AND (colorFamilies: ANY("Red","Blue"))
# Corresponds to the JSON property `condition`
# @return [String]
attr_accessor :condition
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@boost = args[:boost] if args.key?(:boost)
@condition = args[:condition] if args.key?(:condition)
end
end
# The specifications of dynamically generated facets.
class GoogleCloudRetailV2SearchRequestDynamicFacetSpec
include Google::Apis::Core::Hashable
# Mode of the DynamicFacet feature. Defaults to Mode.DISABLED if it's unset.
# Corresponds to the JSON property `mode`
# @return [String]
attr_accessor :mode
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@mode = args[:mode] if args.key?(:mode)
end
end
# A facet specification to perform faceted search.
class GoogleCloudRetailV2SearchRequestFacetSpec
include Google::Apis::Core::Hashable
# Enables dynamic position for this facet. If set to true, the position of this
# facet among all facets in the response is determined by Google Retail Search.
# It will be ordered together with dynamic facets if dynamic facets is enabled.
# If set to false, the position of this facet in the response will be the same
# as in the request, and it will be ranked before the facets with dynamic
# position enable and all dynamic facets. For example, you may always want to
# have rating facet returned in the response, but it's not necessarily to always
# display the rating facet at the top. In that case, you can set
# enable_dynamic_position to true so that the position of rating facet in
# response will be determined by Google Retail Search. Another example, assuming
# you have the following facets in the request: * "rating",
# enable_dynamic_position = true * "price", enable_dynamic_position = false * "
# brands", enable_dynamic_position = false And also you have a dynamic facets
# enable, which will generate a facet 'gender'. Then the final order of the
# facets in the response can be ("price", "brands", "rating", "gender") or ("
# price", "brands", "gender", "rating") depends on how Google Retail Search
# orders "gender" and "rating" facets. However, notice that "price" and "brands"
# will always be ranked at 1st and 2nd position since their
# enable_dynamic_position are false.
# Corresponds to the JSON property `enableDynamicPosition`
# @return [Boolean]
attr_accessor :enable_dynamic_position
alias_method :enable_dynamic_position?, :enable_dynamic_position
# List of keys to exclude when faceting. By default, FacetKey.key is not
# excluded from the filter unless it is listed in this field. For example,
# suppose there are 100 products with color facet "Red" and 200 products with
# color facet "Blue". A query containing the filter "colorFamilies:ANY("Red")"
# and have "colorFamilies" as FacetKey.key will by default return the "Red" with
# count 100. If this field contains "colorFamilies", then the query returns both
# the "Red" with count 100 and "Blue" with count 200, because the "colorFamilies"
# key is now excluded from the filter. A maximum of 100 values are allowed.
# Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `excludedFilterKeys`
# @return [Array<String>]
attr_accessor :excluded_filter_keys
# Specifies how a facet is computed.
# Corresponds to the JSON property `facetKey`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestFacetSpecFacetKey]
attr_accessor :facet_key
# Maximum of facet values that should be returned for this facet. If unspecified,
# defaults to 20. The maximum allowed value is 300. Values above 300 will be
# coerced to 300. If this field is negative, an INVALID_ARGUMENT is returned.
# Corresponds to the JSON property `limit`
# @return [Fixnum]
attr_accessor :limit
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@enable_dynamic_position = args[:enable_dynamic_position] if args.key?(:enable_dynamic_position)
@excluded_filter_keys = args[:excluded_filter_keys] if args.key?(:excluded_filter_keys)
@facet_key = args[:facet_key] if args.key?(:facet_key)
@limit = args[:limit] if args.key?(:limit)
end
end
# Specifies how a facet is computed.
class GoogleCloudRetailV2SearchRequestFacetSpecFacetKey
include Google::Apis::Core::Hashable
# Only get facet values that contains the given strings. For example, suppose "
# categories" has three values "Women > Shoe", "Women > Dress" and "Men > Shoe".
# If set "contains" to "Shoe", the "categories" facet will give only "Women >
# Shoe" and "Men > Shoe". Only supported on textual fields. Maximum is 10.
# Corresponds to the JSON property `contains`
# @return [Array<String>]
attr_accessor :contains
# Set only if values should be bucketized into intervals. Must be set for facets
# with numerical values. Must not be set for facet with text values. Maximum
# number of intervals is 30.
# Corresponds to the JSON property `intervals`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2Interval>]
attr_accessor :intervals
# Required. Supported textual and numerical facet keys in Product object, over
# which the facet values are computed. Facet key is case-sensitive. Allowed
# facet keys when FacetKey.query is not specified: * textual_field = * "brands" *
# "categories" * "genders" * "ageGroups" * "availability" * "colorFamilies" * "
# colors" * "sizes" * "materials" * "patterns" * "conditions" * "attributes.key"
# * "pickupInStore" * "shipToStore" * "sameDayDelivery" * "nextDayDelivery" * "
# customFulfillment1" * "customFulfillment2" * "customFulfillment3" * "
# customFulfillment4" * "customFulfillment5" * "inventory(place_id,attributes.
# key)" * numerical_field = * "price" * "discount" * "rating" * "ratingCount" * "
# attributes.key" * "inventory(place_id,price)" * "inventory(place_id,
# original_price)" * "inventory(place_id,attributes.key)"
# Corresponds to the JSON property `key`
# @return [String]
attr_accessor :key
# The order in which Facet.values are returned. Allowed values are: * "count
# desc", which means order by Facet.FacetValue.count descending. * "value desc",
# which means order by Facet.FacetValue.value descending. Only applies to
# textual facets. If not set, textual values are sorted in [natural order](https:
# //en.wikipedia.org/wiki/Natural_sort_order); numerical intervals are sorted in
# the order given by FacetSpec.FacetKey.intervals; FulfillmentInfo.place_ids are
# sorted in the order given by FacetSpec.FacetKey.restricted_values.
# Corresponds to the JSON property `orderBy`
# @return [String]
attr_accessor :order_by
# Only get facet values that start with the given string prefix. For example,
# suppose "categories" has three values "Women > Shoe", "Women > Dress" and "Men
# > Shoe". If set "prefixes" to "Women", the "categories" facet will give only "
# Women > Shoe" and "Women > Dress". Only supported on textual fields. Maximum
# is 10.
# Corresponds to the JSON property `prefixes`
# @return [Array<String>]
attr_accessor :prefixes
# The query that is used to compute facet for the given facet key. When provided,
# it will override the default behavior of facet computation. The query syntax
# is the same as a filter expression. See SearchRequest.filter for detail syntax
# and limitations. Notice that there is no limitation on FacetKey.key when query
# is specified. In the response, FacetValue.value will be always "1" and
# FacetValue.count will be the number of results that matches the query. For
# example, you can set a customized facet for "shipToStore", where FacetKey.key
# is "customizedShipToStore", and FacetKey.query is "availability: ANY(\"
# IN_STOCK\") AND shipToStore: ANY(\"123\")". Then the facet will count the
# products that are both in stock and ship to store "123".
# Corresponds to the JSON property `query`
# @return [String]
attr_accessor :query
# Only get facet for the given restricted values. For example, when using "
# pickupInStore" as key and set restricted values to ["store123", "store456"],
# only facets for "store123" and "store456" are returned. Only supported on
# textual fields and fulfillments. Maximum is 20. Must be set for the
# fulfillment facet keys: * pickupInStore * shipToStore * sameDayDelivery *
# nextDayDelivery * customFulfillment1 * customFulfillment2 * customFulfillment3
# * customFulfillment4 * customFulfillment5
# Corresponds to the JSON property `restrictedValues`
# @return [Array<String>]
attr_accessor :restricted_values
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@contains = args[:contains] if args.key?(:contains)
@intervals = args[:intervals] if args.key?(:intervals)
@key = args[:key] if args.key?(:key)
@order_by = args[:order_by] if args.key?(:order_by)
@prefixes = args[:prefixes] if args.key?(:prefixes)
@query = args[:query] if args.key?(:query)
@restricted_values = args[:restricted_values] if args.key?(:restricted_values)
end
end
# The specification for personalization.
class GoogleCloudRetailV2SearchRequestPersonalizationSpec
include Google::Apis::Core::Hashable
# Defaults to Mode.AUTO.
# Corresponds to the JSON property `mode`
# @return [String]
attr_accessor :mode
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@mode = args[:mode] if args.key?(:mode)
end
end
# Specification to determine under which conditions query expansion should occur.
class GoogleCloudRetailV2SearchRequestQueryExpansionSpec
include Google::Apis::Core::Hashable
# The condition under which query expansion should occur. Default to Condition.
# DISABLED.
# Corresponds to the JSON property `condition`
# @return [String]
attr_accessor :condition
# Whether to pin unexpanded results. If this field is set to true, unexpanded
# products are always at the top of the search results, followed by the expanded
# results.
# Corresponds to the JSON property `pinUnexpandedResults`
# @return [Boolean]
attr_accessor :pin_unexpanded_results
alias_method :pin_unexpanded_results?, :pin_unexpanded_results
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@condition = args[:condition] if args.key?(:condition)
@pin_unexpanded_results = args[:pin_unexpanded_results] if args.key?(:pin_unexpanded_results)
end
end
# Response message for SearchService.Search method.
class GoogleCloudRetailV2SearchResponse
include Google::Apis::Core::Hashable
# The fully qualified resource name of applied [controls](https://cloud.google.
# com/retail/docs/serving-control-rules).
# Corresponds to the JSON property `appliedControls`
# @return [Array<String>]
attr_accessor :applied_controls
# A unique search token. This should be included in the UserEvent logs resulting
# from this search, which enables accurate attribution of search model
# performance.
# Corresponds to the JSON property `attributionToken`
# @return [String]
attr_accessor :attribution_token
# If spell correction applies, the corrected query. Otherwise, empty.
# Corresponds to the JSON property `correctedQuery`
# @return [String]
attr_accessor :corrected_query
# Results of facets requested by user.
# Corresponds to the JSON property `facets`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchResponseFacet>]
attr_accessor :facets
# The invalid SearchRequest.BoostSpec.condition_boost_specs that are not applied
# during serving.
# Corresponds to the JSON property `invalidConditionBoostSpecs`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchRequestBoostSpecConditionBoostSpec>]
attr_accessor :invalid_condition_boost_specs
# A token that can be sent as SearchRequest.page_token to retrieve the next page.
# If this field is omitted, there are no subsequent pages.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# Information describing query expansion including whether expansion has
# occurred.
# Corresponds to the JSON property `queryExpansionInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2SearchResponseQueryExpansionInfo]
attr_accessor :query_expansion_info
# The URI of a customer-defined redirect page. If redirect action is triggered,
# no search will be performed, and only redirect_uri and attribution_token will
# be set in the response.
# Corresponds to the JSON property `redirectUri`
# @return [String]
attr_accessor :redirect_uri
# A list of matched items. The order represents the ranking.
# Corresponds to the JSON property `results`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchResponseSearchResult>]
attr_accessor :results
# The estimated total count of matched items irrespective of pagination. The
# count of results returned by pagination may be less than the total_size that
# matches.
# Corresponds to the JSON property `totalSize`
# @return [Fixnum]
attr_accessor :total_size
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@applied_controls = args[:applied_controls] if args.key?(:applied_controls)
@attribution_token = args[:attribution_token] if args.key?(:attribution_token)
@corrected_query = args[:corrected_query] if args.key?(:corrected_query)
@facets = args[:facets] if args.key?(:facets)
@invalid_condition_boost_specs = args[:invalid_condition_boost_specs] if args.key?(:invalid_condition_boost_specs)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
@query_expansion_info = args[:query_expansion_info] if args.key?(:query_expansion_info)
@redirect_uri = args[:redirect_uri] if args.key?(:redirect_uri)
@results = args[:results] if args.key?(:results)
@total_size = args[:total_size] if args.key?(:total_size)
end
end
# A facet result.
class GoogleCloudRetailV2SearchResponseFacet
include Google::Apis::Core::Hashable
# Whether the facet is dynamically generated.
# Corresponds to the JSON property `dynamicFacet`
# @return [Boolean]
attr_accessor :dynamic_facet
alias_method :dynamic_facet?, :dynamic_facet
# The key for this facet. E.g., "colorFamilies" or "price" or "attributes.attr1".
# Corresponds to the JSON property `key`
# @return [String]
attr_accessor :key
# The facet values for this field.
# Corresponds to the JSON property `values`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2SearchResponseFacetFacetValue>]
attr_accessor :values
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@dynamic_facet = args[:dynamic_facet] if args.key?(:dynamic_facet)
@key = args[:key] if args.key?(:key)
@values = args[:values] if args.key?(:values)
end
end
# A facet value which contains value names and their count.
class GoogleCloudRetailV2SearchResponseFacetFacetValue
include Google::Apis::Core::Hashable
# Number of items that have this facet value.
# Corresponds to the JSON property `count`
# @return [Fixnum]
attr_accessor :count
# A floating point interval.
# Corresponds to the JSON property `interval`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Interval]
attr_accessor :interval
# Text value of a facet, such as "Black" for facet "colorFamilies".
# Corresponds to the JSON property `value`
# @return [String]
attr_accessor :value
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@count = args[:count] if args.key?(:count)
@interval = args[:interval] if args.key?(:interval)
@value = args[:value] if args.key?(:value)
end
end
# Information describing query expansion including whether expansion has
# occurred.
class GoogleCloudRetailV2SearchResponseQueryExpansionInfo
include Google::Apis::Core::Hashable
# Bool describing whether query expansion has occurred.
# Corresponds to the JSON property `expandedQuery`
# @return [Boolean]
attr_accessor :expanded_query
alias_method :expanded_query?, :expanded_query
# Number of pinned results. This field will only be set when expansion happens
# and SearchRequest.QueryExpansionSpec.pin_unexpanded_results is set to true.
# Corresponds to the JSON property `pinnedResultCount`
# @return [Fixnum]
attr_accessor :pinned_result_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@expanded_query = args[:expanded_query] if args.key?(:expanded_query)
@pinned_result_count = args[:pinned_result_count] if args.key?(:pinned_result_count)
end
end
# Represents the search results.
class GoogleCloudRetailV2SearchResponseSearchResult
include Google::Apis::Core::Hashable
# Product.id of the searched Product.
# Corresponds to the JSON property `id`
# @return [String]
attr_accessor :id
# The count of matched variant Products.
# Corresponds to the JSON property `matchingVariantCount`
# @return [Fixnum]
attr_accessor :matching_variant_count
# If a variant Product matches the search query, this map indicates which
# Product fields are matched. The key is the Product.name, the value is a field
# mask of the matched Product fields. If matched attributes cannot be determined,
# this map will be empty. For example, a key "sku1" with field mask "products.
# color_info" indicates there is a match between "sku1" ColorInfo and the query.
# Corresponds to the JSON property `matchingVariantFields`
# @return [Hash<String,String>]
attr_accessor :matching_variant_fields
# Product captures all metadata information of items to be recommended or
# searched.
# Corresponds to the JSON property `product`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Product]
attr_accessor :product
# The rollup matching variant Product attributes. The key is one of the
# SearchRequest.variant_rollup_keys. The values are the merged and de-duplicated
# Product attributes. Notice that the rollup values are respect filter. For
# example, when filtering by "colorFamilies:ANY(\"red\")" and rollup "
# colorFamilies", only "red" is returned. For textual and numerical attributes,
# the rollup values is a list of string or double values with type google.
# protobuf.ListValue. For example, if there are two variants with colors "red"
# and "blue", the rollup values are ` key: "colorFamilies" value ` list_value `
# values ` string_value: "red" ` values ` string_value: "blue" ` ` ` ` For
# FulfillmentInfo, the rollup values is a double value with type google.protobuf.
# Value. For example, ``key: "pickupInStore.store1" value ` number_value: 10 ```
# means a there are 10 variants in this product are available in the store "
# store1".
# Corresponds to the JSON property `variantRollupValues`
# @return [Hash<String,Object>]
attr_accessor :variant_rollup_values
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@id = args[:id] if args.key?(:id)
@matching_variant_count = args[:matching_variant_count] if args.key?(:matching_variant_count)
@matching_variant_fields = args[:matching_variant_fields] if args.key?(:matching_variant_fields)
@product = args[:product] if args.key?(:product)
@variant_rollup_values = args[:variant_rollup_values] if args.key?(:variant_rollup_values)
end
end
# Request message to set a specified branch as new default_branch.
class GoogleCloudRetailV2SetDefaultBranchRequest
include Google::Apis::Core::Hashable
# The final component of the resource name of a branch. This field must be one
# of "0", "1" or "2". Otherwise, an INVALID_ARGUMENT error is returned. If there
# are no sufficient active products in the targeted branch and force is not set,
# a FAILED_PRECONDITION error is returned.
# Corresponds to the JSON property `branchId`
# @return [String]
attr_accessor :branch_id
# If set to true, it permits switching to a branch with branch_id even if it has
# no sufficient active products.
# Corresponds to the JSON property `force`
# @return [Boolean]
attr_accessor :force
alias_method :force?, :force
# Some note on this request, this can be retrieved by CatalogService.
# GetDefaultBranch before next valid default branch set occurs. This field must
# be a UTF-8 encoded string with a length limit of 1,000 characters. Otherwise,
# an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `note`
# @return [String]
attr_accessor :note
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@branch_id = args[:branch_id] if args.key?(:branch_id)
@force = args[:force] if args.key?(:force)
@note = args[:note] if args.key?(:note)
end
end
# Metadata related to the progress of the SetInventory operation. Currently
# empty because there is no meaningful metadata populated from the SetInventory
# method.
class GoogleCloudRetailV2SetInventoryMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Request message for SetInventory method.
class GoogleCloudRetailV2SetInventoryRequest
include Google::Apis::Core::Hashable
# If set to true, and the Product with name Product.name is not found, the
# inventory update will still be processed and retained for at most 1 day until
# the Product is created. If set to false, a NOT_FOUND error is returned if the
# Product is not found.
# Corresponds to the JSON property `allowMissing`
# @return [Boolean]
attr_accessor :allow_missing
alias_method :allow_missing?, :allow_missing
# Product captures all metadata information of items to be recommended or
# searched.
# Corresponds to the JSON property `inventory`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2Product]
attr_accessor :inventory
# Indicates which inventory fields in the provided Product to update. At least
# one field must be provided. If an unsupported or unknown field is provided, an
# INVALID_ARGUMENT error is returned and the entire update will be ignored.
# Corresponds to the JSON property `setMask`
# @return [String]
attr_accessor :set_mask
# The time when the request is issued, used to prevent out-of-order updates on
# inventory fields with the last update time recorded. If not provided, the
# internal system time will be used.
# Corresponds to the JSON property `setTime`
# @return [String]
attr_accessor :set_time
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@allow_missing = args[:allow_missing] if args.key?(:allow_missing)
@inventory = args[:inventory] if args.key?(:inventory)
@set_mask = args[:set_mask] if args.key?(:set_mask)
@set_time = args[:set_time] if args.key?(:set_time)
end
end
# Response of the SetInventoryRequest. Currently empty because there is no
# meaningful response populated from the SetInventory method.
class GoogleCloudRetailV2SetInventoryResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# UserEvent captures all metadata information Retail API needs to know about how
# end users interact with customers' website.
class GoogleCloudRetailV2UserEvent
include Google::Apis::Core::Hashable
# Extra user event features to include in the recommendation model. If you
# provide custom attributes for ingested user events, also include them in the
# user events that you associate with prediction requests. Custom attribute
# formatting must be consistent between imported events and events provided with
# prediction requests. This lets the Retail API use those custom attributes when
# training models and serving predictions, which helps improve recommendation
# quality. This field needs to pass all below criteria, otherwise an
# INVALID_ARGUMENT error is returned: * The key must be a UTF-8 encoded string
# with a length limit of 5,000 characters. * For text attributes, at most 400
# values are allowed. Empty values are not allowed. Each value must be a UTF-8
# encoded string with a length limit of 256 characters. * For number attributes,
# at most 400 values are allowed. For product recommendations, an example of
# extra user information is traffic_channel, which is how a user arrives at the
# site. Users can arrive at the site by coming to the site directly, coming
# through Google search, or in other ways.
# Corresponds to the JSON property `attributes`
# @return [Hash<String,Google::Apis::RetailV2::GoogleCloudRetailV2CustomAttribute>]
attr_accessor :attributes
# Highly recommended for user events that are the result of PredictionService.
# Predict. This field enables accurate attribution of recommendation model
# performance. The value must be a valid PredictResponse.attribution_token for
# user events that are the result of PredictionService.Predict. The value must
# be a valid SearchResponse.attribution_token for user events that are the
# result of SearchService.Search. This token enables us to accurately attribute
# page view or purchase back to the event and the particular predict response
# containing this clicked/purchased product. If user clicks on product K in the
# recommendation results, pass PredictResponse.attribution_token as a URL
# parameter to product K's page. When recording events on product K's page, log
# the PredictResponse.attribution_token to this field.
# Corresponds to the JSON property `attributionToken`
# @return [String]
attr_accessor :attribution_token
# The ID or name of the associated shopping cart. This ID is used to associate
# multiple items added or present in the cart before purchase. This can only be
# set for `add-to-cart`, `purchase-complete`, or `shopping-cart-page-view`
# events.
# Corresponds to the JSON property `cartId`
# @return [String]
attr_accessor :cart_id
# Detailed completion information including completion attribution token and
# clicked completion info.
# Corresponds to the JSON property `completionDetail`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2CompletionDetail]
attr_accessor :completion_detail
# Only required for UserEventService.ImportUserEvents method. Timestamp of when
# the user event happened.
# Corresponds to the JSON property `eventTime`
# @return [String]
attr_accessor :event_time
# Required. User event type. Allowed values are: * `add-to-cart`: Products being
# added to cart. * `category-page-view`: Special pages such as sale or promotion
# pages viewed. * `detail-page-view`: Products detail page viewed. * `home-page-
# view`: Homepage viewed. * `promotion-offered`: Promotion is offered to a user.
# * `promotion-not-offered`: Promotion is not offered to a user. * `purchase-
# complete`: User finishing a purchase. * `search`: Product search. * `shopping-
# cart-page-view`: User viewing a shopping cart.
# Corresponds to the JSON property `eventType`
# @return [String]
attr_accessor :event_type
# A list of identifiers for the independent experiment groups this user event
# belongs to. This is used to distinguish between user events associated with
# different experiment setups (e.g. using Retail API, using different
# recommendation models).
# Corresponds to the JSON property `experimentIds`
# @return [Array<String>]
attr_accessor :experiment_ids
# The filter syntax consists of an expression language for constructing a
# predicate from one or more fields of the products being filtered. See
# SearchRequest.filter for definition and syntax. The value must be a UTF-8
# encoded string with a length limit of 1,000 characters. Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `filter`
# @return [String]
attr_accessor :filter
# An integer that specifies the current offset for pagination (the 0-indexed
# starting location, amongst the products deemed by the API as relevant). See
# SearchRequest.offset for definition. If this field is negative, an
# INVALID_ARGUMENT is returned. This can only be set for `search` events. Other
# event types should not set this field. Otherwise, an INVALID_ARGUMENT error is
# returned.
# Corresponds to the JSON property `offset`
# @return [Fixnum]
attr_accessor :offset
# The order in which products are returned. See SearchRequest.order_by for
# definition and syntax. The value must be a UTF-8 encoded string with a length
# limit of 1,000 characters. Otherwise, an INVALID_ARGUMENT error is returned.
# This can only be set for `search` events. Other event types should not set
# this field. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `orderBy`
# @return [String]
attr_accessor :order_by
# The categories associated with a category page. To represent full path of
# category, use '>' sign to separate different hierarchies. If '>' is part of
# the category name, please replace it with other character(s). Category pages
# include special pages such as sales or promotions. For instance, a special
# sale page may have the category hierarchy: "pageCategories" : ["Sales > 2017
# Black Friday Deals"]. Required for `category-page-view` events. At least one
# of search_query or page_categories is required for `search` events. Other
# event types should not set this field. Otherwise, an INVALID_ARGUMENT error is
# returned.
# Corresponds to the JSON property `pageCategories`
# @return [Array<String>]
attr_accessor :page_categories
# A unique ID of a web page view. This should be kept the same for all user
# events triggered from the same pageview. For example, an item detail page view
# could trigger multiple events as the user is browsing the page. The `
# pageViewId` property should be kept the same for all these events so that they
# can be grouped together properly. When using the client side event reporting
# with JavaScript pixel and Google Tag Manager, this value is filled in
# automatically.
# Corresponds to the JSON property `pageViewId`
# @return [String]
attr_accessor :page_view_id
# The main product details related to the event. This field is required for the
# following event types: * `add-to-cart` * `detail-page-view` * `purchase-
# complete` * `search` In a `search` event, this field represents the products
# returned to the end user on the current page (the end user may have not
# finished browsing the whole page yet). When a new page is returned to the end
# user, after pagination/filtering/ordering even for the same query, a new `
# search` event with different product_details is desired. The end user may have
# not finished browsing the whole page yet.
# Corresponds to the JSON property `productDetails`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2ProductDetail>]
attr_accessor :product_details
# A transaction represents the entire purchase transaction.
# Corresponds to the JSON property `purchaseTransaction`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2PurchaseTransaction]
attr_accessor :purchase_transaction
# The referrer URL of the current page. When using the client side event
# reporting with JavaScript pixel and Google Tag Manager, this value is filled
# in automatically.
# Corresponds to the JSON property `referrerUri`
# @return [String]
attr_accessor :referrer_uri
# The user's search query. See SearchRequest.query for definition. The value
# must be a UTF-8 encoded string with a length limit of 5,000 characters.
# Otherwise, an INVALID_ARGUMENT error is returned. At least one of search_query
# or page_categories is required for `search` events. Other event types should
# not set this field. Otherwise, an INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `searchQuery`
# @return [String]
attr_accessor :search_query
# A unique identifier for tracking a visitor session with a length limit of 128
# bytes. A session is an aggregation of an end user behavior in a time span. A
# general guideline to populate the sesion_id: 1. If user has no activity for 30
# min, a new session_id should be assigned. 2. The session_id should be unique
# across users, suggest use uuid or add visitor_id as prefix.
# Corresponds to the JSON property `sessionId`
# @return [String]
attr_accessor :session_id
# Complete URL (window.location.href) of the user's current page. When using the
# client side event reporting with JavaScript pixel and Google Tag Manager, this
# value is filled in automatically. Maximum length 5,000 characters.
# Corresponds to the JSON property `uri`
# @return [String]
attr_accessor :uri
# Information of an end user.
# Corresponds to the JSON property `userInfo`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserInfo]
attr_accessor :user_info
# Required. A unique identifier for tracking visitors. For example, this could
# be implemented with an HTTP cookie, which should be able to uniquely identify
# a visitor on a single device. This unique identifier should not change if the
# visitor log in/out of the website. The field must be a UTF-8 encoded string
# with a length limit of 128 characters. Otherwise, an INVALID_ARGUMENT error is
# returned. The field should not contain PII or user-data. We recommend to use
# Google Analystics [Client ID](https://developers.google.com/analytics/
# devguides/collection/analyticsjs/field-reference#clientId) for this field.
# Corresponds to the JSON property `visitorId`
# @return [String]
attr_accessor :visitor_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@attributes = args[:attributes] if args.key?(:attributes)
@attribution_token = args[:attribution_token] if args.key?(:attribution_token)
@cart_id = args[:cart_id] if args.key?(:cart_id)
@completion_detail = args[:completion_detail] if args.key?(:completion_detail)
@event_time = args[:event_time] if args.key?(:event_time)
@event_type = args[:event_type] if args.key?(:event_type)
@experiment_ids = args[:experiment_ids] if args.key?(:experiment_ids)
@filter = args[:filter] if args.key?(:filter)
@offset = args[:offset] if args.key?(:offset)
@order_by = args[:order_by] if args.key?(:order_by)
@page_categories = args[:page_categories] if args.key?(:page_categories)
@page_view_id = args[:page_view_id] if args.key?(:page_view_id)
@product_details = args[:product_details] if args.key?(:product_details)
@purchase_transaction = args[:purchase_transaction] if args.key?(:purchase_transaction)
@referrer_uri = args[:referrer_uri] if args.key?(:referrer_uri)
@search_query = args[:search_query] if args.key?(:search_query)
@session_id = args[:session_id] if args.key?(:session_id)
@uri = args[:uri] if args.key?(:uri)
@user_info = args[:user_info] if args.key?(:user_info)
@visitor_id = args[:visitor_id] if args.key?(:visitor_id)
end
end
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
class GoogleCloudRetailV2UserEventImportSummary
include Google::Apis::Core::Hashable
# Count of user events imported with complete existing catalog information.
# Corresponds to the JSON property `joinedEventsCount`
# @return [Fixnum]
attr_accessor :joined_events_count
# Count of user events imported, but with catalog information not found in the
# imported catalog.
# Corresponds to the JSON property `unjoinedEventsCount`
# @return [Fixnum]
attr_accessor :unjoined_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@joined_events_count = args[:joined_events_count] if args.key?(:joined_events_count)
@unjoined_events_count = args[:unjoined_events_count] if args.key?(:unjoined_events_count)
end
end
# The inline source for the input config for ImportUserEvents method.
class GoogleCloudRetailV2UserEventInlineSource
include Google::Apis::Core::Hashable
# Required. A list of user events to import. Recommended max of 10k items.
# Corresponds to the JSON property `userEvents`
# @return [Array<Google::Apis::RetailV2::GoogleCloudRetailV2UserEvent>]
attr_accessor :user_events
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@user_events = args[:user_events] if args.key?(:user_events)
end
end
# The input config source for user events.
class GoogleCloudRetailV2UserEventInputConfig
include Google::Apis::Core::Hashable
# BigQuery source import data from.
# Corresponds to the JSON property `bigQuerySource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2BigQuerySource]
attr_accessor :big_query_source
# Google Cloud Storage location for input content. format.
# Corresponds to the JSON property `gcsSource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2GcsSource]
attr_accessor :gcs_source
# The inline source for the input config for ImportUserEvents method.
# Corresponds to the JSON property `userEventInlineSource`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2UserEventInlineSource]
attr_accessor :user_event_inline_source
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@big_query_source = args[:big_query_source] if args.key?(:big_query_source)
@gcs_source = args[:gcs_source] if args.key?(:gcs_source)
@user_event_inline_source = args[:user_event_inline_source] if args.key?(:user_event_inline_source)
end
end
# Information of an end user.
class GoogleCloudRetailV2UserInfo
include Google::Apis::Core::Hashable
# True if the request is made directly from the end user, in which case the
# ip_address and user_agent can be populated from the HTTP request. This flag
# should be set only if the API request is made directly from the end user such
# as a mobile app (and not if a gateway or a server is processing and pushing
# the user events). This should not be set when using the JavaScript tag in
# UserEventService.CollectUserEvent.
# Corresponds to the JSON property `directUserRequest`
# @return [Boolean]
attr_accessor :direct_user_request
alias_method :direct_user_request?, :direct_user_request
# The end user's IP address. This field is used to extract location information
# for personalization. This field must be either an IPv4 address (e.g. "104.133.
# 9.80") or an IPv6 address (e.g. "2001:0db8:85a3:0000:0000:8a2e:0370:7334").
# Otherwise, an INVALID_ARGUMENT error is returned. This should not be set when:
# * setting SearchRequest.user_info. * using the JavaScript tag in
# UserEventService.CollectUserEvent or if direct_user_request is set.
# Corresponds to the JSON property `ipAddress`
# @return [String]
attr_accessor :ip_address
# User agent as included in the HTTP header. Required for getting SearchResponse.
# sponsored_results. The field must be a UTF-8 encoded string with a length
# limit of 1,000 characters. Otherwise, an INVALID_ARGUMENT error is returned.
# This should not be set when using the client side event reporting with GTM or
# JavaScript tag in UserEventService.CollectUserEvent or if direct_user_request
# is set.
# Corresponds to the JSON property `userAgent`
# @return [String]
attr_accessor :user_agent
# Highly recommended for logged-in users. Unique identifier for logged-in user,
# such as a user name. Always use a hashed value for this ID. The field must be
# a UTF-8 encoded string with a length limit of 128 characters. Otherwise, an
# INVALID_ARGUMENT error is returned.
# Corresponds to the JSON property `userId`
# @return [String]
attr_accessor :user_id
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@direct_user_request = args[:direct_user_request] if args.key?(:direct_user_request)
@ip_address = args[:ip_address] if args.key?(:ip_address)
@user_agent = args[:user_agent] if args.key?(:user_agent)
@user_id = args[:user_id] if args.key?(:user_id)
end
end
# Metadata related to the progress of the AddFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# AddFulfillmentPlaces method.
class GoogleCloudRetailV2alphaAddFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the AddFulfillmentPlacesRequest. Currently empty because there is
# no meaningful response populated from the AddFulfillmentPlaces method.
class GoogleCloudRetailV2alphaAddFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the AddLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# AddLocalInventories method.
class GoogleCloudRetailV2alphaAddLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the AddLocalInventories API. Currently empty because there is no
# meaningful response populated from the AddLocalInventories method.
class GoogleCloudRetailV2alphaAddLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Configuration of destination for Export related errors.
class GoogleCloudRetailV2alphaExportErrorsConfig
include Google::Apis::Core::Hashable
# Google Cloud Storage path for import errors. This must be an empty, existing
# Cloud Storage bucket. Export errors will be written to a file in this bucket,
# one per line, as a JSON-encoded `google.rpc.Status` message.
# Corresponds to the JSON property `gcsPrefix`
# @return [String]
attr_accessor :gcs_prefix
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@gcs_prefix = args[:gcs_prefix] if args.key?(:gcs_prefix)
end
end
# Metadata related to the progress of the Export operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2alphaExportMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Response of the ExportProductsRequest. If the long running operation is done,
# then this message is returned by the google.longrunning.Operations.response
# field if the operation was successful.
class GoogleCloudRetailV2alphaExportProductsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Export related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2alphaExportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ExportUserEventsRequest. If the long running operation was
# successful, then this message is returned by the google.longrunning.Operations.
# response field if the operation was successful.
class GoogleCloudRetailV2alphaExportUserEventsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Export related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2alphaExportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ImportCompletionDataRequest. If the long running operation is
# done, this message is returned by the google.longrunning.Operations.response
# field if the operation is successful.
class GoogleCloudRetailV2alphaImportCompletionDataResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
end
end
# Configuration of destination for Import related errors.
class GoogleCloudRetailV2alphaImportErrorsConfig
include Google::Apis::Core::Hashable
# Google Cloud Storage prefix for import errors. This must be an empty, existing
# Cloud Storage directory. Import errors will be written to sharded files in
# this directory, one per line, as a JSON-encoded `google.rpc.Status` message.
# Corresponds to the JSON property `gcsPrefix`
# @return [String]
attr_accessor :gcs_prefix
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@gcs_prefix = args[:gcs_prefix] if args.key?(:gcs_prefix)
end
end
# Metadata related to the progress of the Import operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2alphaImportMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Count of entries that encountered errors while processing.
# Corresponds to the JSON property `failureCount`
# @return [Fixnum]
attr_accessor :failure_count
# Pub/Sub topic for receiving notification. If this field is set, when the
# import is finished, a notification will be sent to specified Pub/Sub topic.
# The message data will be JSON string of a Operation. Format of the Pub/Sub
# topic is `projects/`project`/topics/`topic``.
# Corresponds to the JSON property `notificationPubsubTopic`
# @return [String]
attr_accessor :notification_pubsub_topic
# Deprecated. This field is never set.
# Corresponds to the JSON property `requestId`
# @return [String]
attr_accessor :request_id
# Count of entries that were processed successfully.
# Corresponds to the JSON property `successCount`
# @return [Fixnum]
attr_accessor :success_count
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@failure_count = args[:failure_count] if args.key?(:failure_count)
@notification_pubsub_topic = args[:notification_pubsub_topic] if args.key?(:notification_pubsub_topic)
@request_id = args[:request_id] if args.key?(:request_id)
@success_count = args[:success_count] if args.key?(:success_count)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Response of the ImportProductsRequest. If the long running operation is done,
# then this message is returned by the google.longrunning.Operations.response
# field if the operation was successful.
class GoogleCloudRetailV2alphaImportProductsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2alphaImportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ImportUserEventsRequest. If the long running operation was
# successful, then this message is returned by the google.longrunning.Operations.
# response field if the operation was successful.
class GoogleCloudRetailV2alphaImportUserEventsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2alphaImportErrorsConfig]
attr_accessor :errors_config
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
# Corresponds to the JSON property `importSummary`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2alphaUserEventImportSummary]
attr_accessor :import_summary
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
@import_summary = args[:import_summary] if args.key?(:import_summary)
end
end
# Metadata related to the progress of the Purge operation. This will be returned
# by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2alphaPurgeMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the PurgeProducts operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2alphaPurgeProductsMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Count of entries that encountered errors while processing.
# Corresponds to the JSON property `failureCount`
# @return [Fixnum]
attr_accessor :failure_count
# Count of entries that were deleted successfully.
# Corresponds to the JSON property `successCount`
# @return [Fixnum]
attr_accessor :success_count
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@failure_count = args[:failure_count] if args.key?(:failure_count)
@success_count = args[:success_count] if args.key?(:success_count)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Response of the PurgeProductsRequest. If the long running operation is
# successfully done, then this message is returned by the google.longrunning.
# Operations.response field.
class GoogleCloudRetailV2alphaPurgeProductsResponse
include Google::Apis::Core::Hashable
# The total count of products purged as a result of the operation.
# Corresponds to the JSON property `purgeCount`
# @return [Fixnum]
attr_accessor :purge_count
# A sample of the product names that will be deleted. Only populated if `force`
# is set to false. A max of 100 names will be returned and the names are chosen
# at random.
# Corresponds to the JSON property `purgeSample`
# @return [Array<String>]
attr_accessor :purge_sample
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@purge_count = args[:purge_count] if args.key?(:purge_count)
@purge_sample = args[:purge_sample] if args.key?(:purge_sample)
end
end
# Response of the PurgeUserEventsRequest. If the long running operation is
# successfully done, then this message is returned by the google.longrunning.
# Operations.response field.
class GoogleCloudRetailV2alphaPurgeUserEventsResponse
include Google::Apis::Core::Hashable
# The total count of events purged as a result of the operation.
# Corresponds to the JSON property `purgedEventsCount`
# @return [Fixnum]
attr_accessor :purged_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@purged_events_count = args[:purged_events_count] if args.key?(:purged_events_count)
end
end
# Metadata for RejoinUserEvents method.
class GoogleCloudRetailV2alphaRejoinUserEventsMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response message for RejoinUserEvents method.
class GoogleCloudRetailV2alphaRejoinUserEventsResponse
include Google::Apis::Core::Hashable
# Number of user events that were joined with latest product catalog.
# Corresponds to the JSON property `rejoinedUserEventsCount`
# @return [Fixnum]
attr_accessor :rejoined_user_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@rejoined_user_events_count = args[:rejoined_user_events_count] if args.key?(:rejoined_user_events_count)
end
end
# Metadata related to the progress of the RemoveFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2alphaRemoveFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the RemoveFulfillmentPlacesRequest. Currently empty because there
# is no meaningful response populated from the RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2alphaRemoveFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the RemoveLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveLocalInventories method.
class GoogleCloudRetailV2alphaRemoveLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the RemoveLocalInventories API. Currently empty because there is
# no meaningful response populated from the RemoveLocalInventories method.
class GoogleCloudRetailV2alphaRemoveLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the SetInventory operation. Currently
# empty because there is no meaningful metadata populated from the SetInventory
# method.
class GoogleCloudRetailV2alphaSetInventoryMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the SetInventoryRequest. Currently empty because there is no
# meaningful response populated from the SetInventory method.
class GoogleCloudRetailV2alphaSetInventoryResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
class GoogleCloudRetailV2alphaUserEventImportSummary
include Google::Apis::Core::Hashable
# Count of user events imported with complete existing catalog information.
# Corresponds to the JSON property `joinedEventsCount`
# @return [Fixnum]
attr_accessor :joined_events_count
# Count of user events imported, but with catalog information not found in the
# imported catalog.
# Corresponds to the JSON property `unjoinedEventsCount`
# @return [Fixnum]
attr_accessor :unjoined_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@joined_events_count = args[:joined_events_count] if args.key?(:joined_events_count)
@unjoined_events_count = args[:unjoined_events_count] if args.key?(:unjoined_events_count)
end
end
# Metadata related to the progress of the AddFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# AddFulfillmentPlaces method.
class GoogleCloudRetailV2betaAddFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the AddFulfillmentPlacesRequest. Currently empty because there is
# no meaningful response populated from the AddFulfillmentPlaces method.
class GoogleCloudRetailV2betaAddFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the AddLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# AddLocalInventories method.
class GoogleCloudRetailV2betaAddLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the AddLocalInventories API. Currently empty because there is no
# meaningful response populated from the AddLocalInventories method.
class GoogleCloudRetailV2betaAddLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Configuration of destination for Export related errors.
class GoogleCloudRetailV2betaExportErrorsConfig
include Google::Apis::Core::Hashable
# Google Cloud Storage path for import errors. This must be an empty, existing
# Cloud Storage bucket. Export errors will be written to a file in this bucket,
# one per line, as a JSON-encoded `google.rpc.Status` message.
# Corresponds to the JSON property `gcsPrefix`
# @return [String]
attr_accessor :gcs_prefix
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@gcs_prefix = args[:gcs_prefix] if args.key?(:gcs_prefix)
end
end
# Metadata related to the progress of the Export operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2betaExportMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Response of the ExportProductsRequest. If the long running operation is done,
# then this message is returned by the google.longrunning.Operations.response
# field if the operation was successful.
class GoogleCloudRetailV2betaExportProductsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Export related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2betaExportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ExportUserEventsRequest. If the long running operation was
# successful, then this message is returned by the google.longrunning.Operations.
# response field if the operation was successful.
class GoogleCloudRetailV2betaExportUserEventsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Export related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2betaExportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ImportCompletionDataRequest. If the long running operation is
# done, this message is returned by the google.longrunning.Operations.response
# field if the operation is successful.
class GoogleCloudRetailV2betaImportCompletionDataResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
end
end
# Configuration of destination for Import related errors.
class GoogleCloudRetailV2betaImportErrorsConfig
include Google::Apis::Core::Hashable
# Google Cloud Storage prefix for import errors. This must be an empty, existing
# Cloud Storage directory. Import errors will be written to sharded files in
# this directory, one per line, as a JSON-encoded `google.rpc.Status` message.
# Corresponds to the JSON property `gcsPrefix`
# @return [String]
attr_accessor :gcs_prefix
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@gcs_prefix = args[:gcs_prefix] if args.key?(:gcs_prefix)
end
end
# Metadata related to the progress of the Import operation. This will be
# returned by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2betaImportMetadata
include Google::Apis::Core::Hashable
# Operation create time.
# Corresponds to the JSON property `createTime`
# @return [String]
attr_accessor :create_time
# Count of entries that encountered errors while processing.
# Corresponds to the JSON property `failureCount`
# @return [Fixnum]
attr_accessor :failure_count
# Pub/Sub topic for receiving notification. If this field is set, when the
# import is finished, a notification will be sent to specified Pub/Sub topic.
# The message data will be JSON string of a Operation. Format of the Pub/Sub
# topic is `projects/`project`/topics/`topic``.
# Corresponds to the JSON property `notificationPubsubTopic`
# @return [String]
attr_accessor :notification_pubsub_topic
# Deprecated. This field is never set.
# Corresponds to the JSON property `requestId`
# @return [String]
attr_accessor :request_id
# Count of entries that were processed successfully.
# Corresponds to the JSON property `successCount`
# @return [Fixnum]
attr_accessor :success_count
# Operation last update time. If the operation is done, this is also the finish
# time.
# 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)
@create_time = args[:create_time] if args.key?(:create_time)
@failure_count = args[:failure_count] if args.key?(:failure_count)
@notification_pubsub_topic = args[:notification_pubsub_topic] if args.key?(:notification_pubsub_topic)
@request_id = args[:request_id] if args.key?(:request_id)
@success_count = args[:success_count] if args.key?(:success_count)
@update_time = args[:update_time] if args.key?(:update_time)
end
end
# Response of the ImportProductsRequest. If the long running operation is done,
# then this message is returned by the google.longrunning.Operations.response
# field if the operation was successful.
class GoogleCloudRetailV2betaImportProductsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2betaImportErrorsConfig]
attr_accessor :errors_config
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
end
end
# Response of the ImportUserEventsRequest. If the long running operation was
# successful, then this message is returned by the google.longrunning.Operations.
# response field if the operation was successful.
class GoogleCloudRetailV2betaImportUserEventsResponse
include Google::Apis::Core::Hashable
# A sample of errors encountered while processing the request.
# Corresponds to the JSON property `errorSamples`
# @return [Array<Google::Apis::RetailV2::GoogleRpcStatus>]
attr_accessor :error_samples
# Configuration of destination for Import related errors.
# Corresponds to the JSON property `errorsConfig`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2betaImportErrorsConfig]
attr_accessor :errors_config
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
# Corresponds to the JSON property `importSummary`
# @return [Google::Apis::RetailV2::GoogleCloudRetailV2betaUserEventImportSummary]
attr_accessor :import_summary
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@error_samples = args[:error_samples] if args.key?(:error_samples)
@errors_config = args[:errors_config] if args.key?(:errors_config)
@import_summary = args[:import_summary] if args.key?(:import_summary)
end
end
# Metadata related to the progress of the Purge operation. This will be returned
# by the google.longrunning.Operation.metadata field.
class GoogleCloudRetailV2betaPurgeMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the PurgeUserEventsRequest. If the long running operation is
# successfully done, then this message is returned by the google.longrunning.
# Operations.response field.
class GoogleCloudRetailV2betaPurgeUserEventsResponse
include Google::Apis::Core::Hashable
# The total count of events purged as a result of the operation.
# Corresponds to the JSON property `purgedEventsCount`
# @return [Fixnum]
attr_accessor :purged_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@purged_events_count = args[:purged_events_count] if args.key?(:purged_events_count)
end
end
# Metadata for RejoinUserEvents method.
class GoogleCloudRetailV2betaRejoinUserEventsMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response message for RejoinUserEvents method.
class GoogleCloudRetailV2betaRejoinUserEventsResponse
include Google::Apis::Core::Hashable
# Number of user events that were joined with latest product catalog.
# Corresponds to the JSON property `rejoinedUserEventsCount`
# @return [Fixnum]
attr_accessor :rejoined_user_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@rejoined_user_events_count = args[:rejoined_user_events_count] if args.key?(:rejoined_user_events_count)
end
end
# Metadata related to the progress of the RemoveFulfillmentPlaces operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2betaRemoveFulfillmentPlacesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the RemoveFulfillmentPlacesRequest. Currently empty because there
# is no meaningful response populated from the RemoveFulfillmentPlaces method.
class GoogleCloudRetailV2betaRemoveFulfillmentPlacesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the RemoveLocalInventories operation.
# Currently empty because there is no meaningful metadata populated from the
# RemoveLocalInventories method.
class GoogleCloudRetailV2betaRemoveLocalInventoriesMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the RemoveLocalInventories API. Currently empty because there is
# no meaningful response populated from the RemoveLocalInventories method.
class GoogleCloudRetailV2betaRemoveLocalInventoriesResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Metadata related to the progress of the SetInventory operation. Currently
# empty because there is no meaningful metadata populated from the SetInventory
# method.
class GoogleCloudRetailV2betaSetInventoryMetadata
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# Response of the SetInventoryRequest. Currently empty because there is no
# meaningful response populated from the SetInventory method.
class GoogleCloudRetailV2betaSetInventoryResponse
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# A summary of import result. The UserEventImportSummary summarizes the import
# status for user events.
class GoogleCloudRetailV2betaUserEventImportSummary
include Google::Apis::Core::Hashable
# Count of user events imported with complete existing catalog information.
# Corresponds to the JSON property `joinedEventsCount`
# @return [Fixnum]
attr_accessor :joined_events_count
# Count of user events imported, but with catalog information not found in the
# imported catalog.
# Corresponds to the JSON property `unjoinedEventsCount`
# @return [Fixnum]
attr_accessor :unjoined_events_count
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@joined_events_count = args[:joined_events_count] if args.key?(:joined_events_count)
@unjoined_events_count = args[:unjoined_events_count] if args.key?(:unjoined_events_count)
end
end
# The response message for Operations.ListOperations.
class GoogleLongrunningListOperationsResponse
include Google::Apis::Core::Hashable
# The standard List next-page token.
# Corresponds to the JSON property `nextPageToken`
# @return [String]
attr_accessor :next_page_token
# A list of operations that matches the specified filter in the request.
# Corresponds to the JSON property `operations`
# @return [Array<Google::Apis::RetailV2::GoogleLongrunningOperation>]
attr_accessor :operations
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
@operations = args[:operations] if args.key?(:operations)
end
end
# This resource represents a long-running operation that is the result of a
# network API call.
class GoogleLongrunningOperation
include Google::Apis::Core::Hashable
# If the value is `false`, it means the operation is still in progress. If `true`
# , the operation is completed, and either `error` or `response` is available.
# Corresponds to the JSON property `done`
# @return [Boolean]
attr_accessor :done
alias_method :done?, :done
# The `Status` type defines a logical error model that is suitable for different
# programming environments, including REST APIs and RPC APIs. It is used by [
# gRPC](https://github.com/grpc). Each `Status` message contains three pieces of
# data: error code, error message, and error details. You can find out more
# about this error model and how to work with it in the [API Design Guide](https:
# //cloud.google.com/apis/design/errors).
# Corresponds to the JSON property `error`
# @return [Google::Apis::RetailV2::GoogleRpcStatus]
attr_accessor :error
# Service-specific metadata associated with the operation. It typically contains
# progress information and common metadata such as create time. Some services
# might not provide such metadata. Any method that returns a long-running
# operation should document the metadata type, if any.
# Corresponds to the JSON property `metadata`
# @return [Hash<String,Object>]
attr_accessor :metadata
# The server-assigned name, which is only unique within the same service that
# originally returns it. If you use the default HTTP mapping, the `name` should
# be a resource name ending with `operations/`unique_id``.
# Corresponds to the JSON property `name`
# @return [String]
attr_accessor :name
# The normal response of the operation in case of success. If the original
# method returns no data on success, such as `Delete`, the response is `google.
# protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`,
# the response should be the resource. For other methods, the response should
# have the type `XxxResponse`, where `Xxx` is the original method name. For
# example, if the original method name is `TakeSnapshot()`, the inferred
# response type is `TakeSnapshotResponse`.
# Corresponds to the JSON property `response`
# @return [Hash<String,Object>]
attr_accessor :response
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@done = args[:done] if args.key?(:done)
@error = args[:error] if args.key?(:error)
@metadata = args[:metadata] if args.key?(:metadata)
@name = args[:name] if args.key?(:name)
@response = args[:response] if args.key?(:response)
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); `
class GoogleProtobufEmpty
include Google::Apis::Core::Hashable
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
end
end
# The `Status` type defines a logical error model that is suitable for different
# programming environments, including REST APIs and RPC APIs. It is used by [
# gRPC](https://github.com/grpc). Each `Status` message contains three pieces of
# data: error code, error message, and error details. You can find out more
# about this error model and how to work with it in the [API Design Guide](https:
# //cloud.google.com/apis/design/errors).
class GoogleRpcStatus
include Google::Apis::Core::Hashable
# The status code, which should be an enum value of google.rpc.Code.
# Corresponds to the JSON property `code`
# @return [Fixnum]
attr_accessor :code
# A list of messages that carry the error details. There is a common set of
# message types for APIs to use.
# Corresponds to the JSON property `details`
# @return [Array<Hash<String,Object>>]
attr_accessor :details
# A developer-facing error message, which should be in English. Any user-facing
# error message should be localized and sent in the google.rpc.Status.details
# field, or localized by the client.
# Corresponds to the JSON property `message`
# @return [String]
attr_accessor :message
def initialize(**args)
update!(**args)
end
# Update properties of this object
def update!(**args)
@code = args[:code] if args.key?(:code)
@details = args[:details] if args.key?(:details)
@message = args[:message] if args.key?(:message)
end
end
# 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
class GoogleTypeDate
include Google::Apis::Core::Hashable
# 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.
# Corresponds to the JSON property `day`
# @return [Fixnum]
attr_accessor :day
# Month of a year. Must be from 1 to 12, or 0 to specify a year without a month
# and day.
# Corresponds to the JSON property `month`
# @return [Fixnum]
attr_accessor :month
# Year of the date. Must be from 1 to 9999, or 0 to specify 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
end
end
end