Geeigneten Zugriff für eine Erweiterung einrichten

Damit eine Erweiterung die angegebenen Aktionen ausführen kann, gewährt Firebase jeder Instanz einer installierten Erweiterung über ein Dienstkonto eingeschränkten Zugriff auf das Projekt und seine Daten.

Was ist ein Dienstkonto?

Ein Dienstkonto ist eine spezielle Art von Google-Nutzerkonto. Es repräsentiert einen Nutzer nicht menschlicher Natur, der autorisierte API-Aufrufe an Google-Dienste senden kann.

Bei der Installation einer Erweiterung erstellt Firebase ein Dienstkonto für die Erweiterung im Projekt. Jede installierte Instanz einer Erweiterung hat ein eigenes Dienstkonto. Wenn eine Erweiterungsinstanz deinstalliert wird, löscht Firebase das Dienstkonto der Erweiterung.

Dienstkonten, die für Erweiterungen erstellt wurden, haben das folgende Format:

ext-extension-instance-id@project-id.iam.gserviceaccount.com

Firebase beschränkt den Zugriff einer Erweiterung auf ein Projekt und seine Daten, indem dem Dienstkonto der Erweiterung bestimmte Rollen (Berechtigungsbündel) zugewiesen werden. Wenn Sie eine Erweiterung entwickeln, legen Sie fest, welche Rollen für die Funktion der Erweiterung erforderlich sind. Anschließend listen Sie diese Rollen und den Grund, warum Ihre Erweiterung diese Rollen benötigt, in Ihrer extension.yaml-Datei auf (Beispiel unten auf dieser Seite).

Erforderliche Rollen für Ihre Erweiterung ermitteln

Wenn Sie Ihre Erweiterung erstellen, legen Sie fest, welche Zugriffsebene für die Funktion der Erweiterung erforderlich ist.

Während der Installation fordert die Firebase-Befehlszeile den Nutzer auf, das von jeder Rolle gewährte Zugriffsniveau zu akzeptieren. Wenn für Ihre Erweiterung mehr Rollen erforderlich sind, als tatsächlich benötigt werden, ist es weniger wahrscheinlich, dass Nutzer sie installieren.

  1. So stellen Sie fest, ob Ihre Erweiterung mit einem Produkt interagiert:

    • Wenn Ihre Erweiterung mit einem Produkt interagiert, müssen Sie ihr Zugriff auf dieses Produkt gewähren.

      Wenn Ihre Erweiterung beispielsweise Daten in eine Realtime Database-Instanz schreibt, benötigt sie eine Realtime Database-Rolle (genauer gesagt firebasedatabase.admin).

    • Wenn Ihre Erweiterung nur auf ein Auslöseereignis eines Produkts wartet, benötigt sie keine Rolle, die mit diesem Produkt verknüpft ist.

      Wenn Ihre Erweiterung beispielsweise bei einem Schreibvorgang in eine Realtime Database-Instanz ausgelöst wird (aber nichts in die Datenbank schreibt), benötigt Ihre Erweiterung keine Realtime Database-Rolle.

  2. Nachdem Sie festgelegt haben, mit welchen Produkten Ihre Erweiterung interagiert, müssen Sie entscheiden, welche Rolle für diese bestimmte Interaktion erforderlich ist. Für einige Produkte sind je nach ausgeführter Aktion oder Aktionsgruppe unterschiedliche Rollen verfügbar.

    Angenommen, Ihre Erweiterung interagiert mit einem Cloud Storage-Bucket. Mit der Rolle storage.objectCreator kann die Erweiterung ein Objekt in einem Cloud Storage-Bucket erstellen, aber nicht Objekte ansehen, löschen oder überschreiben. Damit die Erweiterung diese zusätzlichen Aktionen ausführen kann, müssen Sie stattdessen die Rolle storage.objectAdmin zuweisen.

Im Abschnitt unten auf dieser Seite finden Sie alle unterstützten Rollen, die Sie dem Dienstkonto Ihrer Erweiterung zuweisen können. Beschreibungen der einzelnen Rollen und Informationen zu den erteilten Berechtigungen finden Sie in der Firebase-Dokumentation oder der Google Cloud-Dokumentation. Sie können Rollen auch in der Google Cloud Console im Bereich „IAM & Verwaltung“ nachschlagen.

