Como criar um chatbot sem servidor para WhatsApp com Python, Google Cloud Functions e Twilio
Um chatbot é um aplicativo de software usado para automatizar interações e conversas com pessoas por meio de plataformas de mensagens. Os usos comuns dos chatbots incluem roteamento de solicitações, atendimento ao cliente e coleta de informações.
A arquitetura sem servidor (Serverless architecture) é um padrão de design em que os aplicativos são divididos em funções individuais que podem ser chamadas e dimensionadas separadamente. O objetivo é acabar com a complexidade do processo de criação e execução de aplicativos para desenvolvimento e implantação da infraestrutura necessária para sua execução.
Neste tutorial, você vai aprender a criar um chatbot sem servidor do WhatsApp com API do WhatsApp da Twilio e as funções Python no Google Cloud. O chatbot aceita o nome de um país e mostra informações sobre ele. Os dados do país são obtidos da API pública REST Countries.
Requisitos do tutorial
Para seguir este tutorial, é necessário ter os seguintes itens:
- Python 3.7 ou mais recente. Se o seu sistema operacional não tiver um interpretador do Python pré-instalado, baixe um arquivo de instalação em python.org.
- Uma conta no Google Cloud. Crie uma conta em cloud.google.com.
- Uma conta ativa no WhatsApp.
- Uma conta da Twilio. Se é a primeira vez que utiliza a Twilio, crie uma conta gratuita agora. Confira os recursos e as limitações de uma conta gratuita da Twilio.
Como configurar a área restrita do WhatsApp da Twilio
A Twilio oferece uma área restrita para o WhatsApp, onde é possível facilmente desenvolver e testar seu aplicativo. Depois que seu aplicativo estiver finalizado, você poderá solicitar o acesso de produção para o número de telefone da Twilio, que exige a aprovação pelo WhatsApp.
Vamos começar o teste da nossa área restrita do WhatsApp. No console da Twilio, selecione Programmable Messaging no menu da barra lateral à esquerda. Clique em "Try it Out" (Experimentar) e depois em "Try WhatsApp" (Experimentar WhatsApp). Na página da área restrita para o WhatsApp, é possível visualizar o número da área restrita e um código para entrar.
Para entrar na área restrita, envie uma mensagem de WhatsApp para o número da área restrita com o texto "join <your sandbox code>" (entrar em <código da área restrita>). É enviada uma resposta de confirmação da área restrita assim que o código é aceito.
Como criar um virtualenv do Python e instalar os requisitos
Na sua máquina local, crie uma pasta onde o código do nosso chatbot fica ativo e configure um virtualenv dentro dessa pasta. Os comandos a seguir funcionam nas plataformas de Unix e Mac. Abra um terminal e digite:
Nas plataformas do Windows, use os seguintes comandos:
Em seguida, é possível prosseguir para instalar os pacotes necessários com o seguinte comando:
Este comando instala 2 pacotes:
- twilio, para acessar as APIs da Twilio
- requests, pacote para nos ajudar a acessar serviços da Internet de terceiros
Devemos gravar os pacotes que instalamos em um arquivo requirements.txt para que o Google Cloud Platform possa usá-los ao instalar a função de nuvem posteriormente. Veja o comando abaixo:
No momento da elaboração deste artigo, veja as versões do pacote em requirements.txt:
Como criar uma função do Google Cloud
O Google Cloud Functions pode ser chamado usando HTTP ou acionadores de eventos. As funções com um acionador HTTP são chamadas quando uma solicitação HTTP é enviada para o URL da função. As funções com acionadores de eventos são chamadas quando um evento ocorre em seu projeto do GCP. Exemplos de fontes de eventos são Pub/Sub, Firestore e Firebase.
Para implementar um chatbot do WhatsApp, a Twilio precisa chamar um webhook HTTP quando um usuário enviar uma mensagem no WhatsApp. Assim, sabemos que é preciso uma função de nuvem chamada HTTP.
Como criar o webhook
Na nossa pasta raiz, twilio-chatbot, crie um arquivo chamado main.py. É aqui que o código do bot fica ativo. Verificação rápida: você deve ter 2 arquivos na pasta até agora, requirements.txt e main.py, além do diretório do ambiente virtual.
Vamos criar uma função que atua como o ponto de entrada para o webhook bot no arquivo main.py:
No corpo da função, é preciso começar recuperando a mensagem enviada pelo usuário pelo WhatsApp. Veja como fazer:
No código acima, recuperamos o valor do argumento Body, que é definido pela Twilio para a mensagem enviada pelo usuário. Se esse valor não existe, o padrão é uma string vazia. Convertemos o texto em minúsculas para padronizar a entrada do usuário. Isso significa que "alemanha", "Alemanha", "ALEMANHA" e "aLemAnha" são interpretados como "alemanha".
Com o nome do país recebido, solicitamos dados da API pública REST Countries da seguinte forma:
Se a API responder com um código de status não HTTP 2xx, significa que nossa solicitação não foi bem-sucedida. Precisamos detectar essa condição de erro e informar o usuário. Esta é a lógica que reproduz:
Os dados devolvidos pela API são uma lista de comprimento 1. Na lista, temos um dicionário de dados de países com chaves como name
, region
, capital
, etc. No exemplo de bot, extrairemos os valores do nome nativo, capital, gentílico e região. Sinta-se à vontade para mudar ou adicionar esses valores ao criar seu bot. Veja aqui o modelo de estrutura de dados da API REST Countries.
Agora que sabemos que os dados retornados são uma matriz, é possível atualizar a instrução IF na parte inferior da função com as seguintes alterações para extrair os quatro valores mencionados acima.
Com as quatro variáveis extraídas, podemos construir uma resposta legível usando as f-strings do Python:
É possível agora nos comunicar com nossa API externa e extrair os dados necessários de sua resposta e precisamos pensar como esses dados serão passados para a Twilio e serem entregues ao usuário. Quando a Twilio chama um webhook, espera-se uma resposta do aplicativo no TwiML (Twilio Markup Language), que é uma linguagem baseada em XML. A biblioteca Twilio helper que instalamos oferece uma maneira fácil de criar e estruturar essa resposta em nosso código. Abaixo, você pode ver um exemplo de como estruturar o corpo da mensagem e incluir uma mídia relacionada.
Vamos atualizar nosso código para que as respostas sigam a linguagem esperada. Observe que agora estamos passando a resposta de solicitações bem-sucedidas e mal-sucedidas para msg.body
e gerar a resposta correta de TwiML e seu registro e abaixo é possível ver o corpo atualizado da função whatsapp_webhook()
:
Neste momento, podemos reunir tudo e concluir nossa função. Veja abaixo a aparência do arquivo main.py completo, incluindo todas as importações necessárias. Verifique se a sua versão é igual.
Implantação
Há quatro maneiras comuns de implantar a função de nuvem que acabamos de criar no Google Cloud Platform:
- No painel do GCP (Google Cloud Platform)
- Localmente em nosso terminal
- Do controle de origem
- A partir da API de funções de nuvem
Este tutorial mostra a primeira opção. Faça login na sua conta do GCP e navegue até o painel e clique em "Cloud Functions" (Funções da nuvem) no menu lateral.
Clique em "Create Function" (Criar função) e defina o nome da função como twilio-webhook. Marque também "Allow unauthenticated invocations" (Permitir chamadas não autenticadas) para tornar o webhook publicamente disponível. Ao clicar em "Save" (Salvar), aparece:
Clique em "NEXT" (Próximo) para ser encaminhado para a página onde inserimos o código de função de nuvem. Defina "Runtime" (Tempo de execução) para 'Python 3.7' e "Entry point" (Ponto de entrada) para 'whatsapp_webhook'. Substitua o conteúdo do arquivo *main.py* à esquerda por aqueles do arquivo main.py criados na seção anterior. Execute as mesmas ações no arquivo requirements.txt. Depois de terminar, clique em "DEPLOY" (IMPLANTAR).
Depois de implantado com êxito, aparece uma marca de seleção verde ao lado do nome da sua função, conforme mostrado abaixo.
Como configurar o webhook da Twilio
Clique na função de nuvem no painel acima e, em seguida, clique na guia "TRIGGER" (ACIONAR) para exibir o URL de acionamento.
Volte ao Console Twilio, clique em Programmable Messaging (Mensagens programáveis), depois em Settings (Configurações) e, por último, em WhatsApp Sandbox Settings (Configurações de sandbox para WhatsApp). Copie o "Trigger URL" (URL de acionamento) da função de nuvem e cole-o nas "WhatsApp Sandbox Settings" (Configurações de área restrita do WhatsApp) no campo "When a message comes in" (Quando receber uma mensagem). Verifique se o método de solicitação está definido como "HTTP POST" (PUBLICAÇÃO HTTP) e clique em "Save" (Salvar).
Com o número de WhatsApp conectado à área restrita, é possível fazer um bate-papo com o bot. Envie o nome de um país para obter uma resposta do webhook Python em execução no GCP. Veja os exemplos abaixo:
Você pode verificar se o bot reconhece erros enviando uma palavra que não é um país:
Arquiteturas alternativas
As arquiteturas sem servidor oferecem a oportunidade de criar um ponto de conexão com a Internet sem se preocupar com infraestrutura e implantação. Conforme nosso exemplo acima, tínhamos um endpoint em menos de 30 linhas de código e não precisamos de uma estrutura da Internet para executá-lo. Além das funções de nuvem do GCP, o AWS oferece um produto semelhante chamado AWS Lambda e a Microsoft tem as funções do Azure.
Por vários motivos, como custos de hospedagem, também é possível considerar o uso de um endpoint tradicional criado com uma estrutura da Internet em Python para seu webhook. Se decidir pesquisar essa opção, veja aqui um tutorial sobre como criar um chatbot WhatsApp com Python, Flask e Twilio.
Publicações relacionadas
Recursos relacionados
Twilio Docs
De APIs a SDKs e aplicativos de amostra
Documentação de referência de API, SDKs, bibliotecas auxiliares, guias de início rápido e tutoriais para sua linguagem e plataforma.
Centro de Recursos
Os mais recentes e-books, relatórios do setor e webinars
Aprenda com especialistas em engajamento do cliente para melhorar sua própria comunicação.
Ahoy
Centro da comunidade de desenvolvedores da Twilio
Melhores práticas, exemplos de código e inspiração para criar comunicações e experiências de engajamento digital.