Project

General

Profile

DesignWebRTC » History » Version 9

Adrian Georgescu, 07/31/2015 04:41 PM

1 1 Saúl Ibarra Corretgé
h1. SylkServer WebRTC Gateway (Moonshot)
2
3
h2. Goal
4
5 9 Adrian Georgescu
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/video call or chat session.
6 1 Saúl Ibarra Corretgé
7
h2. Background
8
9
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.
10
11
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.
12
13
h2. Addressing
14
15
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.
16
17
h2. Implementation
18
19
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.
20
21
h2. Deliverables
22
23
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. 
24
25 3 Saúl Ibarra Corretgé
* SIP SIMPLE client SDK support for WebRTC (written in C and Python)
26
* Gateway application (part of SylkServer) (in Python)
27 4 Adrian Georgescu
* Additions to "janus":https://github.com/meetecho/janus-gateway webrtc server component (written in C)
28 3 Saúl Ibarra Corretgé
* sylkRTC API server side implementation (Python)
29
* sylkRTC API client side implementation (JavaScript)
30 7 Adrian Georgescu
* sylkRTC Api extensions for chat, presence and contacts
31 3 Saúl Ibarra Corretgé
* Web page front-end (HTML, CSS & JavaScript)
32
* Multiparty video conferencing (t.b.d.)
33
* Debian / Ubuntu packaging
34 1 Saúl Ibarra Corretgé
35 8 Adrian Georgescu
The software will be freely available for download on GitHub public repositories, as Debian package and as a a public service at http://sip2sip.info