Parâmetros

Parâmetros são usados para capturar e fazer referência a valores fornecidos pelo usuário final durante uma sessão. Cada parâmetro tem um nome e um tipo de entidade. Ao contrário da entrada bruta do usuário final, os parâmetros são dados estruturados que podem ser facilmente usados para executar uma lógica ou gerar respostas.

Definir, referenciar, configurar e conseguir parâmetros

Há quatro maneiras gerais de usar os parâmetros:

  • Definir no momento do design: durante o momento do design, você usa o console ou a API para definir parâmetros. Por exemplo, você pode definir um parâmetro de intent e usá-lo em uma frase de treinamento para indicar a entrada do usuário final que deve ser extraída.
  • Referência no momento do design: referências de parâmetro são variáveis que armazenam valores de parâmetro extraídos no ambiente de execução. Durante tempo de design, use o console ou a API para fazer referência a parâmetros em vários tipos de dados. Por exemplo, é possível fazer referência a um parâmetro de sessão em uma resposta de fulfillment estática para uma rota.
  • Definir no ambiente de execução: no ambiente de execução, o serviço de agentes de conversação (Dialogflow CX), o serviço que chama a API e o serviço de webhook podem definir valores de parâmetro. Por exemplo, o serviço de agentes de conversação (Dialogflow CX) define o valor de um parâmetro de intent quando uma entrada do usuário final corresponde à intent e a entrada contém dados de parâmetros.
  • Receber no ambiente de execução: no ambiente de execução, as referências de parâmetro contêm os valores de parâmetro que foram definidos, e você pode usar a API ou um webhook para receber os valores de parâmetro. Por exemplo, quando uma intent é correspondida e o webhook é chamado, o serviço de webhook recebe os valores de parâmetro da intent.

Nomenclatura de parâmetros

As seguintes regras se aplicam à nomenclatura de parâmetros:

  • Use os seguintes caracteres: [A-Z], [a-z], [0-9], ., -, _
  • Os nomes dos parâmetros não diferenciam maiúsculas de minúsculas. Por isso, os agentes de conversação (Dialogflow CX) tratam Apple e apple como o mesmo parâmetro. O webhook e o código de cliente da API também precisam tratar os nomes dos parâmetros como indiferentes a maiúsculas, porque não há garantia de nomes de parâmetros retornados pelos agentes de conversação (Dialogflow CX).
  • Ao criar parâmetros com o mesmo ID ou nome de exibição em diferentes intenções ou formulários, verifique se o tipo de entidade e outras configurações são iguais em todas as definições. Se o tipo de entidade ou outras configurações de parâmetro forem diferentes, use o ID ou o nome de exibição do parâmetro exclusivo para cada definição.

Tipos de valores de parâmetro

Os valores de parâmetro são compatíveis com vários tipos de valor. A seção de sessões abaixo descreve como fazer referência a cada tipo de valor de parâmetro. Veja a seguir os tipos compatíveis:

Tipo Descrição
Escalar Um único valor numérico ou de string.
Composto Um objeto JSON preenchido ao corresponder a uma entidade composta ou ao preencher um parâmetro de intent, que contém os campos original e resolved.
Lista Uma lista de valores escalares ou compostos preenchidos para um parâmetro configurado como uma lista. Confira as opções Is List abaixo.

String vazia do parâmetro e valores nulos

É possível definir os valores de parâmetros de string como "", o que define o parâmetro como a string vazia.

É possível definir qualquer valor de parâmetro como null, o que indica que o parâmetro não foi definido.

Valores originais do parâmetro

Quando há correspondência do texto com uma entidade específica no ambiente de execução, muitas vezes ele é resolvido para um valor que é mais conveniente para o processamento. Por exemplo, a palavra "maçãs" na entrada do usuário final pode ser resolvida como "maçã" para uma entidade de fruta.

Todos os tipos de valor para referências de parâmetro de intent podem referenciar o valor original ou resolvido.

Somente os tipos de valor compostos para referências de parâmetro de sessão podem referenciar o valor original.

Parâmetros de intent

