1. Antes de começar
Neste codelab, você vai aprender como o Dialogflow se conecta com sistemas de back-end para fornecer respostas avançadas e dinâmicas aos perguntas.
Pré-requisitos
Antes de continuar, você precisa concluir os seguintes codelabs:
- Criar um agendamento de horários com o Dialogflow
- Integrar o Dialogflow com o Actions on Google
- Entenda as entidades no Dialogflow
Você também precisa entender os conceitos e construções básicos do Dialogflow, extraídos dos vídeos a seguir no programa Criar um bot de bate-papo com o Dialogflow.
O que você vai aprender
- O que é atendimento de pedidos
- Como configurar uma conta de serviço para o Google Agenda
- Como configurar o Google Agenda
- Como ativar o fulfillment no Dialogflow
- Como testar o fulfillment
O que você vai criar
- Fulfillment usando o Cloud Functions
- Uma integração entre o Dialogflow e o Google Agenda
O que é necessário
- Um navegador da Web e um endereço de e-mail para fazer login no console do Dialogflow
- Uma Conta do Google para acessar o Google Agenda
2. O que é atendimento de pedidos?
Fulfillment é o código implantado como um webhook que permite que o agente do Dialogflow chame a lógica de negócios de intent a intent. Durante uma conversa, o fulfillment permite que você use as informações extraídas pelo processamento de linguagem natural do Dialogflow para gerar respostas dinâmicas ou acionar ações no back-end. A maioria dos agentes do Dialogflow usa fulfillment.
Confira a seguir alguns exemplos de quando é possível usar o fulfillment para estender um agente:
- Gerar respostas dinâmicas com base nas informações pesquisadas em um banco de dados.
- Para fazer pedidos com base nos produtos que um cliente pediu
- Para implementar as regras e condições vencedoras para um jogo
3. Ativar a API Calendar
- No Console do Dialogflow, clique em .
- Na guia Geral, role até ID do projeto e clique em Google Cloud .
- No console do Google Cloud, clique em Menu de navegação ☰ > APIs e Serviços > Biblioteca.
- Pesquise "API Google Calendar" Depois clique em Ativar para usar a API no projeto do Google Cloud.
4. Configurar conta de serviço
- Clique em Menu de navegação ☰ > APIs e Serviços > Credenciais.
- Clique em Criar credenciais > Conta de serviço.
- Em Detalhes da conta de serviço, digite "appointment-scheduler". como o Nome da conta de serviço e, em seguida, clique em Criar.
- Em Conceda a essa conta de serviço acesso ao projeto, clique em Continuar para ignorar.
- Em Conceda aos usuários acesso a essa conta de serviço (opcional), clique em Criar chave, selecione JSON e clique em Criar.
Um arquivo JSON será salvo no seu computador e será necessário nas próximas seções de configuração.
5. Configuração do Google Agenda
- Acesse o Google Agenda e clique em Menu principal ☰ > Adicionar outras agendas > Criar nova agenda.
- Digite "Agenda de horários" como o nome da agenda e clique em Criar agenda.
- Atualize a página, clique em Agenda de horários, role até Compartilhar com pessoas específicas e clique em Adicionar pessoas.
- Copie o
client_email
do arquivo JSON que você salvou como parte da configuração da conta de serviço e cole-o na caixa de diálogo.
- Clique na lista suspensa Permissões e em Fazer alterações nos eventos > Enviar.
- Ainda em Configurações, role até Integrar agenda e copie o ID da agenda.
6. Configure o fulfillment no Dialogflow
Adicionar conta de serviço e ID da agenda ao fulfillment
- Navegue até o agente AppointmentScheduler do Dialogflow e clique em Fulfillment.
- Ative o Editor in-line.
- Atualize o arquivo
index.js
com o seguinte código:
'use strict';
// Import the Dialogflow module from Google client libraries.
const functions = require('firebase-functions');
const {google} = require('googleapis');
const {WebhookClient} = require('dialogflow-fulfillment');
// Enter your calendar ID below and service account JSON below
const calendarId = "<INSERT YOUR CALENDAR ID>";
const serviceAccount = {<INSERT CONTENTS OF YOUr JSON FILE HERE>}; // Starts with {"type": "service_account",...
// Set up Google Calendar Service account credentials
const serviceAccountAuth = new google.auth.JWT({
email: serviceAccount.client_email,
key: serviceAccount.private_key,
scopes: 'https://www.googleapis.com/auth/calendar'
});
const calendar = google.calendar('v3');
process.env.DEBUG = 'dialogflow:*'; // enables lib debugging statements
const timeZone = 'America/Los_Angeles';
const timeZoneOffset = '-07:00';
// Set the DialogflowApp object to handle the HTTPS POST request.
exports.dialogflowFirebaseFulfillment = functions.https.onRequest((request, response) => {
const agent = new WebhookClient({ request, response });
console.log("Parameters", agent.parameters);
const appointment_type = agent.parameters.appointment_type;
function makeAppointment (agent) {
// Calculate appointment start and end datetimes (end = +1hr from start)
const dateTimeStart = new Date(Date.parse(agent.parameters.date.split('T')[0] + 'T' + agent.parameters.time.split('T')[1].split('-')[0] + timeZoneOffset));
const dateTimeEnd = new Date(new Date(dateTimeStart).setHours(dateTimeStart.getHours() + 1));
const appointmentTimeString = dateTimeStart.toLocaleString(
'en-US',
{ month: 'long', day: 'numeric', hour: 'numeric', timeZone: timeZone }
);
// Check the availability of the time, and make an appointment if there is time on the calendar
return createCalendarEvent(dateTimeStart, dateTimeEnd, appointment_type).then(() => {
agent.add(`Ok, let me see if we can fit you in. ${appointmentTimeString} is fine!.`);
}).catch(() => {
agent.add(`I'm sorry, there are no slots available for ${appointmentTimeString}.`);
});
}
// Handle the Dialogflow intent named 'Schedule Appointment'.
let intentMap = new Map();
intentMap.set('Schedule Appointment', makeAppointment);
agent.handleRequest(intentMap);
});
//Creates calendar event in Google Calendar
function createCalendarEvent (dateTimeStart, dateTimeEnd, appointment_type) {
return new Promise((resolve, reject) => {
calendar.events.list({
auth: serviceAccountAuth, // List events for time period
calendarId: calendarId,
timeMin: dateTimeStart.toISOString(),
timeMax: dateTimeEnd.toISOString()
}, (err, calendarResponse) => {
// Check if there is a event already on the Calendar
if (err || calendarResponse.data.items.length > 0) {
reject(err || new Error('Requested time conflicts with another appointment'));
} else {
// Create event for the requested time period
calendar.events.insert({ auth: serviceAccountAuth,
calendarId: calendarId,
resource: {summary: appointment_type +' Appointment', description: appointment_type,
start: {dateTime: dateTimeStart},
end: {dateTime: dateTimeEnd}}
}, (err, event) => {
err ? reject(err) : resolve(event);
}
);
}
});
});
}
- Substitua
<INSERT YOUR CALENDAR ID>
pelo ID da agenda copiado na seção anterior. - Substitua
<INSERT CONTENTS OF YOUR JSON FILE HERE>
pelo conteúdo do arquivo JSON. - Opcional. Mude const timeZone e const timeZoneZone de acordo com o fuso horário da Agenda de horários.
- Clique em Implantar.
Ativar resposta de fulfillment
- Navegue até o console do Dialogflow e clique em Intents.
- Clique em Programar intent de agendamento.
- Role para baixo até Fulfillment e ative a opção Enable webhook call for the intent (Ativar chamada de webhook para a intent).
- Clique em Salvar.
- Clique em Implantar.
7. Teste o chatbot
É possível testar o chatbot no simulador do Actions ou usar a integração com a Web ou o Google Home que você já conheceu.
- Usuário: "Agende o registro de veículos às 14h de amanhã."
- Bot de bate-papo: "Ok, vamos ver se podemos encaixar você. 24 de abril, as 14h está tudo bem!"
- O Google Agenda reserva a resposta.
8. Limpar
Se você planeja concluir outros codelabs do Dialogflow, pule esta seção por enquanto e volte mais tarde.
Exclua o agente do Dialogflow
- Clique no ao lado do agente.
- Na guia General, role até a parte inferior e clique em Delete This Agent.
- Digite Excluir na caixa de diálogo e clique em Excluir.
9. Parabéns
Você criou um chatbot no Dialogflow e o integrou ao Google Agenda. Você já sabe como desenvolver um chatbot.
Saiba mais
Para saber mais, confira os exemplos de código na página do Dialogflow no GitHub.