Estendi la connessione dati con le funzioni cloud

Con Cloud Functions for Firebase puoi gestire gli eventi in Firebase Data Connect. Cloud Functions consente di eseguire codice lato server in risposta a eventi, come l'esecuzione di una mutazione nel servizio Data Connect. Ciò consente di aggiungere logica personalizzata senza dover distribuire i propri server.

Casi d'uso comuni

  • Sincronizzazione dei dati:replica o sincronizza i dati con altri sistemi (come Cloud Firestore, BigQuery o API esterne) dopo che si verifica una mutazione.

  • Flussi di lavoro asincroni: avvia processi di lunga durata, come l'elaborazione delle immagini o l'aggregazione dei dati, dopo una modifica al database.

  • Coinvolgimento degli utenti:invia email o notifiche Cloud Messaging agli utenti dopo un evento di mutazione specifico nella tua applicazione, ad esempio la creazione dell'account.

Attiva una funzione su una mutazione Data Connect

Puoi attivare una funzione ogni volta che viene eseguita una Data Connect mutazione utilizzando il gestore di eventi onMutationExecuted. Questo trigger si attiva all'esecuzione di una mutazione.

Una funzione di evento di mutazione di base

L'esempio di base seguente è una funzione che registra i dettagli di qualsiasi mutazione eseguita nel servizio Data Connect:

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";
import { logger } from "firebase-functions";

export const logMutation = onMutationExecuted(
  {
    /* Trigger on all mutations, spanning all services and connectors
       in us-central1 */
  },
  (event) => {
    logger.info("A mutation was executed!", {
      data: event.data,
    });
  }
);

Python

from firebase_functions import dataconnect_fn, logger

@dataconnect_fn.on_mutation_executed()
def log_mutation(event: dataconnect_fn.Event):
  logger.info("A mutation was executed!", event.data)

Quando attivi tutte le mutazioni nel tuo progetto, non devi eseguire alcuna mutazione nel gestore di trigger, altrimenti si verifica un loop infinito. Se vuoi eseguire mutazioni in un trigger di evento, utilizza le opzioni di filtro descritte di seguito e assicurati che la mutazione non si attivi da sola.

Impostare la posizione della funzione

La posizione della funzione deve corrispondere alla posizione del servizioData Connect affinché gli eventi attivino la funzione. Per impostazione predefinita, la regione della funzione è us-central1.

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";

export const onMutationRegionOption = onMutationExecuted(
  {
    region: "europe-west1"  // Set if Data Connect service location is not us-central1
  },
  (event) => { /* ... */ }
);

Python

@dataconnect_fn.on_mutation_executed(
  region="europe-west1"  # Set if Data Connect service location is not us-central1
)
def mutation_executed_handler_region_option(event: dataconnect_fn.Event):
  pass

Filtra eventi

Il gestore onMutationExecuted può essere configurato con opzioni per filtrare gli eventi in base ad attributi specifici. Questa opzione è utile quando vuoi attivare la funzione solo per determinate mutazioni.

Puoi filtrare per service, connector e operation:

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";
import { logger } from "firebase-functions";

// Trigger this function only for the CreateUser mutation
// in the users connector of the myAppService service.
export const onUserCreate = onMutationExecuted(
  {
    service: "myAppService",
    connector: "users",
    operation: "CreateUser",
  },
  (event) => {
    logger.info("A new user was created!", event.data);
    // Add logic here: for example, sending a welcome email.
  }
);

Python

from firebase_functions import dataconnect_fn, logger

@dataconnect_fn.on_mutation_executed(
  service="myAppService",
  connector="users",
  operation="CreateUser"
):
def on_user_create(event: dataconnect_fn.Event):
  logger.info("A new user was created!", event.data)

Caratteri jolly e gruppi di acquisizione

Puoi utilizzare i caratteri jolly e i gruppi di acquisizione per filtrare i trigger in base a più valori. Tutti i gruppi acquisiti sono disponibili in event.params. Per saperne di più, consulta la sezione Informazioni sui pattern di percorso.

Esempi:

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";

// Trigger on all operations that match the pattern `User*`, on any service and
// connector.
export const onMutationWildcards = onMutationExecuted(
  {
    operation: "User*",
  },
  (event) => {}
);

// Trigger on all operations that match the pattern `User*`, on any service and
// connector. Capture the operation name in the variable `op`.
export const onMutationCaptureWildcards = onMutationExecuted(
  {
    operation: "{op=User*}",
  },
  (event) => {
    // `event.params.op` contains the operation name.
  }
);

// Trigger on all operations on the service `myAppService`. Capture the
// operation name in the variable `operation`.
export const onMutationCaptures = onMutationExecuted(
  {
    service: "myAppService",
    operation: "{operation}",
  },
  (event) => {
    // `event.params.operation` contains the operation name.
  }
);

Python

from firebase_functions import dataconnect_fn

# Trigger on all operations that match the pattern `User*`, on any service and
# connector.
@dataconnect_fn.on_mutation_executed(
  operation="User*"
)
def on_mutation_wildcards(event: dataconnect_fn.Event):
  pass

# Trigger on all operations that match the pattern `User*`, on any service and
# connector. Capture the operation name in the variable `op`.
@dataconnect_fn.on_mutation_executed(
  operation="{op=User*}"
)
def on_mutation_capture_wildcards(event: dataconnect_fn.Event):
  # `event.params["op"]` contains the operation name.
  pass