As intents usam parâmetros para extrair dados fornecidos pelos usuários finais quando as intents são correspondidas. Os seguintes dados são usados para definir um parâmetro de intent:

  • Nome (também conhecido como ID ou Nome de exibição): um nome que identifica o parâmetro.
  • Tipo de entidade: o tipo de entidade associado ao parâmetro.
  • É uma lista: se for verdadeiro, o parâmetro será tratado como uma lista de valores.
  • Editar no registro: se for verdadeiro, os dados de parâmetro fornecidos pelo usuário final serão editados.

Definir parâmetros de intent

Os parâmetros de intent são definidos no momento do design ao criar dados de intent ou ao anotar frases de treinamento.

Parâmetros de intent de referência

As referências de parâmetro de intent podem ser usadas em mensagens de resposta de fulfillment estática de rotas de intent.

É possível fazer referência ao valor original ou ao valor resolvido.

Para referir-se a um parâmetro para a intent correspondente, use um dos seguintes formatos:

$intent.params.parameter-id.original
$intent.params.parameter-id.resolved

Por exemplo, se o código do parâmetro for date, é possível fazer referência ao valor resolvido como $intent.params.date.resolved.

Definir parâmetros de intent

Quando uma entrada do usuário final corresponde a uma intent no ambiente de execução, qualquer parâmetro usado por uma anotação para a frase de treinamento associada é definido por agentes de conversação (Dialogflow CX).

O fulfillment de uma rota de intent pode usar uma predefinição de parâmetro de fulfillment para definir um valor de parâmetro de intent no ambiente de execução.

Receber parâmetros de intent

Durante a rodada de conversas em que uma intent é correspondida, o código que você tem pode acessar os valores de parâmetro da intent.

As interações com a API retornarão os valores do parâmetro de intent. Consulte o campo de resposta queryResult.parameters do método detectIntent para o tipo Session.

Selecione um protocolo e uma versão para a referência de sessão:

Protocolo V3 V3beta1
REST Recurso da sessão Recurso da sessão
RPC (remote procedure call) Interface da sessão Interface da sessão
C++ SessionsClient Indisponível
C# SessionsClient Indisponível
Go SessionsClient Indisponível
Java SessionsClient SessionsClient
Node.js SessionsClient SessionsClient
PHP Indisponível Indisponível
Python SessionsClient SessionsClient
Ruby Indisponível Indisponível

Valores de parâmetro de intent de recebimento do webhook. Consulte o campo intentInfo.parameters na solicitação de webhook.

Parâmetros do formulário

Para cada página, é possível definir um formulário, que é uma lista de parâmetros que precisam ser coletados do usuário final para a página. O agente interage com o usuário final em várias rodadas de conversas até que ele tenha coletado todos os parâmetros de formulário obrigatórios, também conhecidos como parâmetros de página. O agente coleta esses parâmetros na ordem definida na página. Para cada parâmetro de formulário obrigatório, você também fornece prompts que o agente usa para solicitar essas informações do usuário final. Esse processo é chamado de preenchimento de formulário.

Por exemplo, é possível criar um formulário que coleta o nome e o número de telefone do usuário final de uma página Collect Customer Info.

Os seguintes dados são usados para definir um parâmetro de formulário:

Nome da opção do console Cadeia de campos da API Descrição
Nome de exibição Page.form.parameters[].displayName Um nome que identifica o parâmetro.
Tipo de entidade Page.form.parameters[].entityType O tipo de entidade associado ao parâmetro.
Obrigatório Page.form.parameters[].required Indica se o parâmetro é obrigatório. Os parâmetros obrigatórios devem ser preenchidos antes da conclusão do preenchimento do formulário, e o agente solicitará valores ao usuário final. Consulte a seção Definir parâmetros de formulário abaixo para ver detalhes.
Valor padrão (visível somente quando a opção Obrigatório está desmarcada) Page.form.parameters[].defaultValue O valor padrão de um parâmetro opcional. Consulte a seção Definir parâmetros de formulário abaixo para ver detalhes.
É uma lista Page.form.parameters[].isList Se for verdadeiro, o parâmetro será tratado como uma lista de valores.
Editar no registro Page.form.parameters[].redact Se verdadeiro, os dados de parâmetros fornecidos pelo usuário final serão editados.
Fulfillment do prompt inicial Page.form.parameters[].fillBehavior.initialPromptFulfillment Solicitações iniciais na forma de fulfillment para solicitar um valor de parâmetro obrigatório ao usuário final. Consulte a seção Definir parâmetros de formulário abaixo para ver detalhes.
Gerenciadores de eventos de nova solicitação Page.form.parameters[].fillBehavior.repromptEventHandlers São usados quando o agente precisa solicitar novamente que o usuário final preencha o parâmetro após uma tentativa com falha. Consulte Gerenciadores de nova solicitação de preenchimento de formulário. Se nenhum gerenciador de eventos de nova solicitação for definido, o agente vai fazer uma nova solicitação com as solicitações iniciais após uma tentativa com falha.
DTMF Indisponível Consulte a seção DTMF abaixo.

