É comum que vários membros da equipe colaborem na criação de um agente e que os serviços acessem o agente. Com os papéis, é possível controlar o acesso e as permissões concedidas aos principais.
Se você estiver usando a API, também será possível ter um ou mais aplicativos que enviam solicitações a um agente. Nesse caso, controle o acesso com as contas de serviço.
É possível controlar o acesso usando o gerenciamento de identidade e acesso (IAM, na sigla em inglês) ou o Console do Dialogflow.
O Console do Dialogflow fornece o papel de administrador do agente ao usuário que criou o agente. Esse usuário recebe automaticamente o papel de proprietário do projeto do IAM no projeto associado ao agente.
Os administradores de agentes podem adicionar desenvolvedores e revisores ao agente no console do Dialogflow. Quando o papel de desenvolvedor ou revisor é concedido no console do Dialogflow, o usuário recebe o papel de editor ou visualizador de projeto do IAM, respectivamente. Outra maneira de adicionar desenvolvedores e revisores ao agente é conceder aos usuários as funções correspondentes de Editor de projeto do IAM ou Leitor de projeto do IAM no console Google Cloud .
Há algumas situações em que é necessário usar o console Google Cloud :
- Se você quiser mudar o administrador, adicionar vários administradores a um agente ou remover administradores de um agente, será necessário usar o console do Google Cloud .
- Se você tiver integrações com outros recursos do Google Cloud , como o Cloud Functions, e não quiser conceder acesso total do projeto a um aplicativo, atribua os papéis da API Dialogflow (administrador, cliente ou leitor) no console do Google Cloud para IAM.
- Um subconjunto de papéis do IAM tem papéis correspondentes no Console do Dialogflow. Se você quiser conceder um papel que não existe no console do Dialogflow, use o console Google Cloud .
Papéis
A tabela a seguir lista os papéis comuns relevantes para o Dialogflow, a correlação entre os papéis do console do Dialogflow e os papéis do IAM, além de detalhes sobre as permissões.
Os resumos de permissões na tabela usam os seguintes termos:
- Acesso total: permissão para modificar, criar, excluir, editar e ler qualquer recurso.
- Acesso de edição: permissão para criar, excluir, editar e ler qualquer recurso.
- Acesso à sessão: permissão para chamar métodos de recursos somente de tempo de execução durante uma conversa, como detectar intent, atualizar contexto, atualizar entidades da sessão ou interações de conversa do Agent Assist. Esse acesso oferece um subconjunto de permissões encontradas no acesso total e de edição.
- Acesso de leitura: permissão para ler qualquer recurso.
| Papel no Console do Dialogflow | Papel do IAM | Resumo da permissão | Detalhes da permissão |
|---|---|---|---|
| Admin | Projeto > Proprietário |
Conceda a proprietários de projetos
que precisam de acesso total a todos os recursos do Google Cloud e do Dialogflow:
|
Consulte Definições dos papéis básicos do IAM. |
| Developer | Projeto > Editor |
Conceda a editores de projetos
que precisam de acesso de edição a todos os recursos do Google Cloud e do Dialogflow:
|
Consulte Definições dos papéis básicos do IAM. |
| Revisor | Projeto > Leitor |
Conceda aos leitores do projeto
que precisam de acesso de leitura a todos os recursos do Google Cloud e do Dialogflow:
|
Consulte Definições dos papéis básicos do IAM. |
| N/A | Projeto > Navegador |
Concede a navegadores do projeto
que precisam de acesso de leitura para navegar na hierarquia de um projeto,
incluindo a pasta, a organização e a política do Cloud IAM:
|
Consulte Definições de papéis do projeto do IAM. |
| N/D | Dialogflow > Administrador da API Dialogflow |
Conceda a administradores da API Dialogflow que precisam de acesso total a recursos específicos do Dialogflow:
|
Consulte Definições de papéis do IAM do Dialogflow. |
| N/A | Dialogflow > Cliente da API Dialogflow |
Conceda a clientes da API Dialogflow
que realizam chamadas de detecção de intent usando a API:
|
Consulte Definições de papéis do IAM do Dialogflow. |
| N/A | Dialogflow > Editor de agente do Console do Dialogflow |
Conceda aos editores do Console do Dialogflow que editam agentes existentes:
|
Consulte Definições de papéis do IAM do Dialogflow. |
| N/A | Dialogflow > Leitor da API Dialogflow |
Conceda a clientes da API Dialogflow que realizam chamadas somente leitura específicas do Dialogflow usando a API:
|
Consulte Definições de papéis do IAM do Dialogflow. |
Controlar o acesso com o console Google Cloud
É possível controlar o acesso com as configurações do IAM. Consulte o guia de início rápido do IAM para ver as instruções detalhadas sobre como adicionar, editar e remover permissões.
Para acessar as configurações abaixo, abra a página IAM no console Google Cloud .
Adicionar um usuário ou uma conta de serviço ao projeto
É possível conceder permissões a usuários ou contas de serviço atribuindo a eles papéis no seu projeto do Google Cloud . Os usuários são adicionados fornecendo os respectivos endereços de e-mail. As contas de serviço também são adicionadas fornecendo o endereço de e-mail associado a elas. Você precisa adicionar membros da conta de serviço quando quiser usar uma conta de serviço para vários projetos e agentes. Para encontrar o endereço de e-mail associado à sua conta de serviço, consulte a página Contas de serviço do IAM no console Google Cloud .
Para adicionar um membro:
- Clique no botão de adição na parte superior da página.
- Digite o endereço de e-mail do membro.
- Selecione um papel.
- Clique em Salvar.
Alterar permissões
- Clique no botão de edição no membro.
- Selecione um papel diferente.
- Clique em Salvar.
Remover um membro
- Clique no botão de exclusão no membro.
Controlar o acesso com o Console do Dialogflow
Opções de compartilhamento são encontradas nas configurações do agente. Para abrir as configurações de compartilhamento do agente:
- Acesse o console do Dialogflow ES.
- Selecione seu agente perto da parte superior do menu da barra lateral esquerda.
- Clique no botão de configurações ao lado do nome do agente.
- Clique na guia Compartilhar. Se a guia Compartilhar não aparecer, é porque você não tem o papel de administrador de agente necessário.
Adicionar um usuário
- Digite o endereço de e-mail do usuário abaixo de Convidar novas pessoas.
- Selecione um papel.
- Clique em Adicionar.
- Clique em Salvar.
Alterar permissões
- Encontre o usuário na lista.
- Selecione um papel diferente.
- Clique em Salvar.
Remover um usuário
Encontre o usuário na lista.
Clique no botão de exclusão no usuário.
Clique em Salvar.
Contas de serviço criadas automaticamente
Quando você cria e trabalha com seu agente, o Dialogflow cria automaticamente alguns agentes de serviço.
Para ver os papéis concedidos a esses agentes de serviço, ative a opção Incluir concessões de papel fornecidos pelo Google na página do IAM.
Não exclua, edite nem faça o download de chaves de nenhum desses agentes de serviço. Além disso, não use-os para fazer chamadas diretas à API. Elas são usadas apenas pelo serviço Dialogflow para se conectar a uma variedade de serviços do Google Cloud usados pelo agente. Talvez seja necessário consultar esses agentes de serviço por e-mail ao configurar determinados recursos do Dialogflow.
A tabela a seguir descreve alguns desses agentes de serviço:
| Formulário de e-mail do IAM | Finalidade |
|---|---|
| service-project-number @gcp-sa-dialogflow.iam.gserviceaccount.com |
Usada para conectar o agente aos serviços que gerenciam o tráfego de integração. |
| firebase-adminsdk-alphanum @project-id.iam.gserviceaccount.com |
Usada para conectar o agente aos serviços que gerenciam o tráfego de integração com o Google Assistente. |
| project-id @appspot.gserviceaccount.com |
Usada para conectar o agente aos serviços que gerenciam o tráfego de integração com o Google Assistente. |
Transferir a função de administrador
Para transferir a função de administrador de um agente, o administrador atual precisa seguir as etapas acima para adicionar um novo administrador. Depois que o novo administrador aceita a função concedida, é seguro remover o administrador antigo.
Se o administrador atual não trabalhar mais na sua organização e você precisar que a função de administrador seja transferida para outro funcionário, você terá duas opções:
- Um administrador da organização associada ao projeto do agente tem permissões para modificar o administrador.
- Se você tiver permissões de leitura para o agente, poderá exportá-lo e importá-lo para um agente em que o funcionário desejado seja administrador. Isso pode criar a inatividade de um agente de produção real enquanto o agente é migrado e as integrações são atualizadas.
OAuth
Se você estiver usando bibliotecas de cliente do Google para acessar o Dialogflow, não será necessário usar o OAuth diretamente, porque essas bibliotecas processam a implementação para você. No entanto, se você estiver implementando seu próprio cliente, talvez seja necessário implementar seu próprio fluxo do OAuth. O acesso à API Dialogflow requer um dos seguintes escopos do OAuth:
https://www.googleapis.com/auth/cloud-platform(acesso a todos os recursos do projeto)https://www.googleapis.com/auth/dialogflow(acesso aos recursos do Dialogflow)
Solicitações que envolvem acesso ao Cloud Storage
Algumas solicitações do Dialogflow acessam objetos no Cloud Storage para ler ou gravar dados. Quando você chama uma dessas solicitações, o Dialogflow acessa os dados do Cloud Storage em nome do autor da chamada. Isso significa que a autenticação da solicitação precisa ter permissões para acessar o Dialogflow e os objetos do Cloud Storage.
Ao usar uma biblioteca de cliente do Google e papéis do IAM, consulte o guia de controle de acesso do Cloud Storage para informações sobre os papéis do Cloud Storage.
Ao implementar seu próprio cliente e usar o OAuth, use o seguinte escopo do OAuth:
https://www.googleapis.com/auth/cloud-platform(acesso a todos os recursos do projeto)