يمكنك تشغيل وظيفة ردًا على تحميل الملفات والمجلدات أو تحديثها أو حذفها في Cloud Storage.
تعتمد الأمثلة في هذه الصفحة على دالة نموذجية يتم تشغيلها عند تحميل ملفات الصور إلى التخزين السحابي. توضح هذه الوظيفة النموذجية كيفية الوصول إلى سمات الحدث ، وكيفية تنزيل ملف إلى مثيل وظائف السحابة ، والأساسيات الأخرى للتعامل مع أحداث التخزين السحابي.
لمزيد من أمثلة حالات الاستخدام ، راجع ماذا يمكنني أن أفعل بوظائف السحابة؟
قم بتشغيل وظيفة على تغييرات التخزين السحابي
استخدم functions.storage
لإنشاء وظيفة تتعامل مع أحداث التخزين السحابي. اعتمادًا على ما إذا كنت تريد توسيع نطاق وظيفتك إلى حاوية تخزين سحابية معينة أو استخدام الحاوية الافتراضية ، استخدم أحد الخيارات التالية:
-
functions.storage.object()
للاستماع إلى تغييرات الكائن في حاوية التخزين السحابي الافتراضية. -
functions.storage.bucket('bucketName').object()
للاستماع إلى تغييرات الكائن في حاوية معينة.
على سبيل المثال ، يتم تحديد نطاق عينة منشئ الصور المصغرة للحاوية الافتراضية للمشروع:
exports.firstGenGenerateThumbnail = functions.storage.object().onFinalize(async (object) => { // ... });
يدعم التخزين السحابي الأحداث التالية:
- يتم إرسال
onArchive
فقط عند قيام حاوية بتمكين إصدارات الكائن . يشير هذا الحدث إلى أن الإصدار المباشر من كائن ما أصبح نسخة مؤرشفة ، إما لأنه تمت أرشفته أو لأنه تم استبداله بتحميل كائن يحمل نفس الاسم. - يتم إرسال
onDelete
عند حذف كائن نهائيًا. يتضمن ذلك الكائنات التي تم استبدالها أو حذفها كجزء من تكوين دورة حياة الحاوية. بالنسبة للحاويات التي تم تمكين تعيين إصدار لها من العناصر ، لا يتم إرسال ذلك عند أرشفة كائن (راجعonArchive
) ، حتى إذا حدثت الأرشفة عبر طريقةstorage.objects.delete
. - يتم إرسال
onFinalize
عند إنشاء كائن جديد (أو جيل جديد من كائن موجود) بنجاح في الحاوية. يتضمن ذلك نسخ أو إعادة كتابة كائن موجود. لا يؤدي التحميل الفاشل إلى تشغيل هذا الحدث. - يتم إرسال
onMetadataUpdate
عندما تتغير البيانات الأولية لكائن موجود.
قم بتعيين الحدث داخل معالج الحدث on
كما هو موضح أعلاه لـ onFinalize
.
الوصول إلى سمات كائن Cloud Storage
تعرض وظائف السحابة عددًا من سمات كائن التخزين السحابي مثل size
ونوع contentType
للملف الذي تم تحديثه. يتم زيادة خاصية "metageneration" كلما حدث تغيير في البيانات الوصفية للكائن. بالنسبة للكائنات الجديدة ، تكون قيمة metageneration
1
.
const fileBucket = object.bucket; // The Storage bucket that contains the file. const filePath = object.name; // File path in the bucket. const contentType = object.contentType; // File content type.
يستخدم نموذج إنشاء الصور المصغرة بعض هذه السمات لاكتشاف حالات الخروج التي ترجع فيها الوظيفة:
// Exit if this is triggered on a file that is not an image. if (!contentType.startsWith('image/')) { return functions.logger.log('This is not an image.'); } // Get the file name. const fileName = path.basename(filePath); // Exit if the image is already a thumbnail. if (fileName.startsWith('thumb_')) { return functions.logger.log('Already a Thumbnail.'); }
تنزيل وتحويل وتحميل ملف
في بعض الحالات ، قد لا يكون من الضروري تنزيل الملفات من Cloud Storage. ومع ذلك ، لأداء مهام مكثفة مثل إنشاء صورة مصغرة من ملف مخزن في التخزين السحابي ، تحتاج إلى تنزيل الملفات إلى مثيل الوظائف - أي الجهاز الظاهري الذي يقوم بتشغيل التعليمات البرمجية الخاصة بك.
لتنزيل الكائنات وإعادة تحميلها بسهولة إلى Cloud Storage ، قم بتثبيت حزمة Google Cloud Storage باستخدام npm install --save @google-cloud/storage
واستيرادها. لاستخدام وعود JavaScript بمعالجة العمليات الخارجية مثل مهام معالجة الصور المصغرة في العينة ، قم أيضًا باستيراد child-process-promise
:
const functions = require('firebase-functions'); const admin = require('firebase-admin'); admin.initializeApp() const path = require('path'); //library for resizing images const sharp = require('sharp');
استخدم gcs.bucket.file(filePath).download
لتنزيل ملف إلى دليل مؤقت في مثيل Cloud Functions. في هذا الموقع ، يمكنك معالجة الملف حسب الحاجة ثم تحميله إلى Cloud Storage. عند تنفيذ مهام غير متزامنة ، تأكد من إرجاع وعد JavaScript في رد الاتصال الخاص بك.
مثال: تحويل الصورة
باستخدام وظائف السحابة مع برامج معالجة الصور مثل sharp
، يمكنك إجراء عمليات معالجة على ملفات الصور الرسومية. فيما يلي مثال على كيفية إنشاء صورة مصغرة لملف صورة تم تحميلها:
// Download file from bucket. const bucket = admin.storage().bucket(fileBucket); const metadata = { contentType: contentType, }; const downloadResponse = await bucket.file(filePath).download(); const imageBuffer = downloadResponse[0]; functions.logger.log("Image downloaded!"); // Generate a thumbnail using sharp. const thumbnailBuffer = await sharp(imageBuffer).resize({ width: 200, height: 200, withoutEnlargement: true, }).toBuffer(); functions.logger.log("Thumbnail created"); // Upload the thumbnail with a 'thumb_' prefix. const thumbFileName = `thumb_${fileName}`; const thumbFilePath = path.join(path.dirname(filePath), thumbFileName); await bucket.file(thumbFilePath).save(thumbnailBuffer, { metadata: metadata, }); return functions.logger.log("Thumbnail uploaded!");
ينشئ هذا الرمز صورة مصغرة بحجم 200 × 200 للصورة المحفوظة في دليل مؤقت ، ثم يقوم بتحميلها مرة أخرى إلى التخزين السحابي.
اكتشف المزيد من الأمثلة
المزيد من الأمثلة على وظائف تحويل الوسائط الشائعة بما في ذلك تحويل الصور ، وتعديل المحتوى ، واستخراج بيانات EXIF الوصفية . القائمة الكاملة للأمثلة متاحة على GitHub.