En esta página, se describe cómo conectar una app de Google Chat con un servicio o una herramienta que no está en Google Chat. Si bien las apps de chat son potentes por sí solas, a menudo funcionan en conjunto con otros sistemas y requieren aplicaciones complementarias para conectar cuentas, autorizar el acceso a los datos, mostrar datos adicionales o configurar las preferencias del usuario.
Requisitos previos
Una app de Google Chat habilitada para funciones interactivas Para crear una app de Chat interactiva, completa una de las siguientes guías de inicio rápido según la arquitectura de la app que quieras usar:- Servicio HTTP con Google Cloud Functions
- Google Apps Script
- Dialogflow CX de Google Cloud
- Google Cloud Pub/Sub
Cómo solicitar la configuración de la app de Chat a un usuario
Si completar una solicitud requiere una configuración adicional que no se puede completar directamente en la app de Chat, devuelve una URL de configuración al usuario como parte de una respuesta normal o preséntala de forma privada en el siguiente formato:
{ "actionResponse": { "type": "REQUEST_CONFIG", "url": "CONFIGURATION_URL" } }
Esto le indica a Google Chat que le presente al usuario un mensaje privado, en el que
CONFIGURATION_URL
es un vínculo
que el usuario debe visitar para obtener autenticación, autorización o
configuración adicionales. Una respuesta REQUEST_CONFIG
es mutuamente exclusiva con un mensaje de respuesta normal. Se ignorarán el texto, las tarjetas y otros atributos.
Completa la solicitud de configuración
Cada evento de interacción MESSAGE
que recibe tu app de Chat también incluye el campo configCompleteRedirectUrl
. Debes codificar esta URL en la URL de configuración que se usará cuando se complete el proceso. El redireccionamiento a esta URL indica a Google Chat que se completó la solicitud de configuración.
Cuando se inicia la app de Chat, el flujo depende del mensaje específico que se recibe. En respuesta a un mensaje como @app help
, una app de Chat debería responder con un mensaje sin requerir configuración adicional.
Cuando se redirecciona correctamente a un usuario a la configCompleteRedirectUrl
proporcionada en el mensaje original, Google Chat realiza los siguientes pasos:
- Borra el mensaje que se le mostró al usuario que inició la acción.
- Convierte el mensaje original en público para que lo vean los demás miembros del espacio.
- Vuelve a enviar el mensaje original a la misma app de Chat.
Visitar un configCompleteRedirectUrl
solo afecta a un solo mensaje del usuario.
Si un usuario intentó enviar un mensaje a una app de chat varias
veces y, como resultado, recibió varias indicaciones, hacer clic en una
indicación en particular y completar el proceso de autenticación y configuración solo afecta
a ese mensaje en particular. Los demás mensajes no se cambian.
Cuando se vuelve a enviar un evento de interacción MESSAGE
de esta manera, debe ser idéntico al evento original. Sin embargo, hay algunas situaciones en las que los eventos de interacción MESSAGE
pueden diferir. Por ejemplo, cuando un mensaje menciona la app de chat A y la app de chat B, el usuario puede editar el mensaje si la app de chat A responde con un mensaje normal antes de autenticarse con la app de chat B. En este caso, la app de chat B recibe el texto del mensaje editado después de que el usuario completa la autenticación y la configuración.
Cómo autenticar al usuario de Chat fuera de Chat
En algunos casos, como cuando se solicita la autorización de OAuth para una API, tu app debe vincularse a una URL fuera de Chat y, al mismo tiempo, mantener la identidad del usuario. La mejor manera de identificar al usuario en estos casos es proteger la app de destino con el Acceso con Google.
Usa el token de identidad emitido durante el acceso para obtener el ID de usuario. El reclamo sub
contiene el ID único del usuario y se puede correlacionar con el ID de usuario de Google Chat.
Si bien los dos IDs no son exactamente idénticos, se pueden forzar. Para forzar el valor de la declaración sub
a un users/{user}
de Google Chat, antepone el valor con users/
. Por ejemplo, el valor del reclamo de 123
equivale al nombre de usuario users/123
en los mensajes que recibes en tu app de chat.
Temas relacionados
- Recibe y responde la interacción del usuario
- En el ejemplo de la app de MyProfile, se usa el token de identidad de la respuesta de Acceso con Google para identificar al usuario.