Definir e gerenciar parâmetros de formulário

Os parâmetros do formulário são definidos no momento do design ao criar uma página.

Para mudar a ordem dos parâmetros do formulário com o console, clique no título da seção Parâmetros na página e arraste as linhas do parâmetro na tabela de parâmetros.

Para excluir um parâmetro de formulário, clique no título da seção Parâmetros na página, passe o mouse sobre um parâmetro e clique no botão de exclusão .

Parâmetros do formulário de referência

As referências de parâmetro do formulário não são usadas diretamente. Você só pode verificar o status de preenchimento dos parâmetros de formulários individuais ou do formulário como um todo. Você pode usar essas referências de status de formulário em um requisito de condição de uma rota de condição.

Para verificar se o formulário completo da página atual está preenchido, use a seguinte condição:

$page.params.status = "FINAL"

Para verificar se um parâmetro de formulário específico foi preenchido na última rodada, use a seguinte condição:

$page.params.parameter-id.status = "UPDATED"

Definir parâmetros de formulário

É possível definir os valores de parâmetro do formulário de várias maneiras. As subseções a seguir descrevem cada mecanismo para definir os valores de parâmetro do formulário.

Valores de parâmetro padrão

Você tem a opção de fornecer valores padrão para parâmetros de formulário opcionais. Quando o preenchimento do formulário é iniciado, todos os parâmetros opcionais não definidos são definidos para os valores padrão. Esses valores podem ser inicializados ou substituídos por alguns dos mecanismos abaixo.

Se um parâmetro for obrigatório, o valor padrão será ignorado.

Preenchimento de formulário

Os agentes de conversação (Dialogflow CX) definem automaticamente os valores de parâmetro fornecidos pelo usuário final durante o preenchimento do formulário. O agente coleta os parâmetros necessários na ordem definida na página. O agente solicita ao usuário final os valores necessários usando o fulfillment inicial que você fornece para cada parâmetro obrigatório. Os parâmetros opcionais não acionarão solicitações.

Se um valor de parâmetro obrigatório não for fornecido pelo usuário final após um prompt do agente, o prompt inicial será repetido, a menos que um comportamento diferente seja definido nos gerenciadores de nova solicitação. Se houver várias solicitações de texto iniciais definidas, o comportamento do agente será o mesmo de qualquer resposta de texto de fulfillment.

Propagação do parâmetro da intent e da sessão

Quando um parâmetro de qualquer tipo for definido no ambiente de execução, ele é gravado na sessão e se torna um parâmetro de sessão.

Quando uma página se torna ativa e durante o período ativo, qualquer parâmetro de formulário com o mesmo nome de um parâmetro de sessão é definido automaticamente como o valor do parâmetro de sessão.

Isso pode acontecer com um parâmetro de intent correspondente em uma rota de intent ou uma propagação de parâmetro.

A propagação de parâmetros de intent e sessão é o único mecanismo para definir parâmetros de formulário opcionais para valores da entrada do usuário final. No entanto, esse mecanismo também pode definir ou modificar os valores de parâmetros do formulário necessários.

Predefinições de parâmetro de fulfillment

O fulfillment para uma rota, manipulador de eventos ou reprompt de formulário pode usar uma predefinição de parâmetro de fulfillment para definir um valor de parâmetro de formulário no ambiente de execução. Uma predefinição de parâmetro de fulfillment substituirá um valor de parâmetro, incluindo valores padrão de parâmetros.

Configuração do parâmetro do webhook

O webhook pode definir os valores dos parâmetros de formulário no ambiente de execução. Veja o campo pageInfo.formInfo.parameterInfo na resposta do webhook.