Rollen einer Erweiterung zuweisen

Listen Sie die IAM-Rollen auf, die für den Betrieb Ihrer Erweiterung im Abschnitt roles Ihrer Datei extension.yaml erforderlich sind.

Hier ist ein Beispiel für eine Erweiterung, die auf einen bestimmten Firebase Realtime Database-Pfad wartet. Wenn die Erweiterung ausgelöst wird, wird die E-Mail-Adresse eines Nutzerkontos aktualisiert (Interaktion mit Firebase Authentication) und eine Benachrichtigung gesendet (Interaktion mit Firebase Cloud Messaging). Beachten Sie Folgendes:

  • Obwohl die Erweiterung durch ein Realtime Database-Ereignis ausgelöst wird, ist die Rolle firebasedatabase.admin nicht aufgeführt, da das Zuhören nicht als Interaktion gilt.
  • Da die Erweiterung mit Authentication und Cloud Messaging interagiert, sind für die Erweiterung Rollen erforderlich, um auf diese Produkte zuzugreifen (firebaseauth.admin bzw. firebasenotifications.admin).
# extension.yaml
...

# Roles assigned to the extension's service account by Firebase during installation
roles:
  - role: firebaseauth.admin
    reason: Required to update the email address of the user account

  - role: firebasenotifications.admin
    reason: Required to send a notification that the email address has been updated

...

Verwenden Sie in Ihrer extension.yaml-Datei die folgenden Felder, um dem Dienstkonto einer Erweiterung eine Rolle zuzuweisen:

Feld Typ Beschreibung
role
(erforderlich)
String Name der IAM-Rolle, die für die Funktion der Erweiterung erforderlich ist
reason
(erforderlich)
String

Kurze Beschreibung des Grunds, warum die Erweiterung den durch die Rolle gewährten Zugriff benötigt

Geben Sie genügend Details an, damit ein Nutzer nachvollziehen kann, wie die Erweiterung die Rolle verwendet.

resource
(optional)
String

Die IAM-Richtlinie der Ressource, der diese Rolle hinzugefügt werden soll. Wenn keine Angabe gemacht wird, lautet der Standardwert projects/${project_id}.

