WebRTC - वास्तुकला
समग्र WebRTC वास्तुकला में जटिलता का एक बड़ा स्तर है।
यहां आप तीन अलग-अलग परतें पा सकते हैं -
API for web developers - इस परत में RTCPeerConnection, RTCDataChannel, और MediaStrean ऑब्जेक्ट सहित आवश्यक सभी API वेब डेवलपर शामिल हैं।
ब्राउज़र निर्माताओं के लिए एपीआई
ओवरराइडेबल एपीआई, जो ब्राउज़र निर्माता हुक कर सकते हैं।
परिवहन घटक विभिन्न प्रकार के नेटवर्क में कनेक्शन स्थापित करने की अनुमति देते हैं जबकि ध्वनि और वीडियो इंजन साउंड कार्ड और कैमरे से ऑडियो और वीडियो स्ट्रीम को नेटवर्क में स्थानांतरित करने के लिए जिम्मेदार होते हैं। वेब डेवलपर्स के लिए, सबसे महत्वपूर्ण हिस्सा वेबआरटीसी एपीआई है।
यदि हम क्लाइंट-सर्वर की तरफ से WebRTC आर्किटेक्चर को देखते हैं तो हम देख सकते हैं कि सबसे अधिक इस्तेमाल किया जाने वाला मॉडल SIP (सेशन इनीशिएशन प्रोटोकॉल) ट्रेपेज़ॉइड से प्रेरित है।
इस मॉडल में, दोनों डिवाइस विभिन्न सर्वरों से एक वेब एप्लिकेशन चला रहे हैं। RTCPeerConnection ऑब्जेक्ट स्ट्रीम को कॉन्फ़िगर करता है ताकि वे एक दूसरे से, पीयर-टू-पीयर से कनेक्ट हो सकें। यह सिग्नलिंग HTTP या वेबसॉकेट के माध्यम से की जाती है।
लेकिन सबसे अधिक इस्तेमाल किया जाने वाला मॉडल त्रिभुज है -
इस मॉडल में दोनों डिवाइस एक ही वेब एप्लिकेशन का उपयोग करते हैं। उपयोगकर्ता कनेक्शन प्रबंधित करते समय यह वेब डेवलपर को अधिक लचीलापन देता है।
WebRTC API
इसमें कुछ मुख्य जावास्क्रिप्ट ऑब्जेक्ट शामिल हैं -
- RTCPeerConnection
- MediaStream
- RTCDataChannel
RTCPeerConnection ऑब्जेक्ट
यह ऑब्जेक्ट WebRTC API का मुख्य प्रवेश बिंदु है। यह हमें साथियों से जुड़ने, कनेक्शन को इनिशियलाइज़ करने और मीडिया स्ट्रीम को अटैच करने में मदद करता है। यह किसी अन्य उपयोगकर्ता के साथ UDP कनेक्शन का प्रबंधन भी करता है।
RTCPeerConnection ऑब्जेक्ट का मुख्य कार्य सेटअप करना और एक सहकर्मी कनेक्शन बनाना है। हम आसानी से कनेक्शन के मुख्य बिंदुओं को हुक कर सकते हैं क्योंकि यह ऑब्जेक्ट दिखाई देने पर घटनाओं का एक सेट निकालता है। ये घटनाएँ आपको हमारे कनेक्शन के विन्यास तक पहुँच प्रदान करती हैं -
RTCPeerConnection एक सरल जावास्क्रिप्ट ऑब्जेक्ट है, जिसे आप बस इस तरह से बना सकते हैं -
[code]
var conn = new RTCPeerConnection(conf);
conn.onaddstream = function(stream) {
// use stream here
};
[/code]
RTCPeerConnection वस्तु एक को स्वीकार करता है conf पैरामीटर है, जो हम बाद में इन ट्यूटोरियल में कवर किया जाएगा। Onaddstream गतिविधि सक्रिय जब दूरस्थ उपयोगकर्ता अपने साथियों के संबंध में कोई वीडियो या ऑडियो स्ट्रीम कहते है।
मीडियास्ट्रीम एपीआई
आधुनिक ब्राउज़र एक डेवलपर को GetUserMedia API देते हैं, जिसे MediaStream API भी कहा जाता है। कार्यक्षमता के तीन प्रमुख बिंदु हैं -
यह एक स्ट्रीम ऑब्जेक्ट को डेवलपर एक्सेस देता है जो वीडियो और ऑडियो स्ट्रीम का प्रतिनिधित्व करता है
यदि उपयोगकर्ता के पास अपने डिवाइस पर कई कैमरे या माइक्रोफोन हैं, तो यह इनपुट उपयोगकर्ता उपकरणों के चयन का प्रबंधन करता है
यह उपयोगकर्ता को हर समय एक सुरक्षा स्तर प्रदान करता है जिससे वह s स्ट्रीम प्राप्त करना चाहता है
इस API का परीक्षण करने के लिए आइए एक साधारण HTML पेज बनाएं। यह एक एकल <वीडियो> तत्व दिखाएगा, उपयोगकर्ता से कैमरे का उपयोग करने की अनुमति मांगेगा और पृष्ठ पर कैमरे से एक लाइव स्ट्रीम दिखाएगा। एक index.html फ़ाइल बनाएँ और जोड़ें -
[code]
<html>
<head>
<meta charset = "utf-8">
</head>
<body>
<video autoplay></video>
<script src = "client.js"></script>
</body>
</html>
[/code]
फिर एक client.js फ़ाइल जोड़ें -
[code]
//checks if the browser supports WebRTC
function hasUserMedia() {
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
|| navigator.mozGetUserMedia || navigator.msGetUserMedia;
return !!navigator.getUserMedia;
}
if (hasUserMedia()) {
navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia
|| navigator.mozGetUserMedia || navigator.msGetUserMedia;
//get both video and audio streams from user's camera
navigator.getUserMedia({ video: true, audio: true }, function (stream) {
var video = document.querySelector('video');
//insert stream into the video tag
video.src = window.URL.createObjectURL(stream);
}, function (err) {});
}else {
alert("Error. WebRTC is not supported!");
}
[/code]
अब index.html खोलें और आपको अपना चेहरा प्रदर्शित करने वाली वीडियो स्ट्रीम देखनी चाहिए।
लेकिन सावधान रहें, क्योंकि WebRTC सर्वर साइड पर ही काम करता है। यदि आप ब्राउज़र के साथ इस पृष्ठ को खोलते हैं तो यह काम नहीं करेगा। आपको इन फ़ाइलों को अपाचे या नोड सर्वर पर होस्ट करने की आवश्यकता है, या जो आप पसंद करते हैं।
RTCDataChannel ऑब्जेक्ट
साथियों के बीच मीडिया स्ट्रीम भेजने के साथ, आप DataChannel API का उपयोग करके अतिरिक्त डेटा भी भेज सकते हैं । यह एपीआई मीडियास्ट्रीम एपीआई जितना ही सरल है। मुख्य काम मौजूदा RTCPeerConnection ऑब्जेक्ट से आने वाले चैनल को बनाना है -
[code]
var peerConn = new RTCPeerConnection();
//establishing peer connection
//...
//end of establishing peer connection
var dataChannel = peerConnection.createDataChannel("myChannel", dataChannelOptions);
// here we can start sending direct messages to another peer
[/code]
यह आपको केवल कोड की दो पंक्तियों की आवश्यकता है। बाकी सब कुछ ब्राउज़र की आंतरिक परत पर किया जाता है। RTCPeerConnectionobject बंद होने तक आप किसी भी सहकर्मी कनेक्शन पर एक चैनल बना सकते हैं ।
सारांश
अब आपके पास WebRTC आर्किटेक्चर का एक फर्म होना चाहिए। हमने MediaStream, RTCPeerConnection, और RTCDataChannel API को भी कवर किया। WebRTC API एक चलता फिरता लक्ष्य है, इसलिए हमेशा नवीनतम विशिष्टताओं के साथ बने रहें।