Un manifest delle estensioni è un elenco di istanze di estensioni e delle relative configurazioni. Con il file manifest puoi:
- Condividere la configurazione delle estensioni con altre persone
- Copiare la configurazione delle estensioni tra progetti diversi (ad esempio dal progetto di staging al progetto di produzione)
- Esegui il deployment di tutte le estensioni contemporaneamente
- Testa il funzionamento delle estensioni con la tua app utilizzando Firebase Local Emulator Suite
- Esegui il commit della configurazione delle estensioni nel controllo del codice sorgente
- Includi le estensioni nella pipeline CI/CD
Un manifest delle estensioni è composto da due parti:
La sezione
extensions
difirebase.json
, che è una mappa dell'ID istanza al riferimento della versione dell'estensione. Ad esempio:{ "extensions": { "my-bigquery-extension": "firebase/firestore-bigquery-export@^0.1.18", "my-image-resizer": "firebase/storage-resize-images@^0.1.22", } }
File
.env
contenenti la configurazione per ogni istanza dell'estensione nella sottodirectoryextensions/
della directory del progetto Firebase. Ad esempio, un'istanza distorage-resize-images
potrebbe avere un file.env
come il seguente:IMAGE_TYPE=jpeg LOCATION=us-central1 IMG_BUCKET=${param:PROJECT_ID}.appspot.com IMG_SIZES=100x100 DELETE_ORIGINAL_FILE=false
Creare un manifest delle estensioni
Esistono tre modi per creare un manifest delle estensioni:
- Gestire il manifest delle estensioni con l'interfaccia a riga di comando di Firebase
- Esportare la configurazione delle estensioni di un progetto
- Modificare manualmente i file manifest
I primi due metodi sono descritti di seguito.
Gestire il manifest delle estensioni con l'interfaccia a riga di comando di Firebase
Puoi eseguire la maggior parte dei comandi ext:
di Firebase CLI con l'opzione --local
per aggiornare il manifest delle estensioni senza modificare effettivamente la configurazione corrente del progetto.
Ad esempio:
firebase ext:install --local firebase/firestore-bigquery-export
L'esecuzione del comando riportato sopra ti chiederà di configurare la versione più recente dell'estensione firebase/firestore-bigquery-export
e di salvare la configurazione nel manifest, ma non eseguirà il deployment della configurazione nel progetto.
Ecco altri esempi di comandi che modificano il file manifest delle estensioni:
# ext:configure changes the params for an extension instance in your extensions manifest
$ firebase ext:configure my-bigquery-extension --local
# ext:update --local updates an instance in your extensions manifest
# to the latest version of that extension
$ firebase ext:update my-bigquery-extension --local
# You can also specify a version if you don't want to update to the latest version
$ firebase ext:update my-bigquery-extension firebase/firestore-bigquery-export@0.1.10 --local
# ext:uninstall --local removes an instance from your extensions manifest
$ firebase ext:uninstall my-bigquery-extension --local
Esportare la configurazione delle estensioni di un progetto
Per salvare la configurazione attuale delle estensioni di un progetto nel file manifest, segui questi passaggi:
- Se non l'hai ancora fatto, configura l'interfaccia a riga di comando di Firebase.
- Da un prompt della shell, passa alla directory del progetto. (la directory del progetto contiene il file
firebase.json
). - Esegui il comando
ext:export
:firebase ext:export
Il comando ext:export
aggiunge una sezione extensions
al
firebase.json
file. Inoltre, il comando ext:export
crea una directory extensions
contenente un file .env
per ogni istanza dell'estensione installata. Questi
file contengono i parametri di configurazione per ogni istanza.
Testare una configurazione delle estensioni con Firebase Local Emulator Suite
Dopo aver aggiunto alcune istanze di estensioni al manifest delle estensioni, puoi testarle utilizzando Local Emulator Suite.
-
- Per eseguire Emulator Suite in modo interattivo, esegui:
firebase emulators:start
- Per eseguire Emulator Suite ed eseguire uno script di test, esegui:
firebase emulators:exec my-test.sh
- Per eseguire Emulator Suite in modo interattivo, esegui:
Ora, se hai istanze di estensioni elencate nel manifest, Local Emulator Suite scaricherà il codice sorgente di queste estensioni in ~/.cache/firebase/extensions
. Una volta scaricate, verrà avviato Local Emulator Suite e potrai attivare qualsiasi funzione attivata in background delle estensioni e connettere la tua app alla suite Emulator per testarne l'integrazione.
Eseguire il deployment di una configurazione delle estensioni in un progetto
Dopo aver aggiunto alcune istanze dell'estensione al manifest delle estensioni, puoi eseguire il deployment in un progetto utilizzando l'interfaccia a riga di comando di Firebase. Quando esegui il deployment con un manifest delle estensioni, installi, aggiorni e configuri contemporaneamente tutte le istanze dell'estensione nel manifest in un progetto.
Per eseguire il deployment di un manifest delle estensioni:
- Da un prompt della shell, vai alla directory contenente la configurazione delle estensioni salvata. (Questa è la directory che contiene
firebase.json
. Se hai appena eseguitoext:export
, significa che sei già nella directory corretta. - Esegui il comando
deploy
. Se vuoi eseguire il deployment delle estensioni in un progetto diverso da quello corrente, specifica anche--project=
:firebase deploy --only extensions –-project=YOUR_PROJECT_ID
Il comando deploy
convalida ogni configurazione dell'istanza, ti chiede se vuoi eliminare le istanze di estensioni dal progetto di destinazione che non sono elencate in firebase.json
e poi esegue il deployment di tutte le istanze di estensioni.
Configurazioni delle estensioni specifiche per il progetto
Le configurazioni delle estensioni salvate possono essere utilizzate per eseguire il deployment in più progetti diversi: ad esempio, un progetto di gestione temporanea e un progetto di produzione. In questo modo, alcuni valori dei parametri potrebbero dover essere diversi per ogni progetto.
I file .env
specifici del progetto rendono possibile quanto segue:
- Inserisci i valori dei parametri che differiscono tra i progetti in
extensions/EXTENSION_INSTANCE_ID.env.YOUR_PROJECT_ID
- Inserisci i valori dei parametri condivisi in
extensions/EXTENSION_INSTANCE_ID.env
.
A volte, potresti voler utilizzare un valore del parametro diverso durante l'emulazione delle estensioni: ad esempio, potresti voler fornire una chiave API di test anziché una di produzione. Inserisci questi parametri in un file .local
:
- Inserisci i parametri non segreti che vuoi utilizzare durante l'emulazione in
extensions/EXTENSION_INSTANCE_ID.env.local
- Inserisci i valori dei parametri secret in
extensions/EXTENSION_INSTANCE_ID.secret.local