Google is committed to advancing racial equity for Black communities. See how.
Questa pagina è stata tradotta dall'API Cloud Translation.
Switch to English

Inizia con Firebase Remote Config

Puoi utilizzare Firebase Remote Config per definire i parametri nella tua app e aggiornare i loro valori nel cloud, permettendoti di modificare l'aspetto e il comportamento della tua app senza distribuire un aggiornamento dell'app. Questa guida ti guida attraverso i passaggi per iniziare e fornisce un codice di esempio, tutto disponibile per la clonazione o il download dal repository GitHub firebase / quickstart-ios .

Aggiungi Remote Config alla tua app

  1. Installa Firebase SDK per iOS.

  2. Crea l'oggetto singleton Remote Config, come mostrato nell'esempio seguente:

    Swift

    remoteConfig = RemoteConfig.remoteConfig()
    let settings = RemoteConfigSettings()
    settings.minimumFetchInterval = 0
    remoteConfig.configSettings = settings

    Obiettivo-C

    self.remoteConfig = [FIRRemoteConfig remoteConfig];
    FIRRemoteConfigSettings *remoteConfigSettings = [[FIRRemoteConfigSettings alloc] init];
    remoteConfigSettings.minimumFetchInterval = 0;
    self.remoteConfig.configSettings = remoteConfigSettings;

Questo oggetto viene utilizzato per archiviare i valori dei parametri predefiniti in-app, recuperare i valori dei parametri aggiornati dal back-end di Remote Config e controllare quando i valori recuperati vengono resi disponibili per la tua app.

Durante lo sviluppo, si consiglia di impostare un intervallo di recupero minimo relativamente basso. Per ulteriori informazioni, vedere Throttling .

Imposta i valori dei parametri predefiniti in-app

Puoi impostare i valori dei parametri predefiniti in-app nell'oggetto Remote Config, in modo che l'app si comporti come previsto prima di connettersi al back-end di Remote Config e in modo che i valori predefiniti siano disponibili se nessuno è impostato nel back-end.

  1. Definire un set di nomi di parametri e valori di parametri predefiniti utilizzando un oggetto NSDictionary o un file plist .
  2. Aggiungere questi valori all'oggetto Remote Config utilizzando setDefaults: L'esempio seguente imposta i valori predefiniti in-app da un file plist: The following example sets in-app default values ​​from a plist file:

Swift

remoteConfig.setDefaults(fromPlist: "RemoteConfigDefaults")

Obiettivo-C

[self.remoteConfig setDefaultsFromPlistFileName:@"RemoteConfigDefaults"];

Ottieni i valori dei parametri da utilizzare nella tua app

Ora puoi ottenere i valori dei parametri dall'oggetto Remote Config. Se successivamente imposti i valori nel back-end di Remote Config, li recuperi e poi li attivi, quei valori sono disponibili per la tua app. Altrimenti, ottieni i valori dei parametri in-app configurati utilizzando setDefaults: Per ottenere questi valori, chiama il metodo configValueForKey: fornendo la chiave del parametro come argomento.

Imposta i valori dei parametri

Utilizzando la console Firebase o le API di backend di Remote Config , puoi creare nuovi valori predefiniti di backend che sovrascrivono i valori in-app in base alla logica condizionale o al targeting dell'utente desiderato. Questa sezione ti guida attraverso i passaggi della console Firebase per creare questi valori.

  1. Nella console Firebase , apri il tuo progetto.
  2. Selezionare Remote Config dal menu per visualizzare il dashboard di Remote Config.
  3. Definisci i parametri con gli stessi nomi dei parametri che hai definito nella tua app. Per ogni parametro, puoi impostare un valore predefinito (che alla fine sovrascriverà il valore predefinito in-app) e puoi anche impostare valori condizionali. Per ulteriori informazioni, vedere Parametri e condizioni di configurazione remota .

Recupera e attiva i valori

Per recuperare i valori dei parametri da Remote Config, chiamare il fetchWithCompletionHandler: o fetchWithExpirationDuration:completionHandler: Tutti i valori impostati nel back-end vengono recuperati e memorizzati nella cache nell'oggetto Remote Config.

Per i casi in cui desideri recuperare e attivare i valori in una chiamata, utilizza fetchAndActivateWithCompletionHandler:

Questo esempio recupera i valori dal back-end di Remote Config (non i valori memorizzati nella cache) e chiama activateWithCompletionHandler: per renderli disponibili per l'app:

Swift

remoteConfig.fetch() { (status, error) -> Void in
  if status == .success {
    print("Config fetched!")
    self.remoteConfig.activate() { (changed, error) in
      // ...
    }
  } else {
    print("Config not fetched")
    print("Error: \(error?.localizedDescription ?? "No error available.")")
  }
  self.displayWelcome()
}

Obiettivo-C

[self.remoteConfig fetchWithCompletionHandler:^(FIRRemoteConfigFetchStatus status, NSError *error) {
    if (status == FIRRemoteConfigFetchStatusSuccess) {
        NSLog(@"Config fetched!");
      [self.remoteConfig activateWithCompletion:^(BOOL changed, NSError * _Nullable error) {
        // ...
      }];
    } else {
        NSLog(@"Config not fetched");
        NSLog(@"Error %@", error.localizedDescription);
    }
    [self displayWelcome];
}];

Poiché questi valori dei parametri aggiornati influenzano il comportamento e l'aspetto della tua app, dovresti attivare i valori recuperati in un momento che garantisca un'esperienza fluida per il tuo utente, come la prossima volta che l'utente apre la tua app. Vedere Strategie di caricamento di Remote Config per ulteriori informazioni ed esempi.

Throttling

Se un'app viene recuperata troppe volte in un breve periodo di tempo, le chiamate di recupero vengono FIRRemoteConfigFetchStatusThrottled e l'SDK restituisce FIRRemoteConfigFetchStatusThrottled . Prima della versione 6.3.0 dell'SDK, il limite era di 5 richieste di recupero in una finestra di 60 minuti (le versioni più recenti hanno limiti più permissivi).

Durante lo sviluppo dell'app, potresti voler aggiornare la cache molto frequentemente (molte volte all'ora) per consentirti di iterare rapidamente mentre sviluppi e collaudi l'app. Per FIRRemoteConfigSettings una rapida iterazione su un progetto con numerosi sviluppatori, puoi aggiungere temporaneamente una proprietà FIRRemoteConfigSettings con un intervallo di recupero minimo basso ( MinimumFetchInterval ) nella tua app.

L'intervallo di recupero della produzione predefinito e consigliato per Remote Config è di 12 ore, il che significa che le configurazioni non verranno recuperate dal back-end più di una volta in una finestra di 12 ore, indipendentemente dal numero di chiamate di recupero effettivamente effettuate. In particolare, l'intervallo di recupero minimo è determinato nel seguente ordine:

  1. Il parametro in fetch(long)
  2. Il parametro in FIRRemoteConfigSettings.MinimumFetchInterval
  3. Il valore predefinito di 12 ore

Prossimi passi

Se non l'hai già fatto, esplora i casi d'uso di Remote Config e dai un'occhiata ad alcuni dei concetti chiave e alla documentazione delle strategie avanzate, tra cui: