आपका एक्सटेंशन इंस्टॉल करने वाले उपयोगकर्ताओं को, अपना एक्सटेंशन डालने की सुविधा दी जा सकती है कस्टम लॉजिक लगा सकते हैं. इसके दो तरीके हैं इसे पूरा करें:
Eventarc इवेंट: इसकी मदद से, उपयोगकर्ताओं को एसिंक्रोनस तरीके से प्रतिक्रिया देने का तरीका बताया जाता है की सुविधा वाले इवेंट, Eventarc पर पब्लिश किए जा सकते हैं. उपयोगकर्ता इवेंट हैंडलर डिप्लॉय कर सकते हैं उदाहरण के लिए, ऐसे फ़ंक्शन जो लंबे समय तक चलने के बाद सूचनाएं भेजते हैं टास्क पूरे हो चुके हैं या वे अपने पोस्ट-प्रोसेसिंग फ़ंक्शन तय कर सकते हैं.
सिंक्रोनस हुक: इसकी मदद से, उपयोगकर्ता आपके डिवाइस पर ब्लॉक करने वाला लॉजिक जोड़ सकते हैं एक्सटेंशन, तो आप एक्सटेंशन की कार्रवाई. इन बिंदुओं पर, आप user-provider फ़ंक्शन चलाते हैं पूरा होने के बाद ही आगे बढ़ें. प्रोसेस से पहले के टास्क आम तौर पर यह कैटगरी.
एक्सटेंशन, इनमें से किसी एक या दोनों तरीकों का इस्तेमाल कर सकता है.
इवेंटआर्क इवेंट
किसी एक्सटेंशन के इवेंट पब्लिश करने के लिए:
extension.yaml
फ़ाइल में बताएं कि आपको किस तरह के इवेंट पब्लिश करने हैं:events: - type: publisher-id.extension-name.version.event-name description: event-description - type: publisher-id.extension-name.version.another-event-name description: another-event-description
type
आइडेंटिफ़ायर, डॉट-डीलिमिटेड फ़ील्ड से बना होता है. कॉन्टेंट बनाने पब्लिशर आईडी, एक्सटेंशन का नाम, और इवेंट के नाम वाले फ़ील्ड आवश्यक. वर्शन फ़ील्ड का सुझाव दिया जाता है. कोई यूनीक और जानकारी देने वाला विकल्प चुनें पब्लिश किए जाने वाले हर इवेंट टाइप के लिए, इवेंट का नाम डालें.उदाहरण के लिए,
storage-resize-images
एक्सटेंशन किसी एक इवेंट टाइप का एलान करता है:events: - type: firebase.extensions.storage-resize-images.v1.complete description: | Occurs when image resizing completes. The event will contain further details about specific formats and sizes.
उपयोगकर्ता अपने हिसाब से यह चुन सकते हैं कि किन इवेंट की सदस्यता लेनी है उस एक्सटेंशन को इंस्टॉल करना होगा.
अपने एक्सटेंशन फ़ंक्शन में, Admin SDK से Eventarc API इंपोर्ट करें और उपयोगकर्ता की इंस्टॉलेशन सेटिंग का इस्तेमाल करके इवेंट चैनल को शुरू करें. ये सेटिंग, यहां दिए गए एनवायरमेंट वैरिएबल का इस्तेमाल करके दिखती हैं:
EVENTARC_CHANNEL
: इसके लिए, Eventarc चैनल का पूरी तरह क्वालिफ़ाइड नाम जिसे उपयोगकर्ता ने इवेंट पब्लिश करने के लिए चुना है.EXT_SELECTED_EVENTS
: इवेंट के टाइप की ऐसी सूची जिसमें उपयोगकर्ता को कॉमा लगाकर अलग किया गया हो पब्लिश करने का विकल्प चुना है. इस वैल्यू के साथ किसी चैनल की शुरुआत करने पर, एडमिन SDK टूल, उन इवेंट को अपने-आप फ़िल्टर कर देता है जिन्हें उपयोगकर्ता ने नहीं चुना है.EVENTARC_CLOUD_EVENT_SOURCE
: क्लाउड इवेंट का सोर्स आइडेंटिफ़ायर. कॉन्टेंट बनाने Admin SDK टूल, इस वैल्यू को इसकेsource
फ़ील्ड में अपने-आप पास करता है पब्लिश किए गए इवेंट. आम तौर पर, आपको साफ़ तौर पर इसका इस्तेमाल करने की ज़रूरत नहीं है वैरिएबल.
अगर इंस्टॉलेशन के दौरान इवेंट चालू नहीं किए गए थे, तो ये वैरिएबल तय नहीं है. इस तथ्य का इस्तेमाल इवेंट चैनल को शुरू करने के लिए सिर्फ़ तब किया जा सकता है, जब इवेंट चालू हैं:
import * as admin from "firebase-admin"; import {getEventarc} from 'firebase-admin/eventarc'; admin.initializeApp(); // Set eventChannel to a newly-initialized channel, or `undefined` if events // aren't enabled. const eventChannel = process.env.EVENTARC_CHANNEL && getEventarc().channel(process.env.EVENTARC_CHANNEL, { allowedEventTypes: process.env.EXT_SELECTED_EVENTS, });
एक्सटेंशन में, अपनी पसंद की जगहों पर चैनल पर इवेंट पब्लिश करें सार्वजनिक तौर पर शेयर किया जा सकता है. उदाहरण के लिए:
// If events are enabled, publish a `complete` event to the configured // channel. eventChannel && eventChannel.publish({ type: 'firebase.extensions.storage-resize-images.v1.complete', subject: filename, // the name of the original file data: { // ... } });
अपने पब्लिश किए गए इवेंट के दस्तावेज़, PREINSTALL या POSTINSTALL में रखें फ़ाइल से लिए जाते हैं.
हर इवेंट के लिए, यहां दी गई जानकारी का दस्तावेज़ बनाएं:
- कॉन्टेंट का मकसद
- आपके एक्सटेंशन के लॉजिक में इस्तेमाल किया जाने वाला पॉइंट
- इसमें शामिल आउटपुट डेटा
- इसके निष्पादन की शर्तें
इसके अलावा, उपयोगकर्ताओं को चेतावनी दें कि वे अपने इवेंट में कोई भी कार्रवाई न करें ऐसे हैंडलर जो एक ही एक्सटेंशन को ट्रिगर कर सकते हैं, जिससे एक अनंत लूप.
किसी एक्सटेंशन से इवेंट पब्लिश करने पर, उपयोगकर्ता इवेंट हैंडलर डिप्लॉय कर सकते हैं का इस्तेमाल करें.
उदाहरण के लिए, नीचे दिए गए उदाहरण में, ओरिजनल इमेज को अपलोड करने के बाद, उसे मिटा दिया जाता है
आकार बदला गया. ध्यान दें कि यह उदाहरण हैंडलर subject
प्रॉपर्टी
इवेंट डालें. इस मामले में यह इमेज का ओरिजनल नाम है.
exports.onimageresized = onCustomEventPublished(
"firebase.extensions.storage-resize-images.v1.complete",
(event) => {
logger.info("Received image resize completed event", event);
// For example, delete the original.
return admin.storage()
.bucket("my-project.appspot.com")
.file(event.subject)
.delete();
});
ज़्यादा जानकारी के लिए कस्टम इवेंट ट्रिगर देखें जानकारी.
उदाहरण
आधिकारिक साइज़ इमेज एक्सटेंशन Eventarc में पब्लिश करके, एसिंक्रोनस हुक इस्तेमाल करता है का साइज़ बदलने के बाद,
सिंक्रोनस हुक
जब आप उपयोगकर्ताओं को ऐसा हुक देना चाहते हों जिसे सही तरीके से पूरा होना चाहिए किसी एक्सटेंशन फ़ंक्शन को चलाने के लिए, सिंक्रोनस हुक का इस्तेमाल करें.
सिंक्रोनस हुक, उपयोगकर्ता के तय किए गए एचटीटीपीएस कॉल किए जा सकने वाले क्लाउड को कॉल करता है फ़ंक्शन को बेहतर बनाने के लिए और पूरा होने का इंतज़ार कर रहा है (संभावित रूप से जारी रखने से पहले, रिटर्न वैल्यू) जोड़ें. उपयोगकर्ता के उपलब्ध कराए गए फ़ंक्शन में कोई गड़बड़ी हुई एक्सटेंशन फ़ंक्शन में कोई गड़बड़ी दिखाता है.
सिंक्रोनस हुक को दिखाने के लिए:
अपने एक्सटेंशन में ऐसा पैरामीटर जोड़ें जिससे उपयोगकर्ता, एक्सटेंशन मौजूद है. उदाहरण के लिए:
- param: PREPROCESSING_FUNCTION label: Pre-processing function URL description: > An HTTPS callable function that will be called to transform the input data before it is processed by this function. type: string example: https://us-west1-my-project-id.cloudfunctions.net/preprocessData required: false
अपने एक्सटेंशन में जहां से आप हुक को एक्सपोज़ करना चाहते हैं, वहां फ़ंक्शन को एक्ज़ीक्यूट करने की ज़रूरत नहीं है. उदाहरण के लिए:
const functions = require('firebase-functions/v1'); const fetch = require('node-fetch'); const preprocessFunctionURL = process.env.PREPROCESSING_FUNCTION; exports.yourFunctionName = functions.firestore.document("collection/{doc_id}") .onWrite((change, context) => { // PREPROCESSING_FUNCTION hook begins here. // If a preprocessing function is defined, call it before continuing. if (preprocessFunctionURL) { try { await fetch(preprocessFunctionURL); // Could also be a POST request if you want to send data. } catch (e) { // Preprocessing failure causes the function to fail. functions.logger.error("Preprocessor error:", e); return; } } // End of PREPROCESSING_FUNCTION hook. // Main function logic follows. // ... });
उपलब्ध कराए गए किसी भी हुक को PREINSTALL या POSTINSTALL फ़ाइल में शामिल किया जाना चाहिए.
हर हुक के लिए, इन बातों का ध्यान रखें:
- कॉन्टेंट का मकसद
- आपके एक्सटेंशन के लॉजिक में इस्तेमाल किया जाने वाला पॉइंट
- इसके आने वाले इनपुट और आउटपुट
- इसके निष्पादन की शर्तें (या विकल्प)
इसके अलावा, उपयोगकर्ताओं को चेतावनी दें कि वे कोई भी कार्रवाई न करें एक ही एक्सटेंशन को ट्रिगर कर सकता है, जिससे एक अनंत लूप.
उदाहरण
Algolia Search एक्सटेंशन उपयोगकर्ता से मिले ट्रांसफ़ॉर्म फ़ंक्शन को कॉल करने के लिए एक सिंक्रोनस हुक उपलब्ध कराता है लिखने से पहले आपने उसे Algolia पर लिखा होगा.