Receber parâmetros de formulário

As interações com a API retornarão os valores de parâmetro do formulário. Consulte o campo de resposta queryResult.parameters do método detectIntent para o tipo Session.

Selecione um protocolo e uma versão para a referência de sessão:

Protocolo V3 V3beta1
REST Recurso da sessão Recurso da sessão
RPC (remote procedure call) Interface da sessão Interface da sessão
C++ SessionsClient Indisponível
C# SessionsClient Indisponível
Go SessionsClient Indisponível
Java SessionsClient SessionsClient
Node.js SessionsClient SessionsClient
PHP Indisponível Indisponível
Python SessionsClient SessionsClient
Ruby Indisponível Indisponível

Valores de parâmetro do formulário de recebimento do webhook. Consulte o campo pageInfo.formInfo.parameterInfo na solicitação de webhook.

Gerenciadores de prompts de preenchimento de formulário

Os gerenciadores de nova solicitação, também conhecidos como gerenciadores de eventos no nível do parâmetro, são usados para definir o comportamento de solicitações complexas de parâmetros obrigatórios. Por exemplo, gerenciadores de nova solicitação podem ser usados para alterar a solicitação quando o usuário final não fornece um valor após a solicitação inicial e fazer a transição para outra página após N tentativas malsucedidas.

Se nenhum gerenciador de nova solicitação for definido, a solicitação inicial será usada para enviar uma nova solicitação ao usuário final, conforme necessário.

Se o usuário final responder com entrada inesperada, um evento sys.no-match-* ou sys.no-input-* será invocado, e todos os gerenciadores de nova solicitação definidos para esses eventos serão chamados.

Assim como outros manipuladores de eventos, um gerenciador de reprompt é um tipo de gerenciador de estado que pode ser configurado com um ou ambos:

  • Um fulfillment para fornecer uma mensagem de reprompt do usuário final e/ou uma predefinição de parâmetro.
  • Um destino de transição para alterar a página atual.

Parâmetros de sessão

Quando um parâmetro de qualquer tipo for definido no ambient de execução, ele é gravado na sessão e se torna um parâmetro de sessão. Esses parâmetros não são definidos explicitamente no momento do design. Durante uma sessão, é possível referir-se a esses parâmetros de sessão a qualquer momento.

Parâmetros da sessão de referência

As referências de parâmetro de sessão podem ser usadas nas mensagens de resposta estática para os seguintes tipos de fulfillment:

  • Fulfillment de entrada de página
  • Fulfillment da rota
  • Fulfillment do manipulador de eventos
  • Fulfillment de prompt de formulário
  • Fulfillment de reprompt de formulário

As referências também podem ser usadas em:

Para fazer referência a um parâmetro de sessão, use os seguintes formatos:

Escalar

Para acessar um parâmetro com um tipo de entidade escalar:

$session.params.parameter-id

Por exemplo, se o código do parâmetro for date, é possível fazer referência ao valor como $session.params.date.

Composto

  • Para acessar um membro de um parâmetro com um tipo de entidade composta:

    $session.params.parameter-id.member-name

    Por exemplo, se o ID do parâmetro for location, faça referência ao valor do membro zip-code como $session.params.location.zip-code.

  • Para acessar o valor original de um parâmetro com um tipo de entidade composta:

    $session.params.parameter-id.original
  • Para acessar o objeto completo de um parâmetro com um tipo de entidade composta, use a função do sistema IDENTITY.

Lista

  • Para acessar uma lista completa de elementos:

    $session.params.parameter-id

    Por exemplo, se o ID do parâmetro de lista for colors e os valores extraídos de uma consulta de usuário forem ["red", "blue", "yellow"], você poderá referenciar todos os valores como $session.params.colors.

  • Para acessar o elemento ith de um parâmetro de lista:

    $session.params.parameter-id[i]

    Por exemplo, se o ID do parâmetro da lista for colors, será possível fazer referência ao primeiro valor como $session.params.colors[0].

Definir parâmetros de sessão

Quando o preenchimento do formulário é concluído, os parâmetros preenchidos são gravados na sessão pelos agentes de conversação (Dialogflow CX).

