2537 lines
103 KiB
Ruby
2537 lines
103 KiB
Ruby
|
# Copyright 2015 Google Inc.
|
||
|
#
|
||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
# you may not use this file except in compliance with the License.
|
||
|
# You may obtain a copy of the License at
|
||
|
#
|
||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||
|
#
|
||
|
# Unless required by applicable law or agreed to in writing, software
|
||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
# See the License for the specific language governing permissions and
|
||
|
# limitations under the License.
|
||
|
|
||
|
require 'date'
|
||
|
require 'google/apis/core/base_service'
|
||
|
require 'google/apis/core/json_representation'
|
||
|
require 'google/apis/core/hashable'
|
||
|
require 'google/apis/errors'
|
||
|
|
||
|
module Google
|
||
|
module Apis
|
||
|
module DialogflowV2beta1
|
||
|
|
||
|
# Represents a conversational agent.
|
||
|
class Agent
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The URI of the agent's avatar.
|
||
|
# Avatars are used throughout API.AI console and in the self-hosted
|
||
|
# [Web Demo](https://dialogflow.com/docs/integrations/web-demo) integration.
|
||
|
# Corresponds to the JSON property `avatarUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :avatar_uri
|
||
|
|
||
|
# Optional. To filter out false positive results and still get variety in
|
||
|
# matched natural language inputs for your agent, you can tune the machine
|
||
|
# learning classification threshold. If the returned score value is less than
|
||
|
# the threshold value, then a fallback intent is be triggered or, if there
|
||
|
# are no fallback intents defined, no intent will be triggered. The score
|
||
|
# values range from 0.0 (completely uncertain) to 1.0 (completely certain).
|
||
|
# If set to 0.0, the default of 0.3 is used.
|
||
|
# Corresponds to the JSON property `classificationThreshold`
|
||
|
# @return [Float]
|
||
|
attr_accessor :classification_threshold
|
||
|
|
||
|
# Required. The default language of the agent as a language tag. See
|
||
|
# [Language Support](https://dialogflow.com/docs/reference/language) for a
|
||
|
# list of the currently supported language codes.
|
||
|
# This field cannot be set by the `Update` method.
|
||
|
# Corresponds to the JSON property `defaultLanguageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :default_language_code
|
||
|
|
||
|
# Optional. The description of this agent.
|
||
|
# The maximum length is 500 characters. If exceeded, the request is rejected.
|
||
|
# Corresponds to the JSON property `description`
|
||
|
# @return [String]
|
||
|
attr_accessor :description
|
||
|
|
||
|
# Required. The name of this agent.
|
||
|
# Corresponds to the JSON property `displayName`
|
||
|
# @return [String]
|
||
|
attr_accessor :display_name
|
||
|
|
||
|
# Optional. Determines whether this agent should log conversation queries.
|
||
|
# Corresponds to the JSON property `enableLogging`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :enable_logging
|
||
|
alias_method :enable_logging?, :enable_logging
|
||
|
|
||
|
# Optional. Determines how intents are detected from user queries.
|
||
|
# Corresponds to the JSON property `matchMode`
|
||
|
# @return [String]
|
||
|
attr_accessor :match_mode
|
||
|
|
||
|
# Required. The project of this agent.
|
||
|
# Format: `projects/<Project ID>`.
|
||
|
# Corresponds to the JSON property `parent`
|
||
|
# @return [String]
|
||
|
attr_accessor :parent
|
||
|
|
||
|
# Optional. The list of all languages supported by this agent (except for the
|
||
|
# `default_language_code`).
|
||
|
# Corresponds to the JSON property `supportedLanguageCodes`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :supported_language_codes
|
||
|
|
||
|
# Required. The time zone of this agent from the
|
||
|
# [time zone database](https://www.iana.org/time-zones), e.g.,
|
||
|
# America/New_York, Europe/Paris.
|
||
|
# Corresponds to the JSON property `timeZone`
|
||
|
# @return [String]
|
||
|
attr_accessor :time_zone
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@avatar_uri = args[:avatar_uri] if args.key?(:avatar_uri)
|
||
|
@classification_threshold = args[:classification_threshold] if args.key?(:classification_threshold)
|
||
|
@default_language_code = args[:default_language_code] if args.key?(:default_language_code)
|
||
|
@description = args[:description] if args.key?(:description)
|
||
|
@display_name = args[:display_name] if args.key?(:display_name)
|
||
|
@enable_logging = args[:enable_logging] if args.key?(:enable_logging)
|
||
|
@match_mode = args[:match_mode] if args.key?(:match_mode)
|
||
|
@parent = args[:parent] if args.key?(:parent)
|
||
|
@supported_language_codes = args[:supported_language_codes] if args.key?(:supported_language_codes)
|
||
|
@time_zone = args[:time_zone] if args.key?(:time_zone)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for EntityTypes.BatchCreateEntities.
|
||
|
class BatchCreateEntitiesRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The collection of entities to create.
|
||
|
# Corresponds to the JSON property `entities`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityTypeEntity>]
|
||
|
attr_accessor :entities
|
||
|
|
||
|
# Optional. The language of entity synonyms defined in `entities`. If not
|
||
|
# specified, the agent's default language is used.
|
||
|
# [More than a dozen
|
||
|
# languages](https://dialogflow.com/docs/reference/language) are supported.
|
||
|
# Note: languages must be enabled in the agent, before they can be used.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entities = args[:entities] if args.key?(:entities)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for EntityTypes.BatchDeleteEntities.
|
||
|
class BatchDeleteEntitiesRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The canonical `values` of the entities to delete. Note that
|
||
|
# these are not fully-qualified names, i.e. they don't start with
|
||
|
# `projects/<Project ID>`.
|
||
|
# Corresponds to the JSON property `entityValues`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :entity_values
|
||
|
|
||
|
# Optional. The language of entity synonyms defined in `entities`. If not
|
||
|
# specified, the agent's default language is used.
|
||
|
# [More than a dozen
|
||
|
# languages](https://dialogflow.com/docs/reference/language) are supported.
|
||
|
# Note: languages must be enabled in the agent, before they can be used.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entity_values = args[:entity_values] if args.key?(:entity_values)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for EntityTypes.BatchDeleteEntityTypes.
|
||
|
class BatchDeleteEntityTypesRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The names entity types to delete. All names must point to the
|
||
|
# same agent as `parent`.
|
||
|
# Corresponds to the JSON property `entityTypeNames`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :entity_type_names
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entity_type_names = args[:entity_type_names] if args.key?(:entity_type_names)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Intents.BatchDeleteIntents.
|
||
|
class BatchDeleteIntentsRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The collection of intents to delete. Only intent `name` must be
|
||
|
# filled in.
|
||
|
# Corresponds to the JSON property `intents`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Intent>]
|
||
|
attr_accessor :intents
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@intents = args[:intents] if args.key?(:intents)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for EntityTypes.BatchCreateEntities.
|
||
|
class BatchUpdateEntitiesRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The collection of new entities to replace the existing entities.
|
||
|
# Corresponds to the JSON property `entities`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityTypeEntity>]
|
||
|
attr_accessor :entities
|
||
|
|
||
|
# Optional. The language of entity synonyms defined in `entities`. If not
|
||
|
# specified, the agent's default language is used.
|
||
|
# [More than a dozen
|
||
|
# languages](https://dialogflow.com/docs/reference/language) are supported.
|
||
|
# Note: languages must be enabled in the agent, before they can be used.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Optional. The mask to control which fields get updated.
|
||
|
# 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)
|
||
|
@entities = args[:entities] if args.key?(:entities)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@update_mask = args[:update_mask] if args.key?(:update_mask)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for EntityTypes.BatchUpdateEntityTypes.
|
||
|
class BatchUpdateEntityTypesRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# This message is a wrapper around a collection of entity types.
|
||
|
# Corresponds to the JSON property `entityTypeBatchInline`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::EntityTypeBatch]
|
||
|
attr_accessor :entity_type_batch_inline
|
||
|
|
||
|
# Warning: Importing entity types from a URI is not implemented yet.
|
||
|
# This feature is coming soon.
|
||
|
# The URI to a Google Cloud Storage file containing entity types to update
|
||
|
# or create. The file format can either be a serialized proto (of
|
||
|
# EntityBatch type) or a JSON object. Note: The URI must start with
|
||
|
# "gs://".
|
||
|
# Corresponds to the JSON property `entityTypeBatchUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :entity_type_batch_uri
|
||
|
|
||
|
# Optional. The language of entity synonyms defined in `entity_types`. If not
|
||
|
# specified, the agent's default language is used.
|
||
|
# [More than a dozen
|
||
|
# languages](https://dialogflow.com/docs/reference/language) are supported.
|
||
|
# Note: languages must be enabled in the agent, before they can be used.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Optional. The mask to control which fields get updated.
|
||
|
# 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)
|
||
|
@entity_type_batch_inline = args[:entity_type_batch_inline] if args.key?(:entity_type_batch_inline)
|
||
|
@entity_type_batch_uri = args[:entity_type_batch_uri] if args.key?(:entity_type_batch_uri)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@update_mask = args[:update_mask] if args.key?(:update_mask)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for EntityTypes.BatchUpdateEntityTypes.
|
||
|
class BatchUpdateEntityTypesResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The collection of updated or created entity types.
|
||
|
# Corresponds to the JSON property `entityTypes`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityType>]
|
||
|
attr_accessor :entity_types
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entity_types = args[:entity_types] if args.key?(:entity_types)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Intents.BatchUpdateIntents.
|
||
|
class BatchUpdateIntentsRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# This message is a wrapper around a collection of intents.
|
||
|
# Corresponds to the JSON property `intentBatchInline`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentBatch]
|
||
|
attr_accessor :intent_batch_inline
|
||
|
|
||
|
# Warning: Importing intents from a URI is not implemented yet.
|
||
|
# This feature is coming soon.
|
||
|
# The URI to a Google Cloud Storage file containing intents to update or
|
||
|
# create. The file format can either be a serialized proto (of IntentBatch
|
||
|
# type) or JSON object. Note: The URI must start with "gs://".
|
||
|
# Corresponds to the JSON property `intentBatchUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :intent_batch_uri
|
||
|
|
||
|
# Optional. The resource view to apply to the returned intent.
|
||
|
# Corresponds to the JSON property `intentView`
|
||
|
# @return [String]
|
||
|
attr_accessor :intent_view
|
||
|
|
||
|
# Optional. The language of training phrases, parameters and rich messages
|
||
|
# defined in `intents`. If not specified, the agent's default language is
|
||
|
# used. [More than a dozen
|
||
|
# languages](https://dialogflow.com/docs/reference/language) are supported.
|
||
|
# Note: languages must be enabled in the agent, before they can be used.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Optional. The mask to control which fields get updated.
|
||
|
# 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)
|
||
|
@intent_batch_inline = args[:intent_batch_inline] if args.key?(:intent_batch_inline)
|
||
|
@intent_batch_uri = args[:intent_batch_uri] if args.key?(:intent_batch_uri)
|
||
|
@intent_view = args[:intent_view] if args.key?(:intent_view)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@update_mask = args[:update_mask] if args.key?(:update_mask)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for Intents.BatchUpdateIntents.
|
||
|
class BatchUpdateIntentsResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The collection of updated or created intents.
|
||
|
# Corresponds to the JSON property `intents`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Intent>]
|
||
|
attr_accessor :intents
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@intents = args[:intents] if args.key?(:intents)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents a context.
|
||
|
class Context
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The number of conversational query requests after which the
|
||
|
# context expires. If set to `0` (the default) the context expires
|
||
|
# immediately. Contexts expire automatically after 10 minutes even if there
|
||
|
# are no matching queries.
|
||
|
# Corresponds to the JSON property `lifespanCount`
|
||
|
# @return [Fixnum]
|
||
|
attr_accessor :lifespan_count
|
||
|
|
||
|
# Required. The unique identifier of the context. Format:
|
||
|
# `projects/<Project ID>/agent/sessions/<Session ID>/contexts/<Context ID>`.
|
||
|
# Note: The Context ID is always converted to lowercase.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
# Optional. The collection of parameters associated with this context.
|
||
|
# Refer to [this doc](https://dialogflow.com/docs/actions-and-parameters) for
|
||
|
# syntax.
|
||
|
# Corresponds to the JSON property `parameters`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :parameters
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@lifespan_count = args[:lifespan_count] if args.key?(:lifespan_count)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
@parameters = args[:parameters] if args.key?(:parameters)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request to detect user's intent.
|
||
|
class DetectIntentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The natural language speech audio to be processed. This field
|
||
|
# should be populated iff `query_input` is set to an input audio config.
|
||
|
# A single request can contain up to 1 minute of speech audio data.
|
||
|
# Corresponds to the JSON property `inputAudio`
|
||
|
# NOTE: Values are automatically base64 encoded/decoded in the client library.
|
||
|
# @return [String]
|
||
|
attr_accessor :input_audio
|
||
|
|
||
|
# Represents the query input. It can contain either:
|
||
|
# 1. an audio config which
|
||
|
# instructs the speech recognizer how to process the speech audio,
|
||
|
# 2. a conversational query in the form of text, or
|
||
|
# 3. an event that specifies which intent to trigger.
|
||
|
# Corresponds to the JSON property `queryInput`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::QueryInput]
|
||
|
attr_accessor :query_input
|
||
|
|
||
|
# Represents the parameters of the conversational query.
|
||
|
# Corresponds to the JSON property `queryParams`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::QueryParameters]
|
||
|
attr_accessor :query_params
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@input_audio = args[:input_audio] if args.key?(:input_audio)
|
||
|
@query_input = args[:query_input] if args.key?(:query_input)
|
||
|
@query_params = args[:query_params] if args.key?(:query_params)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The message returned from the DetectIntent method.
|
||
|
class DetectIntentResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Represents the result of conversational query or event processing.
|
||
|
# Corresponds to the JSON property `queryResult`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::QueryResult]
|
||
|
attr_accessor :query_result
|
||
|
|
||
|
# The unique identifier of the response. It can be used to
|
||
|
# locate a response in the training example set or for reporting issues.
|
||
|
# Corresponds to the JSON property `responseId`
|
||
|
# @return [String]
|
||
|
attr_accessor :response_id
|
||
|
|
||
|
# 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). The error model is designed to be:
|
||
|
# - Simple to use and understand for most users
|
||
|
# - Flexible enough to meet unexpected needs
|
||
|
# # Overview
|
||
|
# The `Status` message contains three pieces of data: error code, error message,
|
||
|
# and error details. The error code should be an enum value of
|
||
|
# google.rpc.Code, but it may accept additional error codes if needed. The
|
||
|
# error message should be a developer-facing English message that helps
|
||
|
# developers *understand* and *resolve* the error. If a localized user-facing
|
||
|
# error message is needed, put the localized message in the error details or
|
||
|
# localize it in the client. The optional error details may contain arbitrary
|
||
|
# information about the error. There is a predefined set of error detail types
|
||
|
# in the package `google.rpc` that can be used for common error conditions.
|
||
|
# # Language mapping
|
||
|
# The `Status` message is the logical representation of the error model, but it
|
||
|
# is not necessarily the actual wire format. When the `Status` message is
|
||
|
# exposed in different client libraries and different wire protocols, it can be
|
||
|
# mapped differently. For example, it will likely be mapped to some exceptions
|
||
|
# in Java, but more likely mapped to some error codes in C.
|
||
|
# # Other uses
|
||
|
# The error model and the `Status` message can be used in a variety of
|
||
|
# environments, either with or without APIs, to provide a
|
||
|
# consistent developer experience across different environments.
|
||
|
# Example uses of this error model include:
|
||
|
# - Partial errors. If a service needs to return partial errors to the client,
|
||
|
# it may embed the `Status` in the normal response to indicate the partial
|
||
|
# errors.
|
||
|
# - Workflow errors. A typical workflow has multiple steps. Each step may
|
||
|
# have a `Status` message for error reporting.
|
||
|
# - Batch operations. If a client uses batch request and batch response, the
|
||
|
# `Status` message should be used directly inside batch response, one for
|
||
|
# each error sub-response.
|
||
|
# - Asynchronous operations. If an API call embeds asynchronous operation
|
||
|
# results in its response, the status of those operations should be
|
||
|
# represented directly using the `Status` message.
|
||
|
# - Logging. If some API errors are stored in logs, the message `Status` could
|
||
|
# be used directly after any stripping needed for security/privacy reasons.
|
||
|
# Corresponds to the JSON property `webhookStatus`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::Status]
|
||
|
attr_accessor :webhook_status
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@query_result = args[:query_result] if args.key?(:query_result)
|
||
|
@response_id = args[:response_id] if args.key?(:response_id)
|
||
|
@webhook_status = args[:webhook_status] if args.key?(:webhook_status)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# A generic empty message that you can re-use to avoid defining duplicated
|
||
|
# empty messages in your APIs. A typical example is to use it as the request
|
||
|
# or the response type of an API method. For instance:
|
||
|
# service Foo `
|
||
|
# rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty);
|
||
|
# `
|
||
|
# The JSON representation for `Empty` is empty JSON object ````.
|
||
|
class Empty
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents an entity type.
|
||
|
# Entity types serve as a tool for extracting parameter values from natural
|
||
|
# language queries.
|
||
|
class EntityType
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. Indicates whether the entity type can be automatically
|
||
|
# expanded.
|
||
|
# Corresponds to the JSON property `autoExpansionMode`
|
||
|
# @return [String]
|
||
|
attr_accessor :auto_expansion_mode
|
||
|
|
||
|
# Required. The name of the entity.
|
||
|
# Corresponds to the JSON property `displayName`
|
||
|
# @return [String]
|
||
|
attr_accessor :display_name
|
||
|
|
||
|
# Optional. The collection of entities associated with the entity type.
|
||
|
# Corresponds to the JSON property `entities`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityTypeEntity>]
|
||
|
attr_accessor :entities
|
||
|
|
||
|
# Required. Indicates the kind of entity type.
|
||
|
# Corresponds to the JSON property `kind`
|
||
|
# @return [String]
|
||
|
attr_accessor :kind
|
||
|
|
||
|
# Required for all methods except `create` (`create` populates the name
|
||
|
# automatically.
|
||
|
# The unique identifier of the entity type. Format:
|
||
|
# `projects/<Project ID>/agent/entityTypes/<Entity Type ID>`.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@auto_expansion_mode = args[:auto_expansion_mode] if args.key?(:auto_expansion_mode)
|
||
|
@display_name = args[:display_name] if args.key?(:display_name)
|
||
|
@entities = args[:entities] if args.key?(:entities)
|
||
|
@kind = args[:kind] if args.key?(:kind)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# This message is a wrapper around a collection of entity types.
|
||
|
class EntityTypeBatch
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# A collection of entity types.
|
||
|
# Corresponds to the JSON property `entityTypes`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityType>]
|
||
|
attr_accessor :entity_types
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entity_types = args[:entity_types] if args.key?(:entity_types)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Optional. Represents an entity.
|
||
|
class EntityTypeEntity
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. A collection of synonyms. For `KIND_LIST` entity types this
|
||
|
# must contain exactly one synonym equal to `value`.
|
||
|
# Corresponds to the JSON property `synonyms`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :synonyms
|
||
|
|
||
|
# Required.
|
||
|
# For `KIND_MAP` entity types:
|
||
|
# A canonical name to be used in place of synonyms.
|
||
|
# For `KIND_LIST` entity types:
|
||
|
# A string that can contain references to other entity types (with or
|
||
|
# without aliases).
|
||
|
# 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)
|
||
|
@synonyms = args[:synonyms] if args.key?(:synonyms)
|
||
|
@value = args[:value] if args.key?(:value)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Events allow for matching intents by event name instead of the natural
|
||
|
# language input. For instance, input `<event: ` name: “welcome_event”,
|
||
|
# parameters: ` name: “Sam” ` `>` can trigger a personalized welcome response.
|
||
|
# The parameter `name` may be used by the agent in the response:
|
||
|
# `“Hello #welcome_event.name! What can I do for you today?”`.
|
||
|
class EventInput
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The language of this query. See [Language
|
||
|
# Support](https://dialogflow.com/docs/languages) for a list of the
|
||
|
# currently supported language codes. Note that queries in the same session
|
||
|
# do not necessarily need to specify the same language.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Required. The unique identifier of the event.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
# Optional. The collection of parameters associated with the event.
|
||
|
# Corresponds to the JSON property `parameters`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :parameters
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
@parameters = args[:parameters] if args.key?(:parameters)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Agents.ExportAgent.
|
||
|
class ExportAgentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Warning: Exporting agents to a URI is not implemented yet.
|
||
|
# This feature is coming soon.
|
||
|
# Optional. The Google Cloud Storage URI to export the agent to.
|
||
|
# Note: The URI must start with
|
||
|
# "gs://". If left unspecified, the serialized agent is returned inline.
|
||
|
# Corresponds to the JSON property `agentUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@agent_uri = args[:agent_uri] if args.key?(:agent_uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for Agents.ExportAgent.
|
||
|
class ExportAgentResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The exported agent.
|
||
|
# Corresponds to the JSON property `agentContent`
|
||
|
# NOTE: Values are automatically base64 encoded/decoded in the client library.
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_content
|
||
|
|
||
|
# The URI to a file containing the exported agent. This field is populated
|
||
|
# only if `agent_uri`
|
||
|
# Corresponds to the JSON property `agentUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@agent_content = args[:agent_content] if args.key?(:agent_content)
|
||
|
@agent_uri = args[:agent_uri] if args.key?(:agent_uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Agents.ImportAgent.
|
||
|
class ImportAgentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The agent to import.
|
||
|
# Corresponds to the JSON property `agentContent`
|
||
|
# NOTE: Values are automatically base64 encoded/decoded in the client library.
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_content
|
||
|
|
||
|
# Warning: Importing agents from a URI is not implemented yet.
|
||
|
# This feature is coming soon.
|
||
|
# The URI to a Google Cloud Storage file containing the agent to import.
|
||
|
# Note: The URI must start with "gs://".
|
||
|
# Corresponds to the JSON property `agentUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@agent_content = args[:agent_content] if args.key?(:agent_content)
|
||
|
@agent_uri = args[:agent_uri] if args.key?(:agent_uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Instructs the speech recognizer how to process the audio content.
|
||
|
class InputAudioConfig
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. Audio encoding of the audio content to process.
|
||
|
# Corresponds to the JSON property `audioEncoding`
|
||
|
# @return [String]
|
||
|
attr_accessor :audio_encoding
|
||
|
|
||
|
# Required. The language of the supplied audio. Dialogflow does not do
|
||
|
# translations. See [Language
|
||
|
# Support](https://dialogflow.com/docs/languages) for a list of the
|
||
|
# currently supported language codes. Note that queries in the same session
|
||
|
# do not necessarily need to specify the same language.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Optional. The collection of phrase hints which are used to boost accuracy
|
||
|
# of speech recognition.
|
||
|
# Refer to [Cloud Speech API documentation](/speech/docs/basics#phrase-hints)
|
||
|
# for more details.
|
||
|
# Corresponds to the JSON property `phraseHints`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :phrase_hints
|
||
|
|
||
|
# Required. Sample rate (in Hertz) of the audio content sent in the query.
|
||
|
# Refer to [Cloud Speech API documentation](/speech/docs/basics) for more
|
||
|
# details.
|
||
|
# Corresponds to the JSON property `sampleRateHertz`
|
||
|
# @return [Fixnum]
|
||
|
attr_accessor :sample_rate_hertz
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@audio_encoding = args[:audio_encoding] if args.key?(:audio_encoding)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@phrase_hints = args[:phrase_hints] if args.key?(:phrase_hints)
|
||
|
@sample_rate_hertz = args[:sample_rate_hertz] if args.key?(:sample_rate_hertz)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents an intent.
|
||
|
# Intents convert a number of user expressions or patterns into an action. An
|
||
|
# action is an extraction of a user command or sentence semantics.
|
||
|
class Intent
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The name of the action associated with the intent.
|
||
|
# Corresponds to the JSON property `action`
|
||
|
# @return [String]
|
||
|
attr_accessor :action
|
||
|
|
||
|
# Optional. The list of platforms for which the first response will be
|
||
|
# taken from among the messages assigned to the DEFAULT_PLATFORM.
|
||
|
# Corresponds to the JSON property `defaultResponsePlatforms`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :default_response_platforms
|
||
|
|
||
|
# Required. The name of this intent.
|
||
|
# Corresponds to the JSON property `displayName`
|
||
|
# @return [String]
|
||
|
attr_accessor :display_name
|
||
|
|
||
|
# Optional. The collection of event names that trigger the intent.
|
||
|
# If the collection of input contexts is not empty, all of the contexts must
|
||
|
# be present in the active user session for an event to trigger this intent.
|
||
|
# Corresponds to the JSON property `events`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :events
|
||
|
|
||
|
# Optional. Collection of information about all followup intents that have
|
||
|
# name of this intent as a root_name.
|
||
|
# Corresponds to the JSON property `followupIntentInfo`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentFollowupIntentInfo>]
|
||
|
attr_accessor :followup_intent_info
|
||
|
|
||
|
# Optional. The list of context names required for this intent to be
|
||
|
# triggered.
|
||
|
# Format: `projects/<Project ID>/agent/sessions/-/contexts/<Context ID>`.
|
||
|
# Corresponds to the JSON property `inputContextNames`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :input_context_names
|
||
|
|
||
|
# Optional. Indicates whether this is a fallback intent.
|
||
|
# Corresponds to the JSON property `isFallback`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :is_fallback
|
||
|
alias_method :is_fallback?, :is_fallback
|
||
|
|
||
|
# Optional. The collection of rich messages corresponding to the
|
||
|
# `Response` field in API.AI console.
|
||
|
# Corresponds to the JSON property `messages`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessage>]
|
||
|
attr_accessor :messages
|
||
|
|
||
|
# Optional. Indicates whether Machine Learning is enabled for the intent.
|
||
|
# Note: If `ml_enabled` setting is set to false, then this intent is not
|
||
|
# taken into account during inference in `ML ONLY` match mode. Also,
|
||
|
# auto-markup in the UI is turned off.
|
||
|
# Corresponds to the JSON property `mlEnabled`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :ml_enabled
|
||
|
alias_method :ml_enabled?, :ml_enabled
|
||
|
|
||
|
# Required for all methods except `create` (`create` populates the name
|
||
|
# automatically.
|
||
|
# The unique identifier of this intent.
|
||
|
# Format: `projects/<Project ID>/agent/intents/<Intent ID>`.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
# Optional. The collection of contexts that are activated when the intent
|
||
|
# is matched. Context messages in this collection should not set the
|
||
|
# parameters field. Setting the `lifespan_count` to 0 will reset the context
|
||
|
# when the intent is matched.
|
||
|
# Format: `projects/<Project ID>/agent/sessions/-/contexts/<Context ID>`.
|
||
|
# Corresponds to the JSON property `outputContexts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Context>]
|
||
|
attr_accessor :output_contexts
|
||
|
|
||
|
# Optional. The collection of parameters associated with the intent.
|
||
|
# Corresponds to the JSON property `parameters`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentParameter>]
|
||
|
attr_accessor :parameters
|
||
|
|
||
|
# The unique identifier of the parent intent in the chain of followup
|
||
|
# intents.
|
||
|
# It identifies the parent followup intent.
|
||
|
# Format: `projects/<Project ID>/agent/intents/<Intent ID>`.
|
||
|
# Corresponds to the JSON property `parentFollowupIntentName`
|
||
|
# @return [String]
|
||
|
attr_accessor :parent_followup_intent_name
|
||
|
|
||
|
# Optional. The priority of this intent. Higher numbers represent higher
|
||
|
# priorities. Zero or negative numbers mean that the intent is disabled.
|
||
|
# Corresponds to the JSON property `priority`
|
||
|
# @return [Fixnum]
|
||
|
attr_accessor :priority
|
||
|
|
||
|
# Optional. Indicates whether to delete all contexts in the current
|
||
|
# session when this intent is matched.
|
||
|
# Corresponds to the JSON property `resetContexts`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :reset_contexts
|
||
|
alias_method :reset_contexts?, :reset_contexts
|
||
|
|
||
|
# The unique identifier of the root intent in the chain of followup intents.
|
||
|
# It identifies the correct followup intents chain for this intent.
|
||
|
# Format: `projects/<Project ID>/agent/intents/<Intent ID>`.
|
||
|
# Corresponds to the JSON property `rootFollowupIntentName`
|
||
|
# @return [String]
|
||
|
attr_accessor :root_followup_intent_name
|
||
|
|
||
|
# Optional. The collection of examples/templates that the agent is
|
||
|
# trained on.
|
||
|
# Corresponds to the JSON property `trainingPhrases`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentTrainingPhrase>]
|
||
|
attr_accessor :training_phrases
|
||
|
|
||
|
# Required. Indicates whether webhooks are enabled for the intent.
|
||
|
# Corresponds to the JSON property `webhookState`
|
||
|
# @return [String]
|
||
|
attr_accessor :webhook_state
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@action = args[:action] if args.key?(:action)
|
||
|
@default_response_platforms = args[:default_response_platforms] if args.key?(:default_response_platforms)
|
||
|
@display_name = args[:display_name] if args.key?(:display_name)
|
||
|
@events = args[:events] if args.key?(:events)
|
||
|
@followup_intent_info = args[:followup_intent_info] if args.key?(:followup_intent_info)
|
||
|
@input_context_names = args[:input_context_names] if args.key?(:input_context_names)
|
||
|
@is_fallback = args[:is_fallback] if args.key?(:is_fallback)
|
||
|
@messages = args[:messages] if args.key?(:messages)
|
||
|
@ml_enabled = args[:ml_enabled] if args.key?(:ml_enabled)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
@output_contexts = args[:output_contexts] if args.key?(:output_contexts)
|
||
|
@parameters = args[:parameters] if args.key?(:parameters)
|
||
|
@parent_followup_intent_name = args[:parent_followup_intent_name] if args.key?(:parent_followup_intent_name)
|
||
|
@priority = args[:priority] if args.key?(:priority)
|
||
|
@reset_contexts = args[:reset_contexts] if args.key?(:reset_contexts)
|
||
|
@root_followup_intent_name = args[:root_followup_intent_name] if args.key?(:root_followup_intent_name)
|
||
|
@training_phrases = args[:training_phrases] if args.key?(:training_phrases)
|
||
|
@webhook_state = args[:webhook_state] if args.key?(:webhook_state)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# This message is a wrapper around a collection of intents.
|
||
|
class IntentBatch
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# A collection of intents.
|
||
|
# Corresponds to the JSON property `intents`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Intent>]
|
||
|
attr_accessor :intents
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@intents = args[:intents] if args.key?(:intents)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents a single followup intent in the chain.
|
||
|
class IntentFollowupIntentInfo
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The unique identifier of the followup intent.
|
||
|
# Format: `projects/<Project ID>/agent/intents/<Intent ID>`.
|
||
|
# Corresponds to the JSON property `followupIntentName`
|
||
|
# @return [String]
|
||
|
attr_accessor :followup_intent_name
|
||
|
|
||
|
# The unique identifier of the followup intent parent.
|
||
|
# Format: `projects/<Project ID>/agent/intents/<Intent ID>`.
|
||
|
# Corresponds to the JSON property `parentFollowupIntentName`
|
||
|
# @return [String]
|
||
|
attr_accessor :parent_followup_intent_name
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@followup_intent_name = args[:followup_intent_name] if args.key?(:followup_intent_name)
|
||
|
@parent_followup_intent_name = args[:parent_followup_intent_name] if args.key?(:parent_followup_intent_name)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Corresponds to the `Response` field in API.AI console.
|
||
|
class IntentMessage
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The basic card message. Useful for displaying information.
|
||
|
# Corresponds to the JSON property `basicCard`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageBasicCard]
|
||
|
attr_accessor :basic_card
|
||
|
|
||
|
# The card response message.
|
||
|
# Corresponds to the JSON property `card`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageCard]
|
||
|
attr_accessor :card
|
||
|
|
||
|
# The card for presenting a carousel of options to select from.
|
||
|
# Corresponds to the JSON property `carouselSelect`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageCarouselSelect]
|
||
|
attr_accessor :carousel_select
|
||
|
|
||
|
# The image response message.
|
||
|
# Corresponds to the JSON property `image`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageImage]
|
||
|
attr_accessor :image
|
||
|
|
||
|
# The suggestion chip message that allows the user to jump out to the app
|
||
|
# or website associated with this agent.
|
||
|
# Corresponds to the JSON property `linkOutSuggestion`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageLinkOutSuggestion]
|
||
|
attr_accessor :link_out_suggestion
|
||
|
|
||
|
# The card for presenting a list of options to select from.
|
||
|
# Corresponds to the JSON property `listSelect`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageListSelect]
|
||
|
attr_accessor :list_select
|
||
|
|
||
|
# The response containing a custom payload.
|
||
|
# Corresponds to the JSON property `payload`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :payload
|
||
|
|
||
|
# Optional. The platform that this message is intended for.
|
||
|
# Corresponds to the JSON property `platform`
|
||
|
# @return [String]
|
||
|
attr_accessor :platform
|
||
|
|
||
|
# The quick replies response message.
|
||
|
# Corresponds to the JSON property `quickReplies`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageQuickReplies]
|
||
|
attr_accessor :quick_replies
|
||
|
|
||
|
# The collection of simple response candidates.
|
||
|
# This message in `QueryResult.fulfillment_messages` and
|
||
|
# `WebhookResponse.fulfillment_messages` should contain only one
|
||
|
# `SimpleResponse`.
|
||
|
# Corresponds to the JSON property `simpleResponses`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageSimpleResponses]
|
||
|
attr_accessor :simple_responses
|
||
|
|
||
|
# The collection of suggestions.
|
||
|
# Corresponds to the JSON property `suggestions`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageSuggestions]
|
||
|
attr_accessor :suggestions
|
||
|
|
||
|
# The text response message.
|
||
|
# Corresponds to the JSON property `text`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageText]
|
||
|
attr_accessor :text
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@basic_card = args[:basic_card] if args.key?(:basic_card)
|
||
|
@card = args[:card] if args.key?(:card)
|
||
|
@carousel_select = args[:carousel_select] if args.key?(:carousel_select)
|
||
|
@image = args[:image] if args.key?(:image)
|
||
|
@link_out_suggestion = args[:link_out_suggestion] if args.key?(:link_out_suggestion)
|
||
|
@list_select = args[:list_select] if args.key?(:list_select)
|
||
|
@payload = args[:payload] if args.key?(:payload)
|
||
|
@platform = args[:platform] if args.key?(:platform)
|
||
|
@quick_replies = args[:quick_replies] if args.key?(:quick_replies)
|
||
|
@simple_responses = args[:simple_responses] if args.key?(:simple_responses)
|
||
|
@suggestions = args[:suggestions] if args.key?(:suggestions)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The basic card message. Useful for displaying information.
|
||
|
class IntentMessageBasicCard
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The collection of card buttons.
|
||
|
# Corresponds to the JSON property `buttons`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageBasicCardButton>]
|
||
|
attr_accessor :buttons
|
||
|
|
||
|
# Required, unless image is present. The body text of the card.
|
||
|
# Corresponds to the JSON property `formattedText`
|
||
|
# @return [String]
|
||
|
attr_accessor :formatted_text
|
||
|
|
||
|
# The image response message.
|
||
|
# Corresponds to the JSON property `image`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageImage]
|
||
|
attr_accessor :image
|
||
|
|
||
|
# Optional. The subtitle of the card.
|
||
|
# Corresponds to the JSON property `subtitle`
|
||
|
# @return [String]
|
||
|
attr_accessor :subtitle
|
||
|
|
||
|
# Optional. The title of the card.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@buttons = args[:buttons] if args.key?(:buttons)
|
||
|
@formatted_text = args[:formatted_text] if args.key?(:formatted_text)
|
||
|
@image = args[:image] if args.key?(:image)
|
||
|
@subtitle = args[:subtitle] if args.key?(:subtitle)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The button object that appears at the bottom of a card.
|
||
|
class IntentMessageBasicCardButton
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Opens the given URI.
|
||
|
# Corresponds to the JSON property `openUriAction`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageBasicCardButtonOpenUriAction]
|
||
|
attr_accessor :open_uri_action
|
||
|
|
||
|
# Required. The title of the button.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@open_uri_action = args[:open_uri_action] if args.key?(:open_uri_action)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Opens the given URI.
|
||
|
class IntentMessageBasicCardButtonOpenUriAction
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The HTTP or HTTPS scheme URI.
|
||
|
# Corresponds to the JSON property `uri`
|
||
|
# @return [String]
|
||
|
attr_accessor :uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@uri = args[:uri] if args.key?(:uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The card response message.
|
||
|
class IntentMessageCard
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The collection of card buttons.
|
||
|
# Corresponds to the JSON property `buttons`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageCardButton>]
|
||
|
attr_accessor :buttons
|
||
|
|
||
|
# Optional. The public URI to an image file for the card.
|
||
|
# Corresponds to the JSON property `imageUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :image_uri
|
||
|
|
||
|
# Optional. The subtitle of the card.
|
||
|
# Corresponds to the JSON property `subtitle`
|
||
|
# @return [String]
|
||
|
attr_accessor :subtitle
|
||
|
|
||
|
# Optional. The title of the card.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@buttons = args[:buttons] if args.key?(:buttons)
|
||
|
@image_uri = args[:image_uri] if args.key?(:image_uri)
|
||
|
@subtitle = args[:subtitle] if args.key?(:subtitle)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Optional. Contains information about a button.
|
||
|
class IntentMessageCardButton
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The text to send back to the Dialogflow API or a URI to
|
||
|
# open.
|
||
|
# Corresponds to the JSON property `postback`
|
||
|
# @return [String]
|
||
|
attr_accessor :postback
|
||
|
|
||
|
# Optional. The text to show on the button.
|
||
|
# Corresponds to the JSON property `text`
|
||
|
# @return [String]
|
||
|
attr_accessor :text
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@postback = args[:postback] if args.key?(:postback)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The card for presenting a carousel of options to select from.
|
||
|
class IntentMessageCarouselSelect
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. Carousel items.
|
||
|
# Corresponds to the JSON property `items`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageCarouselSelectItem>]
|
||
|
attr_accessor :items
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@items = args[:items] if args.key?(:items)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# An item in the carousel.
|
||
|
class IntentMessageCarouselSelectItem
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The body text of the card.
|
||
|
# Corresponds to the JSON property `description`
|
||
|
# @return [String]
|
||
|
attr_accessor :description
|
||
|
|
||
|
# The image response message.
|
||
|
# Corresponds to the JSON property `image`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageImage]
|
||
|
attr_accessor :image
|
||
|
|
||
|
# Additional info about the select item for when it is triggered in a
|
||
|
# dialog.
|
||
|
# Corresponds to the JSON property `info`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageSelectItemInfo]
|
||
|
attr_accessor :info
|
||
|
|
||
|
# Required. Title of the carousel item.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@description = args[:description] if args.key?(:description)
|
||
|
@image = args[:image] if args.key?(:image)
|
||
|
@info = args[:info] if args.key?(:info)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The image response message.
|
||
|
class IntentMessageImage
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The public URI to an image file.
|
||
|
# Corresponds to the JSON property `imageUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :image_uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@image_uri = args[:image_uri] if args.key?(:image_uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The suggestion chip message that allows the user to jump out to the app
|
||
|
# or website associated with this agent.
|
||
|
class IntentMessageLinkOutSuggestion
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The name of the app or site this chip is linking to.
|
||
|
# Corresponds to the JSON property `destinationName`
|
||
|
# @return [String]
|
||
|
attr_accessor :destination_name
|
||
|
|
||
|
# Required. The URI of the app or site to open when the user taps the
|
||
|
# suggestion chip.
|
||
|
# Corresponds to the JSON property `uri`
|
||
|
# @return [String]
|
||
|
attr_accessor :uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@destination_name = args[:destination_name] if args.key?(:destination_name)
|
||
|
@uri = args[:uri] if args.key?(:uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The card for presenting a list of options to select from.
|
||
|
class IntentMessageListSelect
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. List items.
|
||
|
# Corresponds to the JSON property `items`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageListSelectItem>]
|
||
|
attr_accessor :items
|
||
|
|
||
|
# Optional. The overall title of the list.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@items = args[:items] if args.key?(:items)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# An item in the list.
|
||
|
class IntentMessageListSelectItem
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The main text describing the item.
|
||
|
# Corresponds to the JSON property `description`
|
||
|
# @return [String]
|
||
|
attr_accessor :description
|
||
|
|
||
|
# The image response message.
|
||
|
# Corresponds to the JSON property `image`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageImage]
|
||
|
attr_accessor :image
|
||
|
|
||
|
# Additional info about the select item for when it is triggered in a
|
||
|
# dialog.
|
||
|
# Corresponds to the JSON property `info`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::IntentMessageSelectItemInfo]
|
||
|
attr_accessor :info
|
||
|
|
||
|
# Required. The title of the list item.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@description = args[:description] if args.key?(:description)
|
||
|
@image = args[:image] if args.key?(:image)
|
||
|
@info = args[:info] if args.key?(:info)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The quick replies response message.
|
||
|
class IntentMessageQuickReplies
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The collection of quick replies.
|
||
|
# Corresponds to the JSON property `quickReplies`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :quick_replies
|
||
|
|
||
|
# Optional. The title of the collection of quick replies.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@quick_replies = args[:quick_replies] if args.key?(:quick_replies)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Additional info about the select item for when it is triggered in a
|
||
|
# dialog.
|
||
|
class IntentMessageSelectItemInfo
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. A unique key that will be sent back to the agent if this
|
||
|
# response is given.
|
||
|
# Corresponds to the JSON property `key`
|
||
|
# @return [String]
|
||
|
attr_accessor :key
|
||
|
|
||
|
# Optional. A list of synonyms that can also be used to trigger this
|
||
|
# item in dialog.
|
||
|
# Corresponds to the JSON property `synonyms`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :synonyms
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@key = args[:key] if args.key?(:key)
|
||
|
@synonyms = args[:synonyms] if args.key?(:synonyms)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The simple response message containing speech or text.
|
||
|
class IntentMessageSimpleResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The text to display.
|
||
|
# Corresponds to the JSON property `displayText`
|
||
|
# @return [String]
|
||
|
attr_accessor :display_text
|
||
|
|
||
|
# One of text_to_speech or ssml must be provided. Structured spoken
|
||
|
# response to the user in the SSML format. Mutually exclusive with
|
||
|
# text_to_speech.
|
||
|
# Corresponds to the JSON property `ssml`
|
||
|
# @return [String]
|
||
|
attr_accessor :ssml
|
||
|
|
||
|
# One of text_to_speech or ssml must be provided. The plain text of the
|
||
|
# speech output. Mutually exclusive with ssml.
|
||
|
# Corresponds to the JSON property `textToSpeech`
|
||
|
# @return [String]
|
||
|
attr_accessor :text_to_speech
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@display_text = args[:display_text] if args.key?(:display_text)
|
||
|
@ssml = args[:ssml] if args.key?(:ssml)
|
||
|
@text_to_speech = args[:text_to_speech] if args.key?(:text_to_speech)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The collection of simple response candidates.
|
||
|
# This message in `QueryResult.fulfillment_messages` and
|
||
|
# `WebhookResponse.fulfillment_messages` should contain only one
|
||
|
# `SimpleResponse`.
|
||
|
class IntentMessageSimpleResponses
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The list of simple responses.
|
||
|
# Corresponds to the JSON property `simpleResponses`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageSimpleResponse>]
|
||
|
attr_accessor :simple_responses
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@simple_responses = args[:simple_responses] if args.key?(:simple_responses)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The suggestion chip message that the user can tap to quickly post a reply
|
||
|
# to the conversation.
|
||
|
class IntentMessageSuggestion
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The text shown the in the suggestion chip.
|
||
|
# Corresponds to the JSON property `title`
|
||
|
# @return [String]
|
||
|
attr_accessor :title
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@title = args[:title] if args.key?(:title)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The collection of suggestions.
|
||
|
class IntentMessageSuggestions
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The list of suggested replies.
|
||
|
# Corresponds to the JSON property `suggestions`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessageSuggestion>]
|
||
|
attr_accessor :suggestions
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@suggestions = args[:suggestions] if args.key?(:suggestions)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The text response message.
|
||
|
class IntentMessageText
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The collection of the agent's responses.
|
||
|
# 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)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents intent parameters.
|
||
|
class IntentParameter
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The default value to use when the `value` yields an empty
|
||
|
# result.
|
||
|
# Default values can be extracted from contexts by using the following
|
||
|
# syntax: `#context_name.parameter_name`.
|
||
|
# Corresponds to the JSON property `defaultValue`
|
||
|
# @return [String]
|
||
|
attr_accessor :default_value
|
||
|
|
||
|
# Required. The name of the parameter.
|
||
|
# Corresponds to the JSON property `displayName`
|
||
|
# @return [String]
|
||
|
attr_accessor :display_name
|
||
|
|
||
|
# Optional. The name of the entity type, prefixed with `@`, that
|
||
|
# describes values of the parameter. If the parameter is
|
||
|
# required, this must be provided.
|
||
|
# Corresponds to the JSON property `entityTypeDisplayName`
|
||
|
# @return [String]
|
||
|
attr_accessor :entity_type_display_name
|
||
|
|
||
|
# Optional. Indicates whether the parameter represents a list of values.
|
||
|
# Corresponds to the JSON property `isList`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :is_list
|
||
|
alias_method :is_list?, :is_list
|
||
|
|
||
|
# Optional. Indicates whether the parameter is required. That is,
|
||
|
# whether the intent cannot be completed without collecting the parameter
|
||
|
# value.
|
||
|
# Corresponds to the JSON property `mandatory`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :mandatory
|
||
|
alias_method :mandatory?, :mandatory
|
||
|
|
||
|
# The unique identifier of this parameter.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
# Optional. The collection of prompts that the agent can present to the
|
||
|
# user in order to collect value for the parameter.
|
||
|
# Corresponds to the JSON property `prompts`
|
||
|
# @return [Array<String>]
|
||
|
attr_accessor :prompts
|
||
|
|
||
|
# Optional. The definition of the parameter value. It can be:
|
||
|
# - a constant string,
|
||
|
# - a parameter value defined as `$parameter_name`,
|
||
|
# - an original parameter value defined as `$parameter_name.original`,
|
||
|
# - a parameter value from some context defined as
|
||
|
# `#context_name.parameter_name`.
|
||
|
# 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)
|
||
|
@default_value = args[:default_value] if args.key?(:default_value)
|
||
|
@display_name = args[:display_name] if args.key?(:display_name)
|
||
|
@entity_type_display_name = args[:entity_type_display_name] if args.key?(:entity_type_display_name)
|
||
|
@is_list = args[:is_list] if args.key?(:is_list)
|
||
|
@mandatory = args[:mandatory] if args.key?(:mandatory)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
@prompts = args[:prompts] if args.key?(:prompts)
|
||
|
@value = args[:value] if args.key?(:value)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents an example or template that the agent is trained on.
|
||
|
class IntentTrainingPhrase
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The unique identifier of this training phrase.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
# Required. The collection of training phrase parts (can be annotated).
|
||
|
# Fields: `entity_type`, `alias` and `user_defined` should be populated
|
||
|
# only for the annotated parts of the training phrase.
|
||
|
# Corresponds to the JSON property `parts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentTrainingPhrasePart>]
|
||
|
attr_accessor :parts
|
||
|
|
||
|
# Optional. Indicates how many times this example or template was added to
|
||
|
# the intent. Each time a developer adds an existing sample by editing an
|
||
|
# intent or training, this counter is increased.
|
||
|
# Corresponds to the JSON property `timesAddedCount`
|
||
|
# @return [Fixnum]
|
||
|
attr_accessor :times_added_count
|
||
|
|
||
|
# Required. The type of the training phrase.
|
||
|
# 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)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
@parts = args[:parts] if args.key?(:parts)
|
||
|
@times_added_count = args[:times_added_count] if args.key?(:times_added_count)
|
||
|
@type = args[:type] if args.key?(:type)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents a part of a training phrase.
|
||
|
class IntentTrainingPhrasePart
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The parameter name for the value extracted from the
|
||
|
# annotated part of the example.
|
||
|
# Corresponds to the JSON property `alias`
|
||
|
# @return [String]
|
||
|
attr_accessor :alias
|
||
|
|
||
|
# Optional. The entity type name prefixed with `@`. This field is
|
||
|
# required for the annotated part of the text and applies only to
|
||
|
# examples.
|
||
|
# Corresponds to the JSON property `entityType`
|
||
|
# @return [String]
|
||
|
attr_accessor :entity_type
|
||
|
|
||
|
# Required. The text corresponding to the example or template,
|
||
|
# if there are no annotations. For
|
||
|
# annotated examples, it is the text for one of the example's parts.
|
||
|
# Corresponds to the JSON property `text`
|
||
|
# @return [String]
|
||
|
attr_accessor :text
|
||
|
|
||
|
# Optional. Indicates whether the text was manually annotated by the
|
||
|
# developer.
|
||
|
# Corresponds to the JSON property `userDefined`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :user_defined
|
||
|
alias_method :user_defined?, :user_defined
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@alias = args[:alias] if args.key?(:alias)
|
||
|
@entity_type = args[:entity_type] if args.key?(:entity_type)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
@user_defined = args[:user_defined] if args.key?(:user_defined)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# An object representing a latitude/longitude pair. This is expressed as a pair
|
||
|
# of doubles representing degrees latitude and degrees longitude. Unless
|
||
|
# specified otherwise, this must conform to the
|
||
|
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
|
||
|
# standard</a>. Values must be within normalized ranges.
|
||
|
class LatLng
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The latitude in degrees. It must be in the range [-90.0, +90.0].
|
||
|
# Corresponds to the JSON property `latitude`
|
||
|
# @return [Float]
|
||
|
attr_accessor :latitude
|
||
|
|
||
|
# The longitude in degrees. It must be in the range [-180.0, +180.0].
|
||
|
# Corresponds to the JSON property `longitude`
|
||
|
# @return [Float]
|
||
|
attr_accessor :longitude
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@latitude = args[:latitude] if args.key?(:latitude)
|
||
|
@longitude = args[:longitude] if args.key?(:longitude)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for Contexts.ListContexts.
|
||
|
class ListContextsResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The list of contexts. There will be a maximum number of items
|
||
|
# returned based on the page_size field in the request.
|
||
|
# Corresponds to the JSON property `contexts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Context>]
|
||
|
attr_accessor :contexts
|
||
|
|
||
|
# Token to retrieve the next page of results, or empty if there are no
|
||
|
# more results in the list.
|
||
|
# 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)
|
||
|
@contexts = args[:contexts] if args.key?(:contexts)
|
||
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for EntityTypes.ListEntityTypes.
|
||
|
class ListEntityTypesResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The list of agent entity types. There will be a maximum number of items
|
||
|
# returned based on the page_size field in the request.
|
||
|
# Corresponds to the JSON property `entityTypes`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityType>]
|
||
|
attr_accessor :entity_types
|
||
|
|
||
|
# Token to retrieve the next page of results, or empty if there are no
|
||
|
# more results in the list.
|
||
|
# 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)
|
||
|
@entity_types = args[:entity_types] if args.key?(:entity_types)
|
||
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for Intents.ListIntents.
|
||
|
class ListIntentsResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The list of agent intents. There will be a maximum number of items
|
||
|
# returned based on the page_size field in the request.
|
||
|
# Corresponds to the JSON property `intents`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Intent>]
|
||
|
attr_accessor :intents
|
||
|
|
||
|
# Token to retrieve the next page of results, or empty if there are no
|
||
|
# more results in the list.
|
||
|
# 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)
|
||
|
@intents = args[:intents] if args.key?(:intents)
|
||
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for SessionEntityTypes.ListSessionEntityTypes.
|
||
|
class ListSessionEntityTypesResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Token to retrieve the next page of results, or empty if there are no
|
||
|
# more results in the list.
|
||
|
# Corresponds to the JSON property `nextPageToken`
|
||
|
# @return [String]
|
||
|
attr_accessor :next_page_token
|
||
|
|
||
|
# The list of session entity types. There will be a maximum number of items
|
||
|
# returned based on the page_size field in the request.
|
||
|
# Corresponds to the JSON property `sessionEntityTypes`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::SessionEntityType>]
|
||
|
attr_accessor :session_entity_types
|
||
|
|
||
|
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)
|
||
|
@session_entity_types = args[:session_entity_types] if args.key?(:session_entity_types)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# This resource represents a long-running operation that is the result of a
|
||
|
# network API call.
|
||
|
class Operation
|
||
|
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). The error model is designed to be:
|
||
|
# - Simple to use and understand for most users
|
||
|
# - Flexible enough to meet unexpected needs
|
||
|
# # Overview
|
||
|
# The `Status` message contains three pieces of data: error code, error message,
|
||
|
# and error details. The error code should be an enum value of
|
||
|
# google.rpc.Code, but it may accept additional error codes if needed. The
|
||
|
# error message should be a developer-facing English message that helps
|
||
|
# developers *understand* and *resolve* the error. If a localized user-facing
|
||
|
# error message is needed, put the localized message in the error details or
|
||
|
# localize it in the client. The optional error details may contain arbitrary
|
||
|
# information about the error. There is a predefined set of error detail types
|
||
|
# in the package `google.rpc` that can be used for common error conditions.
|
||
|
# # Language mapping
|
||
|
# The `Status` message is the logical representation of the error model, but it
|
||
|
# is not necessarily the actual wire format. When the `Status` message is
|
||
|
# exposed in different client libraries and different wire protocols, it can be
|
||
|
# mapped differently. For example, it will likely be mapped to some exceptions
|
||
|
# in Java, but more likely mapped to some error codes in C.
|
||
|
# # Other uses
|
||
|
# The error model and the `Status` message can be used in a variety of
|
||
|
# environments, either with or without APIs, to provide a
|
||
|
# consistent developer experience across different environments.
|
||
|
# Example uses of this error model include:
|
||
|
# - Partial errors. If a service needs to return partial errors to the client,
|
||
|
# it may embed the `Status` in the normal response to indicate the partial
|
||
|
# errors.
|
||
|
# - Workflow errors. A typical workflow has multiple steps. Each step may
|
||
|
# have a `Status` message for error reporting.
|
||
|
# - Batch operations. If a client uses batch request and batch response, the
|
||
|
# `Status` message should be used directly inside batch response, one for
|
||
|
# each error sub-response.
|
||
|
# - Asynchronous operations. If an API call embeds asynchronous operation
|
||
|
# results in its response, the status of those operations should be
|
||
|
# represented directly using the `Status` message.
|
||
|
# - Logging. If some API errors are stored in logs, the message `Status` could
|
||
|
# be used directly after any stripping needed for security/privacy reasons.
|
||
|
# Corresponds to the JSON property `error`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::Status]
|
||
|
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 have the format of `operations/some/unique/name`.
|
||
|
# 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
|
||
|
|
||
|
# Represents the contents of the original request that was passed to
|
||
|
# the `[Streaming]DetectIntent` call.
|
||
|
class OriginalDetectIntentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. This field is set to the value of `QueryParameters.payload` field
|
||
|
# passed in the request.
|
||
|
# Corresponds to the JSON property `payload`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :payload
|
||
|
|
||
|
# The source of this request, e.g., `google`, `facebook`, `slack`. It is set
|
||
|
# by Dialogflow-owned servers. Possible values of this field correspond to
|
||
|
# Intent.Message.Platform.
|
||
|
# Corresponds to the JSON property `source`
|
||
|
# @return [String]
|
||
|
attr_accessor :source
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@payload = args[:payload] if args.key?(:payload)
|
||
|
@source = args[:source] if args.key?(:source)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents the query input. It can contain either:
|
||
|
# 1. an audio config which
|
||
|
# instructs the speech recognizer how to process the speech audio,
|
||
|
# 2. a conversational query in the form of text, or
|
||
|
# 3. an event that specifies which intent to trigger.
|
||
|
class QueryInput
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Instructs the speech recognizer how to process the audio content.
|
||
|
# Corresponds to the JSON property `audioConfig`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::InputAudioConfig]
|
||
|
attr_accessor :audio_config
|
||
|
|
||
|
# Events allow for matching intents by event name instead of the natural
|
||
|
# language input. For instance, input `<event: ` name: “welcome_event”,
|
||
|
# parameters: ` name: “Sam” ` `>` can trigger a personalized welcome response.
|
||
|
# The parameter `name` may be used by the agent in the response:
|
||
|
# `“Hello #welcome_event.name! What can I do for you today?”`.
|
||
|
# Corresponds to the JSON property `event`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::EventInput]
|
||
|
attr_accessor :event
|
||
|
|
||
|
# Represents the natural language text to be processed.
|
||
|
# Corresponds to the JSON property `text`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::TextInput]
|
||
|
attr_accessor :text
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@audio_config = args[:audio_config] if args.key?(:audio_config)
|
||
|
@event = args[:event] if args.key?(:event)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents the parameters of the conversational query.
|
||
|
class QueryParameters
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Optional. The collection of contexts to be activated before this query is
|
||
|
# executed.
|
||
|
# Corresponds to the JSON property `contexts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Context>]
|
||
|
attr_accessor :contexts
|
||
|
|
||
|
# An object representing a latitude/longitude pair. This is expressed as a pair
|
||
|
# of doubles representing degrees latitude and degrees longitude. Unless
|
||
|
# specified otherwise, this must conform to the
|
||
|
# <a href="http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf">WGS84
|
||
|
# standard</a>. Values must be within normalized ranges.
|
||
|
# Corresponds to the JSON property `geoLocation`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::LatLng]
|
||
|
attr_accessor :geo_location
|
||
|
|
||
|
# Optional. This field can be used to pass custom data into the webhook
|
||
|
# associated with the agent. Arbitrary JSON objects are supported.
|
||
|
# Corresponds to the JSON property `payload`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :payload
|
||
|
|
||
|
# Optional. Specifies whether to delete all contexts in the current session
|
||
|
# before the new ones are activated.
|
||
|
# Corresponds to the JSON property `resetContexts`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :reset_contexts
|
||
|
alias_method :reset_contexts?, :reset_contexts
|
||
|
|
||
|
# Optional. The collection of session entity types to replace or extend
|
||
|
# developer entities with for this query only. The entity synonyms apply
|
||
|
# to all languages.
|
||
|
# Corresponds to the JSON property `sessionEntityTypes`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::SessionEntityType>]
|
||
|
attr_accessor :session_entity_types
|
||
|
|
||
|
# Optional. The time zone of this conversational query from the
|
||
|
# [time zone database](https://www.iana.org/time-zones), e.g.,
|
||
|
# America/New_York, Europe/Paris. If not provided, the time zone specified in
|
||
|
# agent settings is used.
|
||
|
# Corresponds to the JSON property `timeZone`
|
||
|
# @return [String]
|
||
|
attr_accessor :time_zone
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@contexts = args[:contexts] if args.key?(:contexts)
|
||
|
@geo_location = args[:geo_location] if args.key?(:geo_location)
|
||
|
@payload = args[:payload] if args.key?(:payload)
|
||
|
@reset_contexts = args[:reset_contexts] if args.key?(:reset_contexts)
|
||
|
@session_entity_types = args[:session_entity_types] if args.key?(:session_entity_types)
|
||
|
@time_zone = args[:time_zone] if args.key?(:time_zone)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents the result of conversational query or event processing.
|
||
|
class QueryResult
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The action name from the matched intent.
|
||
|
# Corresponds to the JSON property `action`
|
||
|
# @return [String]
|
||
|
attr_accessor :action
|
||
|
|
||
|
# This field is set to:
|
||
|
# - `false` if the matched intent has required parameters and not all of
|
||
|
# the required parameter values have been collected.
|
||
|
# - `true` if all required parameter values have been collected, or if the
|
||
|
# matched intent doesn't contain any required parameters.
|
||
|
# Corresponds to the JSON property `allRequiredParamsPresent`
|
||
|
# @return [Boolean]
|
||
|
attr_accessor :all_required_params_present
|
||
|
alias_method :all_required_params_present?, :all_required_params_present
|
||
|
|
||
|
# The free-form diagnostic info. For example, this field
|
||
|
# could contain webhook call latency.
|
||
|
# Corresponds to the JSON property `diagnosticInfo`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :diagnostic_info
|
||
|
|
||
|
# The collection of rich messages to present to the user.
|
||
|
# Corresponds to the JSON property `fulfillmentMessages`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessage>]
|
||
|
attr_accessor :fulfillment_messages
|
||
|
|
||
|
# The text to be pronounced to the user or shown on the screen.
|
||
|
# Corresponds to the JSON property `fulfillmentText`
|
||
|
# @return [String]
|
||
|
attr_accessor :fulfillment_text
|
||
|
|
||
|
# Represents an intent.
|
||
|
# Intents convert a number of user expressions or patterns into an action. An
|
||
|
# action is an extraction of a user command or sentence semantics.
|
||
|
# Corresponds to the JSON property `intent`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::Intent]
|
||
|
attr_accessor :intent
|
||
|
|
||
|
# The intent detection confidence. Values range from 0.0
|
||
|
# (completely uncertain) to 1.0 (completely certain).
|
||
|
# Corresponds to the JSON property `intentDetectionConfidence`
|
||
|
# @return [Float]
|
||
|
attr_accessor :intent_detection_confidence
|
||
|
|
||
|
# The language that was triggered during intent detection.
|
||
|
# See [Language Support](https://dialogflow.com/docs/reference/language)
|
||
|
# for a list of the currently supported language codes.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# The collection of output contexts. If applicable,
|
||
|
# `output_contexts.parameters` contains entries with name
|
||
|
# `<parameter name>.original` containing the original parameter values
|
||
|
# before the query.
|
||
|
# Corresponds to the JSON property `outputContexts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Context>]
|
||
|
attr_accessor :output_contexts
|
||
|
|
||
|
# The collection of extracted parameters.
|
||
|
# Corresponds to the JSON property `parameters`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :parameters
|
||
|
|
||
|
# The original conversational query text:
|
||
|
# - If natural language text was provided as input, `query_text` contains
|
||
|
# a copy of the input.
|
||
|
# - If natural language speech audio was provided as input, `query_text`
|
||
|
# contains the speech recognition result. If speech recognizer produced
|
||
|
# multiple alternatives, a particular one is picked.
|
||
|
# - If an event was provided as input, `query_text` is not set.
|
||
|
# Corresponds to the JSON property `queryText`
|
||
|
# @return [String]
|
||
|
attr_accessor :query_text
|
||
|
|
||
|
# The confidence estimate between 0.0 and 1.0. A higher number
|
||
|
# indicates an estimated greater likelihood that the recognized words are
|
||
|
# correct. The default of 0.0 is a sentinel value indicating that confidence
|
||
|
# was not set. This field is populated if natural speech audio was provided
|
||
|
# as input.
|
||
|
# Corresponds to the JSON property `speechRecognitionConfidence`
|
||
|
# @return [Float]
|
||
|
attr_accessor :speech_recognition_confidence
|
||
|
|
||
|
# If the query was fulfilled by a webhook call, this field is set to the
|
||
|
# value of the `payload` field returned in the webhook response.
|
||
|
# Corresponds to the JSON property `webhookPayload`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :webhook_payload
|
||
|
|
||
|
# If the query was fulfilled by a webhook call, this field is set to the
|
||
|
# value of the `source` field returned in the webhook response.
|
||
|
# Corresponds to the JSON property `webhookSource`
|
||
|
# @return [String]
|
||
|
attr_accessor :webhook_source
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@action = args[:action] if args.key?(:action)
|
||
|
@all_required_params_present = args[:all_required_params_present] if args.key?(:all_required_params_present)
|
||
|
@diagnostic_info = args[:diagnostic_info] if args.key?(:diagnostic_info)
|
||
|
@fulfillment_messages = args[:fulfillment_messages] if args.key?(:fulfillment_messages)
|
||
|
@fulfillment_text = args[:fulfillment_text] if args.key?(:fulfillment_text)
|
||
|
@intent = args[:intent] if args.key?(:intent)
|
||
|
@intent_detection_confidence = args[:intent_detection_confidence] if args.key?(:intent_detection_confidence)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@output_contexts = args[:output_contexts] if args.key?(:output_contexts)
|
||
|
@parameters = args[:parameters] if args.key?(:parameters)
|
||
|
@query_text = args[:query_text] if args.key?(:query_text)
|
||
|
@speech_recognition_confidence = args[:speech_recognition_confidence] if args.key?(:speech_recognition_confidence)
|
||
|
@webhook_payload = args[:webhook_payload] if args.key?(:webhook_payload)
|
||
|
@webhook_source = args[:webhook_source] if args.key?(:webhook_source)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Agents.RestoreAgent.
|
||
|
class RestoreAgentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The agent to restore.
|
||
|
# Corresponds to the JSON property `agentContent`
|
||
|
# NOTE: Values are automatically base64 encoded/decoded in the client library.
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_content
|
||
|
|
||
|
# Warning: Restoring agents from a URI is not implemented yet.
|
||
|
# This feature is coming soon.
|
||
|
# The URI to a Google Cloud Storage file containing the agent to restore.
|
||
|
# Note: The URI must start with "gs://".
|
||
|
# Corresponds to the JSON property `agentUri`
|
||
|
# @return [String]
|
||
|
attr_accessor :agent_uri
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@agent_content = args[:agent_content] if args.key?(:agent_content)
|
||
|
@agent_uri = args[:agent_uri] if args.key?(:agent_uri)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for Agents.SearchAgents.
|
||
|
class SearchAgentsResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# The list of agents. There will be a maximum number of items returned based
|
||
|
# on the page_size field in the request.
|
||
|
# Corresponds to the JSON property `agents`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Agent>]
|
||
|
attr_accessor :agents
|
||
|
|
||
|
# Token to retrieve the next page of results, or empty if there are no
|
||
|
# more results in the list.
|
||
|
# 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)
|
||
|
@agents = args[:agents] if args.key?(:agents)
|
||
|
@next_page_token = args[:next_page_token] if args.key?(:next_page_token)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# Represents a session entity type.
|
||
|
# Extends or replaces a developer entity type at the user session level (we
|
||
|
# refer to the entity types defined at the agent level as "developer entity
|
||
|
# types").
|
||
|
# Note: session entity types apply to all queries, regardless of the language.
|
||
|
class SessionEntityType
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The collection of entities associated with this session entity
|
||
|
# type.
|
||
|
# Corresponds to the JSON property `entities`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::EntityTypeEntity>]
|
||
|
attr_accessor :entities
|
||
|
|
||
|
# Required. Indicates whether the additional data should override or
|
||
|
# supplement the developer entity type definition.
|
||
|
# Corresponds to the JSON property `entityOverrideMode`
|
||
|
# @return [String]
|
||
|
attr_accessor :entity_override_mode
|
||
|
|
||
|
# Required. The unique identifier of this session entity type. Format:
|
||
|
# `projects/<Project ID>/agent/sessions/<Session ID>/entityTypes/<Entity Type
|
||
|
# Display Name>`.
|
||
|
# Corresponds to the JSON property `name`
|
||
|
# @return [String]
|
||
|
attr_accessor :name
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@entities = args[:entities] if args.key?(:entities)
|
||
|
@entity_override_mode = args[:entity_override_mode] if args.key?(:entity_override_mode)
|
||
|
@name = args[:name] if args.key?(:name)
|
||
|
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). The error model is designed to be:
|
||
|
# - Simple to use and understand for most users
|
||
|
# - Flexible enough to meet unexpected needs
|
||
|
# # Overview
|
||
|
# The `Status` message contains three pieces of data: error code, error message,
|
||
|
# and error details. The error code should be an enum value of
|
||
|
# google.rpc.Code, but it may accept additional error codes if needed. The
|
||
|
# error message should be a developer-facing English message that helps
|
||
|
# developers *understand* and *resolve* the error. If a localized user-facing
|
||
|
# error message is needed, put the localized message in the error details or
|
||
|
# localize it in the client. The optional error details may contain arbitrary
|
||
|
# information about the error. There is a predefined set of error detail types
|
||
|
# in the package `google.rpc` that can be used for common error conditions.
|
||
|
# # Language mapping
|
||
|
# The `Status` message is the logical representation of the error model, but it
|
||
|
# is not necessarily the actual wire format. When the `Status` message is
|
||
|
# exposed in different client libraries and different wire protocols, it can be
|
||
|
# mapped differently. For example, it will likely be mapped to some exceptions
|
||
|
# in Java, but more likely mapped to some error codes in C.
|
||
|
# # Other uses
|
||
|
# The error model and the `Status` message can be used in a variety of
|
||
|
# environments, either with or without APIs, to provide a
|
||
|
# consistent developer experience across different environments.
|
||
|
# Example uses of this error model include:
|
||
|
# - Partial errors. If a service needs to return partial errors to the client,
|
||
|
# it may embed the `Status` in the normal response to indicate the partial
|
||
|
# errors.
|
||
|
# - Workflow errors. A typical workflow has multiple steps. Each step may
|
||
|
# have a `Status` message for error reporting.
|
||
|
# - Batch operations. If a client uses batch request and batch response, the
|
||
|
# `Status` message should be used directly inside batch response, one for
|
||
|
# each error sub-response.
|
||
|
# - Asynchronous operations. If an API call embeds asynchronous operation
|
||
|
# results in its response, the status of those operations should be
|
||
|
# represented directly using the `Status` message.
|
||
|
# - Logging. If some API errors are stored in logs, the message `Status` could
|
||
|
# be used directly after any stripping needed for security/privacy reasons.
|
||
|
class Status
|
||
|
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 the natural language text to be processed.
|
||
|
class TextInput
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Required. The language of this conversational query. See [Language
|
||
|
# Support](https://dialogflow.com/docs/languages) for a list of the
|
||
|
# currently supported language codes. Note that queries in the same session
|
||
|
# do not necessarily need to specify the same language.
|
||
|
# Corresponds to the JSON property `languageCode`
|
||
|
# @return [String]
|
||
|
attr_accessor :language_code
|
||
|
|
||
|
# Required. The UTF-8 encoded natural language text to be processed.
|
||
|
# Text length must not exceed 256 bytes.
|
||
|
# Corresponds to the JSON property `text`
|
||
|
# @return [String]
|
||
|
attr_accessor :text
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@language_code = args[:language_code] if args.key?(:language_code)
|
||
|
@text = args[:text] if args.key?(:text)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for Agents.TrainAgent.
|
||
|
class TrainAgentRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The request message for a webhook call.
|
||
|
class WebhookRequest
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Represents the contents of the original request that was passed to
|
||
|
# the `[Streaming]DetectIntent` call.
|
||
|
# Corresponds to the JSON property `originalDetectIntentRequest`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::OriginalDetectIntentRequest]
|
||
|
attr_accessor :original_detect_intent_request
|
||
|
|
||
|
# Represents the result of conversational query or event processing.
|
||
|
# Corresponds to the JSON property `queryResult`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::QueryResult]
|
||
|
attr_accessor :query_result
|
||
|
|
||
|
# The unique identifier of the response. Contains the same value as
|
||
|
# `[Streaming]DetectIntentResponse.response_id`.
|
||
|
# Corresponds to the JSON property `responseId`
|
||
|
# @return [String]
|
||
|
attr_accessor :response_id
|
||
|
|
||
|
# The unique identifier of detectIntent request session.
|
||
|
# Can be used to identify end-user inside webhook implementation.
|
||
|
# Format: `projects/<Project ID>/agent/sessions/<Session ID>`.
|
||
|
# Corresponds to the JSON property `session`
|
||
|
# @return [String]
|
||
|
attr_accessor :session
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@original_detect_intent_request = args[:original_detect_intent_request] if args.key?(:original_detect_intent_request)
|
||
|
@query_result = args[:query_result] if args.key?(:query_result)
|
||
|
@response_id = args[:response_id] if args.key?(:response_id)
|
||
|
@session = args[:session] if args.key?(:session)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
# The response message for a webhook call.
|
||
|
class WebhookResponse
|
||
|
include Google::Apis::Core::Hashable
|
||
|
|
||
|
# Events allow for matching intents by event name instead of the natural
|
||
|
# language input. For instance, input `<event: ` name: “welcome_event”,
|
||
|
# parameters: ` name: “Sam” ` `>` can trigger a personalized welcome response.
|
||
|
# The parameter `name` may be used by the agent in the response:
|
||
|
# `“Hello #welcome_event.name! What can I do for you today?”`.
|
||
|
# Corresponds to the JSON property `followupEventInput`
|
||
|
# @return [Google::Apis::DialogflowV2beta1::EventInput]
|
||
|
attr_accessor :followup_event_input
|
||
|
|
||
|
# Optional. The collection of rich messages to present to the user. This
|
||
|
# value is passed directly to `QueryResult.fulfillment_messages`.
|
||
|
# Corresponds to the JSON property `fulfillmentMessages`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::IntentMessage>]
|
||
|
attr_accessor :fulfillment_messages
|
||
|
|
||
|
# Optional. The text to be shown on the screen. This value is passed directly
|
||
|
# to `QueryResult.fulfillment_text`.
|
||
|
# Corresponds to the JSON property `fulfillmentText`
|
||
|
# @return [String]
|
||
|
attr_accessor :fulfillment_text
|
||
|
|
||
|
# Optional. The collection of output contexts. This value is passed directly
|
||
|
# to `QueryResult.output_contexts`.
|
||
|
# Corresponds to the JSON property `outputContexts`
|
||
|
# @return [Array<Google::Apis::DialogflowV2beta1::Context>]
|
||
|
attr_accessor :output_contexts
|
||
|
|
||
|
# Optional. This value is passed directly to `QueryResult.webhook_payload`.
|
||
|
# Corresponds to the JSON property `payload`
|
||
|
# @return [Hash<String,Object>]
|
||
|
attr_accessor :payload
|
||
|
|
||
|
# Optional. This value is passed directly to `QueryResult.webhook_source`.
|
||
|
# Corresponds to the JSON property `source`
|
||
|
# @return [String]
|
||
|
attr_accessor :source
|
||
|
|
||
|
def initialize(**args)
|
||
|
update!(**args)
|
||
|
end
|
||
|
|
||
|
# Update properties of this object
|
||
|
def update!(**args)
|
||
|
@followup_event_input = args[:followup_event_input] if args.key?(:followup_event_input)
|
||
|
@fulfillment_messages = args[:fulfillment_messages] if args.key?(:fulfillment_messages)
|
||
|
@fulfillment_text = args[:fulfillment_text] if args.key?(:fulfillment_text)
|
||
|
@output_contexts = args[:output_contexts] if args.key?(:output_contexts)
|
||
|
@payload = args[:payload] if args.key?(:payload)
|
||
|
@source = args[:source] if args.key?(:source)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|