Puoi utilizzare Firebase Remote Config per definire i parametri nella tua app e aggiornarne i valori nel cloud, in modo da modificare l'aspetto e il comportamento della tua app senza distribuire un aggiornamento. Questa guida illustra i passaggi iniziali e fornisce alcune codice campione.
Passaggio 1: aggiungi Firebase e l'SDK Remote Config all'app
Installa e inizializza gli SDK Firebase per Flutter se non l'hai ancora fatto.
Per Remote Config, Google Analytics è obbligatorio per targeting condizionale di istanze di app alle proprietà utente e ai segmenti di pubblico. Accertati che devi abilitare Google Analytics nel tuo progetto.
Dalla directory root del tuo progetto Flutter, esegui questo per installare il plug-in Remote Config:
flutter pub add firebase_remote_config
Inoltre, durante la configurazione di Remote Config, devi aggiungere l'SDK Firebase per Google Analytics alla tua app:
flutter pub add firebase_analytics
Ricostruisci il progetto:
flutter run
Se utilizzi Remote Config su macOS, attiva Condivisione del portachiavi in Xcode.
Passaggio 2: recupera l'oggetto singleton di Remote Config
Ottieni un'istanza dell'oggetto Remote Config e imposta intervallo di recupero minimo per consentire aggiornamenti frequenti:
final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
fetchTimeout: const Duration(minutes: 1),
minimumFetchInterval: const Duration(hours: 1),
));
L'oggetto singleton viene utilizzato per memorizzare i valori predefiniti dei parametri in-app, recuperare i valori dei parametri aggiornati dal backend e controllare quando i valori recuperati vengono resi disponibili per l'app.
Durante lo sviluppo, consigliamo di impostare un recupero minimo relativamente basso intervallo di tempo. Per ulteriori informazioni, consulta la sezione Limitazione.
Passaggio 3: imposta i valori predefiniti dei parametri in-app
Puoi impostare i valori parametro predefiniti in-app in Remote Config in modo che l'app si comporti come previsto prima di connettersi il backend Remote Config e in modo che siano disponibili valori predefiniti se non lo sono. nel backend.
await remoteConfig.setDefaults(const {
"example_param_1": 42,
"example_param_2": 3.14159,
"example_param_3": true,
"example_param_4": "Hello, world!",
});
Passaggio 4: ottieni i valori parametro da utilizzare nell'app
Ora puoi ottenere i valori parametro dall'oggetto Remote Config. Se imposti
nel backend, recuperarli e attivarli,
questi valori sono disponibili per la tua app. Altrimenti, otterrai lo strumento
valori dei parametri configurati utilizzando setDefaults()
.
Per ottenere questi valori, chiama il metodo elencato di seguito che mappa il tipo di dati previsto dalla tua app, fornendo la chiave del parametro come argomento:
getBool()
getDouble()
getInt()
getString()
Passaggio 5: imposta i valori parametro nel backend di Remote Config
Utilizzando la console Firebase o le API di backend di Remote Config, puoi creare nuovi valori predefiniti lato server che sostituiscono i valori in-app in base alla logica condizionale o al targeting per utente che preferisci. Questa sezione descrive i passaggi della console Firebase per creare questi valori.
- Nella Console Firebase, apri il progetto.
- Seleziona Remote Config dal menu per visualizzare Remote Config Fitbit.com.
- Definisci i parametri con gli stessi nomi di quelli definiti in la tua app. Per ogni parametro puoi impostare un valore predefinito (che alla fine sostituire il valore predefinito in-app corrispondente) e puoi anche impostare valori condizionali. Per scoprire di più, consulta Parametri e condizioni di Remote Config.
Passaggio 6: recupera e attiva i valori
Per recuperare i valori dei parametri dal backend Remote Config, chiama il metodo
fetch()
. Vengono recuperati tutti i valori impostati nel backend e archiviato nell'oggetto Remote Config.Per rendere disponibili per la tua app i valori dei parametri recuperati, chiama il metodo
activate()
.Se vuoi recuperare e attivare i valori in una sola chiamata, puoi utilizzare una richiesta
fetchAndActivate()
per recuperare i valori dal backend di Remote Config e renderli disponibili per l'app:await remoteConfig.fetchAndActivate();
Perché questi valori dei parametri aggiornati influiscono sul comportamento e sull'aspetto dell'app, devi attivare i valori recuperati in un momento in modo da garantire fluida per l'utente, ad esempio la prossima volta che apre dell'app. Vedi Strategie di caricamento di Remote Config per ulteriori informazioni ed esempi.
Passaggio 7: ascolta gli aggiornamenti in tempo reale
Dopo aver recuperato i valori dei parametri, puoi utilizzare Remote Config in tempo reale per gli aggiornamenti dal backend Remote Config. gli indicatori di Remote Config dispositivi connessi quando sono disponibili aggiornamenti e recupera automaticamente i modifiche apportate dopo la pubblicazione di una nuova versione di Remote Config.
Tieni presente che Remote Config in tempo reale non è disponibile per il web.
Nella tua app, utilizza
onConfigUpdated
per iniziare a monitorare gli aggiornamenti e recuperare automaticamente i nuovi valori parametro.remoteConfig.onConfigUpdated.listen((event) async { await remoteConfig.activate(); // Use the new config values here. });
La prossima volta che pubblicherai una nuova versione di Remote Config, stai eseguendo la tua app e l'ascolto delle modifiche attiverà la nuova configurazione.
Limitazione
Se un'app esegue il recupero troppe volte in un breve periodo di tempo, le chiamate di recupero verranno limitate e il valore della proprietà lastFetchStatus
di FirebaseRemoteConfig
sarà RemoteConfigFetchStatus.throttle
.
L'intervallo di recupero minimo predefinito per Remote Config è di 12 ore, il che significa che le configurazioni non verranno recuperate dal backend più di una volta in un intervallo di 12 ore, indipendentemente dal numero di chiamate di recupero effettivamente effettuate.
Durante lo sviluppo dell'app, se non utilizzi la Configurazione in tempo reale (che consigliamo), potresti voler recuperare e attivare le configurazioni molto di frequente (molte volte all'ora) per eseguire rapidamente l'iterazione durante lo sviluppo e il test dell'app. Per eseguire l'iterazione rapida di un progetto con un massimo di 10 sviluppatori, puoi impostare temporaneamente un intervallo di recupero minimo ridotto con setConfigSettings()
.
final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
fetchTimeout: const Duration(minutes: 1),
minimumFetchInterval: const Duration(minutes: 5),
));
Passaggi successivi
Se non l'hai ancora fatto, esplora il Remote Config casi d'uso e dare un'occhiata ad alcuni dei sulla documentazione sui concetti chiave e sulle strategie avanzate, tra cui: