Skip to content
This repository has been archived by the owner on May 15, 2022. It is now read-only.

Latest commit

 

History

History
171 lines (111 loc) · 15.4 KB

README.md

File metadata and controls

171 lines (111 loc) · 15.4 KB

Tutorial-Echobot

Un bot básico de Facebook Messenger que te responde lo que tú escribiste./A basic Facebook Messenger bot that replies with the message you sent.

Si te gustó este tutorial, dale una estrella./If you liked this tutorial, please give it a star.

Spanish

¿Qué necesito?

Para este tutorial necesitas:

1. Haz tu aplicación en Facebook

  • Lo primero que debes de hacer es una aplicación en Facebook, a la cual tu página estará suscrita. Para hacer tu aplicación de facebook debes de entrar a https://developers.facebook.com/, e iniciar sesión (en caso de que no inicie sesión automáticamente). Después deberás de ir a la esquina superior derecha, donde dice mis aplicaciones, y seleccionar 'añadir nueva aplicación'

alt_text

  • Tendrás que ingresar un nuevo identificador de la aplicación. En nombre para mostrar pondrás el nombre de tu proyecto (en este caso Tutorial Echobot y después tendrás que ingresar un correo electrónico de contacto.)

alt_text

  • Probablemente y por seguridad te pida llenar un captcha. Llénalo y te llevará al dashboard principal.

  • Dentro del dashboard principal te saldrán todos los productos que podemos utilizar. En este caso seleccionaremos Messenger y nos abrirá la pestaña de configuracón del producto.

alt_text

2. Haz tu página de Facebook

  • En caso de que ya tengas una página de Facebook, puedes omitir este paso.
  • Para hacer una página de FB existen varios métodos. En este caso lo haremos desde el dashboard del paso anterior. Dentro de la página de configuración de Messenger, hay una sección que dice Generación de Identificador, donde en pasos más adelante vincularemos la página y nuestra aplicación. Dentro de dicha sección, debajo del cuadro de identificador de acceso, hay un pequeño enlace que dice Crea una nueva página, le damos clic y nos llevara al panel de configuración de nuestra página.

alt_text

Dentro de dicho panel seleccionaremos la clase de paǵina que desees, y la nombraremos. En este caso yo la nombraré Echobot.

alt_text

alt_text

3. Vincula tu página de Facebook y tu aplicación

  • Dentro del dashboard de configuración de Messenger (Generación de Identificador), seleccionamos nuestra página de las opciones. Tal vez te salga un cuadro de confirmación que te sugiera enviar a revisión. Sólo tenemos que seleccionar Continuar como tu usuario, y después te pedirá permisos para que tu aplicación pueda administrar tu página. De manera similar habrá que aceptar la ventana. Si todo salió bien se generará el token de acceso de la página. Es importante tenerlo a la mano.

4. Escribe el código

  • Crea una carpeta que se llame app y dentro de ella crea o copia el archivo app.py. Teniendo como resultado algo como /app/app.py

  • Abre tu editor de textos y copia el código de app.py, sustituye tu token generado en el paso anterior en PAGE_ACCESS_TOKEN y ejecútalo desde la terminal (recuerda que debes de ubicarte en el directorio /app que creaste) con python app.py (Puedes usar la versión 3 de python, solo debes de sustituir python por python3).

  • Si todo sale bien el "servidor" de Flask se levantará en el localhost con el puerto 5000, estará en el modo debug. Deberás ver una pantalla como la siguiente:

alt_text

5. "Súbelo" a internet

  • Como sabemos, el servidor de Flask se levantó en un ambiente local, pero Facebook requiere de un servidor con certificado de seguridad y protocolo https. Para resolver este tema usaremos Ngrok. Éste hace un tunneling a través de http, a un puerto designado. Esto quiere decir que tu puerto en el que se montó Flask (en este caso el 5000), quedará expuesto para que cualquiera le pueda hacer peticiones. Para ejecutar ngrok los comandos varían con cada sistema operativo, pero debera ser un comando similar a ./ngrok http 5000, o si ya está instalado simplemente ngrok http 5000.
  • Si todo sale bien, deberás ver una pantalla como la siguiente:

alt_text

6. Configura el Webhook

  • De nuevo regresamos al dashboard de configuración de Messenger, y nos iremos a la sección de webhooks. Ahí seleccionaremos la opción de Configurar webhooks. En la ventana que se abre, en el campo de URL deberemos de escribir la url de nuestro ngrok (selecciona el url de https, IMPORTANTE cada que reinicia Ngrok, te da una url diferente, por lo que cada vez que reinicies, deberás hacer este paso), y agregaremos al final /webhook. En verificar identificador, escribiremos EchoBotChido (siéntete con la libertad de cambiar el identificador, sólo recuerda cambiarlo también en el código dentro de VERIFY_TOKEN), y en los campos de suscripción selecciona messages, messaging_postbacks, messaging_optins.

  • Se debería de ver como la siguiente imagen:

alt_text

  • Por último, debes de suscribir tu página de facebook a tu aplicación. Esto se hace dentro de la misma sección de webhook dentro del dashboard. IMPORTANTE si no suscribes tu página a la aplicación no podrás interactuar con ella. Éste es uno de los errores más comunes.

alt_text

7. Prueba tu app

  • Ya has configurado todo. Ahora es momento de ir a https://www.messenger.com/, iniciar sesión en caso de que no lo haga automáticamente, buscar tu página, y mandarle un mensaje. La página debería de responder con tu mismo mensaje, y en caso de que no envies texto, éste lo detectará y te mandará otro mensaje. Se verá algo como la siguiente imagen:

alt_text

Problemas comunes

Si tu bot no responde, prueba con lo siguiente:

  • Asegúrate que tengas internet.
  • Asegúrate que tu ngrok esté corriendo, y en el puerto 5000.
  • Asegúrate que app.py esté corriendo, y se esté ejecutando en el puerto 5000.
  • Recuerda que cada vez que reinicias ngrok se cambia la url, entonces asegúrate que en la configuración de tu webhook esté tu url actual, y que al final de la url, hayas escrito /webhook.
  • Asegúrate que hayas cambiado en el archivo app.py tu token de la página, y si cambiaste el código de verificación, asegúrate que esté igual tanto en la configuración del webhook como en la página.
  • Asegúrate que la aplicación esté suscrita a tu página (Paso 6).

Pasos siguientes:

  • Como habrás notado, cada que terminas ngrok, tu bot "muere". Esto se debe a que tu computadora está sirviendo como servidor. Para solucionar este problema puedes meter tu aplicación a un contenedor con Docker, y subir dicho contenedor a alguna plataforma como Heroku. Así se mantendrá "vivo" todo el tiempo tu bot. Seguiré trabajando en un tutorial que haga eso.

English (sorry for the spanish images, i'm working on it)

¿What do you need?

For this tutorial you need:

1. Make your Facebook App

  • The first thing you have to do is an app in Facebook, later your Facebook Page will be subscribed to it. To create your Facebook App you have to go to https://developers.facebook.com/, and log in (in case you don't login automatically). Then you have to go to the upper right corner, it should say my apps, and you have to select add new app.

alt_text

  • You will have to create a new app identifier. In the name field you should write your project's name (in this case Tutorial Echobot and then you should write a contact email)

alt_text

  • Maybe Facebook would ask you to verify a captcha. Verify it, and it will take you to the main dashboard.

  • In the main dashboard, you will see all the available products. In this case, we will select Messenger, and it will take us to the product configuration page.

alt_text

2. Make your Facebook page

  • If you already have a Facebook page, feel free to skip this step.
  • There are different ways to create a Facebook page. In this case, we will create it from the main dashboard from the previous step. In the Messenger configuration page, thre's a section that is named Identifier Generation, where we will pair our page and aour application in teh next steps. In this section, below the access identifier, there's a small link that says Create new page. We click it and it will take us to the page configuration panel.

alt_text

In this panel, we should select the page type that best fits our needs, and you have to name it. I will name my page Echobot.

alt_text

alt_text

3. Pair your Facebook app, and your Facebook page

  • In the Messenger configuration dashboard (identifier generator) select your page from the options combobox. It may pop up a dialog who asks confirmation, so you may click Continue as your user, and then it will ask permission for administrate your page, so you should accept too. If everything goes ok, it will generate the Page Access Token. Keep it handy, you will use it soon.

4. Let's code!

  • Make a folder and name it app and inside it create a file named app.py. Having something like /app/app.py

  • In your favorite text editor open app.py, and substitute in the code PAGE_ACCESS_TOKEN with the token cretated in the previous step. Then run the code (remember that you have to be inside teh directory /app that you just creaetd) with python app.py (You can use the latest version of python, you just have to substitute python with python3).

  • If everything goes ok, our Flask "server" wil be running on our localhost in the port 5000, it will be in debug mode. You should see a screen like this:

alt_text

5. Connect your server to Facebook

  • As we know, the flask server is running locally, but Facebook needs a web server with a security certificate and https protocol. To solve this issue we will use Ngrok. This program makes a safe tunnel for a specific port. This means that the port in which we are running our flask server (in this case the 5000), will be exposed safely for Facebook to make requests. The commands for running ngrok may change between diferents os, but it should be a command like this ./ngrok http 5000, or if it is already installed, you would use ngrok http 5000.
  • If everything goes well, you should see a screen like this one:

alt_text

6. Webhook Configuration

  • We access dashboard from Messenger configuration, and we go to webhooks section. There we select Configure webhooks. In the window that pops up, in the url field, you write the url of your ngrok (select the url with https, IMPORTANT everytime that ngrok restarts, it gives to you a different url. So everytime you shut it down, you may do this step), and we add to the url /webhook. In identifier verification, write EchoBotChido (feel free to change this identifier, just remember to change it in teh code too, in VERIFY_TOKEN), and in the subscription fields select messages, messaging_postbacks, messaging_optins.

  • It should look like this image:

alt_text

  • Finally, you must subscribe your facebook page to your facebook app. You can do this in the webhook section inside the dashboard. IMPORTANT if you don't subscribe your facebook page, you will not be able to interact with it. This is one of the common issues.

alt_text

7. Test your app

  • You have configured everything. It is time to go to a https://www.messenger.com/, login, in case it didn do it automatically, look for your facebook page, and send a message. It would look like this: Se verá algo como la siguiente imagen:

alt_text

Common issues

  • If your bot don't answers, try this:

    • Verify that you have full access to internet  * Verify tha ngrok is running, and in the port 5000.  * Verify that app.py is running, and that it is using the port 5000.  * Remember that everytime you run ngrok it changes the url, so you must change the webhook configuration so it has the actual url, and be sure you add at the end of the url /webhook.  * Verify that you change your PAGE_ACCESS_TOKEN in the app.py file. And if you changed teh VERIFY_TOKEN, make sure you changed it in the webhook, and in the code in app.py.  * Make sure that your app is subscribed to your page. (Step 6)

    Next Steps:

 * As you may see, your pc or laptop must be on and running the app.py and ngrok, but what happens when you need to turn it off? To solve this issue we may create a Docker container, and upload it to a platform like Heroku, so aour app must be running all the time, and without the need of our computer. I'll be working on a tutorial that show you how tod o this.