Ir al contenido principal

Mi primer chatbot con whatsapp

No voy a hacer "apología de whatsapp" pues es claro para todos que es una herramienta de comunicación que todo el mundo (al menos occidental) tiene y usa a diario.

Siendo así ¿que tal si mi aplicación pudiera responder por ese medio? ¿Qué skills necesitaría? ¿Qué otros recursos?

Revisé algunos contenidos al respecto, por cierto los recomiendo, especialmente los producidos en el GX29: https://meetings.genexus.com/2019/sessions/chatbots

Es tremendo lo que se puede hacer alrededor del tema. Sin embargo lo que yo quería era algo bien sencillo, no quería tanto la parte de NLP (PLN), IA, etc que es un camino muy interesante pero que implicaba más trabajo y lo mio era explorar, divertirme, hacer algo útil y aprender en el camino (algunos le llaman "procastinar":)).

Quería probar la utilidad de "dialogar" con mi aplicación vía Whatsapp, generar otras ideas a partir de ver y sentir algo funcionando, resolviendo un problema real, un prototipo de bajo costo.
Así que partí de un servicio que simplemente me contesta un dato (cantidad de usuarios registrados), el cual ya tengo y es cuestión de ponerle Whatsapp arriba.
Si funciona para ese primer servicio, podría implementarlo para otros servicios: ¿que tal que Whatsapp fuera la UI de esos servicios?

Algo así:

Whatsapp llama a mi "proxy" y mi "proxy" llama al servicio que se quiera consumir.
Ir directo con whatsapp me complicó un poco (cuenta certificada, etc) así que terminé incluyendo Twilio como un "broker" entre Whataspp y mi proxy (algo de esto habla Sebastián en su charla del GX29)

Así que el esquema quedó:


Es decir: Whatsapp "llama" a Twilio, Twilio a mi app, esta determina cuál es el servicio y lo llama, luego contesta a Twilio que contesta a Whatsapp.

¿A qué se resume hacer un chatbot como este?

1. Crearse una cuenta en Twilio (acá una guía)
2. Definir un "webhook" que atenderá las llamadas de Twilio.

Esto en GeneXus 16 U6 es un proc HTTP y con el módulo de GeneXusChannels que viene en GeneXus es simplemente:

&Value = Parameters.TwilioKey
&Query = &HttpRequest.ToString()
GeneXusChannels.Webhooks.Whatsapp.Twilio.WhatsappTwilioWebhook(&Query, &Message, &ChannelConfiguration)

&ChannelConfigurationProperty = new()
&ChannelConfigurationProperty.Key = WhatsappProperties.Token
&ChannelConfigurationProperty.Value = &Value
&ChannelConfiguration.Properties.Add(&ChannelConfigurationProperty)

// processing the message received
do case
    case &Message.Text.ToLower().Trim() = !"1"
        &Message.Text = str(GetGeneXusUsersTotal())
    case &Message.Text.ToLower().Trim() = !"2"
        &Message.Text = "another service"
    otherwise
        &Message.Text="Choose:"+newline()+"1. Total Registered Users (demo)"+newline()+"2. Another service"+Newline()
endcase

GeneXusChannels.Message.SendMessage(&ChannelConfiguration, &Message, &Messages)
Digamos que creando la cuenta y escribiendo 10 lineas de código tengo un chatbot funcional!
Es más, si no la quieren escribir pueden obtener la KB de acá y esta guía puede aportar.

Se ve así:



De acuerdo que no tiene NLP, la seguridad es básica (uso un token en el header del servicio que consumo), no mantiene estado de la conversación, etc pero funciona y me llevó 20 minutos dejarlo andando!!

A su vez, viendo la cantidad de servicios de datos que existen hoy, viendo las charlas del GX29 y lo que hay publicado en el wiki de GeneXus quisiera tener un par de horas para poder seguir explorando, aprendiendo, haciendo prototipos rápido y fácil porque se pueden hacer cosas muy útiles (y divertidas) con esto!

