כדי שהתוסף יבצע את הפעולות שצוינו, Firebase מעניק לכל מופע של תוסף מותקן גישה מוגבלת לפרויקט ולנתונים שלו באמצעות חשבון שירות.
מה זה חשבון שירות?
חשבון שירות הוא סוג מיוחד של חשבון משתמש ב-Google. הוא מייצג משתמש לא אנושי שיכול לבצע קריאות מורשות ל-API לשירותי Google.
במהלך ההתקנה של תוסף, מערכת Firebase יוצרת חשבון שירות לתוסף בפרויקט. לכל מופע מותקן של תוסף יש חשבון שירות משלו. אם מסירים התקנה של מופע של תוסף, Firebase מוחק את חשבון השירות של התוסף.
חשבונות שירות שנוצרו לתוספים הם בפורמט:
ext-extension-instance-id@project-id.iam.gserviceaccount.com
מערכת Firebase מגבילה את הגישה של תוסף לפרויקט ולנתונים שלו על ידי הקצאת תפקידים ספציפיים (חבילות של הרשאות) לחשבון השירות של התוסף. כשמפתחים תוסף, צריך לקבוע אילו תפקידים נדרשים כדי שהתוסף יפעל, ואז לפרט את התפקידים האלה ואת הסיבה לכך שהתוסף זקוק להם בקובץ extension.yaml
(ראו דוגמה בחלק התחתון של הדף הזה).
קובעים אילו תפקידים נדרשים לתוסף
כשמפתחים תוסף, קובעים את רמת הגישה שנדרשת לתוסף כדי לפעול.
במהלך ההתקנה, ממשק Firebase CLI מבקש מהמשתמש לאשר את רמת הגישה שניתנת לכל תפקיד. אם התוסף שלכם מבקש יותר תפקידים ממה שהוא צריך בפועל, יכול להיות שהמשתמשים לא ירצו להתקין אותו.
קובעים אם התוסף שלכם יוצר אינטראקציה עם מוצר:
אם התוסף יוצר אינטראקציה עם מוצר, צריך לתת לתוסף גישה למוצר הזה.
לדוגמה, אם התוסף כותב נתונים למופע Realtime Database, התוסף צריך הרשאת Realtime Database (בספציפיות,
firebasedatabase.admin
).אם התוסף שלכם רק מאזין לאירוע הפעלה ממוצר, אז לא צריך לשייך לתוסף תפקיד שקשור למוצר הזה.
לדוגמה, אם התוסף שלכם מופעל כשמתבצעת כתיבה למופע Realtime Database (אבל לא כותב שום דבר למסד הנתונים), אז התוסף לא צריך הרשאת Realtime Database.
אחרי שתקבעו עם אילו מוצרים התוסף מקיים אינטראקציה, תצטרכו להחליט איזו הרשאה נדרשת לאינטראקציה הספציפית הזו. בחלק מהמוצרים יש תפקידים שונים בהתאם לפעולה או לסדרת הפעולות שמבצעים.
לדוגמה, נניח שהתוסף שלכם יוצר אינטראקציה עם Cloud Storagebucket. התפקיד
storage.objectCreator
יאפשר לתוסף ליצור אובייקט בקטגוריה Cloud Storage, אבל התפקיד הזה לא יאפשר לתוסף לצפות באובייקטים, למחוק אותם או להחליף אותם. כדי שהתוסף יוכל לבצע את הפעולות הנוספות האלה, צריך להקצות לו את התפקידstorage.objectAdmin
.
בקטע שבתחתית הדף מפורטים כל התפקידים הנתמכים שאפשר להקצות לחשבון השירות של התוסף. כדי לקרוא על תיאור התפקיד וההרשאות שניתנות לכל תפקיד, אפשר לעיין במסמכי התיעוד של Firebase או במסמכי התיעוד של Google Cloud. אפשר גם לחפש תפקידים בחלונית IAM & Admin במסוף Google Cloud.
איך מקצים תפקידים לתוסף
מפרטים את תפקידי ה-IAM שנדרשים כדי שהתוסף יפעל בקטע roles
בקובץ extension.yaml
.
דוגמה לתוסף שמקשיב לנתיב Firebase Realtime Database שצוין. כשהאירוע מופעל, התוסף מעדכן את כתובת האימייל של חשבון המשתמש (אינטראקציה עם Firebase Authentication) ושולח התראה (אינטראקציה עם Firebase Cloud Messaging). חשוב לשים לב לנקודות הבאות:
- למרות שהתוסף מופעל מאירוע Realtime Database, התפקיד
firebasedatabase.admin
לא מופיע (האזנה לא נחשבת לאינטראקציה). - התוסף מקיים אינטראקציה עם Authentication ועם Cloud Messaging, ולכן הוא זקוק להרשאות גישה למוצרים האלה (
firebaseauth.admin
ו-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
...
בקובץ extension.yaml
, משתמשים בשדות הבאים כדי להקצות תפקיד לחשבון השירות של התוסף:
שדה | סוג | תיאור |
---|---|---|
role (חובה) |
מחרוזת | שם תפקיד ה-IAM שהתוסף צריך כדי לפעול |
reason (חובה) |
מחרוזת |
תיאור קצר של הסיבה שבגללה התוסף זקוק לגישה שניתנת על ידי התפקיד חשוב לספק מספיק פרטים כדי שהמשתמש יוכל להבין איך התוסף משתמש בתפקיד. |
resource (אופציונלי) |
מחרוזת |
למדיניות ה-IAM של איזה משאב צריך להוסיף את התפקיד הזה. אם לא מציינים ערך, ברירת המחדל היא
הערכים הנתמכים הם |
צמצום היקף התפקידים
תוספים צריכים לפעול בהתאם לעיקרון של הרשאות מינימליות ולבקש גישה רק למשאבים שהם צריכים.
אפשר להגביל את היקף הגישה של תוסף באמצעות השדה role.resource
.
לדוגמה, אם התוסף צריך לכתוב אובייקטים לקטגוריה של Cloud Storage, אפשר להשתמש בתפקיד הבא:
roles:
- role: storage.objectCreator
reason: Needed in order to write
resource: projects/${PROJECT_ID}/buckets/${STORAGE_BUCKET}
כך התוסף יכול לגשת רק לקטגוריה שהוא צריך, ולא לקטגוריות אחרות באותו פרויקט.
השדה הזה תומך בפרויקטים (projects/{project_id}
) ובקטגוריות של Cloud Storage (projects/{project_id}/buckets/{bucket_id}
).
תפקידים נתמכים לתוספים
בטבלה הבאה מפורטים תפקידי ה-IAM הנתמכים לצורך אינטראקציה עם מוצרי Firebase. רוב התפקידים בטבלה הזו הם תפקידים ברמת המוצר ב-Firebase, אבל חלקם מנוהלים ישירות על ידי Google Cloud (במיוחד Cloud Firestore ו-Cloud Storage).
מוצרי Firebase
אם התוסף שלכם יוצר אינטראקציה עם... | הקצאת אחד מהתפקידים האלה... |
---|---|
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 |
כללי אבטחה |
firebaserules.viewer firebaserules.developer firebaserules.deployer |
Google Analytics |
firebaseanalytics.admin firebaseanalytics.viewer |
מוצרי Google Cloud
מידע נוסף על התפקידים האלה זמין במסמכי התיעוד של Google Cloud.
אם התוסף שלכם יוצר אינטראקציה עם... | הקצאת אחד מהתפקידים האלה... |
---|---|
פעולות |
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 |
חיוב | billing.viewer |
צ'אטים ב-Hangouts |
chat.owner chat.reader |
נכס בענן |
cloudasset.owner cloudasset.viewer |
Cloud Data Fusion |
datafusion.admin datafusion.viewer |
כלי לניפוי באגים בענן |
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 |
מניעת אובדן נתונים בענן |
dlp.reader dlp.user |
Error Reporting |
errorreporting.user errorreporting.viewer errorreporting.writer |
Eventarc |
eventarc.publisher eventarc.eventReceiver |
Cloud Filestore |
file.editor file.viewer |
רישום ביומן |
logging.configWriter logging.logWriter logging.privateLogViewer logging.viewer |
Machine Learning Engine |
ml.developer ml.jobOwner ml.modelOwner ml.modelUser ml.operationOwner ml.viewer |
מעקב |
monitoring.editor monitoring.metricWriter monitoring.viewer |
מחברות AI |
notebooks.admin notebooks.viewer |
Pub/Sub |
pubsub.editor pubsub.publisher pubsub.subscriber pubsub.viewer |
Memorystore Redis |
redis.editor redis.viewer |
Cloud Run | run.invoker |
מקור |
source.reader source.writer |
Cloud Spanner |
spanner.databaseAdmin spanner.databaseReader spanner.databaseUser spanner.viewer |
שימוש בשירות | serviceusage.apiKeysMetadataViewer |
Cloud Storage Transfer Service |
storagetransfer.user storagetransfer.viewer |
Cloud Transcoder |
transcoder.admin transcoder.viewer |
Vertex AI | aiplatform.user |
אחר |
identitytoolkit.admin identitytoolkit.viewer |