1. शुरू करने से पहले
इस कोडलैब में, आपको एआई की मदद से काम करने वाले ऐसे वेब ऐप्लिकेशन बनाने का तरीका पता चलेगा जो Firebase एक्सटेंशन का इस्तेमाल करके, उपयोगकर्ताओं का ध्यान खींचने वाला दिलचस्प अनुभव देते हैं.
ज़रूरी शर्तें
- Node.js और JavaScript की जानकारी
आपको यह जानकारी मिलेगी
- भाषा और वीडियो इनपुट को प्रोसेस करने के लिए, एआई से जुड़े एक्सटेंशन इस्तेमाल करने का तरीका.
- एक्सटेंशन के बीच एक पाइपलाइन बनाने के लिए, Firebase के लिए Cloud Functions इस्तेमाल करने का तरीका.
- एक्सटेंशन से मिलने वाले आउटपुट को ऐक्सेस करने के लिए, JavaScript का इस्तेमाल कैसे करें.
आपको इन चीज़ों की ज़रूरत होगी
- आपकी पसंद का ब्राउज़र, जैसे कि Google Chrome
- कोड एडिटर और टर्मिनल वाला डेवलपमेंट एनवायरमेंट
- आपके Firebase प्रोजेक्ट को बनाने और मैनेज करने के लिए Google खाता
2. वेब ऐप्लिकेशन और उनकी Firebase सेवाओं की समीक्षा करें
इस सेक्शन में उन वेब ऐप्लिकेशन की जानकारी दी गई है जिन्हें इस कोडलैब में बनाया जाएगा. साथ ही, यह भी बताया गया है कि उन्हें बनाने के लिए किस Firebase का इस्तेमाल किया जाएगा.
समीक्षा करने वाला ऐप्लिकेशन
एक टी-शर्ट कंपनी, अपनी किसी टी-शर्ट के बारे में लंबे-लंबे समीक्षा और उसकी पूरी रेटिंग के बारे में पक्के तौर पर नहीं जानते. पूरी तरह से तैयार Reviewly वेब ऐप्लिकेशन में, हर समीक्षा की खास जानकारी दी जाती है, हर समीक्षा के लिए स्टार रेटिंग दी जाती है, और प्रॉडक्ट की कुल रेटिंग का अनुमान लगाने के लिए हर समीक्षा का इस्तेमाल किया जाता है. मूल समीक्षा देखने के लिए, उपयोगकर्ता खास जानकारी वाली हर समीक्षा को बड़ा भी कर सकते हैं.
सेवा | इस्तेमाल करने की वजह |
हर समीक्षा के टेक्स्ट को स्टोर करें. इसके बाद, एक्सटेंशन की मदद से समीक्षा को प्रोसेस किया जाता है. | |
Firebase सेवाओं का ऐक्सेस सुरक्षित रखने के लिए, सुरक्षा नियम लागू करें. | |
वेब ऐप्लिकेशन में नकली समीक्षाएं जोड़ें. | |
Firestore में जोड़ी गई हर समीक्षा की खास जानकारी देने के लिए, PaLM API के साथ भाषा टास्क एक्सटेंशन को इंस्टॉल, कॉन्फ़िगर, और ट्रिगर करें |
Chatbot ऐप्लिकेशन
किसी स्कूल का शिक्षक, सामान्य विषयों के बारे में बार-बार पूछे जाने वाले सवालों से बहुत परेशान होता है. इसलिए, वह अपने-आप जवाब देने की सुविधा चाहता है. इस ऐप्लिकेशन में, चैटबॉट की मदद से छात्र-छात्राओं को बातचीत करने के लिए एक चैटबॉट बनाया गया है. यह लार्ज लैंग्वेज मॉडल (एलएलएम) का इस्तेमाल करके, सामान्य विषयों से जुड़े सवालों के जवाब दे सकता है. चैटबॉट का इतिहास काफ़ी पुराना होता है. इसलिए, इसके जवाबों के आधार पर यह देखा जा सकता है कि छात्र-छात्राओं ने एक ही बातचीत में पिछले सवाल कैसे पूछे थे.
सेवा | इस्तेमाल करने की वजह |
उपयोगकर्ताओं को मैनेज करने के लिए, 'Google से साइन इन करें' सुविधा का इस्तेमाल करें. | |
हर बातचीत का टेक्स्ट सेव करें; उपयोगकर्ताओं के मैसेज को किसी एक्सटेंशन के ज़रिए प्रोसेस किया जाता है. | |
Firebase सेवाओं का ऐक्सेस सुरक्षित रखने के लिए, सुरक्षा नियम लागू करें. | |
PaLM API के साथ चैटबॉट एक्सटेंशन को इंस्टॉल, कॉन्फ़िगर, और ट्रिगर करें, ताकि Firestore में नया मैसेज जोड़े जाने पर जवाब दिया जा सके | |
ऐप्लिकेशन को स्थानीय तौर पर चलाने के लिए, Local Emulator Suite का इस्तेमाल करें. | |
ऐप्लिकेशन इंस्टॉल करने के लिए, होस्टिंग के साथ वेब फ़्रेमवर्क का इस्तेमाल करें. |
वीडियो हिंट ऐप्लिकेशन
एक सरकारी विभाग चाहता है कि उसके वीडियो में, जानकारी सुनने की सुविधा उपलब्ध हो, ताकि उसे आसानी से ऐक्सेस किया जा सके. हालांकि, इसके लिए सैकड़ों वीडियो मौजूद हैं, जिनकी व्याख्या करने के लिए यह तरीका अपनाया जा सकता है. तैयार हो चुका वीडियो हिंट ऐप्लिकेशन एक प्रोटोटाइप है, जिसकी समीक्षा विभाग इसके असर का आकलन करने के लिए करेगा.
सेवा | इस्तेमाल करने की वजह |
उपयोगकर्ताओं को मैनेज करने के लिए, 'Google से साइन इन करें' सुविधा का इस्तेमाल करें. | |
हर वीडियो की खास जानकारी का टेक्स्ट सेव करें. | |
वीडियो और JSON फ़ाइलों को, वीडियो के ब्यौरे के साथ सेव करें. | |
Firebase सेवाओं का ऐक्सेस सुरक्षित रखने के लिए, सुरक्षा नियम लागू करें. | |
विभिन्न एक्सटेंशन को इंस्टॉल, कॉन्फ़िगर और ट्रिगर करें (नीचे सूची देखें). | |
Cloud Functions की मदद से एक्सटेंशन के बीच एक पाइपलाइन बनाएं. | |
ऐप्लिकेशन को स्थानीय तौर पर चलाने के लिए, Local Emulator Suite का इस्तेमाल करें. | |
ऐप्लिकेशन इंस्टॉल करने के लिए, होस्टिंग के साथ वेब फ़्रेमवर्क का इस्तेमाल करें. |
वीडियो हिंट ऐप्लिकेशन में इन एक्सटेंशन का इस्तेमाल किया जाता है:
- Cloud Video AI की मदद से वीडियो को लेबल करें — यह एक्सटेंशन, स्टोरेज में अपलोड किए गए हर वीडियो से लेबल एक्सट्रैक्ट कर सकता है.
- PLM API की मदद से, भाषा से जुड़े टास्क — यह लेबल की खास जानकारी को टेक्स्ट के रूप में दिखाता है.
- टेक्स्ट को बोली में बदलें एक्सटेंशन — वीडियो के ब्यौरे का ऑडियो वर्शन बनाएं.
3. अपना डेवलपमेंट एनवायरमेंट सेट अप करें
अपने Node.js वर्शन की पुष्टि करें
- अपने टर्मिनल में, पुष्टि करें कि आपने Node.js v20.0.0 या उसके बाद का वर्शन इंस्टॉल किया हुआ है:
node -v
- अगर आपके पास Node.js v20.0.0 या इसके बाद का वर्शन नहीं है, तो इसे डाउनलोड करके इंस्टॉल करें.
डेटा स्टोर करने की जगह डाउनलोड करना
- अगर आपने git इंस्टॉल किया है, तो कोडलैब के GitHub रिपॉज़िटरी का क्लोन बनाएं:
git clone https://github.com/FirebaseExtended/ai-extensions-codelab.git
- अगर आपने git इंस्टॉल नहीं किया है, तो GitHub रिपॉज़िटरी को ZIP फ़ाइल के तौर पर डाउनलोड करें.
फ़ोल्डर के स्ट्रक्चर की समीक्षा करें
अपने कंप्यूटर पर, क्लोन किया गया डेटा स्टोर करने की जगह ढूंढें और फ़ोल्डर के स्ट्रक्चर की समीक्षा करें. नीचे दी गई टेबल में फ़ोल्डर और उनकी जानकारी मौजूद है:
फ़ोल्डर | जानकारी |
| Reviewly वेब ऐप्लिकेशन के लिए स्टार्टर कोड |
| Reviewly वेब ऐप्लिकेशन का समाधान कोड |
| Chatbot वेब ऐप्लिकेशन के लिए स्टार्टर कोड |
| Chatbot के वेब ऐप्लिकेशन के लिए सलूशन का कोड |
| वीडियो हिंट वेब ऐप्लिकेशन के लिए स्टार्टर कोड |
| वीडियो हिंट वाले वेब ऐप्लिकेशन के लिए सलूशन कोड |
हर फ़ोल्डर में एक readme.md
फ़ाइल होती है, जो स्ट्रीमलाइन किए गए निर्देशों का पालन करके, अपने वेब ऐप्लिकेशन को आसानी से चलाने का विकल्प देती है. हालांकि, अगर आप पहली बार सीखने वाले हैं, तो आपको इस कोडलैब को पूरा करना चाहिए, क्योंकि इसमें निर्देशों का सबसे बेहतर सेट शामिल है.
अगर आपको नहीं पता कि इस कोडलैब के दौरान दिए गए निर्देशों के मुताबिक, आपने कोड को सही तरीके से लागू किया है या नहीं, तो reviewly-end
, chatbot-end
, और video-hint-end
फ़ोल्डर में इसका समाधान कोड देखा जा सकता है.
Firebase सीएलआई इंस्टॉल करें
नीचे दिया गया कमांड चलाकर पुष्टि करें कि आपने Firebase सीएलआई इंस्टॉल किया है और वह v12.5.4 या उसके बाद का है:
firebase --version
- अगर आपने Firebase सीएलआई इंस्टॉल किया है, लेकिन वह v12.5.4 या उसके बाद का वर्शन नहीं है, तो उसे अपडेट करें:
npm update -g firebase-tools
- अगर आपने Firebase सीएलआई इंस्टॉल नहीं किया है, तो इसे इंस्टॉल करें:
npm install -g firebase-tools
अगर अनुमति की गड़बड़ियों की वजह से Firebase सीएलआई इंस्टॉल नहीं हो पा रहा है, तो एनपीएम से जुड़ा दस्तावेज़ देखें या किसी दूसरे इंस्टॉलेशन के विकल्प का इस्तेमाल करें.
Firebase में लॉग इन करें
- अपने टर्मिनल में,
ai-extensions-codelab
फ़ोल्डर पर जाएं और Firebase में लॉग इन करें:cd ai-extensions-codelab firebase login
- अगर आपके टर्मिनल का कहना है कि आपने पहले से ही Firebase में लॉग इन किया हुआ है, तो इस कोडलैब के अपना Firebase प्रोजेक्ट सेट अप करें सेक्शन पर जाएं.
- आप Firebase में डेटा इकट्ठा करना चाहते हैं या नहीं, इसके आधार पर
Y
याN
डालें. - अपने ब्राउज़र में, अपना Google खाता चुनें. इसके बाद, अनुमति दें पर क्लिक करें.
4. अपना Firebase प्रोजेक्ट सेट अप करना
इस सेक्शन में, Firebase प्रोजेक्ट सेट अप किया जाएगा और उसके साथ Firebase वेब ऐप्लिकेशन जोड़ा जाएगा. आपको उन Firebase सेवाओं को भी चालू करना होगा जिनका इस्तेमाल सैंपल वेब ऐप्लिकेशन में किया गया है.
Firebase प्रोजेक्ट बनाना
- Firebase कंसोल में प्रोजेक्ट बनाएं पर क्लिक करें.
- अपने प्रोजेक्ट का नाम डालें टेक्स्ट बॉक्स में,
AI Extensions Codelab
(या अपनी पसंद का प्रोजेक्ट नाम) डालें. इसके बाद, जारी रखें पर क्लिक करें. - इस कोडलैब के लिए, आपको Google Analytics की ज़रूरत नहीं है. इसलिए, इस प्रोजेक्ट के लिए Google Analytics चालू करें विकल्प को टॉगल करके बंद कर दें.
- प्रोजेक्ट बनाएं पर क्लिक करें.
- अपने प्रोजेक्ट के प्रावधान होने का इंतज़ार करें. इसके बाद, जारी रखें पर क्लिक करें.
- Firebase प्रोजेक्ट में, प्रोजेक्ट सेटिंग पर जाएं. अपना प्रोजेक्ट आईडी नोट कर लें, क्योंकि आपको बाद में इसकी ज़रूरत है. इस यूनीक आइडेंटिफ़ायर की मदद से, आपके प्रोजेक्ट की पहचान की जाती है. उदाहरण के लिए, Firebase सीएलआई में.
Firebase सेवा खाता डाउनलोड करना
इस कोडलैब में बनाए गए कुछ वेब ऐप्लिकेशन, Next.js के साथ सर्वर साइड रेंडरिंग का इस्तेमाल करते हैं.
Node.js के लिए Firebase एडमिन SDK का इस्तेमाल करके यह पक्का किया जाता है कि सुरक्षा के नियम, सर्वर साइड कोड से काम करते हैं. Firebase एडमिन में एपीआई का इस्तेमाल करने के लिए, आपको Firebase कंसोल से Firebase सेवा खाता डाउनलोड करना होगा.
- Firebase कंसोल में, अपने प्रोजेक्ट सेटिंग में सेवा खाते पेज पर जाएं.
- नई निजी कुंजी जनरेट करें पर क्लिक करें > कुंजी जनरेट करें.
- अपने फ़ाइल सिस्टम में फ़ाइल डाउनलोड होने के बाद, उस फ़ाइल का पूरा पाथ पाएं.
उदाहरण के लिए, अगर आपने फ़ाइल को डाउनलोड फ़ोल्डर में डाउनलोड किया है, तो पूरा पाथ इस तरह से दिख सकता है:/Users/me/Downloads/my-project-id-firebase-adminsdk-123.json
- अपने टर्मिनल में,
GOOGLE_APPLICATION_CREDENTIALS
एनवायरमेंट वैरिएबल को डाउनलोड की गई निजी कुंजी के पाथ पर सेट करें. यूनिक्स एनवायरमेंट में, निर्देश इस तरह दिख सकता है:export GOOGLE_APPLICATION_CREDENTIALS="/Users/me/Downloads/my-project-id-firebase-adminsdk-123.json"
- इस टर्मिनल को खुला रखें और कोडलैब के बाकी बचे हिस्से के लिए इसका इस्तेमाल करें. नया टर्मिनल सेशन शुरू करने पर, एनवायरमेंट वैरिएबल मिट सकता है.
अगर कोई नया टर्मिनल सेशन खोला जाता है, तो आपको पिछले निर्देश को फिर से चलाना होगा.
Firebase प्राइसिंग प्लान को अपग्रेड करना
Cloud Functions और Firebase एक्सटेंशन का इस्तेमाल करने के लिए, आपका Firebase प्रोजेक्ट ब्लेज़ प्राइसिंग प्लान पर होना चाहिए. इसका मतलब है कि यह प्रोजेक्ट किसी क्लाउड बिलिंग खाते से जुड़ा है.
- क्लाउड बिलिंग खाते के लिए, पेमेंट का कोई तरीका ज़रूरी है, जैसे कि क्रेडिट कार्ड.
- अगर आपने Firebase और Google Cloud का इस्तेमाल पहले कभी नहीं किया है, तो देखें कि आपको 300 डॉलर का क्रेडिट और मुफ़्त में आज़माने वाला क्लाउड बिलिंग खाता मिल सकता है या नहीं.
हालांकि, ध्यान रखें कि इस कोडलैब के पूरा होने पर कोई असल शुल्क नहीं लगेगा.
अपने प्रोजेक्ट को Blaze प्लान में अपग्रेड करने के लिए, यह तरीका अपनाएं:
- Firebase कंसोल में, अपना प्लान अपग्रेड करें चुनें.
- डायलॉग बॉक्स में, ब्लेज़ प्लान चुनें. इसके बाद, अपने प्रोजेक्ट को क्लाउड बिलिंग खाते से जोड़ने के लिए, स्क्रीन पर दिए गए निर्देशों का पालन करें.
अगर आपको क्लाउड बिलिंग खाता बनाना है, तो अपग्रेड पूरा करने के लिए 'Firebase कंसोल' में अपग्रेड फ़्लो पर वापस जाना पड़ सकता है.
Firebase कंसोल में Firebase सेवाएं सेट अप करें
इस सेक्शन में, आपको इस कोडलैब में मौजूद वेब ऐप्लिकेशन की ओर से इस्तेमाल की जाने वाली कई Firebase सेवाओं का प्रावधान और उन्हें सेट अप करने का विकल्प मिलेगा. ध्यान दें कि इन सभी सेवाओं का इस्तेमाल हर वेब ऐप्लिकेशन में नहीं किया जाता है. हालांकि, इस कोडलैब के ज़रिए काम करने के लिए, इन सभी सेवाओं को अभी सेट अप करना एक आसान सुविधा है.
पुष्टि करने की सुविधा सेट अप करें
आप Chatbot ऐप्लिकेशन और वीडियो हिंट ऐप्लिकेशन, दोनों के साथ पुष्टि करने की सुविधा का इस्तेमाल करेंगे. याद रखें कि अगर आपको असली ऐप्लिकेशन बनाना है, तो हर ऐप्लिकेशन का अपना Firebase प्रोजेक्ट होना चाहिए.
- Firebase कंसोल में, पुष्टि करने की सुविधा पर जाएं.
- शुरू करें पर क्लिक करें.
- अन्य कंपनी कॉलम में, Google > चालू करें.
- प्रोजेक्ट को सभी के लिए उपलब्ध कराने वाला नाम टेक्स्ट बॉक्स में, याद रहने वाला कोई नाम डालें, जैसे कि
My AI Extensions Codelab
. - प्रोजेक्ट के लिए सहायता ईमेल ड्रॉप-डाउन से, अपना ईमेल पता चुनें.
- सेव करें पर क्लिक करें.
Cloud Firestore सेट अप करना
आप तीनों ऐप्लिकेशन के साथ Firestore का इस्तेमाल करेंगे. याद रखें कि अगर आपको असली ऐप्लिकेशन बनाना है, तो हर ऐप्लिकेशन का अपना Firebase प्रोजेक्ट होना चाहिए.
- Firebase कंसोल में, Firestore पर जाएं.
- डेटाबेस बनाएं > परीक्षण मोड में प्रारंभ करें > अगला चरण.
इस कोडलैब में, बाद में अपने डेटा को सुरक्षित रखने के लिए सुरक्षा के नियम जोड़े जा सकते हैं. अपने डेटाबेस के लिए सुरक्षा के नियम जोड़े बिना, किसी ऐप्लिकेशन को सार्वजनिक रूप से उपलब्ध न करें या उसे सार्वजनिक न करें. - डिफ़ॉल्ट जगह की जानकारी का इस्तेमाल करें या अपनी पसंद की जगह चुनें.
असल ऐप्लिकेशन के लिए, आपको ऐसी जगह चुननी है जो आपके उपयोगकर्ताओं के आस-पास हो. ध्यान दें कि बाद में इस जगह की जानकारी को नहीं बदला जा सकता. यह अपने-आप आपके डिफ़ॉल्ट Cloud Storage बकेट की जगह पर सेव हो जाएगी (अगला चरण). - हो गया पर क्लिक करें.
Firebase के लिए Cloud Storage सेट अप करना
आपको वीडियो हिंट ऐप्लिकेशन के साथ Cloud Storage का इस्तेमाल करना होगा और टेक्स्ट को बोली में बदलें एक्सटेंशन (कोडलैब का अगला चरण) आज़माने के लिए भी इस्तेमाल करना होगा.
- Firebase कंसोल में, स्टोरेज पर जाएं.
- शुरू करें > परीक्षण मोड में प्रारंभ करें > अगला चरण.
इस कोडलैब में, बाद में अपने डेटा को सुरक्षित रखने के लिए सुरक्षा के नियम जोड़े जा सकते हैं. अपनी स्टोरेज बकेट के लिए सुरक्षा नियम जोड़े बिना, किसी ऐप्लिकेशन को सार्वजनिक रूप से डिस्ट्रिब्यूट या सार्वजनिक किए बिना न दिखाएं. - आपके बकेट की जगह पहले से ही चुनी जानी चाहिए (पिछले चरण में Firestore सेट करने की वजह से).
- हो गया पर क्लिक करें.
इस कोडलैब के अगले सेक्शन में, आपको इस कोडलैब के कोडलैब में एक्सटेंशन इंस्टॉल करने होंगे और हर सैंपल ऐप्लिकेशन के कोड बेस में बदलाव करना होगा, ताकि तीन अलग-अलग वेब ऐप्लिकेशन काम कर सकें.
5. "PaLM API की मदद से भाषा टास्क" सेट अप करना के लिए एक्सटेंशन समीक्षा करने वाला ऐप्लिकेशन
PLM API के साथ भाषा Tasks एक्सटेंशन इंस्टॉल करें
- PLM API की मदद से, भाषा Tasks एक्सटेंशन पर जाएं.
- Firebase कंसोल में इंस्टॉल करें पर क्लिक करें.
- अपना Firebase प्रोजेक्ट चुनें.
- चालू किए गए एपीआई और बनाए गए संसाधनों की समीक्षा करें सेक्शन में, आपको सुझाई गई किसी भी सेवा के आगे चालू करें पर क्लिक करें:
- अगला > आगे बढ़ें.
- कलेक्शन पाथ टेक्स्ट बॉक्स में,
bot
डालें. - प्रॉम्प्ट टेक्स्ट बॉक्स में,
{{ input }}
डालें. - वैरिएबल फ़ील्ड टेक्स्ट बॉक्स में,
input
डालें. - रिस्पॉन्स फ़ील्ड के टेक्स्ट बॉक्स में,
text
डालें. - Cloud Functions की जगह वाले ड्रॉप-डाउन से, Iowa (us-central1) या वह जगह चुनें जिसे आपने Firestore और Cloud Storage के लिए पहले चुना था.
- Language Model ड्रॉप-डाउन से, text-bison-001 चुनें.
- दूसरी सभी वैल्यू को डिफ़ॉल्ट वैल्यू के तौर पर रहने दें.
- एक्सटेंशन इंस्टॉल करें पर क्लिक करें. इसके बाद, एक्सटेंशन इंस्टॉल होने का इंतज़ार करें.
Palm API के साथ भाषा से जुड़े टास्क एक्सटेंशन आज़माएं
इस कोडलैब का मकसद किसी वेब ऐप्लिकेशन की मदद से, PaLM API के साथ भाषा टास्क एक्सटेंशन के साथ इंटरैक्ट करना है. हालांकि, Firebase कंसोल का इस्तेमाल करके एक्सटेंशन को ट्रिगर करने से, एक्सटेंशन के काम करने का तरीका समझने में मदद मिलती है. bot
कलेक्शन में Cloud Firestore दस्तावेज़ जोड़े जाने पर एक्सटेंशन ट्रिगर होता है.
यह देखने के लिए कि Firebase कंसोल का इस्तेमाल करके एक्सटेंशन कैसे काम करता है, इन चरणों का पालन करें:
- Firebase कंसोल में, Firestore पर जाएं.
bot
कलेक्शन में, दस्तावेज़ जोड़ें पर क्लिक करें.- दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो-आईडी पर क्लिक करें.
- फ़ील्ड टेक्स्ट बॉक्स में,
input
डालें. - वैल्यू टेक्स्ट बॉक्स में,
Tell me about the moon
डालें. - सेव करें पर क्लिक करें और कुछ सेकंड इंतज़ार करें.
bot
कलेक्शन में मौजूद आपके दस्तावेज़ में अब आपकी क्वेरी का जवाब शामिल है.
6. Firebase का इस्तेमाल करने के लिए, Reviewly ऐप्लिकेशन सेट अप करें
Reviewly ऐप्लिकेशन को चलाने के लिए, आपको अपने ऐप्लिकेशन का कोड और Firebase सीएलआई सेट अप करना होगा, ताकि आप अपने Firebase प्रोजेक्ट के साथ इंटरैक्ट कर सकें.
अपने ऐप्लिकेशन के कोड में Firebase की सेवाएं और कॉन्फ़िगरेशन जोड़ें
Firebase का इस्तेमाल करने के लिए, आपके ऐप्लिकेशन के कोडबेस को उन सेवाओं के लिए Firebase SDK टूल की ज़रूरत होती है जिनका आप इस्तेमाल करना चाहते हैं. साथ ही, Firebase कॉन्फ़िगरेशन जो उन SDK टूल को यह बताता है कि किस Firebase प्रोजेक्ट का इस्तेमाल करना है.
इस कोडलैब के सैंपल ऐप्लिकेशन में, SDK टूल के लिए सभी ज़रूरी इंपोर्ट और शुरू करने के कोड पहले से ही शामिल हैं (reviewly-start/js/reviews.js
देखें). इसलिए, आपको इन्हें जोड़ने की ज़रूरत नहीं है. हालांकि, सैंपल ऐप्लिकेशन में Firebase कॉन्फ़िगरेशन के लिए सिर्फ़ प्लेसहोल्डर वैल्यू होती हैं (reviewly-start/js/firebase-config.js
देखें). इसलिए, आपको अपने ऐप्लिकेशन के लिए Firebase कॉन्फ़िगरेशन की यूनीक वैल्यू पाने के लिए, अपने ऐप्लिकेशन को Firebase प्रोजेक्ट के साथ रजिस्टर करना होगा.
- Firebase कंसोल में, अपने Firebase प्रोजेक्ट में प्रोजेक्ट की खास जानकारी पर जाएं. इसके बाद, वेब पर क्लिक करें.
- ऐप्लिकेशन का कोई दूसरा नाम टेक्स्ट बॉक्स में, ऐप्लिकेशन के लिए कोई याद रखने लायक नाम डालें, जैसे कि
My Reviewly app
. - इस ऐप्लिकेशन के लिए Firebase होस्टिंग की सुविधा भी सेट अप करें चेकबॉक्स को न चुनें. कोडलैब में इन चरणों को बाद में पूरा किया जा सकेगा.
- ऐप्लिकेशन रजिस्टर करें पर क्लिक करें.
- कंसोल, Firebase SDK टूल को ऐप्लिकेशन के हिसाब से बने Firebase कॉन्फ़िगरेशन ऑब्जेक्ट के साथ जोड़ने और शुरू करने के लिए, एक कोड स्निपेट दिखाता है. Firebase कॉन्फ़िगरेशन ऑब्जेक्ट में सभी प्रॉपर्टी कॉपी करें.
- अपने कोड एडिटर में,
reviewly-start/js/firebase-config.js
फ़ाइल खोलें. - प्लेसहोल्डर वैल्यू को अभी-अभी कॉपी की गई वैल्यू से बदलें. अगर आपके पास Firebase सेवाओं के लिए ऐसी प्रॉपर्टी और वैल्यू हैं जिनका इस्तेमाल Reviewly ऐप्लिकेशन में नहीं किया जाता है, तो कोई बात नहीं.
- फ़ाइल सेव करें.
- Firebase कंसोल पर वापस जाकर, कंसोल पर जारी रखें पर क्लिक करें.
अपने Firebase प्रोजेक्ट के लिए Firebase सीएलआई कमांड चलाने के लिए, अपना टर्मिनल सेट अप करें
- अपने टर्मिनल में, उस
ai-extensions-codelab
फ़ोल्डर पर जाएं जिसे आपने पहले डाउनलोड किया था. reviewly-start
वेब ऐप्लिकेशन फ़ोल्डर पर जाएं:cd reviewly-start
- Firebase सीएलआई को किसी खास Firebase प्रोजेक्ट के लिए निर्देश चलाएं:
firebase use YOUR_PROJECT_ID
Reviewly वेब ऐप्लिकेशन चलाएं और देखें
वेब ऐप्लिकेशन को चलाने और देखने के लिए, इन चरणों का पालन करें:
- अपने टर्मिनल में, डिपेंडेंसी इंस्टॉल करें. इसके बाद, वेब ऐप्लिकेशन चलाएं:
npm install # Include the parentheses in the following command. (cd functions && npm install) npm run dev
- अपने ब्राउज़र में, अपने टर्मिनल में दिखाए गए यूआरएल पर जाएं. उदाहरण के लिए: http://localhost:8080.
पेज लोड होना चाहिए, लेकिन आपको दिखेगा कि कई सुविधाएं मौजूद नहीं हैं. हम कोडलैब के इस मॉड्यूल के अगले चरणों में इन्हें जोड़ेंगे.
7. समीक्षा करने वाला ऐप्लिकेशन
इस कोडलैब के आखिरी चरण में, आपने Reviewly ऐप्लिकेशन को स्थानीय तौर पर चलाया, लेकिन उसमें ज़्यादा सुविधाएं नहीं थीं और आपने अब तक इंस्टॉल किए गए एक्सटेंशन का इस्तेमाल नहीं किया. कोडलैब के इस चरण में, आपको यह सुविधा जोड़नी होगी और एक्सटेंशन ट्रिगर करने के लिए वेब ऐप्लिकेशन का इस्तेमाल करना होगा.
सुरक्षा के नियम डिप्लॉय करें
इस कोडलैब के सैंपल ऐप्लिकेशन में, Firestore और Cloud Storage के लिए Firebase के लिए सुरक्षा नियमों के सेट शामिल हैं. इन सुरक्षा नियमों को अपने Firebase प्रोजेक्ट पर लागू करने के बाद, आपके डेटाबेस और बकेट में मौजूद डेटा को गलत इस्तेमाल से बचाया जाता है.
firestore.rules
और storage.rules
फ़ाइलों में, इन नियमों को देखा जा सकता है.
- इन सुरक्षा नियमों को लागू करने के लिए, अपने टर्मिनल में इस निर्देश को चलाएं:
firebase deploy --only firestore:rules,storage
- अगर आपसे यह पूछा जाता है कि:
"Cloud Storage for Firebase needs an IAM Role to use cross-service rules. Grant the new role?"
, तो हां चुनें.
एक्सटेंशन को ट्रिगर करने के लिए ऐप्लिकेशन का कोड अपडेट करें
Reviewly ऐप्लिकेशन में, Firestore में जोड़ी गई एक नई समीक्षा, समीक्षा की खास जानकारी देने के लिए एक्सटेंशन ट्रिगर करती है.
- अपने कोड एडिटर में,
functions/add-mock-reviews.js
फ़ाइल खोलें. reviewWithPrompt
वैरिएबल की जगह नीचे दिया गया कोड डालें. इससे भाषा के मॉडल को समीक्षा के लिए छोटा किया जा सकता है.const reviewWithPrompt = `Here's a user supplied review. Give me a shorter summary of the review, and a rating out of 5, and a flag which indicates if there was a product defect. Product name: "Blue t-shirt with cat picture". Review: """${review}""" Craft your response as JSON with properties has_defect, summary and rating. Don't include any extra text.`;
reviewWithPrompt
वैरिएबल के बाद,reviewDocument
वैरिएबल को इस कोड से बदलें. इससे समीक्षा वाला एक दस्तावेज़ बनता है, ताकि इसे Firestore में जोड़ा जा सके.const reviewDocument = { input: reviewWithPrompt, originalReview: review, timestamp: Timestamp.now(), }; getFirestore().collection(DB_COLLECTION_NAME).add(reviewDocument);
- फ़ाइल सेव करें.
js/reviews.js
फ़ाइल में,Insert code below, to import your Firebase Callable Cloud Function
टिप्पणी के बाद,httpsCallable
सहायता की मदद से अपना Firebase एचटीटीपी कॉल करने वाला फ़ंक्शन इंपोर्ट करें:const addMockReviews = httpsCallable(functions, "addMockReviews");
Insert code below, to invoke your Firebase Callable Cloud Function
टिप्पणी के बाद, अपने Firebase एचटीटीपी से कॉल करने लायक फ़ंक्शन को शुरू करें:await addMockReviews();
- फ़ाइल सेव करें.
नई समीक्षाएं जोड़ने के लिए फ़ंक्शन डिप्लॉय करें
Reviewly वेब ऐप्लिकेशन में, समीक्षाएं जोड़ने के लिए Cloud फ़ंक्शन का इस्तेमाल किया जाता है. हालांकि, फ़िलहाल Cloud फ़ंक्शन को डिप्लॉय नहीं किया गया है.
अपने फ़ंक्शन को Firebase सीएलआई के साथ डिप्लॉय करने के लिए, यह तरीका अपनाएं:
reviewly-start
फ़ोल्डर में रहते हुए अपने टर्मिनल में, सर्वर को बंद करने के लिएControl+C
दबाएं.- अपने फ़ंक्शन को डिप्लॉय करें:
firebase deploy --only functions
- अगर आपको
Permission denied while using the Eventarc Service Agent
या इससे मिलती-जुलती गड़बड़ी दिखती है, तो कुछ मिनट इंतज़ार करें. इसके बाद, फिर से निर्देश देने की कोशिश करें.
आपने अभी-अभी अपने पहले कस्टम फ़ंक्शन को Cloud Functions के साथ डिप्लॉय किया है. Firebase कंसोल में एक डैशबोर्ड होता है, जहां Firebase प्रोजेक्ट में डिप्लॉय किए गए सभी फ़ंक्शन देखे जा सकते हैं.
Reviewly वेब ऐप्लिकेशन को फिर से चलाएं और देखें (अब यह काम करने की सुविधा के साथ उपलब्ध है)
अब काम कर रहे वेब ऐप्लिकेशन को चलाने और देखने के लिए, यह तरीका अपनाएं:
- अपने टर्मिनल में, सर्वर को फिर से चलाएं:
npm run dev
- अपने ब्राउज़र में, अपने टर्मिनल में दिखाए गए यूआरएल पर जाएं. उदाहरण के लिए: http://localhost:8080.
- ऐप्लिकेशन में, नकली समीक्षाएं जोड़ें पर क्लिक करें और कुछ लंबी समीक्षाएं दिखने के लिए कुछ सेकंड इंतज़ार करें.
बैकग्राउंड में, PLM API के साथ भाषा के टास्क एक्सटेंशन, नई समीक्षा को दिखाने वाले नए दस्तावेज़ के हिसाब से प्रतिक्रिया देता है. आपने जो प्रॉम्प्ट पहले जोड़ा था उसमें लैंग्वेज मॉडल से, कम शब्दों में खास जानकारी देने का अनुरोध किया जाता है. - पूरी समीक्षा और समीक्षा के लिए इस्तेमाल किए गए प्रॉम्प्ट को देखने के लिए, किसी एक समीक्षा पर क्लिक करें. इसके बाद, PLM का अनुरोध दिखाएं को चुनें.
8. "PaLM API के साथ चैटबॉट" सेट अप करना के लिए एक्सटेंशन Chatbot ऐप्लिकेशन
PaLM API के साथ Chatbot एक्सटेंशन इंस्टॉल करें
- PaLM API वाला चैटबॉट एक्सटेंशन पर जाएं.
- Firebase कंसोल में इंस्टॉल करें पर क्लिक करें.
- अपना Firebase प्रोजेक्ट चुनें.
- अगला > अगला > इसके बाद, जब तक आप एक्सटेंशन कॉन्फ़िगर करें सेक्शन पर न पहुंच जाएं.
- कलेक्शन पाथ टेक्स्ट बॉक्स में,
users/{uid}/discussion/{discussionId}/messages
डालें. - Cloud Functions की जगह वाले ड्रॉप-डाउन से, Iowa (us-central1) या वह जगह चुनें जिसे आपने Firestore और Cloud Storage के लिए पहले चुना था.
- भाषा का मॉडल ड्रॉप-डाउन में जाकर, chat-bison चुनें.
- दूसरी सभी वैल्यू को डिफ़ॉल्ट वैल्यू के तौर पर रहने दें.
- एक्सटेंशन इंस्टॉल करें पर क्लिक करें. इसके बाद, एक्सटेंशन इंस्टॉल होने का इंतज़ार करें.
PaLM API वाला चैटबॉट एक्सटेंशन आज़माएं
इस कोडलैब का मकसद किसी वेब ऐप्लिकेशन के ज़रिए PaLM API के साथ Chatbot एक्सटेंशन के साथ इंटरैक्ट करना है. हालांकि, Firebase कंसोल का इस्तेमाल करके एक्सटेंशन को ट्रिगर करने से यह समझने में मदद मिलती है कि एक्सटेंशन कैसे काम करता है. जब users/{uid}/discussion/{discussionId}/messages
कलेक्शन में Cloud Firestore दस्तावेज़ बनाया जाता है, तब एक्सटेंशन ट्रिगर होता है.
- Firebase कंसोल में, Firestore पर जाएं.
- कलेक्शन शुरू करें पर क्लिक करें.
- कलेक्शन आईडी टेक्स्ट बॉक्स में,
users
डालें. इसके बाद, आगे बढ़ें पर क्लिक करें. - दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो आईडी पर क्लिक करें. इसके बाद, सेव करें पर क्लिक करें.
- कलेक्शन आईडी टेक्स्ट बॉक्स में,
users
कलेक्शन में, कलेक्शन शुरू करें पर क्लिक करें.- कलेक्शन आईडी टेक्स्ट बॉक्स में,
discussion
डालें. इसके बाद, आगे बढ़ें पर क्लिक करें. - दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो आईडी पर क्लिक करें. इसके बाद, सेव करें पर क्लिक करें.
- कलेक्शन आईडी टेक्स्ट बॉक्स में,
discussion
कलेक्शन में, कलेक्शन शुरू करें पर क्लिक करें.- कलेक्शन आईडी टेक्स्ट बॉक्स में,
messages
डालें. इसके बाद, आगे बढ़ें पर क्लिक करें. - दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो-आईडी पर क्लिक करें.
- फ़ील्ड टेक्स्ट बॉक्स में,
prompt
डालें. - वैल्यू टेक्स्ट बॉक्स में,
Tell me 5 random fruits
डालें. - सेव करें पर क्लिक करें और कुछ सेकंड इंतज़ार करें.
messages
कलेक्शन में अब एक दस्तावेज़ शामिल होता है. इसमें आपकी क्वेरी का जवाब शामिल होता है.
- कलेक्शन आईडी टेक्स्ट बॉक्स में,
messages
कलेक्शन में, दस्तावेज़ जोड़ें पर क्लिक करें.- दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो-आईडी पर क्लिक करें.
- फ़ील्ड टेक्स्ट बॉक्स में,
prompt
डालें. - वैल्यू टेक्स्ट बॉक्स में,
And now, vegetables
डालें. - सेव करें पर क्लिक करें और कुछ सेकंड इंतज़ार करें.
messages
कलेक्शन में अब एक दस्तावेज़ शामिल होता है. इसमें आपकी क्वेरी का जवाब शामिल होता है.
9. Firebase का इस्तेमाल करने के लिए, Chatbot ऐप्लिकेशन को सेट अप करना
Chatbot ऐप्लिकेशन चलाने के लिए, आपको ऐप्लिकेशन का कोड और Firebase सीएलआई सेट अप करना होगा, ताकि आप अपने Firebase प्रोजेक्ट के साथ इंटरैक्ट कर सकें.
अपने ऐप्लिकेशन के कोड में Firebase की सेवाएं और कॉन्फ़िगरेशन जोड़ें
Firebase का इस्तेमाल करने के लिए, आपके ऐप्लिकेशन के कोडबेस को उन सेवाओं के लिए Firebase SDK टूल की ज़रूरत होती है जिनका आप इस्तेमाल करना चाहते हैं. साथ ही, Firebase कॉन्फ़िगरेशन जो उन SDK टूल को यह बताता है कि किस Firebase प्रोजेक्ट का इस्तेमाल करना है.
इस कोडलैब के सैंपल ऐप्लिकेशन में, SDK टूल के लिए सभी ज़रूरी इंपोर्ट और शुरू करने के कोड पहले से ही शामिल हैं (chatbot-start/lib/firebase/firebase.js
देखें). इसलिए, आपको इन्हें जोड़ने की ज़रूरत नहीं है. हालांकि, सैंपल ऐप्लिकेशन में Firebase कॉन्फ़िगरेशन के लिए सिर्फ़ प्लेसहोल्डर वैल्यू होती हैं (chatbot-start/lib/firebase/firebase-config.js
देखें). इसलिए, आपको अपने ऐप्लिकेशन के लिए Firebase कॉन्फ़िगरेशन की यूनीक वैल्यू पाने के लिए, अपने ऐप्लिकेशन को Firebase प्रोजेक्ट के साथ रजिस्टर करना होगा.
- Firebase कंसोल में, अपने Firebase प्रोजेक्ट में प्रोजेक्ट की खास जानकारी पर जाएं. इसके बाद, वेब पर क्लिक करें. अगर आपने प्रोजेक्ट के साथ पहले से ही कोई ऐप्लिकेशन रजिस्टर किया हुआ है, तो ऐप्लिकेशन जोड़ें पर क्लिक करें.
- ऐप्लिकेशन का कोई दूसरा नाम टेक्स्ट बॉक्स में, ऐप्लिकेशन के लिए कोई याद रखने लायक नाम डालें, जैसे कि
My Chatbot app
. - इस ऐप्लिकेशन के लिए Firebase होस्टिंग की सुविधा भी सेट अप करें चेकबॉक्स को न चुनें. कोडलैब में इन चरणों को बाद में पूरा किया जा सकेगा.
- ऐप्लिकेशन रजिस्टर करें पर क्लिक करें.
- कंसोल, Firebase SDK टूल को ऐप्लिकेशन के हिसाब से बने Firebase कॉन्फ़िगरेशन ऑब्जेक्ट के साथ जोड़ने और शुरू करने के लिए, एक कोड स्निपेट दिखाता है. Firebase कॉन्फ़िगरेशन ऑब्जेक्ट में सभी प्रॉपर्टी कॉपी करें.
- अपने कोड एडिटर में,
chatbot-start/lib/firebase/firebase-config.js
फ़ाइल खोलें. - प्लेसहोल्डर वैल्यू को अभी-अभी कॉपी की गई वैल्यू से बदलें. अगर आपके पास Firebase सेवाओं के लिए ऐसी प्रॉपर्टी और वैल्यू हैं जिनका इस्तेमाल Chatbot ऐप्लिकेशन में नहीं किया जाता है, तो आपको परेशान होने की ज़रूरत नहीं है.
- फ़ाइल सेव करें.
- Firebase कंसोल पर वापस जाकर, कंसोल पर जारी रखें पर क्लिक करें.
अपने Firebase प्रोजेक्ट के लिए Firebase सीएलआई कमांड चलाने के लिए, अपना टर्मिनल सेट अप करें
- अपने टर्मिनल में, सर्वर को पिछला वेब ऐप्लिकेशन चलाने से रोकने के लिए
Control+C
दबाएं. - अपने टर्मिनल में,
chatbot-start
वेब ऐप्लिकेशन फ़ोल्डर पर जाएं:cd ../chatbot-start
- Firebase सीएलआई को किसी खास Firebase प्रोजेक्ट के लिए निर्देश चलाएं:
firebase use YOUR_PROJECT_ID
फ़्रेमवर्क को ध्यान में रखकर बनाई गई Firebase होस्टिंग का इस्तेमाल करने के लिए, अपने ऐप्लिकेशन का कोड बेस सेट अप करें
यह कोडलैब, Chatbot के वेब ऐप्लिकेशन के साथ होस्टिंग के साथ वेब फ़्रेमवर्क (झलक) का इस्तेमाल करता है.
- अपने टर्मिनल में, Firebase होस्टिंग के साथ वेब फ़्रेमवर्क चालू करें:
firebase experiments:enable webframeworks
- Firebase होस्टिंग शुरू करें:
firebase init hosting
Detected an existing
Next.js
codebase in your current directory, should we use this?
से निर्देश मिलने पर, Y दबाएं.In which region would you like to host server-side content, if applicable?
से पूछे जाने पर, डिफ़ॉल्ट क्षेत्र या वह जगह चुनें जिसे आपने Firestore और Cloud Storage के लिए पहले चुना था. इसके बाद,Enter
(या macOS परreturn
) दबाएं.Set up automatic builds and deploys with GitHub?
से निर्देश मिलने पर,N
दबाएं.
Chatbot का वेब ऐप्लिकेशन चलाएं और देखें
- अपने टर्मिनल में, डिपेंडेंसी इंस्टॉल करें. इसके बाद, वेब ऐप्लिकेशन चलाएं:
npm install firebase emulators:start --only hosting
- अपने ब्राउज़र में, स्थानीय रूप से होस्ट किए गए होस्टिंग URL पर नेविगेट करें. ज़्यादातर मामलों में, यह http://localhost:5000/ या इससे मिलता-जुलता होता है.
पेज लोड होना चाहिए, लेकिन आपको दिखेगा कि कई सुविधाएं मौजूद नहीं हैं. हम कोडलैब के इस मॉड्यूल के अगले चरणों में इन्हें जोड़ेंगे.
वेब ऐप्लिकेशन चलाने से जुड़ी समस्या हल करना
अगर आपको वेब पेज में Error: Firebase session cookie has incorrect...
से शुरू होने वाली गड़बड़ी दिखती है, तो आपको अपने लोकल होस्ट एनवायरमेंट में अपनी सभी कुकी मिटानी होंगी. ऐसा करने के लिए, कुकी हटाएं | DevTools दस्तावेज़..
10. में फ़ंक्शन जोड़ें Chatbot ऐप्लिकेशन
कोडलैब के इस आखिरी चरण में आपने Chatbot ऐप्लिकेशन को स्थानीय तौर पर चलाया, लेकिन इसमें ज़्यादा सुविधाएं नहीं थीं और आपने अब तक इंस्टॉल किए गए एक्सटेंशन का इस्तेमाल नहीं किया. कोडलैब के इस चरण में, आपको यह सुविधा जोड़नी होगी और एक्सटेंशन ट्रिगर करने के लिए वेब ऐप्लिकेशन का इस्तेमाल करना होगा.
सुरक्षा के नियम डिप्लॉय करें
इस कोडलैब के सैंपल ऐप्लिकेशन में, Firestore और Cloud Storage के लिए Firebase के लिए सुरक्षा नियमों के सेट शामिल हैं. इन सुरक्षा नियमों को अपने Firebase प्रोजेक्ट पर लागू करने के बाद, आपके डेटाबेस और बकेट में मौजूद डेटा को गलत इस्तेमाल से बचाया जाता है.
firestore.rules
और storage.rules
फ़ाइलों में, इन नियमों को देखा जा सकता है.
- इन सुरक्षा नियमों को लागू करने के लिए, अपने टर्मिनल में इस निर्देश को चलाएं:
firebase deploy --only firestore:rules,storage
- अगर आपसे यह पूछा जाता है कि:
"Cloud Storage for Firebase needs an IAM Role to use cross-service rules. Grant the new role?"
, तो हां चुनें.
Cloud Firestore में मैसेज जोड़ने के लिए कोड अपडेट करें
Chatbot ऐप्लिकेशन में, उपयोगकर्ता का एक नया मैसेज Firestore में जोड़ा जाता है. यह मैसेज, जवाब जनरेट करने के लिए एक्सटेंशन को ट्रिगर करता है.
- अपने कोड एडिटर में,
lib/firebase/firestore.js
फ़ाइल खोलें. - फ़ाइल के आखिर में,
addNewMessage
फ़ंक्शन ढूंढें. यह फ़ंक्शन, नए मैसेज जोड़ने का काम मैनेज करता है.
फ़ंक्शन नीचे दिए गए ऑब्जेक्ट प्रॉपर्टी को पहले से ही इस्तेमाल कर लेता है:पैरामीटर
जानकारी
userId
लॉग-इन किए हुए उपयोगकर्ता का आईडी
discussionId
बातचीत का वह आईडी जिसमें मैसेज जोड़ा गया है
message
मैसेज का टेक्स्ट
db
Firestore डेटाबेस इंस्टेंस
// Insert your code below ⬇️
टिप्पणी के बादaddNewMessage
फ़ंक्शन के मुख्य भाग में, यह कोड जोड़ें:await addDoc( collection( db, "users", userId, "discussion", discussionId, "messages" ), { prompt: message, createTime: serverTimestamp(), } ); await updateDoc(doc(db, "users", userId, "discussion", discussionId), { latestMessage: message, updatedTime: serverTimestamp(), });
क्वेरी बनाने के लिए कोड को अपडेट करें, ताकि मैसेज पाए जा सकें
- अब भी
lib/firebase/firestore.js
फ़ाइल में,getMessagesQuery
फ़ंक्शन का पता लगाएं. इसे Cloud Firestore की क्वेरी के तौर पर दिखाना है, जोusers/{uid}/discussion/{discussionId}/messages
कलेक्शन पाथ में सेव किए गए मैसेज को ढूंढती है. - पूरे
getMessagesQuery
फ़ंक्शन को नीचे दिए गए कोड से बदलें:function getMessagesQuery(db, userId, discussionId) { if (!userId || !discussionId) { return null; } const messagesRef = collection( db, "users", userId, "discussion", discussionId, "messages" ); return query(messagesRef, orderBy("createTime", "asc")); }
Cloud Firestore मैसेज दस्तावेज़ों को मैनेज करने के लिए कोड को अपडेट करें
- अब भी
lib/firebase/firestore.js
फ़ाइल में,handleMessageDoc
फ़ंक्शन का पता लगाएं, जिसे Cloud Firestore दस्तावेज़ मिलता है. यह एक मैसेज दिखाता है.
इस फ़ंक्शन को डेटा को ऐसे फ़ॉर्मैट और स्ट्रक्चर करने की ज़रूरत है जो Chatbot ऐप्लिकेशन के यूज़र इंटरफ़ेस (यूआई) के लिए सही हो. - पूरे
handleMessageDoc
फ़ंक्शन को नीचे दिए गए कोड से बदलें:function handleMessageDoc(doc) { const data = doc.data(); const item = { prompt: data.prompt, response: data.response, id: doc.id, createTime: formatDate(data.createTime.toDate()), }; if (data?.status?.completeTime) { item.completeTime = formatDate(data.status.completeTime.toDate()); } return item; }
- फ़ाइल सेव करें.
Chatbot वेब ऐप्लिकेशन को फिर से चलाएं और देखें (अब यह सुविधा उपलब्ध है)
अब काम कर रहे वेब ऐप्लिकेशन को चलाने और देखने के लिए, यह तरीका अपनाएं:
- अपने ब्राउज़र में, Chatbot वेब ऐप्लिकेशन वाले टैब पर वापस आएं और पेज को फिर से लोड करें.
- Google से साइन इन करें पर क्लिक करें.
- अगर ज़रूरी हो, तो अपना Google खाता चुनें.
- साइन इन करने के बाद, पेज को फिर से लोड करें.
- अपना मैसेज डालें टेक्स्ट बॉक्स में, मैसेज डालें, जैसे कि
Tell me about space
. - भेजें पर क्लिक करें. इसके बाद, Chatbot के वेब ऐप्लिकेशन का जवाब देने के लिए, कुछ सेकंड इंतज़ार करें.
PaLM API के साथ चैटबॉट एक्सटेंशन का एक और फ़ायदा है, बातचीत का इतिहास.
ऐतिहासिक कॉन्टेक्स्ट के साथ बातचीत करने की इसकी क्षमता का उदाहरण देखने के लिए, यह तरीका अपनाएं:
- अपना मैसेज डालें टेक्स्ट बॉक्स में, कोई सवाल पूछें, जैसे कि
What are five random fruits?
. - अपना मैसेज डालें टेक्स्ट बॉक्स में, पिछले सवाल से जुड़ा अगला सवाल पूछें, जैसे कि
And what about vegetables?
.
Chatbot वेब ऐप्लिकेशन में जवाब देने के लिए, पुरानी जानकारी का इस्तेमाल किया जाता है. भले ही, आपने पिछले सवाल में पांच सब्जियों के बारे में नहीं बताया था, लेकिन PaLM API वाला चैटबॉट एक्सटेंशन, आगे के सवालों को समझ जाता है.
11. "टेक्स्ट को बोली में बदलें" सेट अप करें के लिए एक्सटेंशन वीडियो हिंट ऐप्लिकेशन
टेक्स्ट को बोली में बदलें एक्सटेंशन इंस्टॉल करें
- टेक्स्ट को बोली में बदलें एक्सटेंशन पर जाएं.
- Firebase कंसोल में इंस्टॉल करें पर क्लिक करें.
- अपना Firebase प्रोजेक्ट चुनें.
- आगे बढ़ें पर क्लिक करें.
- चालू किए गए एपीआई और बनाए गए संसाधनों की समीक्षा करें सेक्शन में, आपको सुझाई गई किसी भी सेवा के आगे चालू करें पर क्लिक करें:
- आगे बढ़ें पर क्लिक करें. इसके बाद, आपको सुझाई गई किसी भी अनुमति के बगल में मौजूद, अनुमति दें को चुनें.
- आगे बढ़ें पर क्लिक करें.
- कलेक्शन पाथ टेक्स्ट बॉक्स में,
bot
डालें. - स्टोरेज पाथ टेक्स्ट बॉक्स में,
tts
डालें. - दूसरी सभी वैल्यू को उनके डिफ़ॉल्ट विकल्पों के तौर पर रहने दें.
- एक्सटेंशन इंस्टॉल करें पर क्लिक करें. इसके बाद, एक्सटेंशन इंस्टॉल होने का इंतज़ार करें.
टेक्स्ट को बोली में बदलें एक्सटेंशन आज़माएं
इस कोडलैब का मकसद किसी वेब ऐप्लिकेशन के ज़रिए, टेक्स्ट को बोली में बदलें एक्सटेंशन के साथ इंटरैक्ट करना है. हालांकि, Firebase कंसोल का इस्तेमाल करके एक्सटेंशन को ट्रिगर करने से, एक्सटेंशन के काम करने का तरीका समझने में मदद मिलती है. जब bot
कलेक्शन में Cloud Firestore दस्तावेज़ बनाया जाता है, तब एक्सटेंशन ट्रिगर होता है.
यह देखने के लिए कि Firebase कंसोल का इस्तेमाल करके एक्सटेंशन कैसे काम करता है, इन चरणों का पालन करें:
- Firebase कंसोल में, Firestore पर जाएं
- कलेक्शन शुरू करें पर क्लिक करें.
- कलेक्शन आईडी टेक्स्ट बॉक्स में,
bot
डालें. - आगे बढ़ें पर क्लिक करें.
- दस्तावेज़ आईडी टेक्स्ट बॉक्स में, ऑटो-आईडी पर क्लिक करें.
- फ़ील्ड टेक्स्ट बॉक्स में,
text
डालें. - वैल्यू टेक्स्ट बॉक्स में,
The quick brown fox jumps over the lazy dog
डालें. - सेव करें पर क्लिक करें.
अपनी बनाई गई MP3 फ़ाइल देखने और सुनने के लिए, यह तरीका अपनाएं:
- Firebase कंसोल में, स्टोरेज पर जाएं.
- जिस पैनल में फ़ाइलें अपलोड की जा सकती हैं उसमें,
gs://
वैल्यू के बाद बकेट का नाम लिखें. यह इस प्रोजेक्ट के लिए आपके डिफ़ॉल्ट बकेट का नाम है. इस कोडलैब के दौरान, अलग-अलग टास्क के लिए आपको इसकी ज़रूरत पड़ेगी.
- Google Cloud Console में, Cloud Storage पर जाएं.
- अपना प्रोजेक्ट चुनें.
अगर आपको हाल ही के प्रोजेक्ट की सूची में अपना प्रोजेक्ट नहीं दिखता है, तो प्रोजेक्ट पिकर में अपना प्रोजेक्ट ढूंढने के लिए, प्रोजेक्ट चुनें पर क्लिक करें.
- अपना डिफ़ॉल्ट स्टोरेज बकेट चुनें.
tts/
फ़ोल्डर पर जाएं.- MP3 फ़ाइल पर क्लिक करें.
- MP3 फ़ाइल के आखिर में, पर क्लिक करें. इसके बाद, देखें कि आपके टेक्स्ट को स्पीच में बदला गया है.
12. "Cloud Video AI की मदद से वीडियो को लेबल करें" सेटिंग को सेट अप करना के लिए एक्सटेंशन वीडियो हिंट ऐप्लिकेशन
Cloud Video AI की मदद से वीडियो लेबल करें एक्सटेंशन को इंस्टॉल करें
- Cloud Video AI की मदद से वीडियो को लेबल करें एक्सटेंशन पर जाएं.
- Firebase कंसोल में इंस्टॉल करें पर क्लिक करें.
- अपना Firebase प्रोजेक्ट चुनें.
- अगला > अगला > इसके बाद, जब तक कि आप एक्सटेंशन कॉन्फ़िगर करें सेक्शन पर न पहुंच जाएं.
- Cloud Functions की जगह वाले ड्रॉप-डाउन से, इस्तेमाल की जा सकने वाली जगह चुनें (वह जगह जिसे आपने पहले Firestore और Cloud Storage के लिए चुना था या उसके आस-पास की कोई जगह). उन जगहों के लिए
AnnotateVideoRequest
मेंlocation_id
सेक्शन देखें जहां यह सुविधा काम करती है. - मॉडल ड्रॉप-डाउन से, सबसे नया चुनें.
- Stationary Camera ड्रॉप-डाउन मेन्यू से, नहीं चुनें.
- दूसरी सभी वैल्यू को डिफ़ॉल्ट वैल्यू के तौर पर रहने दें.
- एक्सटेंशन इंस्टॉल करें पर क्लिक करें. इसके बाद, एक्सटेंशन इंस्टॉल होने का इंतज़ार करें.
Cloud Video AI की मदद से वीडियो को लेबल करें एक्सटेंशन को आज़माएं
इस कोडलैब का मकसद किसी वेब ऐप्लिकेशन के ज़रिए, क्लाउड वीडियो एआई की मदद से वीडियो को लेबल करें एक्सटेंशन के साथ इंटरैक्ट करना है. हालांकि, Firebase कंसोल का इस्तेमाल करके एक्सटेंशन को ट्रिगर करने से, एक्सटेंशन के काम करने का तरीका समझने में मदद मिलेगी. यह एक्सटेंशन तब ट्रिगर होता है, जब किसी वीडियो फ़ाइल को आपके स्टोरेज बकेट में अपलोड किया जाता है.
यह देखने के लिए कि Firebase कंसोल का इस्तेमाल करके एक्सटेंशन कैसे काम करता है, इन चरणों का पालन करें:
- अपने Firebase प्रोजेक्ट में स्टोरेज पर जाएं > फ़ोल्डर बनाएं.
- फ़ोल्डर का नाम टेक्स्ट बॉक्स में,
video_annotation_input
डालें.
- फ़ोल्डर जोड़ें पर क्लिक करें.
video_annotation_input
फ़ोल्डर में, फ़ाइल अपलोड करें पर क्लिक करें.- आपने जिस
ai-extensions-codelab/video-hint-start/public/videos
फ़ोल्डर को पहले क्लोन किया है या डाउनलोड किया है उसमें पहली वीडियो फ़ाइल चुनें. - अपने ब्राउज़र पर वापस Google Cloud Console में, Cloud Storage पर जाएं.
- अपना डिफ़ॉल्ट स्टोरेज बकेट चुनें, जिसे आपने पहले नोट किया हो.
video_annotation_output
फ़ोल्डर पर क्लिक करें.
अगर आपकोvideo_annotation_output
फ़ोल्डर नहीं दिखता है, तो कुछ सेकंड इंतज़ार करें और पेज को रीफ़्रेश करें, क्योंकि हो सकता है कि Video Intelligence API अब भी वीडियो को प्रोसेस कर रहा हो.
- ध्यान दें कि एक JSON फ़ाइल मौजूद है, जो उस फ़ाइल के नाम से मिलती-जुलती है जिसे आपने पहले अपलोड किया था.
- FILENAME को डाउनलोड करें पर क्लिक करें.
- डाउनलोड की गई JSON फ़ाइल को अपने कोड एडिटर में खोलें. इसमें Video Intelligence API से मिला रॉ आउटपुट शामिल होता है. इसमें, अपलोड किए गए वीडियो के पहचाने गए लेबल भी शामिल होते हैं.
13. Firebase का इस्तेमाल करने के लिए, वीडियो हिंट ऐप्लिकेशन सेट अप करें
वीडियो संकेत ऐप्लिकेशन चलाने के लिए, आपको अपने ऐप्लिकेशन का कोड और Firebase सीएलआई सेट अप करना होगा, ताकि आप अपने Firebase प्रोजेक्ट के साथ इंटरैक्ट कर सकें.
अपने ऐप्लिकेशन के कोड में Firebase की सेवाएं और कॉन्फ़िगरेशन जोड़ें
Firebase का इस्तेमाल करने के लिए, आपके ऐप्लिकेशन के कोडबेस को उन सेवाओं के लिए Firebase SDK टूल की ज़रूरत होती है जिनका आप इस्तेमाल करना चाहते हैं. साथ ही, Firebase कॉन्फ़िगरेशन जो उन SDK टूल को यह बताता है कि किस Firebase प्रोजेक्ट का इस्तेमाल करना है.
इस कोडलैब के सैंपल ऐप्लिकेशन में, SDK टूल के लिए सभी ज़रूरी इंपोर्ट और शुरू करने के कोड पहले से ही शामिल हैं (video-hint-start/lib/firebase/firebase.js
देखें). इसलिए, आपको इन्हें जोड़ने की ज़रूरत नहीं है. हालांकि, सैंपल ऐप्लिकेशन में Firebase कॉन्फ़िगरेशन के लिए सिर्फ़ प्लेसहोल्डर वैल्यू होती हैं (video-hint-start/lib/firebase/firebase-config.js
देखें). इसलिए, आपको अपने ऐप्लिकेशन के लिए Firebase कॉन्फ़िगरेशन की यूनीक वैल्यू पाने के लिए, अपने ऐप्लिकेशन को Firebase प्रोजेक्ट के साथ रजिस्टर करना होगा.
- Firebase कंसोल में, अपने Firebase प्रोजेक्ट में प्रोजेक्ट की खास जानकारी पर जाएं. इसके बाद, वेब पर क्लिक करें. अगर आपने प्रोजेक्ट के साथ पहले से ही कोई ऐप्लिकेशन रजिस्टर किया हुआ है, तो ऐप्लिकेशन जोड़ें पर क्लिक करें.
- ऐप्लिकेशन का कोई दूसरा नाम टेक्स्ट बॉक्स में, ऐप्लिकेशन के लिए कोई याद रखने लायक नाम डालें, जैसे कि
My Video Hint app
. - इस ऐप्लिकेशन के लिए Firebase होस्टिंग की सुविधा भी सेट अप करें चेकबॉक्स को न चुनें. कोडलैब में इन चरणों को बाद में पूरा किया जा सकेगा.
- ऐप्लिकेशन रजिस्टर करें पर क्लिक करें.
- कंसोल, Firebase SDK टूल को ऐप्लिकेशन के हिसाब से बने Firebase कॉन्फ़िगरेशन ऑब्जेक्ट के साथ जोड़ने और शुरू करने के लिए, एक कोड स्निपेट दिखाता है. Firebase कॉन्फ़िगरेशन ऑब्जेक्ट में सभी प्रॉपर्टी कॉपी करें.
- अपने कोड एडिटर में,
video-hint-start/lib/firebase/firebase-config.js
फ़ाइल खोलें. - प्लेसहोल्डर वैल्यू को अभी-अभी कॉपी की गई वैल्यू से बदलें. अगर आपके पास Firebase सेवाओं के लिए ऐसी प्रॉपर्टी और वैल्यू हैं जिनका इस्तेमाल वीडियो हिंट ऐप्लिकेशन में नहीं किया जाता, तो आपको परेशान होने की ज़रूरत नहीं है.
- फ़ाइल सेव करें.
- Firebase कंसोल पर वापस जाकर, कंसोल पर जारी रखें पर क्लिक करें.
अपने Firebase प्रोजेक्ट के लिए Firebase सीएलआई कमांड चलाने के लिए, अपना टर्मिनल सेट अप करें
- अपने टर्मिनल में, सर्वर को पिछला वेब ऐप्लिकेशन चलाने से रोकने के लिए
Control+C
दबाएं. - अपने टर्मिनल में,
video-hint-start
वेब ऐप्लिकेशन फ़ोल्डर पर जाएं:cd ../video-hint-start
- Firebase सीएलआई को किसी खास Firebase प्रोजेक्ट के लिए निर्देश चलाएं:
firebase use YOUR_PROJECT_ID
फ़्रेमवर्क को ध्यान में रखकर बनाई गई Firebase होस्टिंग का इस्तेमाल करने के लिए, अपने ऐप्लिकेशन का कोड बेस सेट अप करें
यह कोडलैब, वीडियो हिंट वेब ऐप्लिकेशन के साथ, होस्टिंग के साथ वेब फ़्रेमवर्क (झलक) का इस्तेमाल करता है.
- अपने टर्मिनल में, Firebase होस्टिंग के साथ वेब फ़्रेमवर्क चालू करें:
firebase experiments:enable webframeworks
- Firebase होस्टिंग शुरू करें:
firebase init hosting
Detected an existing
Next.js
codebase in your current directory, should we use this?
से निर्देश मिलने पर, Y दबाएं.In which region would you like to host server-side content, if applicable?
से पूछे जाने पर, डिफ़ॉल्ट क्षेत्र या वह जगह चुनें जिसे आपने Firestore और Cloud Storage के लिए पहले चुना था. इसके बाद,Enter
(या macOS परreturn
) दबाएं.Set up automatic builds and deploys with GitHub?
से निर्देश मिलने पर,N
दबाएं.
वीडियो संकेत वाला वेब ऐप्लिकेशन चलाएं और देखें
- अपने टर्मिनल में,
video-hint-start
औरfunctions
फ़ोल्डर में डिपेंडेंसी इंस्टॉल करें. इसके बाद, ऐप्लिकेशन चलाएं:npm install # Include the parentheses in the following command. (cd functions && npm install) firebase emulators:start --only hosting
- अपने ब्राउज़र में, स्थानीय रूप से होस्ट किए गए होस्टिंग URL पर नेविगेट करें. ज़्यादातर मामलों में, यह http://localhost:5000/ या इससे मिलता-जुलता होता है.
पेज लोड होना चाहिए, लेकिन आपको दिखेगा कि कई सुविधाएं मौजूद नहीं हैं. हम कोडलैब के इस मॉड्यूल के अगले चरणों में इन्हें जोड़ेंगे.
वेब ऐप्लिकेशन चलाने से जुड़ी समस्या हल करना
अगर आपको DevTools के कंसोल पैनल में, Error: The query requires an index. You can create it here: https://console.firebase.google.com
जैसा गड़बड़ी का कोई मैसेज दिखता है, तो यह तरीका अपनाएं:
- दिए गए यूआरएल पर जाएं.
- सेव करें पर क्लिक करें और स्थिति को बिल्डिंग से चालू है में बदलने का इंतज़ार करें.
14. वीडियो हिंट ऐप्लिकेशन
कोडलैब के इस आखिरी चरण में, आपने वीडियो हिंट ऐप्लिकेशन को स्थानीय तौर पर चलाया. हालांकि, इसमें ज़्यादा सुविधाएं नहीं थीं और आपने अब तक इंस्टॉल किए गए एक्सटेंशन का इस्तेमाल नहीं किया है. कोडलैब के इस चरण में, आपको यह सुविधा जोड़नी होगी और एक्सटेंशन ट्रिगर करने के लिए वेब ऐप्लिकेशन का इस्तेमाल करना होगा.
सुरक्षा के नियम डिप्लॉय करें
इस कोडलैब के सैंपल ऐप्लिकेशन में, Firestore और Cloud Storage के लिए Firebase के लिए सुरक्षा नियमों के सेट शामिल हैं. इन सुरक्षा नियमों को अपने Firebase प्रोजेक्ट पर लागू करने के बाद, आपके डेटाबेस और बकेट में मौजूद डेटा को गलत इस्तेमाल से बचाया जाता है.
firestore.rules
और storage.rules
फ़ाइलों में, इन नियमों को देखा जा सकता है.
- इन सुरक्षा नियमों को लागू करने के लिए, अपने टर्मिनल में इस निर्देश को चलाएं:
firebase deploy --only firestore:rules,storage
- अगर आपसे यह पूछा जाता है कि:
"Cloud Storage for Firebase needs an IAM Role to use cross-service rules. Grant the new role?"
, तो हां चुनें.
फ़ंक्शन को जोड़ने के लिए, कोड को अपडेट करें
- अपने कोड एडिटर में,
functions
फ़ोल्डर को बड़ा करें.
इस फ़ोल्डर में कई फ़ंक्शन हैं, जो मिलकर एक एक्सटेंशन पाइपलाइन बनाते हैं. यहां दी गई टेबल में, हर फ़ंक्शन के बारे में बताया गया है:फ़ंक्शन
जानकारी
functions/01-handle-video-upload.js
एक्सटेंशन पाइपलाइन में पहला चरण. यह उपयोगकर्ता की अपलोड की गई वीडियो फ़ाइल को प्रोसेस करता है.
functions/02-handle-video-labels.js
एक्सटेंशन पाइपलाइन में दूसरा चरण. यह उस वीडियो-लेबल फ़ाइल को प्रोसेस करता है, जिसे
storage-label-videos
एक्सटेंशन से जनरेट किया गया था.functions/03-handle-audio-file.js
एक्सटेंशन पाइपलाइन में तीसरा चरण. यह बोली को लेख में बदलने वाली ऑडियो फ़ाइल का इस्तेमाल करता है.
functions/index.js
फ़ाइल में, यह कोड जोड़ें:import { initializeApp } from "firebase-admin/app"; export * from "./01-handle-video-upload.js"; export * from "./02-handle-video-labels.js"; export * from "./03-handle-audio-file.js"; initializeApp();
यह कोड, index.js
फ़ाइल से फ़ंक्शन को इंपोर्ट और एक्सपोर्ट करने के लिए, JavaScript मॉड्यूल का इस्तेमाल करता है, ताकि सभी फ़ंक्शन के लिए एक ही जगह बनी रहे.
वीडियो अपलोडिंग मैनेज करने के लिए कोड अपडेट करें
- अपने कोड एडिटर में,
lib/firebase/storage.js
फ़ाइल खोलें. uploadVideo
फ़ंक्शन ढूंढें.
इस फ़ंक्शन कोuserId
,filePath
, औरfile
पैरामीटर मिलते हैं. यह डेटा, Cloud Storage में फ़ाइल अपलोड करने के लिए काफ़ी है.uploadVideo
फ़ंक्शन के मुख्य भाग में, यह कोड जोड़ें:const storageRef = ref(storage, `video_annotation_input/${filePath}`); const uploadTask = uploadBytesResumable(storageRef, file, { customMetadata: { uid: userId, }, }); return uploadTask;
फ़ंक्शन डिप्लॉय करना
अपने फ़ंक्शन को Firebase सीएलआई के साथ डिप्लॉय करने के लिए, यह तरीका अपनाएं:
video-hint-start
फ़ोल्डर में रहते हुए अपने टर्मिनल में, मौजूदा प्रोसेस को रोकने के लिएControl+C
दबाएं.- अपने फ़ंक्शन डिप्लॉय करें:
अगर आपसे पहले के किसी Cloud Functions को मिटाने के लिए कहा जाता है, तोfirebase deploy --only functions
No
चुनें. - अगर आपको
Permission denied while using the Eventarc Service Agent
से मिलता-जुलता कोई मैसेज दिखता है, तो कुछ मिनट इंतज़ार करें और फिर से निर्देश देने की कोशिश करें. - निर्देश खत्म होने के बाद, ऐप्लिकेशन को स्थानीय तौर पर फिर से चलाएं:
firebase emulators:start --only hosting
वीडियो हिंट वाले वेब ऐप्लिकेशन को फिर से चलाएं और देखें (अब सुविधा के साथ)
अब काम कर रहे वेब ऐप्लिकेशन को चलाने और देखने के लिए, यह तरीका अपनाएं:
- अपने ब्राउज़र में, वह टैब ढूंढें जहां आपने http://localhost:5000 पर नेविगेट किया था.
- अगर ज़रूरी हो, तो Google से साइन इन करें पर क्लिक करें और अपना Google खाता चुनें.
- उदाहरण वीडियो #1 अपलोड करें पर क्लिक करें और वीडियो की खास जानकारी के नतीजे देखने के लिए, कुछ मिनट इंतज़ार करें.
- अगर वीडियो अपलोड करने के बाद आपको कोई नतीजा नहीं दिखता, तो इस कोडलैब के अन्य सेक्शन में, Cloud Functions से जुड़ी गड़बड़ियों को हल करना देखें.
15. नतीजा
बधाई हो! आपने इस कोडलैब में बहुत कुछ हासिल किया है!
इंस्टॉल और कॉन्फ़िगर किए गए Firebase एक्सटेंशन
आपने Firebase कंसोल का इस्तेमाल, कई तरह के एआई एक्सटेंशन को कॉन्फ़िगर और इंस्टॉल करने के लिए किया था. एक्सटेंशन का इस्तेमाल करना आसान है, क्योंकि इसमें आपको बहुत सारे बॉयलरप्लेट कोड लिखने की ज़रूरत नहीं पड़ती. ये कोड Google Cloud सेवाओं की मदद से पुष्टि करने, Firestore से पढ़ने और लिखने, और Google Cloud की सेवाओं के साथ इंटरैक्ट करने में मददगार होते हैं. साथ ही, इन कामों में इस्तेमाल होने वाली अलग-अलग बारीकियों का भी ध्यान रखना होता है.
Firebase कंसोल का इस्तेमाल करके, एक्सटेंशन के साथ काम किया
सीधे कोड पर जाने के बजाय, आपने यह समझने में समय लिया कि एआई एक्सटेंशन कैसे काम करते हैं. यह आपके लिए, पैनल के ज़रिए Firestore या Cloud Storage के लिए दिए गए इनपुट के आधार पर काम करता है. इस तरह का इंटरैक्शन खास तौर पर तब मददगार हो सकता है, जब आपको एक्सटेंशन के आउटपुट को डीबग करने की ज़रूरत हो.
एआई की मदद से काम करने वाले तीन ऐसे वेब ऐप्लिकेशन बनाए जो Firebase एक्सटेंशन का इस्तेमाल करते हैं
समीक्षा करना
Reviewly वेब ऐप्लिकेशन में, आपने PLM API के साथ भाषा से जुड़े टास्क एक्सटेंशन का इस्तेमाल करके, उन लंबी समीक्षाओं की खास जानकारी दी है जिन्हें उपयोगकर्ताओं ने टी-शर्ट वाले किसी प्रॉडक्ट के लिए छोड़ा है. आपने यह भी अनुरोध किया है कि भाषा के मॉडल से आपकी क्वेरी का जवाब JSON फ़ॉर्मैट में मिले. इसमें, JSON ने स्टार रेटिंग दी थी और लंबी अवधि के ओरिजनल समीक्षा की खास जानकारी दी थी.
ज़रूरी नहीं होनी चाहिए: टी-शर्ट कंपनी कम शब्दों में दी गई समीक्षाओं से खुश है, लेकिन उसने इस बारे में ज़्यादा जानकारी मांगी है कि गड़बड़ी किस तरह की है. क्या समस्या की खास जानकारी को लौटाने के लिए, अनुरोध में बदलाव किया जा सकता है और फिर उस खास जानकारी को वेब ऐप्लिकेशन के यूज़र इंटरफ़ेस में शामिल किया जा सकता है?
चैटबॉट
चैटबॉट वेब ऐप्लिकेशन में, आपने उपयोगकर्ता को इंटरैक्टिव चैट इंटरफ़ेस उपलब्ध कराने के लिए PaLM API वाले चैटबॉट का इस्तेमाल किया था, जिसमें बातचीत के इतिहास की जानकारी शामिल होती है - जहां हर मैसेज को किसी खास उपयोगकर्ता के लिए बनाए गए Firestore दस्तावेज़ में सेव किया जाता है.
वैकल्पिक कसरत: छात्र-छात्राएं, चैटबॉट से खुश हैं, लेकिन स्टाफ़ कुछ सुधार करना चाहता है. जवाब देने के बाद, छात्र-छात्राओं को सोचने पर मजबूर करने वाले सवाल पूछे जाने चाहिए. उदाहरण के लिए:
Student asks: What is the ozone? Response: The ozone is a molecule composed of...How do you think human activities can impact the ozone layer?
हिंट: ऐसा करने के लिए, कॉन्फ़िगर हो सकने वाले कॉन्टेक्स्ट विकल्प का इस्तेमाल किया जा सकता है.
वीडियो हिंट
वीडियो हिंट वेब ऐप्लिकेशन में, आपने टेक्स्ट को बोली में बदलें, PLM API की मदद से भाषा टास्क, और क्लाउड वीडियो की मदद से वीडियो लेबल करें एक्सटेंशन का इस्तेमाल करके, एक्सटेंशन पाइपलाइन बनाई. इससे वीडियो में टेक्स्ट और ऑडियो की जानकारी मिलती है.
वैकल्पिक तरीका: सरकारी विभाग को प्रोटोटाइप दिलचस्प लगा और अब वह चाहता है कि उपयोगकर्ता, टेक्स्ट वाले लेबल पर क्लिक करके, वीडियो में लेबल वाले हिस्से पर सीधे पहुंच सके.
16. अपेंडिक्स: Cloud Functions की गड़बड़ियों को हल करना
अगर आपका वेब ऐप्लिकेशन उम्मीद के मुताबिक काम नहीं कर रहा है और आपको लगता है कि यह किसी फ़ंक्शन की वजह से हो सकता है, तो समस्या हल करने वाले इस पेज पर दिया गया तरीका अपनाएं.
सार्वजनिक अप्रमाणित ऐक्सेस की अनुमति दें
अगर आपको Chrome DevTools के कंसोल पैनल में अनुमति से जुड़ी कोई भी गड़बड़ी दिखती है, तो यह तरीका अपनाएं:
- पुष्टि करने से जुड़ी खास जानकारी | Cloud Run पेज
- फ़ंक्शन को बिना पुष्टि वाले सार्वजनिक ऐक्सेस की अनुमति देने के लिए, ज़रूरी टास्क देखने और उन्हें पूरा करने के लिए, लिंक पर क्लिक करें.
- Reviewly ऐप्लिकेशन पर वापस जाएं. उदाहरण के लिए: http://localhost:8080.
- कुछ चुनिंदा समीक्षाएं जोड़ें पर क्लिक करें और कुछ सेकंड इंतज़ार करें.
- अगर समीक्षाएं दिखती हैं: तो आपको समस्या हल करने के लिए इन चरणों को पूरा करने की ज़रूरत नहीं है. आपके पास सीधे इस कोडलैब में, चैटबॉट का वेब ऐप्लिकेशन सेट अप करें सेक्शन पर जाने का विकल्प है..
- अगर समीक्षाएं नहीं दिखती हैं, तो समस्या हल करने के इस सेक्शन को देखें.
अनुमति से जुड़ी ज़रूरी गड़बड़ियों को ठीक करना
- Firebase कंसोल में, Functions पर जाएं.
addMockReviews
फ़ंक्शन पर कर्सर घुमाएं और फिर पर क्लिक करें > लॉग देखें.
- लॉग पर तब तक स्क्रोल करें, जब तक आपको इनमें से किसी एक जैसी गड़बड़ी नहीं मिलती:
Exception from a finished function: Error: 7 PERMISSION_DENIED: Missing or insufficient permissions.
0001-compute@developer.gserviceaccount.com does not have storage.objects.get access to the Google Cloud Storage object. Permission 'storage.objects.get' denied on resource (or it may not exist).
- Google Cloud Console में, आईएएम की अनुमतियों वाले पेज पर जाएं. इसके बाद, अपना प्रोजेक्ट चुनें.
- टेबल में, नाम कॉलम ढूंढें.
IAM और एडमिन पेज पर, उपयोगकर्ताओं और उनकी भूमिकाओं की एक टेबल दिखती है. टेबल के नाम वाले कॉलम में, उपयोगकर्ता या प्रिंसिपल के बारे में जानकारी होती है. हो सकता है कि आपको कंप्यूट सेवा खाते का डिफ़ॉल्ट खाता एक मुख्य खाता असाइन किया गया हो.
अगर आपको कंप्यूट सेवा का डिफ़ॉल्ट खाता दिखता है, तो यह तरीका अपनाएं:
- प्रिंसिपल में बदलाव करें पर क्लिक करें.
- इस कोडलैब में, कंप्यूट सेवा खाते के डिफ़ॉल्ट वर्शन में भूमिकाएं जोड़ें सेक्शन के साथ आगे बढ़ें.
अगर आपको डिफ़ॉल्ट कंप्यूट सेवा खाता नहीं दिखता है, तो यह तरीका अपनाएं:
- ऐक्सेस दें पर क्लिक करें.
- प्रिंसिपल वाले नए टेक्स्ट बॉक्स में,
compute
डालें. - इसके बाद, आपको अपने-आप सुझाव मिलने की सुविधा के मेन्यू में, डिफ़ॉल्ट कंप्यूट सेवा खाता चुनें.
Compute के डिफ़ॉल्ट सेवा खाते में भूमिकाएं जोड़ें
कंप्यूट सेवा खाते के डिफ़ॉल्ट सेक्शन में, भूमिकाएं असाइन करें सेक्शन में:
- भूमिका चुनें मेन्यू को बड़ा करें.
- फ़िल्टर टेक्स्ट बॉक्स में
Cloud Datastore User
डालें. - इसके बाद, अपने-आप मिलने वाले सुझावों के मेन्यू में, Cloud Datastore उपयोगकर्ता चुनें.
- एक और भूमिका जोड़ें पर क्लिक करें.
- भूमिका चुनें मेन्यू को बड़ा करें.
- फ़िल्टर टेक्स्ट बॉक्स में
Cloud Storage for Firebase Admin
डालें. - इसके बाद, अपने-आप मिलने वाले सुझावों के मेन्यू में, Firebase के लिए Cloud Storage एडमिन चुनें.
- एक और भूमिका जोड़ें पर क्लिक करें.
- भूमिका चुनें मेन्यू को बड़ा करें.
- फ़िल्टर टेक्स्ट बॉक्स में
Cloud Storage for Firebase Service Agent
डालें. - इसके बाद, अपने-आप मिलने वाले सुझावों के मेन्यू में, Firebase के लिए Cloud Storage सेवा एजेंट को चुनें.
- सेव करें पर क्लिक करें.