Comentarios

  1. It’s amazing in support of me to have a site, which is useful in support of my know-how. thanks admin, you surely come with remarkable articles. Cheers for sharing your website page.
    AI Chatbot
    Chatbot Development
    RPA Bot
    Bank Chatbot
    Artificial Intelligence Company in Dubai
    Artificial Intelligence Companies

    ResponderBorrar
  2. Hola que tal mi nombre es Andres. La empresa para la que trabajo quiere poder integrar su padron de socios y enviar recordatorio de citas o comunicados en general. Quisiera preguntarte si tienes la posibilidad de realizar algun desarrollo en genexus y hacernos ese trabajo?. Te agradezco si me puedes informar. Saludos!

    ResponderBorrar
    Respuestas
    1. Andrés,
      Personalmente no, sin embargo diría que la gente de Delfasoft te pueden dar una mano porque tienen aplicaciones para padrones de socios, etc. Sé que se especializan en deportes, gimnasios, boxes pero tienen otras aplicaciones que pueden servir.
      Te paso el contacto:

      Fabricio De los Santos
      https://www.delfasoft.com | https://www.delfasport.com
      Twitter: http://twitter.com/fabriciodls
      LinkedIn: http://www.linkedin.com/in/fabriciodelossantos

      Saludos,

      Borrar
  3. La idea del chatbot en Gx funciona en proyectos simples o demos como esta. Sin embargo cuando intentas agregar un mínimo de complejidad comienzan los problemas típicos de Genexus, la documentación dice una cosa pero la realidad es otra. Hay que terminar haciendo todo a prueba y error.
    Si van a comenzar un proyecto de chatbot, no lo recomiendo. Lo digo por experiencia.
    Estudien otras herramientas, lleva un poco más de esfuerzo pero al final vale la pena.

    ResponderBorrar
    Respuestas
    1. JY,

      Entiendo, lo mío era un "sample" nomás, no me ha tocado participar directamente en proyectos más "complejos" que seguro implican otros desafíos.
      Sí conozco varios que son más "divertidos" que el hello world que armé yo y andan bárbaro.
      Lamento que no te haya ido bien en tu caso, espero te vaya bien con esas otras herramientas (hay muchas y muy buenas por cierto!! todo depende de lo que se quiera hacer), si en algún momento le das otra oportunidad a hacerlo con Genexus contá conmigo que no soy especialista pero capaz alguna mano puedo dar.

      Gustavo

      Borrar
  4. Yo integre unas apis que elabore y las uso con genexus para el envio a whatsapp, tanto con el chatbot como tambien para el envio de recordatorios , alertas o notificaciones. pueden escribirme a juandarenas@gmail.com y les doy informacion

    ResponderBorrar

Publicar un comentario

Entradas más populares de este blog

Abrir links con aplicaciones nativas y no el browser (deeplinking)

El problema que tengo con algunas aplicaciones Android/iOS es que cuando recibo un link por algún medio (mail, tweet, etc) al abrirlo me lo abre con el browser, en lugar de abrirlo con una aplicación nativa asociada a ese “contenido”. Por ejemplo, si recibo un link a un tweet espero que lo abra con alguna aplicación de twitter que tenga instalada y no con el browser. De modo análogo si recibo un mail con una nota de prensa de un medio X y tengo la aplicación de ese medio X instalada, espero que el link lo abra con la aplicación nativa y no con el browser. Lo mismo quisiera con mi aplicación de "banking" o cualquiera que tenga instalada y sepa manejar ese "contenido" (link). Los motivos son bastante obvios pero los resumo en: la experiencia de usuario es mucho mejor en la aplicación nativa que en el navegador. Parte importante del tema es que el mismo link sea válido tanto para ver el contenido en el browser como para verlo en la aplicación, porque como prove

¡A la salud de mi KB!

Es bueno, especialmente en "bases de conocimiento" (KB) que han pasado por varias versiones de Genexus, chequear su "estado de salud". En este sentido KBDoctor  es una herramienta que ayuda mucho, principalmente desde el punto de vista del "modelo" Genexus (atributos, calls, definiciones de variables, etc) representado en una KB. También es útil revisar la salud de los archivos que lo soportan. Hasta la 9.0 eran archivos C-tree (los famosos .DAT) que tenían indices (los famosos .IDX) y teníamos en "rebuild -y" que mejoraba esos archivos y sobre todo reconstruía los indices. A partir de la X las KBs se almacenan en MS SQL Server por lo cual la administración de la misma pasó de ser un "file server" a un "database server". En este sentido algo que me ha dado muy buenos resultados es el "CheckKnowledgeBase".

Rocha:Constantes tipo fecha

En la Rocha se soportan constantes del tipo fecha o fecha-hora con formato ANSI/ISO (AAAA-MM-DD HH:MM:SS).  Tecnicamente (Sintáxis): <date>::=    [0-9]{1,4}"/"[0-9]{1,2}"/"[0-9]{1,2} | [0-9]{1,4}"."[0-9]{1,2}"."[0-9]{1,2} | [0-9]{1,4}"-"[0-9]{1,2}"-"[0-9]{1,2} <hms>::=    [0-9]{1,2}[ap] | [0-9]{1,2}":"[0-9]{1,2}[ap]? | [0-9]{1,2}":"[0-9]{1,2}":"[0-9]{1,2}[ap]? <constant> ::=   "#"<date>"#" | "#"<date> <hms>"#" | "#"<hms>"#" Funcionalmente Se pueden utilizar esas constantes en las reglas, eventos, propiedades, etc (todo lugar donde se utilice el parser): Algunos ejemplos básicos: &FechaInicial=#2007-01-01# &FechaHoraInicial=#07-1-1 11:15a# &HoraInicial=#11a# Me parece bueno no tener que escribir funciones (CTOD, TTOC) sobre constantes tipo char para lograr una fecha y mucho mejor aun en