O fulfillment para uma rota, manipulador de eventos ou reprompt de formulário pode usar uma predefinição de parâmetro de fulfillment para definir um valor de parâmetro de sessão no ambiente de execução.

O webhook pode definir os valores dos parâmetros de sessão no ambiente de execução. Consulte o campo sessionInfo.parameters na resposta de webhook padrão ou a resposta de webhook flexível.

As interações com a API podem definir valores de parâmetro de sessão. Consulte o campo de solicitação queryParams.parameters do método detectIntent para o tipo Session.

Selecione um protocolo e uma versão para a referência de sessão:

Protocolo V3 V3beta1
REST Recurso da sessão Recurso da sessão
RPC (remote procedure call) Interface da sessão Interface da sessão
C++ SessionsClient Indisponível
C# SessionsClient Indisponível
Go SessionsClient Indisponível
Java SessionsClient SessionsClient
Node.js SessionsClient SessionsClient
PHP Indisponível Indisponível
Python SessionsClient SessionsClient
Ruby Indisponível Indisponível

Receber parâmetros de sessão

As interações com a API retornarão os valores de parâmetro de sessão. Consulte o campo de resposta queryResult.parameters do método detectIntent para o tipo Session.

Selecione um protocolo e uma versão para a referência de sessão:

Protocolo V3 V3beta1
REST Recurso da sessão Recurso da sessão
RPC (remote procedure call) Interface da sessão Interface da sessão
C++ SessionsClient Indisponível
C# SessionsClient Indisponível
Go SessionsClient Indisponível
Java SessionsClient SessionsClient
Node.js SessionsClient SessionsClient
PHP Indisponível Indisponível
Python SessionsClient SessionsClient
Ruby Indisponível Indisponível

Valores de parâmetro de sessão de recebimento do webhook. Consulte o campo sessionInfo.parameters na solicitação de webhook.

Propagação de parâmetro

Quando uma entrada de usuário final fornece um valor de parâmetro, ele pode ser propagado para outros níveis:

  • Quando um parâmetro de intent é definido por uma correspondência de intent, os parâmetros de formulário semelhantes à página ativa são definidos com o mesmo valor. O tipo de entidade do parâmetro é determinado pela definição do parâmetro da intent.
  • Quando um parâmetro de intent é definido por uma correspondência de intent ou um parâmetro de formulário é definido durante o preenchimento de um formulário, ele se torna um parâmetro de sessão.

DTMF para integrações de telefonia

É possível ativar e configurar o DTMF (sinalização multifrequência único de frequência) para um parâmetro. Depois de ativado, o usuário final de um agente que usa uma integração de telefonia pode usar o teclado telefônico para fornecer valores de parâmetro.

Para reduzir a ambiguidade, a entrada DTMF pode ser interpretada em formas normais e específicas do DTMF (recomendado):

  • A forma normal é simplesmente os valores do teclado inseridos pelo usuário final. Por exemplo, 123#
  • O formulário específico do DTMF converte a entrada para dtmf_digits_[digits], em que [digits] são os dígitos originais do DTMF por * substituídos por star e # substituídos. com pound. Por exemplo, 123# é interpretado como dtmf_digits_123pound.

Ao corresponder aos tipos de entidade de um parâmetro, os agentes de conversação (Dialogflow CX) vão tentar corresponder aos formulários normais e específicos do DTMF. Quando um tipo de entidade é usado para a entrada DTMF, é recomendável definir sinônimos como dtmf_digits_123 para melhorar a correspondência de NLU.

Se a entrada do DTMF não atender à condição de encerramento (ou não tiver atingido o comprimento máximo do dígito ou não tiver sido encerrada pelo dígito final), o agente de agentes de conversação (Dialogflow CX) vai continuar aguardando mais entradas. Durante esse período, se o tempo limite de falta de fala for acionado, o agente invocará um evento sem entrada. Se apenas uma fala for detectada, o agente fará a correspondência com a entrada de fala. Se as entradas de fala e de DTMF forem detectadas, a entrada de fala será descartada, e apenas a de DTMF será considerada.

Para ativar e personalizar o DTMF para um parâmetro:

