لكي تتمكّن إحدى الإضافات من تنفيذ الإجراءات المحدّدة لها، تمنح Firebase لكل مثيل من الإضافة المثبّتة إذن وصول محدودًا إلى المشروع وبياناته من خلال حساب خدمة.
ما هو حساب الخدمة؟
حساب الخدمة هو نوع خاص من حسابات مستخدمي Google. ويمثّل هذا المستخدم مستخدمًا غير بشري يمكنه إجراء طلبات مفوَّضة من واجهة برمجة التطبيقات إلى خدمات 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 Storage مجموعة. سيسمح الدور
storage.objectCreator
للإضافة بإنشاء عنصر في حزمة Cloud Storage، ولكن لن يتيح هذا الدور للإضافة عرض العناصر أو حذفها أو استبدالها. لتفعيل الإضافة كي تتمكّن من تنفيذ هذه الإجراءات الإضافية، عليك منح الدورstorage.objectAdmin
بدلاً من ذلك.
راجِع القسم في أسفل هذه الصفحة للاطّلاع على كل الأدوار المتوافقة التي يمكنك منحها لحساب خدمة الإضافة. للتعرّف على وصف كل دور والأذونات الممنوحة، يُرجى الانتقال إلى مستندات Firebase أو مستندات Google Cloud. يمكنك أيضًا البحث عن الأدوار في لوحة "إدارة الهوية وإمكانية الوصول" في "وحدة تحكّم Google Cloud".
كيفية إسناد أدوار إلى إضافة
أدخِل أدوار إدارة الهوية وإمكانية الوصول المطلوبة لكي تعمل الإضافة في قسم 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 (مطلوب) |
السلسلة | اسم دور إدارة الهوية وإمكانية الوصول الذي تحتاجه الإضافة لتشغيله |
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}
) و
حِزم التخزين (projects/{project_id}/buckets/{bucket_id}
).
الأدوار المتوافقة للإضافات
يسرد الجدول التالي أدوار إدارة الهوية وإمكانية الوصول المتوافقة للتفاعل مع منتجات 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 |
وظائف السحابة الإلكترونية |
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 |
أداة فحص أمان السحابة الإلكترونية |
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 |
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 |
محرك تعلُّم الآلة |
ml.developer ml.jobOwner ml.modelOwner ml.modelUser ml.operationOwner ml.viewer |
المراقبة |
segmentation.editor Monitoring.metricWriter Monitoring.viewer |
دفاتر ملاحظات الذكاء الاصطناعي |
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 |
Service Usage | serviceusage.apiKeysMetadataViewer |
خدمة نقل بيانات Cloud Storage |
storagetransfer.user storagetransfer.viewer |
Cloud Transcoder |
transcoder.admin transcoder.viewer |
Vertex AI | aiplatform.user |
غير ذلك |
identitytoolkit.admin identitytoolkit.viewer |