En esta guía, se muestran ejemplos de funciones que se activan cuando realizas cambios en un documento dentro de una colección especificada.
Antes de comenzar
Antes de ejecutar el código de muestra de esta guía, deberás hacer lo siguiente:
- Habilita las APIs y otorga los roles necesarios para implementar funciones
- Cómo configurar una base de datos de Firestore
Ejemplos
En los siguientes ejemplos, se muestra cómo escribir funciones que respondan a un activador de Firestore.
Ejemplo 1: Función de Hola Firestore
En la siguiente muestra, se imprimen los campos de un evento de activación de Firestore:
Node.js
Python
Go
Java
C#
Implementa la función de Hola Firestore
Si aún no está lista, configura la base de datos de Firestore.
Haz clic en la pestaña para obtener instrucciones de la herramienta que elijas.
Console
Cuando usas la consola de Google Cloud para crear una función, también puedes agregar un activador a ella. Sigue estos pasos para crear un activador para tu función:
En la consola de Google Cloud ve a Cloud Run:
Haz clic en Escribe una función y, luego, ingresa los detalles de la función. Para obtener más información sobre la configuración de funciones durante la implementación, consulta Cómo implementar funciones.
En la sección Activador, haz clic en Agregar activador.
Selecciona Activador de Firestore.
En el panel Activador de Eventarc, modifica los detalles del activador de la siguiente manera:
Ingresa un nombre para el activador en el campo Nombre del activador o usa el nombre predeterminado.
Selecciona un tipo de activador de la lista para especificar uno de los siguientes tipos de activador:
Fuentes de Google para especificar activadores para Pub/Sub, Cloud Storage, Firestore y otros proveedores de eventos de Google.
Terceros para integrarse a proveedores externos a Google que ofrecen una fuente de Eventarc. Para obtener más información, consulta Eventos de terceros en Eventarc.
Selecciona Firestore en la lista Proveedor de eventos para elegir un producto que proporcione el tipo de evento para activar tu función. Para obtener la lista de proveedores de eventos, consulta Proveedores y destinos de eventos.
Selecciona type=google.cloud.firestore.document.v1.written en la lista Tipo de evento. La configuración del activador varía según el tipo de evento compatible. Para obtener más información, consulta Tipos de eventos.
En la sección Filtros, selecciona una base de datos, una operación y valores de atributos, o bien usa las selecciones predeterminadas.
Si el campo Región está habilitado, selecciona una ubicación para el activador de Eventarc. En general, la ubicación de un activador de Eventarc debe coincidir con la ubicación del recurso de Google Cloud que deseas supervisar para detectar eventos. En la mayoría de los casos, también debes implementar tu función en la misma región. Consulta Información sobre las ubicaciones de Eventarc para obtener más detalles sobre las ubicaciones de activadores de Eventarc.
En el campo Cuenta de servicio, selecciona una cuenta de servicio. Los activadores de Eventarc están vinculados a cuentas de servicio para usarlos como identidad cuando se invoca la función. La cuenta de servicio del activador de Eventarc debe tener el permiso para invocar tu función. De forma predeterminada, Cloud Run usa la cuenta de servicio predeterminada de Compute Engine.
De manera opcional, especifica la ruta de URL del servicio a la que se enviará la solicitud entrante. Esta es la ruta de acceso relativa en el servicio de destino al que se deben enviar los eventos del activador. Por ejemplo,
/
,/route
,route
yroute/subroute
.
Una vez que hayas completado los campos obligatorios, haz clic en Guardar activador.
gcloud
Cuando creas una función con gcloud CLI, primero debes deploy y, luego, crear un activador. Sigue estos pasos para crear un activador para tu función:
Ejecuta el siguiente comando en el directorio que contiene el código de muestra para implementar la función:
gcloud beta run deploy FUNCTION \ --source . \ --function FUNCTION_ENTRYPOINT \ --base-image BASE_IMAGE_ID \ --region REGION
Reemplaza lo siguiente:
Reemplaza FUNCTION por el nombre de la función que implementas. Puedes omitir este parámetro por completo, pero se te solicitará el nombre si lo haces.
FUNCTION_ENTRYPOINT por el punto de entrada a tu función en tu código fuente. Este es el código que ejecuta Cloud Run cuando se ejecuta tu función. El valor de esta marca debe ser un nombre de función o un nombre de clase completamente calificado que exista en tu código fuente.
BASE_IMAGE_ID por el entorno de la imagen base de tu función. Para obtener más detalles sobre las imágenes base y los paquetes incluidos en cada imagen, consulta Imágenes base de los entornos de ejecución.
REGION por la región de Google Cloud en la que deseas implementar tu función. Por ejemplo,
us-central1
.
Ejecuta el siguiente comando para crear un activador que filtre eventos:
gcloud eventarc triggers create TRIGGER_NAME \ --location=EVENTARC_TRIGGER_LOCATION \ --destination-run-service=FUNCTION \ --destination-run-region=REGION \ --event-filters=type=google.cloud.firestore.document.v1.written \ --event-filters=database='(default)' \ --event-data-content-type=application/protobuf \ --event-filters-path-pattern=document='users/{username}' \ --service-account=PROJECT_NUMBER-compute@developer.gserviceaccount.com
Reemplaza lo siguiente:
TRIGGER_NAME por el nombre de tu activador.
EVENTARC_TRIGGER_LOCATION con la ubicación del activador de Eventarc. En general, la ubicación de un activador de Eventarc debe coincidir con la ubicación del recurso de Google Cloud que deseas supervisar para detectar eventos. En la mayoría de los casos, también debes implementar tu función en la misma región. Para obtener más información, consulta Ubicaciones de Eventarc.
Reemplaza FUNCTION por el nombre de la función que implementas.
REGION por la región de Cloud Run de la función.
PROJECT_NUMBER por tu número de proyecto de Google Cloud Los activadores de Eventarc están vinculados a cuentas de servicio para usarlos como identidad cuando se invoca la función. La cuenta de servicio del activador de Eventarc debe tener permiso para invocar tu función. De forma predeterminada, Cloud Run usa la cuenta de servicio de procesamiento predeterminada.
La marca
event-filters
especifica los filtros de eventos que supervisa el activador. Un evento que coincida con todos los filtrosevent-filters
activa llamadas a tu función. Cada activador debe tener un tipo de evento compatible. No puedes cambiar el tipo de filtro de eventos después de crearlo. Para cambiar el tipo de filtro de eventos, debes crear un activador nuevo y borrar el anterior. De forma opcional, puedes repetir la marca--event-filters
con un filtro compatible en el formatoATTRIBUTE=VALUE
para agregar más filtros.
Usa los otros campos tal como están:
--event-filters=type=google.cloud.firestore.document.v1.written
especifica que la función se activa cuando se crea, actualiza o borra un documento, según el tipo de eventogoogle.cloud.firestore.document.v1.written
.--event-filters=database='(default)'
especifica la base de datos de Firebase. Para ver el nombre de la base de datos predeterminada, usa(default)
.--event-filters-path-pattern=document='users/{username}'
proporciona el patrón de ruta de acceso de los documentos que deben supervisarse para detectar cambios relevantes. En este patrón de ruta de acceso, se indica que se deben supervisar todos los documentos de la colecciónusers
. Para obtener más información, consulta Información sobre los patrones de ruta de acceso.
Prueba la función de Hola Firestore
Para probar la función Hola Firestore, configura una colección llamada users
en tu base de datos de Firestore:
En la consola de Google Cloud, ve a la página Bases de datos de Firestore:
Haz clic en Iniciar una colección.
Especifica
users
como el ID de colección.Para empezar a agregar el primer documento de la colección, en Agregar su primer documento, acepta el ID de documento generado de forma automática.
Agrega al menos un campo para el documento y especifica un nombre y un valor. Por ejemplo, en Nombre del campo, ingresa
username
y, en Valor del campo, ingresarowan
.Cuando termines, haz clic en Guardar.
Esta acción crea un documento nuevo, lo que activa tu función.
Para confirmar que tu función se activó, haz clic en el nombre vinculado de la función en la consola de Google Cloud.Página de descripción general de Cloud Run para abrir la página Detalles del servicio.
Selecciona la pestaña Registros y busca esta cadena:
Function triggered by change to: //firestore.googleapis.com/projects/your-project-id/databases/(default)'
Ejemplo 2: función Convertir en mayúsculas
En el siguiente ejemplo, se recupera el valor que agrega el usuario, se convierte la cadena en esa ubicación a mayúscula y se reemplaza el valor por la cadena en mayúscula:
Node.js
Usa protobufjs para decodificar los datos del evento. Incluye el google.events.cloud.firestore.v1
data.proto
en la fuente.
Python
Go
Java
C#
Implementa la función Convertir a mayúsculas
Si aún no está lista, configura la base de datos de Firestore.
Haz clic en la pestaña para obtener instrucciones de la herramienta que elijas.
Console
Cuando usas la consola de Google Cloud para crear una función, también puedes agregar un activador a ella. Sigue estos pasos para crear un activador para tu función:
En la consola de Google Cloud ve a Cloud Run:
Haz clic en Escribe una función y, luego, ingresa los detalles de la función. Para obtener más información sobre la configuración de funciones durante la implementación, consulta Cómo implementar funciones.
En la sección Activador, haz clic en Agregar activador.
Selecciona Activador de Firestore.
En el panel Activador de Eventarc, modifica los detalles del activador de la siguiente manera:
Ingresa un nombre para el activador en el campo Nombre del activador o usa el nombre predeterminado.
Selecciona un tipo de activador de la lista para especificar uno de los siguientes tipos de activador:
Fuentes de Google para especificar activadores para Pub/Sub, Cloud Storage, Firestore y otros proveedores de eventos de Google.
Terceros para integrarse a proveedores externos a Google que ofrecen una fuente de Eventarc. Para obtener más información, consulta Eventos de terceros en Eventarc.
Selecciona Firestore en la lista Proveedor de eventos para elegir un producto que proporcione el tipo de evento para activar tu función. Para obtener la lista de proveedores de eventos, consulta Proveedores y destinos de eventos.
Selecciona type=google.cloud.firestore.document.v1.written en la lista Tipo de evento. La configuración del activador varía según el tipo de evento compatible. Para obtener más información, consulta Tipos de eventos.
En la sección Filtros, selecciona una base de datos, una operación y valores de atributos, o bien usa las selecciones predeterminadas.
Si el campo Región está habilitado, selecciona una ubicación para el activador de Eventarc. En general, la ubicación de un activador de Eventarc debe coincidir con la ubicación del recurso de Google Cloud que deseas supervisar para detectar eventos. En la mayoría de los casos, también debes implementar tu función en la misma región. Consulta Información sobre las ubicaciones de Eventarc para obtener más detalles sobre las ubicaciones de activadores de Eventarc.
En el campo Cuenta de servicio, selecciona una cuenta de servicio. Los activadores de Eventarc están vinculados a cuentas de servicio para usarlos como identidad cuando se invoca la función. La cuenta de servicio del activador de Eventarc debe tener el permiso para invocar tu función. De forma predeterminada, Cloud Run usa la cuenta de servicio predeterminada de Compute Engine.
De manera opcional, especifica la ruta de URL del servicio a la que se enviará la solicitud entrante. Esta es la ruta de acceso relativa en el servicio de destino al que se deben enviar los eventos del activador. Por ejemplo,
/
,/route
,route
yroute/subroute
.
Una vez que hayas completado los campos obligatorios, haz clic en Guardar activador.
gcloud
Cuando creas una función con gcloud CLI, primero debes deploy y, luego, crear un activador. Sigue estos pasos para crear un activador para tu función:
Ejecuta el siguiente comando en el directorio que contiene el código de muestra para implementar la función:
gcloud beta run deploy FUNCTION \ --source . \ --function FUNCTION_ENTRYPOINT \ --base-image BASE_IMAGE_ID \ --region REGION
Reemplaza lo siguiente:
Reemplaza FUNCTION por el nombre de la función que implementas. Puedes omitir este parámetro por completo, pero se te solicitará el nombre si lo haces.
FUNCTION_ENTRYPOINT por el punto de entrada a tu función en tu código fuente. Este es el código que ejecuta Cloud Run cuando se ejecuta tu función. El valor de esta marca debe ser un nombre de función o un nombre de clase completamente calificado que exista en tu código fuente.
BASE_IMAGE_ID por el entorno de la imagen base de tu función. Para obtener más detalles sobre las imágenes base y los paquetes incluidos en cada imagen, consulta Imágenes base de los entornos de ejecución.
REGION por la región de Google Cloud en la que deseas implementar tu función. Por ejemplo,
us-central1
.
Ejecuta el siguiente comando para crear un activador que filtre eventos:
gcloud eventarc triggers create TRIGGER_NAME \ --location=EVENTARC_TRIGGER_LOCATION \ --destination-run-service=FUNCTION \ --destination-run-region=REGION \ --event-filters=type=google.cloud.firestore.document.v1.written \ --event-filters=database='(default)' \ --event-data-content-type=application/protobuf \ --event-filters-path-pattern=document='messages/{pushId}' \ --service-account=PROJECT_NUMBER-compute@developer.gserviceaccount.com
Reemplaza lo siguiente:
TRIGGER_NAME por el nombre de tu activador.
EVENTARC_TRIGGER_LOCATION con la ubicación del activador de Eventarc. En general, la ubicación de un activador de Eventarc debe coincidir con la ubicación del recurso de Google Cloud que deseas supervisar para detectar eventos. En la mayoría de los casos, también debes implementar tu función en la misma región. Para obtener más información, consulta Ubicaciones de Eventarc.
Reemplaza FUNCTION por el nombre de la función que implementas.
REGION por la región de Cloud Run de la función.
PROJECT_NUMBER por tu número de proyecto de Google Cloud Los activadores de Eventarc están vinculados a cuentas de servicio para usarlos como identidad cuando se invoca la función. La cuenta de servicio del activador de Eventarc debe tener permiso para invocar tu función. De forma predeterminada, Cloud Run usa la cuenta de servicio de procesamiento predeterminada.
La marca
event-filters
especifica los filtros de eventos que supervisa el activador. Un evento que coincida con todos los filtrosevent-filters
activa llamadas a tu función. Cada activador debe tener un tipo de evento compatible. No puedes cambiar el tipo de filtro de eventos después de crearlo. Para cambiar el tipo de filtro de eventos, debes crear un activador nuevo y borrar el anterior. De forma opcional, puedes repetir la marca--event-filters
con un filtro compatible en el formatoATTRIBUTE=VALUE
para agregar más filtros.
Usa los otros campos tal como están:
--event-filters=type=google.cloud.firestore.document.v1.written
especifica que la función se activa cuando se crea, actualiza o borra un documento, según el tipo de eventogoogle.cloud.firestore.document.v1.written
.--event-filters=database='(default)'
especifica la base de datos de Firestore. Para ver el nombre de la base de datos predeterminada, usa(default)
.--event-filters-path-pattern=document='messages/{pushId}'
proporciona el patrón de ruta de acceso de los documentos que deben supervisarse para detectar cambios relevantes. En este patrón de ruta de acceso, se indica que se deben supervisar todos los documentos de la colecciónmessages
. Para obtener más información, consulta Información sobre los patrones de ruta de acceso.
Prueba la función Convertir a mayúsculas
Para probar la función Convertir a mayúsculas que acabas de implementar, configura una colección llamada messages
en tu base de datos de Firestore:
En la consola de Google Cloud, ve a la página Bases de datos de Firestore:
Haz clic en Iniciar una colección.
Especifica
messages
como el ID de colección.Para empezar a agregar el primer documento de la colección, en Agregar su primer documento, acepta el ID de documento generado de forma automática.
Para activar la función implementada, agrega un documento en el que el Nombre del campo sea
original
y el Valor del campo seaminka
.Cuando guardes el documento, verás la palabra en minúsculas en el campo de valor que convierte a mayúsculas.
Si luego editas el valor del campo para que contenga letras minúsculas, se activará la función de nuevo y se convertirán todas las letras minúsculas en mayúsculas.
Limitaciones de las funciones
- No se garantiza el ordenamiento. Los cambios rápidos pueden activar invocaciones de funciones en un orden inesperado.
- Los eventos se entregan al menos una vez, pero un solo evento puede dar lugar a varias invocaciones de funciones. Evita depender de la mecánica de entrega de eventos exactamente una vez y escribe funciones idempotentes.
- Un activador se asocia con una sola base de datos. No puedes crear un activador que coincida con varias bases de datos.
- Cuando se borra una base de datos, no se borra automáticamente ningún activador de la base de datos. El activador deja de entregar eventos, pero sigue existiendo hasta que lo borras.