لبدء استخدام Cloud Functions، جرِّب الاطّلاع على هذا الدليل التعليمي، الذي يبدأ بمهام الإعداد المطلوبة وينتقل إلى إنشاء دالتين ذات صلة واختبارهما ونشرهما:
- دالة "إضافة رسالة" تعرض عنوان URL يقبل قيمة نصية ويكتبها في Cloud Firestore.
- دالة "make uppercase" التي يتم تفعيلها عند كتابة Cloud Firestore وتحوِّل النص إلى أحرف كبيرة
في ما يلي نموذج الرمز البرمجي الكامل الذي يحتوي على الدوالّ:
Node.js
// The Cloud Functions for Firebase SDK to create Cloud Functions and triggers.
const {logger} = require("firebase-functions");
const {onRequest} = require("firebase-functions/v2/https");
const {onDocumentCreated} = require("firebase-functions/v2/firestore");
// The Firebase Admin SDK to access Firestore.
const {initializeApp} = require("firebase-admin/app");
const {getFirestore} = require("firebase-admin/firestore");
initializeApp();
// Take the text parameter passed to this HTTP endpoint and insert it into
// Firestore under the path /messages/:documentId/original
exports.addmessage = onRequest(async (req, res) => {
// Grab the text parameter.
const original = req.query.text;
// Push the new message into Firestore using the Firebase Admin SDK.
const writeResult = await getFirestore()
.collection("messages")
.add({original: original});
// Send back a message that we've successfully written the message
res.json({result: `Message with ID: ${writeResult.id} added.`});
});
// Listens for new messages added to /messages/:documentId/original
// and saves an uppercased version of the message
// to /messages/:documentId/uppercase
exports.makeuppercase = onDocumentCreated("/messages/{documentId}", (event) => {
// Grab the current value of what was written to Firestore.
const original = event.data.data().original;
// Access the parameter `{documentId}` with `event.params`
logger.log("Uppercasing", event.params.documentId, original);
const uppercase = original.toUpperCase();
// You must return a Promise when performing
// asynchronous tasks inside a function
// such as writing to Firestore.
// Setting an 'uppercase' field in Firestore document returns a Promise.
return event.data.ref.set({uppercase}, {merge: true});
});
Python
# The Cloud Functions for Firebase SDK to create Cloud Functions and set up triggers.
from firebase_functions import firestore_fn, https_fn
# The Firebase Admin SDK to access Cloud Firestore.
from firebase_admin import initialize_app, firestore
import google.cloud.firestore
app = initialize_app()
@https_fn.on_request()
def addmessage(req: https_fn.Request) -> https_fn.Response:
"""Take the text parameter passed to this HTTP endpoint and insert it into
a new document in the messages collection."""
# Grab the text parameter.
original = req.args.get("text")
if original is None:
return https_fn.Response("No text parameter provided", status=400)
firestore_client: google.cloud.firestore.Client = firestore.client()
# Push the new message into Cloud Firestore using the Firebase Admin SDK.
_, doc_ref = firestore_client.collection("messages").add({"original": original})
# Send back a message that we've successfully written the message
return https_fn.Response(f"Message with ID {doc_ref.id} added.")
@firestore_fn.on_document_created(document="messages/{pushId}")
def makeuppercase(event: firestore_fn.Event[firestore_fn.DocumentSnapshot | None]) -> None:
"""Listens for new documents to be added to /messages. If the document has
an "original" field, creates an "uppercase" field containg the contents of
"original" in upper case."""
# Get the value of "original" if it exists.
if event.data is None:
return
try:
original = event.data.get("original")
except KeyError:
# No "original" field, so do nothing.
return
# Set the "uppercase" field.
print(f"Uppercasing {event.params['pushId']}: {original}")
upper = original.upper()
event.data.reference.update({"uppercase": upper})
لمحة عن هذا البرنامج التعليمي
لقد اخترنا Cloud Firestore والدوالّ التي يتم تشغيلها من خلال HTTP لهذا المثال، ويعود السبب جزئيًا إلى أنّه يمكن اختبار عوامل التفعيل هذه في الخلفية بشكل كامل من خلال Firebase Local Emulator Suite. تتيح مجموعة الأدوات هذه أيضًا استخدام Realtime Database وCloud Storage وPubSub وAuth وHTTP للتشغيل. يمكن اختبار الأنواع الأخرى من عوامل التفعيل التي تعمل في الخلفية، مثل عوامل التفعيل في Remote Config وTestLab، بشكل تفاعلي باستخدام مجموعات أدوات غير описанة في هذه الصفحة.
توضّح الأقسام التالية من هذا الدليل التعليمي الخطوات المطلوبة لإنشاء النموذج و اختباره ونشره.
إنشاء مشروع على Firebase
-
في وحدة تحكّم Firebase، انقر على إضافة مشروع.
-
لإضافة موارد Firebase إلى مشروع Google Cloud حالي، أدخِل اسم المشروع أو اختَره من القائمة المنسدلة.
-
لإنشاء مشروع جديد، أدخِل اسم المشروع المطلوب. يمكنك أيضًا اختياريًا تعديل رقم تعريف المشروع المعروض أسفل اسم المشروع.
-
-
راجِع بنود Firebase واقبلها في حال طُلب منك ذلك.
-
انقر على متابعة.
-
(اختياري) يمكنك إعداد Google Analytics لمشروعك، ما يتيح لك الحصول على تجربة مثالية باستخدام أيّ من منتجات Firebase التالية:
اختَر إما حساب Google Analytics حاليًا أو أنشئ حسابًا جديدًا.
إذا أنشأت حسابًا جديدًا، اختَر Analytics الموقع الجغرافي لإعداد التقارير، ثم وافِق على إعدادات مشاركة البيانات وبنود Google Analytics لمشروعك.
-
انقر على إنشاء مشروع (أو إضافة Firebase، إذا كنت تستخدم مشروعًا حاليًا على Google Cloud).
توفّر Firebase الموارد تلقائيًا لمشروعك على Firebase. عند اكتمال العملية، سيتم نقلك إلى صفحة النظرة العامة لمشروع Firebase في وحدة تحكّم Firebase.
إعداد بيئتك وواجهة Firebase CLI
Node.js
ستحتاج إلى بيئة Node.js لكتابة الدوالّ، وستحتاج إلى واجهة برمجة التطبيقات Firebase لنشر الدوالّ في وقت تشغيل Cloud Functions. لتثبيت Node.js وnpm،ننصح باستخدام Node Version Manager.
بعد تثبيت Node.js وnpm، ثبِّت Firebase CLI باستخدام الطريقة المفضّلة لديك. لتثبيت واجهة سطر الأوامر من خلال npm، استخدِم:
npm install -g firebase-tools
يؤدي ذلك إلى تثبيت أمر Firebase المتاح على مستوى العالم. إذا
تعذّر تنفيذ الأمر، قد تحتاج إلى
تغيير أذونات npm.
لتحديث أحدث إصدار من firebase-tools
، يُرجى إعادة تشغيل الأمر نفسه.
Python
ستحتاج إلى بيئة Python
لكتابة الدوال،
وستحتاج إلى واجهة برمجة التطبيقات Firebase لنشر الدوال إلى
وقت تشغيل Cloud Functions. ننصحك باستخدام venv
لمحاولة
عزل التبعيات. يمكن استخدام الإصدارَين 3.10 و3.11 من Python.
بعد تثبيت Python، ثبِّت Firebase CLI باستخدام الطريقة المفضّلة لديك.
بدء مشروعك
عند إعداد حزمة تطوير البرامج (SDK) لنظام التشغيل Firebase على نظام التشغيل Cloud Functions، يتم إنشاء مشروع فارغ يحتوي على التبعيات وبعض النماذج البسيطة من الرموز البرمجية. إذا كنت تستخدم Node.js، يمكنك اختيار إما TypeScript أو JavaScript لإنشاء الدوالّ. لأغراض هذا الدليل التمهيدي، عليك أيضًا إعداد Cloud Firestore.
لبدء مشروعك:
- شغِّل
firebase login
لتسجيل الدخول من خلال المتصفّح ومصادقة Firebase CLI. - انتقِل إلى دليل مشروعك على Firebase.
- شغِّل
firebase init firestore
. في هذا الدليل التعليمي، يمكنك قبول القيمة الافتراضية عند طلب قواعد Firestore وملفات الفهرسة. إذا لم يسبق لك استخدام Cloud Firestore في هذا المشروع، عليك أيضًا اختيار وضع بدء وموقع جغرافي لخدمة Firestore كما هو موضّح في مقالة البدء باستخدام Cloud Firestore. - شغِّل
firebase init functions
. تطلب منك واجهة برمجة التطبيقات اختيار قاعدة رمز برمجي حالية أو بدء قاعدة جديدة وتسميتها. عند البدء للتو، يكفي استخدام قاعدة بيانات واحدة في الموقع التلقائي. ولاحقًا، مع توسيع نطاق التنفيذ، قد تحتاج إلى تنظيم الدوالّ في قواعد البيانات. تمنحك واجهة برمجة التطبيقات هذه الخيارات لتوفير الدعم اللغوي:
- JavaScript
- TypeScript
- Python
في هذا الدليل التعليمي، اختَر JavaScript أو Python. لإنشاء المحتوى باستخدام لغة برمجة TypeScript، اطّلِع على مقالة كتابة الدوال باستخدام TypeScript.
تمنحك واجهة برمجة التطبيقات خيار تثبيت التبعيات. يمكنك بأمان رفض هذا الخيار إذا كنت تريد إدارة التبعيات بطريقة أخرى.
بعد اكتمال هذه الأوامر بنجاح، ستظهر بنية مشروعك على النحو التالي:
Node.js
myproject
+- .firebaserc # Hidden file that helps you quickly switch between
| # projects with `firebase use`
|
+- firebase.json # Describes properties for your project
|
+- functions/ # Directory containing all your functions code
|
+- .eslintrc.json # Optional file containing rules for JavaScript linting.
|
+- package.json # npm package file describing your Cloud Functions code
|
+- index.js # Main source file for your Cloud Functions code
|
+- node_modules/ # Directory where your dependencies (declared in
# package.json) are installed
بالنسبة إلى Node.js، يحتوي ملف package.json
الذي تم إنشاؤه أثناء الإعداد على مفتاح مهم: "engines": {"node": "18"}
. يحدِّد هذا الخيار إصدار Node.js لكتابة الدوالّ ونشرها. يمكنك
اختيار إصدارات أخرى متوافقة.
Python
myproject
+- .firebaserc # Hidden file that helps you quickly switch between
| # projects with `firebase use`
|
+- firebase.json # Describes properties for your project
|
+- functions/ # Directory containing all your functions code
|
+- main.py # Main source file for your Cloud Functions code
|
+- requirements.txt # List of the project's modules and packages
|
+- venv/ # Directory where your dependencies are installed
استيراد الوحدات المطلوبة وبدء تطبيق
بعد إكمال مهام الإعداد، يمكنك فتح دليل المصدر والبدء في إضافة الرمز كما هو موضّح في القسمين التاليين. في هذا العيّنة، يجب أن يستورد مشروعك وحدتَي IDE Cloud Functions وAdmin SDK. أضِف أسطرًا مثل ما يلي إلى ملف المصدر:
Node.js
// The Cloud Functions for Firebase SDK to create Cloud Functions and triggers.
const {logger} = require("firebase-functions");
const {onRequest} = require("firebase-functions/v2/https");
const {onDocumentCreated} = require("firebase-functions/v2/firestore");
// The Firebase Admin SDK to access Firestore.
const {initializeApp} = require("firebase-admin/app");
const {getFirestore} = require("firebase-admin/firestore");
initializeApp();
Python
# The Cloud Functions for Firebase SDK to create Cloud Functions and set up triggers.
from firebase_functions import firestore_fn, https_fn
# The Firebase Admin SDK to access Cloud Firestore.
from firebase_admin import initialize_app, firestore
import google.cloud.firestore
app = initialize_app()
تحمِّل هذه الأسطر الوحدات المطلوبة و
تُنشئ مثيل تطبيق admin
يمكن من خلاله إجراء Cloud Firestore تغييرات.
في حال توفّر حزمة تطوير البرامج (SDK) الخاصة بالمسؤولين، كما هو الحال في FCM وAuthentication وFirebase Realtime Database، توفّر هذه الحزمة
طريقة فعّالة لدمج Firebase باستخدام Cloud Functions.
تثبِّت أداة Firebase CLI تلقائيًا حزمة تطوير البرامج (SDK) لخدمة "Firebase Admin SDK" وحزمة Firebase SDK لمكوّنات Cloud Functions عند بدء مشروعك. لمزيد من المعلومات حول إضافة مكتبات تابعة لجهات خارجية إلى مشروعك، يُرجى الاطّلاع على مقالة معالجة التبعيات.
إضافة الدالة add message
بالنسبة إلى الدالة "إضافة رسالة"، أضِف الأسطر التالية إلى ملف المصدر:
Node.js
// Take the text parameter passed to this HTTP endpoint and insert it into
// Firestore under the path /messages/:documentId/original
exports.addmessage = onRequest(async (req, res) => {
// Grab the text parameter.
const original = req.query.text;
// Push the new message into Firestore using the Firebase Admin SDK.
const writeResult = await getFirestore()
.collection("messages")
.add({original: original});
// Send back a message that we've successfully written the message
res.json({result: `Message with ID: ${writeResult.id} added.`});
});
Python
@https_fn.on_request()
def addmessage(req: https_fn.Request) -> https_fn.Response:
"""Take the text parameter passed to this HTTP endpoint and insert it into
a new document in the messages collection."""
# Grab the text parameter.
original = req.args.get("text")
if original is None:
return https_fn.Response("No text parameter provided", status=400)
firestore_client: google.cloud.firestore.Client = firestore.client()
# Push the new message into Cloud Firestore using the Firebase Admin SDK.
_, doc_ref = firestore_client.collection("messages").add({"original": original})
# Send back a message that we've successfully written the message
return https_fn.Response(f"Message with ID {doc_ref.id} added.")
دالة "إضافة رسالة" هي نقطة نهاية HTTP. يؤدي أي طلب إلى نقطة النهاية
إلى إنشاء كائنَي الطلب والاستجابة يتم تمريرهما إلى
معالج الطلبات لمنصتك (onRequest()
أو on_request
).
دوال HTTP متزامنة (مثل
الدوال القابلة للاستدعاء)، لذا عليك إرسال استجابة
في أسرع وقت ممكن وتأجيل العمل باستخدام Cloud Firestore. تُرسِل دالة HTTP "إضافة رسالة"
قيمة نصية إلى نقطة نهاية HTTP وتُدرجها في قاعدة بيانات
باستخدام المسار /messages/:documentId/original
.
أضِف الدالة make uppercase.
بالنسبة إلى الدالة make uppercase، أضِف الأسطر التالية إلى ملف المصدر:
Node.js
// Listens for new messages added to /messages/:documentId/original
// and saves an uppercased version of the message
// to /messages/:documentId/uppercase
exports.makeuppercase = onDocumentCreated("/messages/{documentId}", (event) => {
// Grab the current value of what was written to Firestore.
const original = event.data.data().original;
// Access the parameter `{documentId}` with `event.params`
logger.log("Uppercasing", event.params.documentId, original);
const uppercase = original.toUpperCase();
// You must return a Promise when performing
// asynchronous tasks inside a function
// such as writing to Firestore.
// Setting an 'uppercase' field in Firestore document returns a Promise.
return event.data.ref.set({uppercase}, {merge: true});
});
Python
@firestore_fn.on_document_created(document="messages/{pushId}")
def makeuppercase(event: firestore_fn.Event[firestore_fn.DocumentSnapshot | None]) -> None:
"""Listens for new documents to be added to /messages. If the document has
an "original" field, creates an "uppercase" field containg the contents of
"original" in upper case."""
# Get the value of "original" if it exists.
if event.data is None:
return
try:
original = event.data.get("original")
except KeyError:
# No "original" field, so do nothing.
return
# Set the "uppercase" field.
print(f"Uppercasing {event.params['pushId']}: {original}")
upper = original.upper()
event.data.reference.update({"uppercase": upper})
يتم تنفيذ الدالة make uppercase عند الكتابة إلى Cloud Firestore، لتحديد المستند الذي سيتم الاستماع إليه. لأسباب تتعلّق بالأداء، يجب أن تكون دقيقًا قدر الإمكان.
تحيط الأقواس، على سبيل المثال {documentId}
، بـ "المَعلمات"، وهي العناصر النائبة
التي تعرض بياناتها المطابقة في دالة "مكالمة إعادة الاتصال". يؤدي Cloud Firestore إلى بدء الإجراء المُعاد الاتصال به عند إضافة رسائل جديدة.
في Node.js، تكون الدوالّ المستندة إلى الأحداث، مثل أحداث Cloud Firestore،
غير متزامنة. يجب أن تعرِض وظيفة ردّ الاتصال إما null
أو عنصرًا
أو وعدًا.
إذا لم يتم عرض أيّ شيء، تنتهي مهلة الدالة، ما يشير إلى حدوث خطأ، ويتم إعادة المحاولة. اطّلِع على Sync وAsync وPromises.
محاكاة تنفيذ دوالّك
يتيح لك IDE Firebase Local Emulator Suite إنشاء التطبيقات واختبارها على جهازك المحلي بدلاً من نشرها على مشروع على Firebase. ننصح بشدة بإجراء الاختبار على الجهاز أثناء التطوير، ويعود السبب في ذلك جزئيًا إلى أنّه يقلل من خطر أخطاء الترميز التي قد تؤدي إلى تحمُّل تكلفة في بيئة الإنتاج (على سبيل المثال، حلقة لا نهائية).
لمحاكاة وظائفك:
شغِّل
firebase emulators:start
وتحقّق من الناتج لعنوان URL للEmulator Suite UI. الإعداد التلقائي هو localhost:4000، ولكن قد يتم استضافته على منفذ مختلف على جهازك. أدخِل عنوان URL هذا في المتصفّح لفتح Emulator Suite UI.تحقّق من ناتج الأمر
firebase emulators:start
لعنوان URL لدالة HTTP. سيبدو مشابهًا لرمزhttp://localhost:5001/MY_PROJECT/us-central1/addMessage
، باستثناء ما يلي:- سيتم استبدال
MY_PROJECT
بمعرّف مشروعك. - قد يكون المنفذ مختلفًا على جهازك المحلي.
- سيتم استبدال
أضِف سلسلة الطلب
?text=uppercaseme
إلى نهاية عنوان URL للدالة. من المفترض أن يظهر المحتوى على النحو التالي:http://localhost:5001/MY_PROJECT/us-central1/addMessage?text=uppercaseme
. يمكنك اختياريًا تغيير الرسالة "uppercaseme" إلى رسالة مخصّصة.أنشئ رسالة جديدة من خلال فتح عنوان URL في علامة تبويب جديدة في المتصفّح.
اطّلِع على تأثيرات الدوالّ في Emulator Suite UI:
في علامة التبويب السجلّات، من المفترض أن تظهر لك سجلّات جديدة تشير إلى أنّه تم تنفيذ وظائف HTTP بنجاح:
i functions: Beginning execution of "addMessage"
i functions: Beginning execution of "makeUppercase"
في علامة التبويب Firestore، من المفترض أن يظهر لك مستند يحتوي على رسالتك الأصلية بالإضافة إلى النسخة المكتوبة بأحرف كبيرة من رسالتك (إذا كانت في الأصل "uppercaseme"، ستظهر لك "UPPERCASEME").
نشر الدوالّ في بيئة الإنتاج
بعد أن تعمل وظائفك على النحو المطلوب في المحاكي، يمكنك المتابعة لطرحها واختبارها وتشغيلها في بيئة الإنتاج. يُرجى العِلم أنّه للتثبيت في قناة الإصدار العلني، يجب أن يكون مشروعك ضمن خطة أسعار Blaze. يمكنك الاطّلاع على أسعار Cloud Functions.
لإكمال البرنامج التعليمي، عليك نشر دوالّك ثم تنفيذها.
نفِّذ هذا الأمر لنشر دوالّك:
firebase deploy --only functions
بعد تنفيذ هذا الأمر، تُخرج Firebase واجهة سطر الأوامر عنوان URL لأي نقاط نهاية لدالة HTTP. من المفترض أن يظهر لك سطر مثل ما يلي في وحدة التحكّم الطرفية:
Function URL (addMessage): https://us-central1-MY_PROJECT.cloudfunctions.net/addMessage
يحتوي عنوان URL على معرّف مشروعك بالإضافة إلى منطقة لوظيفة HTTP. على الرغم من أنّه ليس عليك القلق بشأن ذلك الآن، يجب أن تحدِّد بعض وظائف HTTP في مرحلة الإنتاج موقعًا جغرافيًا لمحاولة تقليل وقت استجابة الشبكة.
إذا ظهرت لك أخطاء في الوصول مثل "تعذّر تفويض الوصول إلى project"، حاوِل التحقّق من الاسم المعرِّف للمشروع.
باستخدام عنوان URL الذي يعرضه سطر الأوامر، أضِف مَعلمة طلب بحث نصية، ثم افتح الرابط في متصفّح:
https://us-central1-MY_PROJECT.cloudfunctions.net/addMessage?text=uppercasemetoo
تنفِّذ الدالة المتصفّح وتعيد توجيهه إلىconsole Firebase في موقع قاعدة البيانات حيث يتم تخزين السلسلة النصية. يؤدي حدث الكتابة هذا إلى تنشيط الدالة make uppercase التي تكتب نسخة بالأحرف اللاتينية الكبيرة من السلسلة.
بعد نشر الدوالّ وتنفيذها، يمكنك عرض السجلات في وحدة تحكّم Google Cloud. إذا كنت بحاجة إلى حذف الدوالّ في مرحلة التطوير أو مرحلة الإنتاج، استخدِم واجهة برمجة التطبيقات Firebase.
في مرحلة الإنتاج، قد تحتاج إلى تحسين أداء الدالة والتحكّم في التكاليف من خلال ضبط الحد الأدنى والحد الأقصى لعدد النُسخ التي سيتم تشغيلها. اطّلِع على التحكّم في سلوك التوسيع للحصول على مزيد من المعلومات عن خيارات وقت التشغيل هذه.
الخطوات التالية
في هذه المستندات، يمكنك الاطّلاع على مزيد من المعلومات حول كيفية إدارة الدوالّ في Cloud Functions بالإضافة إلى كيفية معالجة جميع أنواع الأحداث المتوافقة مع Cloud Functions.
للاطّلاع على مزيد من المعلومات عن Cloud Functions، يمكنك تنفيذ ما يلي أيضًا:
- اطّلِع على حالات استخدام Cloud Functions.
- جرِّب الدرس التطبيقي حول Cloud Functions.
- مراجعة عيّنات الرموز البرمجية على GitHub وتشغيلها