Console

  1. Ative as Configurações avançadas da fala de agente e as configurações de URA, caso ainda não tenha ativado.
  2. Crie um parâmetro de página.
  3. No painel de parâmetros, ative a opção Ativar DTMF.
  4. Defina Números máximos como o número máximo de dígitos que o usuário final pode fornecer para esse parâmetro.
  5. Defina o Dígito de fim para o valor do teclado que encerrará a entrada do DTMF para o parâmetro. É comum usar # nesta configuração. O dígito final não é adicionado à consulta dos agentes de conversação (Dialogflow CX) no agente. Portanto, se o dígito final for # e a entrada for 123#, a entrada real da consulta será "123".

Ao criar seu agente, você pode testar entradas DTMF no simulador.

Endpoints inteligentes

Se a endpoint inteligente estiver ativada para o agente, será possível personalizar o comportamento de endpoint inteligente para um parâmetro numérico.

  1. Defina Dígitos mínimos para sugerir que o endpoint inteligente aguarde até que todos os dígitos sejam coletados.
  2. Defina Fix transcripts para melhorar o reconhecimento de voz de dígitos corrigindo erros comuns de transcrição de dígitos. Isso só é aceito para solicitações que especificam um código de idioma en ou en-*.
  3. Defina o Tempo limite de espera para especificar o tempo extra que os agentes de conversação (Dialogflow CX) vão esperar para que o usuário forneça mais entradas.

Parâmetros com escopo de fluxo

Os parâmetros no escopo do fluxo podem ser definidos como predefinições de parâmetros de fulfillment ou parâmetros de formulário. Esses parâmetros só podem ser referenciados enquanto o fluxo em que são definidos está ativo e não são mantidos nos parâmetros da sessão.

Para definir ou fazer referência a um parâmetro no escopo do fluxo, use a seguinte sintaxe:

$flow.parameter-name

Por exemplo, se o nome do parâmetro for date, faça referência a ele como $flow.date.

O uso de um prefixo $ ao definir parâmetros é diferente de outros tipos de parâmetros que não usam $ para definições de parâmetros.

Exemplo de definição de parâmetro no escopo do fluxo: Captura de tela do parâmetro no escopo do fluxo.

Tempo de vida do valor do parâmetro no escopo do fluxo

Isso não é comum, mas, em alguns casos avançados, é necessário entender como os valores de parâmetros com escopo de fluxo são mantidos (ou descartados) quando um fluxo fica inativo e depois ativo novamente.

A retenção dos valores de parâmetros no escopo do fluxo quando um fluxo fica inativo e depois ativo novamente depende da pilha de fluxo e das instâncias de fluxo na pilha.

  • Quando o fluxo A transita para o fluxo B usando um destino de transição específico, o fluxo A (pai) permanece na pilha, o fluxo A retém os valores de parâmetro no escopo do fluxo e uma nova instância do fluxo B (filho) é adicionada à pilha.
  • Quando um fluxo filho transita de volta para um fluxo pai usando uma meta de transição simbólica (por exemplo, END_FLOW), o fluxo filho é removido da pilha, todos os valores de parâmetro no escopo do fluxo filho são descartados e todos os valores de parâmetro no escopo do fluxo pai são mantidos.
  • Usando uma série de transições com destinos de transição específicos, a pilha de fluxo pode conter várias instâncias de um tipo de fluxo. Cada instância do tipo de fluxo tem valores de parâmetro exclusivos no escopo do fluxo. Por exemplo: A1 -> B1 -> C1 -> B2, em que A, B e C são tipos de fluxo, e os números denotam instâncias desses tipos de fluxo. Neste exemplo, B1 e B2 são instâncias diferentes do fluxo B e têm parâmetros exclusivos no escopo do fluxo.

Exemplos:

Transições Resultado
O fluxo A (A1) fica ativo.
O fluxo B (B1) fica ativo usando um destino de transição específico.
O fluxo B volta para o fluxo A (A1) que o iniciou usando um alvo de transição simbólica.
O fluxo A retém os valores dos parâmetros.
O fluxo A (A1) fica ativo.
O fluxo B (B1) fica ativo usando um destino de transição específico.
O fluxo B faz a transição para uma nova instância do fluxo A (A2) usando um destino de transição específico.
A nova instância do fluxo A (A2) na parte de cima da pilha não tem acesso aos valores de parâmetro do fluxo A (A1) na parte de baixo da pilha.
O fluxo A (A1) fica ativo.
O fluxo B (B1) fica ativo usando um destino de transição específico.
O fluxo A (A1) fica ativo usando um alvo de transição simbólica.
O fluxo B (B2) fica ativo usando um destino de transição específico.
O fluxo B (B2) não retém os valores de parâmetro definidos enquanto estava ativo após a segunda transição (B1).

