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.