DesignWebRTC
Version 3 (Saúl Ibarra Corretgé, 07/31/2015 04:32 pm) → Version 4/17 (Adrian Georgescu, 07/31/2015 04:35 pm)
h1. SylkServer WebRTC Gateway (Moonshot)
h2. Goal
Allow end-users that have access to a web-based tablet to communicate with the rest of the Internet without having to download and configure locally a SIP or XMPP client. Optionally, a temporary or permanent address can be created on the fly and assigned to the user for receiving incoming calls. A web page will be designed that can be customizable by third-party web developers where users will be able to enter an address and start an audio or chat session.
h2. Background
WebRTC provides a media library that allows web developers to load a web page through which Java script runs code that can access the microphone, speakers and camera. The soon to emerge standard provides a media stream and its SDP (session description protocol) that can be used by a signaling protocol like SIP or XMPP to locate another users and negotiate a media session. ICE methodology is used to probe a media path.
SylkServer allows transparent bridging of call flows for audio, chat, presence file transfer between SIP and XMPP protocols and supports ICE. All these call flow have an equivalent in WebRTC realm.
h2. Addressing
WebRTC is not a signaling protocol and does not introduce any new addressing scheme. To allow users to have a globally reachable address for receiving incoming calls we envisage a mechanism by which an external end-user controlled identity management system can be mapped to a SIP/XMPP address provided by the operator that runs SylkServer. For example we can link the webfinger profile of end-users with a user@domain addresses reachable through SylkServer.
h2. Implementation
To achieve the goal we propose to make SylkServer WebRTC enabled. A web server with web sockets support will be added to SylkServer and an API will be created that allows the end-users that loaded the page to join a conference or start an outgoing session to any other client on the Internet that uses user@domain addressing. The server will be zero configuration for the protocol mechanics.
h2. Deliverables
The outcome is a software with an open source license that can be packaged either as a server or a client running on end-user computers.
* SIP SIMPLE client SDK support for WebRTC (written in C and Python)
* Gateway application (part of SylkServer) (in Python)
* Additions to "janus":https://github.com/meetecho/janus-gateway Janus webrtc server component (written in C)
* sylkRTC API server side implementation (Python)
* sylkRTC API client side implementation (JavaScript)
* Web page front-end (HTML, CSS & JavaScript)
* Multiparty video conferencing (t.b.d.)
* Debian / Ubuntu packaging
The software will be freely available for download on GitHub public repositories and as a a public service at http://sip2sip.info
h2. Goal
Allow end-users that have access to a web-based tablet to communicate with the rest of the Internet without having to download and configure locally a SIP or XMPP client. Optionally, a temporary or permanent address can be created on the fly and assigned to the user for receiving incoming calls. A web page will be designed that can be customizable by third-party web developers where users will be able to enter an address and start an audio or chat session.
h2. Background
WebRTC provides a media library that allows web developers to load a web page through which Java script runs code that can access the microphone, speakers and camera. The soon to emerge standard provides a media stream and its SDP (session description protocol) that can be used by a signaling protocol like SIP or XMPP to locate another users and negotiate a media session. ICE methodology is used to probe a media path.
SylkServer allows transparent bridging of call flows for audio, chat, presence file transfer between SIP and XMPP protocols and supports ICE. All these call flow have an equivalent in WebRTC realm.
h2. Addressing
WebRTC is not a signaling protocol and does not introduce any new addressing scheme. To allow users to have a globally reachable address for receiving incoming calls we envisage a mechanism by which an external end-user controlled identity management system can be mapped to a SIP/XMPP address provided by the operator that runs SylkServer. For example we can link the webfinger profile of end-users with a user@domain addresses reachable through SylkServer.
h2. Implementation
To achieve the goal we propose to make SylkServer WebRTC enabled. A web server with web sockets support will be added to SylkServer and an API will be created that allows the end-users that loaded the page to join a conference or start an outgoing session to any other client on the Internet that uses user@domain addressing. The server will be zero configuration for the protocol mechanics.
h2. Deliverables
The outcome is a software with an open source license that can be packaged either as a server or a client running on end-user computers.
* SIP SIMPLE client SDK support for WebRTC (written in C and Python)
* Gateway application (part of SylkServer) (in Python)
* Additions to "janus":https://github.com/meetecho/janus-gateway Janus webrtc server component (written in C)
* sylkRTC API server side implementation (Python)
* sylkRTC API client side implementation (JavaScript)
* Web page front-end (HTML, CSS & JavaScript)
* Multiparty video conferencing (t.b.d.)
* Debian / Ubuntu packaging
The software will be freely available for download on GitHub public repositories and as a a public service at http://sip2sip.info