Parâmetros no escopo da solicitação

Os parâmetros no escopo da solicitação são parâmetros de curta duração criados por agentes de conversação (Dialogflow CX) que só podem ser referenciados durante o ciclo de vida da solicitação atual e não são mantidos nos parâmetros da sessão.

Os parâmetros no escopo da solicitação são gerados por agentes de conversação (Dialogflow CX) para os seguintes recursos:

Parâmetros integrados

É possível acessar os vários dados associados à solicitação usando:

Referência Descrição
$request.agent-id O identificador do agente.
$request.session-id O identificador da sessão.
$request.language Código de idioma especificado em QueryInput.language_code.
$request.resolved-language O código do idioma real usado pelo agente durante o processamento. O idioma resolvido pode ser diferente do especificado na solicitação. Por exemplo, se o agente só oferecer suporte a "en", mas o idioma especificado na solicitação for "en-US", o idioma resolvido será "en".
$request.user-utterance A frase do usuário atual especificada na solicitação.
$request.last-agent-utterance A última frase enviada pelo agente.

Payload personalizado

Quando QueryParameters.payload está definido, é possível acessar o parâmetro correspondente por $request.payload.param-id.

Análise de sentimento

As seguintes referências de sentimento estão disponíveis quando a análise de sentimento está ativada:

Referência Tipo Descrição
$request.sentiment.score Número Sentimento entre -1,0 (sentimento negativo) e 1,0 (sentimento positivo).
$request.sentiment.magnitude Número Indica a intensidade geral da emoção (positiva e negativa) entre 0,0 e +inf. Ao contrário da pontuação, a magnitude não é normalizada. Cada expressão de emoção na entrada do usuário final (positiva e negativa) contribui para a magnitude da entrada. Entradas mais longas podem ter magnitudes maiores.
$request.sentiment.succeeded Booleano Verdadeiro se a análise de sentimento foi bem-sucedida. Caso contrário, é falso.

Edição de parâmetros

Para qualquer parâmetro de intent ou formulário, é possível ativar a edição de parâmetros. Isso editará os dados do parâmetro de ambiente de execução do usuário final de registros e de armazenamento interno de agentes de conversação (Dialogflow CX). Os parâmetros editados são exibidos como $parameter-name_redacted nos registros.

Por exemplo, considere uma entrada do usuário final de "Meu endereço é 1600 Amphitheatre Parkway" que resulta no envio de um parâmetro address para "1600 Amphitheatre Parkway". O texto registrado será "Meu endereço é $address_redacted".

Para ativar a edição de parâmetros:

Console

Marque a caixa de seleção Editar no registro ao criar ou atualizar um parâmetro.

API

Defina o campo parameters[].redact como verdadeiro para o tipo Intent.

Selecione um protocolo e uma versão para a referência de intent:

Protocolo V3 V3beta1
REST Recurso de intent Recurso de intent
RPC Interface da intent Interface da intent
C++ IntentsClient Indisponível
C# IntentsClient Indisponível
Go IntentsClient Indisponível
Java IntentsClient IntentsClient
Node.js IntentsClient IntentsClient
PHP Indisponível Indisponível
Python IntentsClient IntentsClient
Ruby Indisponível Indisponível

Defina o campo form.parameters[].redact como verdadeiro para o tipo Page.

Selecione um protocolo e uma versão para a referência da página:

Protocolo V3 V3beta1
REST Recurso da página Recurso da página
RPC (remote procedure call) Interface da página Interface da página
C++ PagesClient Indisponível
C# PagesClient Indisponível
Go PagesClient Indisponível
Java PagesClient PagesClient
Node.js PagesClient PagesClient
PHP Indisponível Indisponível
Python PagesClient PagesClient
Ruby Indisponível Indisponível

É possível também editar todos os parâmetros de um tipo de entidade específico.