Google Meet के Media API की मदद से, Google Meet कॉन्फ़्रेंस से रीयल-टाइम मीडिया ऐक्सेस किया जा सकता है. इससे कई तरह के इस्तेमाल के उदाहरण मिलते हैं. जैसे, ऐक्शन आइटम को रिकॉर्ड करने वाले ऐप्लिकेशन, मौजूदा मीटिंग के बारे में रीयल-टाइम में अहम जानकारी देने वाले ऐप्लिकेशन या किसी नए प्लैटफ़ॉर्म पर ऑडियो और वीडियो स्ट्रीम करने वाले ऐप्लिकेशन.
उपयोग के उदाहरण
Google Cloud Console में रजिस्टर किए गए ऐप्लिकेशन, Meet के Media API का इस्तेमाल करके Meet कॉन्फ़्रेंस से कनेक्ट हो सकते हैं. इससे उन्हें ये काम करने में मदद मिलती है:
- वीडियो स्ट्रीम देखना. उदाहरण के लिए:
- मीटिंग में जनरेट हुई वीडियो स्ट्रीम को अपने एआई मॉडल में शामिल करें.
- कस्टम रिकॉर्डिंग के लिए स्ट्रीम फ़िल्टर करें.
- ऑडियो स्ट्रीम सुनना. उदाहरण के लिए:
- Gemini को सीधे तौर पर ऑडियो फ़ीड करें और मीटिंग के लिए एआई चैटबॉट बनाएं.
- मीटिंग में जनरेट हुई ऑडियो स्ट्रीम को अपनी ट्रांसक्रिप्शन सेवा में फ़ीड करना
- अलग-अलग भाषाओं में कैप्शन जनरेट करना.
- कैप्चर किए गए ऑडियो से, मॉडल के ज़रिए जनरेट किए गए साइन लैंग्वेज फ़ीड बनाना.
- कॉन्फ़्रेंस से बैकग्राउंड और नॉइज़ी आर्टफ़ैक्ट हटाने के लिए, अपने खुद के डेनॉइज़र मॉडल बनाएं.
- हिस्सा लेने वाले व्यक्ति का मेटाडेटा इस्तेमाल करना. उदाहरण के लिए:
- यह पता लगाया जा सकता है कि कॉन्फ़्रेंस में कौन-कौन शामिल है. इससे बेहतर इंटेलिजेंस और विश्लेषण किया जा सकता है.
Meet Media API का लाइफ़साइकल
यहां दी गई इमेज में, Meet Media API का लाइफ़साइकल दिखाया गया है:
-
पहली इमेज. Meet Media API बॉट, तीसरे पक्ष की वेबसाइट पर शामिल होने की कोशिश करता है. अगर किसी खाते में नाबालिगों के खाते मौजूद हैं, तो कनेक्शन अस्वीकार कर दिया जाता है. -
दूसरी इमेज. मीटिंग को एन्क्रिप्ट (सुरक्षित) किया जा सकता है और उसमें वॉटरमार्क जोड़ा जा सकता है. अगर किसी मीटिंग में एन्क्रिप्शन या वॉटरमार्क की सुविधा चालू है, तो Meet Media API को कनेक्ट नहीं किया जा सकता. -
तीसरी इमेज. पक्का करें कि एडमिन की सेटिंग सही हो. -
चौथी इमेज. Calendar में मीटिंग सेट अप करें. मीटिंग के होस्ट को Calendar की सेटिंग में जाकर, तीसरे पक्ष के ऐप्लिकेशन को अनुमति देनी होगी. ऐसा न करने पर, कनेक्शन का अनुरोध अस्वीकार कर दिया जाएगा. -
पांचवीं इमेज. कॉल के दौरान सेटिंग में बदलाव किया गया हो. अगर होस्ट, कॉल के दौरान Meet Media API सेटिंग को बंद करता है, तो कनेक्शन बंद हो जाता है. -
छठी इमेज. अगर मीटिंग के मालिक के पास उपभोक्ता खाता (ऐसा खाता जिसका आखिरी हिस्सा @gmail.com से खत्म होता है) है, तो मीटिंग शुरू करने वाले व्यक्ति को मीटिंग में मौजूद रहना होगा, ताकि वह सहमति दे सके. ऐसा न होने पर, कनेक्शन अस्वीकार कर दिया जाएगा. -
सातवीं इमेज. कनेक्शन बन जाने के बाद, होस्ट, को-होस्ट या होस्ट के संगठन के सभी सदस्यों को, लाइव स्ट्रीम शुरू करने का डायलॉग बॉक्स दिखता है. -
आठवीं इमेज. कॉल के दौरान, कोई भी व्यक्ति Meet Media API को बंद कर सकता है.
सहमति देने वाले व्यक्ति के लिए ज़रूरी शर्तें
Meet Media API वाले ऐप्लिकेशन को सिर्फ़ तब मीटिंग में शामिल होने की अनुमति मिलती है, जब कॉल में कोई ऐसा व्यक्ति मौजूद हो जिसे मीटिंग की ओर से सहमति देने की अनुमति हो.
Google Workspace की मीटिंग के लिए
Google Workspace मीटिंग में सहमति देने के लिए, आपको उस संगठन का सदस्य होना चाहिए जो मीटिंग का मालिक है. ज़्यादातर मामलों में, मीटिंग का मालिक और उसे आयोजित करने वाला व्यक्ति एक ही होता है. अगर होस्ट या मीटिंग शुरू करने वाला व्यक्ति, मीटिंग में शामिल है और वह उस संगठन में है जिसके पास मीटिंग का मालिकाना हक है, तो उसे सबसे पहले मीटिंग शुरू करने का डायलॉग बॉक्स दिखेगा.
उपभोक्ताओं के लिए होने वाली मीटिंग के लिए
Gmail खातों से बुलाई गई मीटिंग के लिए, मीटिंग शुरू करने वाले व्यक्ति को सहमति देनी होगी. इसके लिए, उसका मीटिंग में शामिल होना ज़रूरी है.
सामान्य शब्द
- Cloud प्रोजेक्ट नंबर
- Google Cloud प्रोजेक्ट के लिए, जनरेट किया गया
int64आइडेंटिफ़ायर, जिसे बदला नहीं जा सकता. ये वैल्यू, Google Cloud Console हर रजिस्टर किए गए ऐप्लिकेशन के लिए जनरेट करता है. - कॉन्फ़्रेंस
- यह मीटिंग स्पेस में सर्वर से जनरेट किया गया कॉल का इंस्टेंस होता है. उपयोगकर्ता आम तौर पर इस स्थिति को एक मीटिंग मानते हैं.
- कॉन्फ़्रेंस के संसाधन का डेटा चैनल
Google Meet REST API की तरह, Meet Media API क्लाइंट, एचटीटीपी पर संसाधनों का अनुरोध करने के बजाय, डेटा चैनलों पर सर्वर से संसाधनों का अनुरोध करते हैं.
हर संसाधन टाइप के लिए, एक अलग डेटा चैनल खोला जा सकता है. कनेक्शन चालू होने के बाद, क्लाइंट चैनल पर अनुरोध भेज सकता है. संसाधन से जुड़े अपडेट, उसी चैनल पर भेजे जाएंगे.
- योगदान देने वाला सोर्स (सीएसआरसी)
वर्चुअल मीडिया स्ट्रीम के साथ, यह नहीं माना जा सकता कि मीडिया स्ट्रीम हमेशा एक ही उपयोगकर्ता की ओर इशारा करती है. हर आरटीपी पैकेट के हेडर में मौजूद सीएसआरसी वैल्यू से, पैकेट के असली सोर्स की पहचान होती है.
मीटिंग में शामिल होने पर, Meet हर व्यक्ति को एक यूनीक सीएसआरसी वैल्यू असाइन करता है. यह वैल्यू तब तक एक जैसी रहती है, जब तक वे छोड़कर नहीं चले जाते.
- डेटा चैनल
WebRTC डेटा चैनल, ऑडियो और वीडियो स्ट्रीम से अलग किसी भी तरह के डेटा (टेक्स्ट, फ़ाइलें वगैरह) को शेयर करने की सुविधा देते हैं. डेटा चैनल, मीडिया स्ट्रीम की तरह ही कनेक्शन का इस्तेमाल करते हैं. इससे WebRTC ऐप्लिकेशन में डेटा एक्सचेंज को आसानी से जोड़ा जा सकता है.
- Interactive Connectivity Establishment (ICE)
यह कनेक्टिविटी सेट अप करने का एक प्रोटोकॉल है. यह पीयर-टू-पीयर (P2P) नेटवर्किंग के ज़रिए, दो कंप्यूटरों के बीच कम्यूनिकेशन के सभी संभावित रास्ते ढूँढता है. इसके बाद, यह पक्का करता है कि आपका कनेक्शन बना रहे.
- मीडिया स्ट्रीम
WebRTC मीडिया स्ट्रीम का मतलब है, मीडिया डेटा का फ़्लो. आम तौर पर, यह ऑडियो या वीडियो होता है. इसे किसी डिवाइस, जैसे कि कैमरा या माइक्रोफ़ोन से कैप्चर किया जाता है. इसमें एक या उससे ज़्यादा मीडिया स्ट्रीम ट्रैक होते हैं. हर ट्रैक, मीडिया के एक सोर्स को दिखाता है. जैसे, वीडियो ट्रैक या ऑडियो ट्रैक.
- मीडिया स्ट्रीम ट्रैक
इसमें आरटीपी पैकेट का एक ही यूनिडायरेक्शनल फ़्लो होता है. मीडिया स्ट्रीम ट्रैक, ऑडियो या वीडियो हो सकता है. हालांकि, दोनों नहीं हो सकते. आम तौर पर, दोनों दिशाओं में काम करने वाले सिक्योर रीयल-टाइम ट्रांसपोर्ट प्रोटोकॉल (एसआरटीपी) कनेक्शन में दो मीडिया स्ट्रीम ट्रैक होते हैं. इनमें से एक ट्रैक, लोकल पीयर से रिमोट पीयर तक जाता है और दूसरा ट्रैक, रिमोट पीयर से लोकल पीयर तक आता है.
- मीटिंग स्पेस
कोई वर्चुअल जगह या स्थायी ऑब्जेक्ट (जैसे, मीटिंग रूम) जहां कॉन्फ़्रेंस आयोजित की जाती है. किसी भी समय, एक स्पेस में सिर्फ़ एक चालू कॉन्फ़्रेंस हो सकता है. मीटिंग स्पेस की मदद से, उपयोगकर्ता एक-दूसरे से मिल सकते हैं और शेयर किए गए संसाधन ढूंढ सकते हैं.
- हिस्सा लेने वाला व्यक्ति
कोई व्यक्ति कॉन्फ़्रेंस में शामिल हुआ हो या कंपैनियन मोड का इस्तेमाल कर रहा हो. इसके अलावा, कोई व्यक्ति दर्शक के तौर पर शामिल हुआ हो या कॉल से कनेक्ट किया गया कोई रूम डिवाइस. जब कोई व्यक्ति कॉन्फ़्रेंस में शामिल होता है, तो उसे एक यूनीक आईडी असाइन किया जाता है.
- काम की स्ट्रीम
क्लाइंट के लिए, वर्चुअल ऑडियो स्ट्रीम और वर्चुअल वीडियो स्ट्रीम खोलने की संख्या तय की गई है.
ऐसा हो सकता है कि किसी कॉन्फ़्रेंस में शामिल होने वाले लोगों की संख्या, इस संख्या से ज़्यादा हो. इन स्थितियों में, Meet के सर्वर उन प्रतिभागियों की ऑडियो और वीडियो स्ट्रीम ट्रांसमिट करते हैं जिन्हें "सबसे ज़्यादा काम का" माना जाता है. मीटिंग में शामिल लोगों की दिलचस्पी का पता लगाने के लिए, कई बातों को ध्यान में रखा जाता है. जैसे, स्क्रीन शेयर करना और किसी व्यक्ति ने हाल ही में कब बात की.
- चुनिंदा फ़ॉरवर्डिंग यूनिट (एसएफ़यू)
चुनिंदा फ़ॉरवर्डिंग यूनिट (एसएफ़यू), WebRTC कॉन्फ़्रेंसिंग में सर्वर-साइड कॉम्पोनेंट होता है. यह मीडिया स्ट्रीम के डिस्ट्रिब्यूशन को मैनेज करता है. इसमें हिस्सा लेने वाले लोग सिर्फ़ SFU से कनेक्ट होते हैं. SFU, काम की स्ट्रीम को चुनिंदा लोगों के साथ शेयर करता है. इससे क्लाइंट प्रोसेसिंग और बैंडविड्थ की ज़रूरत कम हो जाती है. साथ ही, बड़े पैमाने पर कॉन्फ़्रेंस की सुविधा मिलती है.
- सेशन डेस्क्रिप्शन प्रोटोकॉल (एसडीपी)
यह एक सिग्नलिंग मैकेनिज़्म है. इसका इस्तेमाल WebRTC, P2P कनेक्शन पर बातचीत करने के लिए करता है.
RFC 8866इसे कंट्रोल करता है.- एसडीपी जवाब
एसडीपी ऑफ़र का जवाब. जवाब में, रिमोट पीयर से मिली किसी भी स्ट्रीम को स्वीकार या अस्वीकार किया जाता है. यह इस बात पर भी बातचीत करता है कि वह किन स्ट्रीम को वापस ऑफ़र करने वाले पीयर को ट्रांसमिट करने की योजना बना रहा है. यह ध्यान रखना ज़रूरी है कि एसडीपी के जवाब में, शुरुआती ऑफ़र से सिग्नल की गई स्ट्रीम नहीं जोड़ी जा सकतीं. उदाहरण के लिए, अगर कोई ऑफ़र करने वाला पीयर, रिमोट पीयर से तीन ऑडियो स्ट्रीम स्वीकार करता है, तो रिमोट पीयर ट्रांसमिशन के लिए चार ऑडियो स्ट्रीम का सिग्नल नहीं दे सकता.
- एसडीपी ऑफ़र
ऑफ़र-जवाब के पीयर-टू-पीयर नेगोशिएशन फ़्लो में शुरुआती एसडीपी. ऑफ़र, सेशन शुरू करने वाले व्यक्ति ने बनाया है. इसमें पीयर-टू-पीयर सेशन की शर्तें तय की जाती हैं. ऑफ़र हमेशा Meet Media API क्लाइंट बनाता है और Meet सर्वर को सबमिट करता है.
उदाहरण के लिए, किसी ऑफ़र में यह जानकारी हो सकती है कि ऑफ़र देने वाला व्यक्ति कितनी ऑडियो या वीडियो स्ट्रीम भेज रहा है या उसे कितनी स्ट्रीम मिल सकती हैं. साथ ही, यह भी बताया जा सकता है कि डेटा चैनल खोले जाने हैं या नहीं.
- सिंक्रनाइज़ेशन सोर्स (एसएसआरसी)
एसएसआरसी, 32-बिट का आइडेंटिफ़ायर होता है. यह आरटीपी (रीयल-टाइम ट्रांसपोर्ट प्रोटोकॉल) सेशन में, मीडिया स्ट्रीम के किसी एक सोर्स की खास पहचान करता है. WebRTC में, एसएसआरसी का इस्तेमाल अलग-अलग मीडिया स्ट्रीम के बीच अंतर करने के लिए किया जाता है. ये स्ट्रीम, अलग-अलग लोगों या एक ही व्यक्ति के अलग-अलग ट्रैक (जैसे, अलग-अलग कैमरे) से जनरेट होती हैं.
- RtpTransceiver
RFC 8829में दी गई जानकारी के मुताबिक, ट्रांससीवर, पीयर-टू-पीयर सेशन में आरटीपी स्ट्रीम के आस-पास का ऐब्स्ट्रैक्शन होता है.एसडीपी में, एक ट्रांससीवर को एक मीडिया ब्यौरे के साथ मैप किया जाता है और उसके बारे में बताया जाता है. ट्रांसीवर में
RtpSenderऔरRtpReceiverहोता है.आरटीपी दोतरफ़ा होता है. इसलिए, हर पीयर के पास एक ही आरटीपी कनेक्शन के लिए, अपना ट्रांससीवर इंस्टेंस होता है. लोकल पीयर के लिए, किसी दिए गए ट्रांसीवर का
RtpSender, रिमोट पीयर में मौजूद किसी ट्रांसीवर केRtpReceiverपर मैप किया जाता है. इसका उल्टा भी सही है. रिमोट पीयर के एक ही ट्रांसीवर काRtpSender, लोकल पीयर केRtpReceiverपर मैप किया जाता है.हर मीडिया ब्यौरे का अपना ट्रांससीवर होता है. इसलिए, कई आरटीपी स्ट्रीम वाले पीयर-टू-पीयर सेशन में, कई ट्रांससीवर होते हैं. साथ ही, हर पीयर के लिए कई
RtpSendersऔरRtpReceiverहोते हैं.- वर्चुअल मीडिया स्ट्रीम
वर्चुअल मीडिया स्ट्रीम, WebRTC कॉन्फ़्रेंस में चुनिंदा फ़ॉरवर्डिंग यूनिट (एसएफ़यू) से जनरेट की गई एग्रीगेटेड मीडिया स्ट्रीम होती हैं. एसएफ़यू में, हर व्यक्ति को अपनी स्ट्रीम भेजने के बजाय, चुनिंदा लोगों की स्ट्रीम को मल्टीप्लेक्स किया जाता है. इससे, आउटगोइंग वर्चुअल स्ट्रीम की संख्या कम हो जाती है. इससे कनेक्शन टोपोलॉजी आसान हो जाती है और मीटिंग में शामिल लोगों पर लोड कम हो जाता है. साथ ही, इससे बड़े पैमाने पर कॉन्फ़्रेंस की जा सकती हैं. हर वर्चुअल स्ट्रीम में, एक से ज़्यादा लोगों का मीडिया शामिल हो सकता है. इसे SFU डाइनैमिक तरीके से मैनेज करता है.
मिलते-जुलते विषय
Meet Media API क्लाइंट को डेवलप करने का तरीका जानने के लिए, शुरू करें में दिया गया तरीका अपनाएं.
Meet Media API के सैंपल रेफ़रंस क्लाइंट को सेट अप और चलाने का तरीका जानने के लिए, C++ रेफ़रंस क्लाइंट के लिए क्विकस्टार्ट गाइड पढ़ें.
कॉन्सेप्ट के बारे में खास जानकारी पाने के लिए, Meet Media API के कॉन्सेप्ट देखें.
WebRTC के बारे में ज़्यादा जानने के लिए, WebRTC For The Curious लेख पढ़ें.
Google Workspace API का इस्तेमाल करके डेवलपमेंट करने के बारे में जानने के लिए, Google Workspace पर डेवलप करें लेख पढ़ें. इसमें पुष्टि करने और अनुमति देने की प्रोसेस को मैनेज करने के बारे में भी बताया गया है.