# Trigger on all operations on the service `myAppService`. Capture the
# operation name in the variable `operation`.
@dataconnect_fn.on_mutation_executed(
  service="myAppService",
  operation="{operation}"
)
def on_mutation_captures(event: dataconnect_fn.Event):
  # `event.params["operation"]` contains the operation name.
  pass

Accedere alle informazioni di autenticazione utente

Puoi accedere alle informazioni di autenticazione dell'utente relative al principal che ha attivato l'evento. Per ulteriori informazioni sui dati disponibili nel contesto di autenticazione, vedi Contesto di autenticazione.

L'esempio seguente mostra come recuperare le informazioni di autenticazione:

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";

export const onMutation = onMutationExecuted(
  { operation: "MyMutation" },
  (event) => {
    // mutationExecuted event provides authType and authId:
    // event.authType
    // event.authId
  }
);

Python

from firebase_functions import dataconnect_fn

@dataconnect_fn.on_mutation_executed(operation="MyMutation")
def mutation_executed_handler(event: dataconnect_fn.Event):
  # mutationExecuted event provides auth_type and auth_id, which are accessed as follows
  # event.auth_type
  # event.auth_id
  pass

Il tipo di autenticazione e l'ID autenticazione verranno compilati come segue:

Mutazione avviata da authtype authid
Utente finale autenticato app_user UID token Firebase Auth
Utente finale non autenticato unauthenticated vuoto
SDK Admin che simula un utente finale app_user UID token Firebase Auth dell'utente rappresentato
L'SDK Admin che simula una richiesta non autenticata unauthenticated vuoto
SDK Admin con autorizzazioni complete admin vuoto

Accedere ai dati degli eventi

L'oggetto CloudEvent passato alla funzione contiene informazioni sull'evento che l'ha attivata.

Attributi evento

Attributo Tipo Descrizione
id string Un identificatore univoco per l'evento.
source string La risorsa connettore che ha prodotto l'evento (ad esempio, //firebasedataconnect.googleapis.com/projects/*/locations/*/services/*/connectors/*).
specversion string La versione della specifica CloudEvents (ad es. "1.0").
type string Il tipo di evento: google.firebase.dataconnect.connector.v1.mutationExecuted.
time string Il timestamp (formato ISO 8601) di quando è stato prodotto l'evento.
subject string Facoltativo. Informazioni aggiuntive sul contesto dell'evento, ad esempio il nome dell'operazione.
params object Una mappa dei pattern di percorso acquisiti.
authType string Un enum che rappresenta il tipo di entità che ha attivato l'evento.
authId string Un identificatore univoco del principal che ha attivato l'evento.
data MutationEventData Il payload dell'evento Data Connect. Consulta la sezione successiva.

Payload

L'oggetto MutationEventData contiene il payload dell'evento Data Connect:

{
  // ...
  "authType": // ...
  "data": {
    "payload": {
      "variables": {
        "userId": "user123",
        "updateData": {
          "displayName": "New Name"
        }
      },
      "data": {
        "updateUser": {
          "id": "user123",
          "displayName": "New Name",
          "email": "user@example.com"
        }
      },
      "errors": []
    }
  }
}
  • payload.variables: un oggetto contenente le variabili passate alla mutazione.
  • payload.data: un oggetto contenente i dati restituiti dalla mutazione.
  • payload.errors: un array di eventuali errori verificatisi durante l'esecuzione della mutazione. Se la mutazione è andata a buon fine, questo array sarà vuoto.

Esempio

Ecco come accedere alle variabili di mutazione e ai dati restituiti:

Node.js

import { onMutationExecuted } from "firebase-functions/dataconnect";
import { logger } from "firebase-functions";

export const processNewUserData = onMutationExecuted(
  {
    "service": "myAppService",
    "connector": "users",
    "operation": "CreateUser",
  },
  (event) => {
    // The variables passed to the mutation
    const mutationVariables = event.data.payload.variables;

    // The data returned by the mutation
    const returnedData = event.data.payload.data;

    logger.info("Processing mutation with variables:", mutationVariables);
    logger.info("Mutation returned:", returnedData);

    // ... your custom logic here
  }
);

Python

from firebase_functions import dataconnect_fn, logger

@dataconnect_fn.on_mutation_executed(
  service="myAppService",
  connector="users",
  operation="CreateUser"
):
def process_new_user_data(event: dataconnect_fn.Event):
  # The variables passed to the mutation
  mutation_vars = event.data.payload.variables
  # The data returned by the mutation
  returned_data = event.data.payload.data

  logger.info("Processing mutation with variables:", mutationVariables)
  logger.info("Mutation returned", returnedData)

  # ... your custom logic here

Tieni presente che, a differenza di altri trigger di database, come Cloud Firestore o Realtime Database, l'evento Data Connect non fornisce uno snapshot "prima" dei dati. Poiché Data Connect esegue il proxy delle richieste al database sottostante, lo snapshot "prima" dei dati non può essere ottenuto in modo transazionale. Hai invece accesso agli argomenti inviati alla mutazione e ai dati restituiti.

Una conseguenza di ciò è che non puoi utilizzare la strategia di confronto degli snapshot "prima" e "dopo" per evitare loop infiniti, in cui un trigger di evento attiva lo stesso evento. Se devi eseguire una mutazione da una funzione attivata da un evento di mutazione, utilizza i filtri degli eventi e assicurati che nessuna mutazione possa attivarsi, anche indirettamente.