Unterstützte Werte sind projects/* und projects/*/buckets/*.

Umfang von Rollen verringern

Erweiterungen sollten dem Prinzip der geringsten Berechtigung folgen und nur Zugriff auf die Ressourcen anfordern, die sie benötigen. Sie können den Zugriff einer Erweiterung mit dem Feld role.resource einschränken. Wenn Ihre Erweiterung beispielsweise Objekte in einen Cloud Storage-Bucket schreiben muss, können Sie die folgende Rolle verwenden:

roles:
  - role: storage.objectCreator
    reason: Needed in order to write
    resource: projects/${PROJECT_ID}/buckets/${STORAGE_BUCKET}

So kann die Erweiterung nur auf den Bucket zugreifen, den sie benötigt, und nicht auf andere im selben Projekt.

Dieses Feld unterstützt Projekte (projects/{project_id}) und Storage-Buckets (projects/{project_id}/buckets/{bucket_id}).

Unterstützte Rollen für Erweiterungen

In der folgenden Tabelle sind die unterstützten IAM-Rollen für die Interaktion mit Firebase-Produkten aufgeführt. Die meisten Rollen in dieser Tabelle sind Rollen auf Firebase-Produktebene, einige werden jedoch direkt von Google Cloud verwaltet (insbesondere Cloud Firestore und Cloud Storage).

Firebase-Produkte

Wenn Ihre Erweiterung mit Folgendem interagiert Weisen Sie eine dieser Rollen zu…
Cloud Firestore datastore.importExportAdmin
datastore.indexAdmin
datastore.owner
datastore.user
datastore.viewer
Cloud Storage for Firebase storage.admin
storage.objectAdmin
storage.objectCreator
storage.objectViewer
Firebase App Distribution firebaseappdistro.admin
firebaseappdistro.viewer
Firebase Authentication firebaseauth.admin
firebaseauth.viewer
Firebase A/B Testing firebaseabt.admin
firebaseabt.viewer
Firebase Cloud Messaging firebasenotifications.admin
firebasenotifications.viewer
Firebase Crashlytics firebasecrashlytics.admin
firebasecrashlytics.viewer
Firebase Hosting firebasehosting.admin
firebasehosting.viewer
Firebase In-App Messaging firebaseinappmessaging.admin
firebaseinappmessaging.viewer
Firebase ML firebaseml.admin
firebaseml.viewer
Firebase Performance Monitoring firebaseperformance.viewer
firebaseperformance.reader
firebaseperformance.writer
Firebase Realtime Database firebasedatabase.admin
firebasedatabase.viewer
Sicherheitsregeln firebaserules.viewer
firebaserules.developer
firebaserules.deployer
Google Analytics firebaseanalytics.admin
firebaseanalytics.viewer

Google Cloud-Produkte

Weitere Informationen zu diesen Rollen finden Sie in der Google Cloud-Dokumentation.

Wenn Ihre Erweiterung mit Folgendem interagiert Weisen Sie eine dieser Rollen zu…
Aktionen actions.Admin
actions.Viewer
Apigee apigee.analyticsAgent
apigee.analyticsEditor
apigee.analyticsViewer
apigee.apiCreator
apigee.deployer
apigee.developerAdmin
apigee.readOnlyAdmin
apigee.synchronizerManager
App Engine appengine.appAdmin
appengine.appViewer
appengine.codeViewer
appengine.deployer
appengine.serviceAdmin
AutoML automl.editor
automl.predictor
automl.viewer
BigQuery bigquery.connectionAdmin
bigquery.connectionUser
bigquery.dataEditor
bigquery.dataOwner
bigquery.dataViewer
bigquery.jobUser
bigquery.metadataViewer
bigquery.readSessionUser
bigquery.user
Cloud Bigtable bigtable.reader
bigtable.user
bigtable.viewer
Abrechnung billing.viewer
Hangout-Chats chat.owner
chat.reader
Cloudasset cloudasset.owner
cloudasset.viewer
Cloud Data Fusion datafusion.admin
datafusion.viewer
Cloud Debugger clouddebugger.agent
clouddebugger.user
Cloud Functions cloudfunctions.invoker
cloudfunctions.viewer
Cloud IAP iap.admin
iap.httpsResourceAccessor
iap.settingsAdmin
iap.tunnelResourceAccessor
Cloud IoT cloudiot.deviceController
cloudiot.editor
cloudiot.provisioner
cloudiot.viewer
Stackdriver Profiler cloudprofiler.agent
cloudprofiler.user
Cloud Scheduler cloudscheduler.admin
cloudscheduler.jobRunner
cloudscheduler.viewer
Cloud Security Scanner cloudsecurityscanner.editor
cloudsecurityscanner.runner
cloudsecurityscanner.viewer
Cloud SQL cloudsql.client
cloudsql.editor
cloudsql.viewer
Cloud Trace cloudtrace.admin
cloudtrace.agent
cloudtrace.user
Dataflow dataflow.developer
dataflow.viewer
dataflow.worker
Dialogflow dialogflow.admin
dialogflow.client
dialogflow.reader
Cloud Data Loss Prevention dlp.reader
dlp.user
Error Reporting errorreporting.user
errorreporting.viewer
errorreporting.writer
Eventarc eventarc.publisher
eventarc.eventReceiver
Cloud Filestore file.editor
file.viewer
Logging logging.configWriter
logging.logWriter
logging.privateLogViewer
logging.viewer
Machine Learning Engine ml.developer
ml.jobOwner
ml.modelOwner
ml.modelUser
ml.operationOwner
ml.viewer
Monitoring monitoring.editor
monitoring.metricWriter
monitoring.viewer
AI Notebooks notebooks.admin
notebooks.viewer
Pub/Sub pubsub.editor
pubsub.publisher
pubsub.subscriber
pubsub.viewer
Memorystore Redis redis.editor
redis.viewer
Cloud Run run.invoker
Quelle source.reader
source.writer
Cloud Spanner spanner.databaseAdmin
spanner.databaseReader
spanner.databaseUser
spanner.viewer
Service Usage serviceusage.apiKeysMetadataViewer
Cloud Storage Transfer Service storagetransfer.user
storagetransfer.viewer
Cloud Transcoder transcoder.admin
transcoder.viewer
Vertex AI aiplatform.user
Sonstiges identitytoolkit.admin
identitytoolkit.viewer