Firebase

Firebase Synchronisierung Unser App-Template ist vorbereitet, Nutzerdaten, sowie Standard-Konfigurationen aus Firebase zu laden und zu synchronisieren. Dies erlaubt es, Nutzerdaten über verschiedene Geräte synchron zu halten. Um den Service zu aktivieren, definiere folgende Konstanten in der AppBasement.csproj Datei und füge folgende Nuget-Pakete hinzu. Firebase einrichten Falls nicht vorhanden, benötigest du einen Account bei Firebase. Dieser…

Image Description

Firebase Synchronisierung

Unser App-Template ist vorbereitet, Nutzerdaten, sowie Standard-Konfigurationen aus Firebase zu laden und zu synchronisieren. Dies erlaubt es, Nutzerdaten über verschiedene Geräte synchron zu halten. Um den Service zu aktivieren, definiere folgende Konstanten in der AppBasement.csproj Datei und füge folgende Nuget-Pakete hinzu.

	<!-- Enables all firebase code -->
	<DefineConstants>$(DefineConstants);Firebase;FirebaseAuth</DefineConstants>


	<!-- Needed for Firebase -->
	<PackageReference Include="FirebaseAuthentication.net" Version="4.1.0" />
	<PackageReference Include="FirebaseDatabase.net" Version="4.2.0" />

Firebase einrichten

Falls nicht vorhanden, benötigest du einen Account bei Firebase. Dieser ist kostenlos und kann mit einem Google-Konto ganz einfach erstellt werden. Besuche dazu einfach folgenden Link:

Firebase Console: https://console.firebase.google.com/u/1/

Anschließend erstelle ein neues Projekt, indem du auf “Projekt hinzufügen” klickst.

Neues Projekt erstellen
Neues Projekt erstellen

Folge anschließend den Setup-Assistenten.

Benenne dein Projekt
Benenne dein Projekt
Konfiguriere Google Analytics
Konfiguriere Google Analytics, falls gewünscht

Nach dem das Projekt erstellt wurde, füge die Dienste “Echtzeitdatenbank” und “Authentifizierung” zu deinem Projekt hinzu.

Erstellen der benötigten Dienste
Erstellen der benötigten Dienste

Firebase Authentifizierung

Um die Authentifizierung nutzen zu können, solltest du mindestens die Registrierung per Mail und Passwort aktivieren. Dies ist auch die Standard-Loginmethode für das App Template. Alle weiteren Dienste sind aktuell noch nicht umgesetzt.

Anmeldemethoden verwalten und erstellen
Anmeldemethoden verwalten und erstellen

Firebase Realtime Database

Zum Speichern der Daten ist eine Datenbank erforderlich. Diese kannst du ebenfalls mit ein paar Klicks erstellen. Klicke dazu unter “Entwickeln” auf “Realtime Database” und anschließend auf “Datenbank erstellen”. Folge den Schritten bis zum Abschluss.

Speicherort der Datenbank auswählen (USA ist empfohlen)
Speicherort der Datenbank auswählen (USA ist empfohlen)
Einrichten der Sicherheitsregel (hier im Testmodus starten)
Einrichten der Sicherheitsregel (hier im Testmodus starten)

Anschließend müssen die Sicherheitsregeln überarbeitet werden. Aktuell hat jeder Zugriff auf alle Daten. Du kannst folgende Sicherheitsregel als Grundlage verwenden.

{
 "rules": {
   /* Access for custom folders (preset data for instance)
   "Printers":{
     ".read": "auth != null",
     ".write": false,
   },
   */
   "users": {
      "$uid": {
        ".write": "$uid === auth.uid",
        ".read": "$uid === auth.uid",
      }
   }
 	}
}

Hier ist es allen erlaubt zu lesen, welche sich Authentifiziert haben (über API-Schlüssel oder Anmeldung). Des Weiteren können Benutzer (“users”) unter dem Datenbankpfad “users”, dort wo die Benutzerdaten abgelegt werden, nur unter Ihrer ID Schreiben und Lesen.

App konfigurieren

Abschließend muss die App konfiguriert werden, dass diese mit dem Firebase Projekt interagieren kann. Dazu musst du erst eine “Web App” in Firebase erstellen. Klicke dazu auf das “</>” Symbol.

Neue Web-App erstellen
Neue Web-App erstellen

Anschließend gib deiner App noch einen passenden Namen und bestätige das Setup mit “App registrieren”.

