No momento, seu webhook usa dados codificados na função accountBalanceCheck.
Nesta etapa do tutorial,
você vai criar um
banco de dados do Spanner, preenchê-lo com dados de saldo,
e atualizar sua função para consultar o banco de dados.
Configuração do projeto
É importante que seu agente do Dialogflow e o banco de dados estejam no mesmo projeto. Essa é a maneira mais fácil de sua função ter acesso seguro ao banco de dados. Além disso, você precisa ativar a API Spanner.
Antes de criar o banco de dados, selecione seu projeto no Google Cloud console.
Ative a API Spanner para o projeto.
Criar uma instância do Spanner
Quando você usa o Spanner pela primeira vez, é preciso criar uma instância, que é uma alocação de recursos usados pelos bancos de dados do Spanner naquela instância.
No Google Cloud console, acesse a página Instâncias do Spanner.
Clique em Criar instância.
Para o nome da instância, insira Instância do tutorial.
O ID da instância é inserido automaticamente com base no nome dela.
Em Escolha sua configuração, mantenha a opção padrão Regional e selecione o mesmo local da região escolhido ao criar a função.
Em Alocar capacidade de computação, insira 100 unidades de processamento. Isso fornece uma capacidade mínima para o tutorial.
Clique em Criar. O Google Cloud console mostra a página Visão geral da instância criada.
Criar um banco de dados do Spanner
Agora que você tem uma instância, é necessário criar um banco de dados. Para criar um banco de dados:
- Na página Visão geral da instância, clique em Criar banco de dados.
- Para o nome do banco de dados, insira tutorial-database.
- Selecione o dialeto do banco de dados SQL padrão do Google.
- Clique em Criar. O Google Cloud console mostra a página Visão geral do banco de dados criado.
Criar tabelas para seu banco de dados
Agora que você tem um banco de dados, é necessário criar tabelas para ele. Para criar tabelas:
- Na seção "Tabelas" da página Visão geral do banco de dados, clique em Criar tabela.
Na página Escrever instruções DDL, insira:
CREATE TABLE Checking ( AccountId INT64, Balance INT64, ) PRIMARY KEY(AccountId);Clique em Enviar. O Google Cloud console retorna à página Visão geral do banco de dados e mostra que as atualizações do esquema estão em andamento. Aguarde até que a atualização seja concluída.
Na seção "Tabelas" da página Visão geral do banco de dados, clique em Criar tabela.
Na página Escrever instruções DDL, insira:
CREATE TABLE Savings ( AccountId INT64, Balance INT64, ) PRIMARY KEY(AccountId);Clique em Enviar. O Google Cloud console retorna à página Visão geral do banco de dados e mostra que as atualizações do esquema estão em andamento. Aguarde até que a atualização seja concluída.
Inserir dados nas tabelas
Agora que seu banco de dados tem tabelas, é necessário adicionar dados a elas. Para adicionar dados:
- Na lista de tabelas na página Visão geral do banco de dados, clique na tabela "Checking". O Google Cloud console mostra a página Esquema da tabela.
- No menu de navegação à esquerda, clique em Dados para mostrar a página Dados da tabela.
Clique em Inserir. O Google Cloud console mostra a página Consulta da tabela com uma nova guia de consulta que contém instruções
INSERTeSELECT. Substitua essas instruções pelo seguinte:INSERT INTO Checking (AccountId, Balance) VALUES(1, 1000), (2, 2000);Clique em Executar.
No menu de navegação à esquerda, clique em Dados novamente para mostrar os dados da tabela. Confirme se a tabela contém os dados desejados.
Clique no link tutorial-database: Visão geral para retornar à página de visão geral do banco de dados.
Na lista de tabelas na página Visão geral do banco de dados, clique na tabela "Savings". O Google Cloud console mostra a página Esquema da tabela.
No menu de navegação à esquerda, clique em Dados para mostrar a página Dados da tabela.
Clique em Inserir. O Google Cloud console mostra a página Consulta da tabela com uma nova guia de consulta que contém instruções
INSERTeSELECT. Substitua essas instruções pelo seguinte:INSERT INTO Savings (AccountId, Balance) VALUES(1, 10000), (2, 20000);Clique em Executar.
No menu de navegação à esquerda, clique em Dados novamente para mostrar os dados da tabela. Confirme se a tabela contém os dados desejados.
Atualizar a Função do Cloud para consultar o banco de dados
A função accountBalanceCheck no código do webhook verifica se variáveis de ambiente específicas estão definidas com informações para conexão ao banco de dados.
Se essas variáveis de ambiente não estiverem definidas, a função usará um saldo da conta codificado.
Agora que você tem um banco de dados configurado, atualize sua Função do Cloud para definir as variáveis de ambiente necessárias:
Abra a página de visão geral do Cloud Functions.
Clique na função tutorial-banking-webhook para acessar a página de detalhes.
Clique em Editar.
Abra a seção Configurações de ambiente de execução, criação e conexões.
Selecione a guia Ambiente de execução.
Adicione as seguintes variáveis na seção "Variáveis de ambiente de execução":
PROJECT_ID: ID do projetoSPANNER_INSTANCE_ID: ID da instância do Spanner (provavelmentetutorial-instance)SPANNER_DATABASE_ID: ID do banco de dados do Spanner (provavelmentetutorial-database)
Clique em Próxima.
Clique em Implantar.
Aguarde até que o indicador de status mostre que a função foi implantada.
Testar o agente
Seu agente está pronto para ser testado. Clique no botão Testar agente no console do Dialogflow para abrir o simulador. Tente ter a seguinte conversa com o agente:
| Turno de conversa | Você | Agente |
|---|---|---|
| 1 | Olá | Olá, obrigado por escolher o ACME Bank. |
| 2 | Quero saber o saldo da minha conta | Qual conta você quer o saldo: poupança ou corrente? |
| 3 | Corrente | Este é o seu saldo mais recente: US$ 10,00 |
Se você examinar o código, US$ 10 não será o valor codificado. Isso significa que seu webhook se conectou ao banco de dados, que tem um saldo de US $10.
Solução de problemas
O código do webhook inclui instruções de registro. Se você estiver com problemas, tente visualizar os registros da Função do Cloud.
Se a função não estiver se conectando ao banco de dados e você encontrar um erro de permissão nos registros, talvez seja necessário corrigir o papel da conta de serviço padrão usada pela função.
Essa conta de serviço tem o formato
PROJECT_ID@appspot.gserviceaccount.com.
Você pode corrigir isso de uma das seguintes maneiras:
Se a conta de serviço padrão for mostrada na página principal do IAM, altere as permissões da conta de serviço. O papel Editor vai funcionar, mas talvez você queira um papel mais granular em um cenário de produção.
Se uma conta de serviço padrão não for mostrada na página principal do IAM, conceda o papel necessário adicionando a conta de serviço como um novo principal.
Como alternativa, você pode usar uma conta de serviço criada.
Mais informações
Para mais informações sobre as etapas acima, consulte:
- Como usar o Cloud Spanner com Cloud Functions
- Criar e consultar um banco de dados usando o console do Google Cloud
- Linguagem de definição de dados do SQL padrão do Google
- Linguagem de manipulação de dados SQL padrão do Google