Neue Web App registrieren
Neue Web App registrieren

Nun erhältst du alle nötigen Zugangsdaten, welche unser App-Template benötigt, um mit deinem Firebase Projekt zu interagieren. Die Daten sehen wie folgt aus:

const firebaseConfig = {
  apiKey: "xxxxx_your_api_key",
  authDomain: "your_project.firebaseapp.com",
  databaseURL: "https://your_project-rtdb.firebaseio.com",
  projectId: "your_project",
  storageBucket: "your_project.appspot.com",
  messagingSenderId: "XXX",
  appId: "1:XXXXX",
  measurementId: "G-XXXXXXX"
};

Diese Informationen müssen nun in der secrets.json Datei eingegeben werden.

{
  "AppBasement": {
    //...
    "FirebaseUri": "https://your_project-rtdb.firebaseio.com",			// The databaseURL
    "FirebaseSecret": "xxxxx_your_secret_key",							// The secret (obsolete)
    "FirebaseApiKey": "xxxxx_your_api_key",								// The apiKey
    "FirebaseAuthDomain": "your_project.firebaseapp.com",				// the authDomain
    //...
  }
}

Der DatabaseSecret ist abgekündigt und sollte nicht mehr verwendet werden. Stattessen sollte die Authentifizierung über eine Anmeldung bzw. den API-Schlüssel erfolgen. Nichtsdestotrotz findest du das Secret unter “Projekteinstellungen -> Dienstkonto -> Datenbank-Secrets”.

Mehr zu der secrets.json Datei findest du in den Ersten Schritten.

FirebaseHandler

Im App-Template übernimmt die Helferklasse FirebaseHandler den Datenaustausch, sowie die Authentifizierung mit Firebase. Im LoadingPageViewModel.Refresh() wird, sofern sich schon ein Benutzer angemeldet hat, die Einstellungen synchronisiert.

Func<Task> onSuccess = async () =>
{
  var settings = await FirebaseHandler.Instance.GetAppSettingsDictionaryAsync();
  await SettingsApp.LoadSettingsAsync(dictionary: settings);
};
if (!string.IsNullOrEmpty(SettingsApp.Firebase_Username) && !string.IsNullOrEmpty(SettingsApp.Firebase_Password))
{
  await LoginFirebaseWithCredentialsAsync(SettingsApp.Firebase_Username, SettingsApp.Firebase_Password, onSuccess: onSuccess);
}
else
{
  // If no account infos are available, login as anonymous (If allowed by your Firebase setup)
  //await LoginFirebaseAnonymouslyAsync(onSuccess: onSuccess);
}

Werden während der Laufzeit Einstellungen angepasst, so werde diese gleich Richtung Firebase synchronisiert.

[ObservableProperty]
bool allowAppTracking = false;
partial void OnAllowAppTrackingChanged(bool value)
{
  if (!IsLoading)
  {
    SettingsApp.Privacy_AllowAppTracking = value;
    SettingsApp.SettingsChanged = true;
    #if FirebaseAuth
      FirebaseHandler.Instance.SyncSettings(setting => SettingsApp.Privacy_AllowPersonalizedAds);
    #endif
    }
  if (AllowAppTracking && !IsLoading && SettingsStaticDefault.Privacy_AllowPersonalizedAds)
  {
    Task.Run(RequestTrackingAuthorization);
  }
}

Durch das Ändern der Einstellungen in der “Firebase Realtime Database”, wird automatisch ein Event ausgelöst und alle aktiven Applikationen benachrichtig. Um auf das Event reagieren zu können, wird beim Anmelden eine Func mitgegeben, welche die geänderten Einstellungen lokal aktualisiert.

userInfo = await FirebaseHandler.Instance.LoginWithEmailAndPasswordAsyncAsync(username, password, onDataChanged: async (p) =>
{
    // Save the users settings on any changes
    await SettingsApp.LoadSettingsAsync(p.Item1, p.Item2);
});

//....

OnUserDataChangedEvent(new()
{
    User = CurrentUser,
    SettingsKey = p.Item1,
    ChangedSetting = data,
});

Die gewährleistet, dass bei Mehrfachnutzung der Applikation, die Daten nicht auseinander laufen und eine Instanz die Daten der zweiten Instanz überschreibt.

War dieser Artikel hilfreich für Sie?

Ja Nein

Verwandte Artikel