Project

General

Profile

Moonshot » History » Version 8

Adrian Georgescu, 05/13/2015 02:47 AM

1 3 Adrian Georgescu
h1. Project Moonshot (a.k.a. WebSylk)
2 1 Adrian Georgescu
3 4 Adrian Georgescu
Adding WebRTC and video capability to SylkServer. This will allow anyone with basic computer knowledge to setup a zero-configuration meeting point that can be used to join a multi-party conference using standards-based clients like SIP, XMPP, IRC and and Web-browsers.
4 1 Adrian Georgescu
5
(Items in this list are not necessarily in order)
6
7
h2. Add VP8 support to SIP SIMPLE Client SDK
8
9
WebRTC mandates implementing both VP8 and H264, but the H264 part is getting quite some resistance. The current state (as of 12th of May 2015) is: Chrome does not implement H264, and in Firefox it has to be manually enabled through the advanced configuration menu.
10
11
We need to add support for it to the SDK so we can transparently interoperate with WebRTC endpoints without the need for transcoding.
12
13
Apparently libvpx already has VP9 support, which is currently behind a flag in Chrome, it's probably a good idea to try to add it too.
14
15 6 Adrian Georgescu
h2. Extend SylkServer with a web framework
16 5 Adrian Georgescu
17 6 Adrian Georgescu
Using such framework any web based application can tap into. Different applications might need to serve web content: screensharing images, conference web page, WebRTC endpoint, etc. There should be a single HTTP(S) endpoint where applications tap into and serve content.
18 1 Adrian Georgescu
19
Example URLs:
20
21
https://conference.sip2sip.info/sylk/conference/screen-sharing/
22
https://conference.sip2sip.info/sylk/conference/
23
https://conference.sip2sip.info/sylk/webrtcgateway/
24 6 Adrian Georgescu
25
When staring a conference room, SylkServer will advertise the following entry points:
26
27
 * A SIP address (all media possible)
28
 * An optional phone number (audio only)
29
 * An  XMPP address (chat and optional audio/video)
30
 * A WEB URL (all media is possible)
31
 * IRC room (text only)
32 1 Adrian Georgescu
33
34
h2. Design SylkRTC
35
36
The WebSocket API for gatewaying WebRTC endpoints to the SIP world. It needs to cover:
37
38
h3. Phase 1
39
40
* Registration of multiple accounts
41
* Multiple sessions
42
* Audio / video sessions
43
44
h3. Phase 2
45
46
* Chat
47
* Presence
48
* Contacts management
49
50
h3. Phase 3
51
52
* File transfer
53
* Screen sharing
54 8 Adrian Georgescu
* WebODF documents shared editing
55 1 Adrian Georgescu
56
57
h2. Implement the gateway skeleton (first alpha release)
58
59
It needs to cover:
60
61
* Multiple accounts
62
* Single session per account
63
* Audio and video
64
65
66
h2. Gateway phase 2
67
68
* Chat
69
* Presence
70
* Contact management
71
72
73
h1. Other
74
75 8 Adrian Georgescu
Random notes, thoughts.
76 1 Adrian Georgescu
77
h2. Write our own Janus SIP plugin
78
79
Based on the existing one, but using PJSIP instead. It will become clearer once we are further in the project. We'd use just the SIP signaling part, not any media capability, that's taken care of.
80
81
The SylkRTC API would not change, but it should facilitate some features such as multiple sessions per account.
82
83
h2. Multi-party video
84
85
There is a Janus plugin for that, maybe we can leverage it. Adding support for this to our SDK is a no go, in it's current state.
86
87
Adding support for "transparent streams" (and sessions) might be required. Basically we'd need a Session which doesn't really handle media, but it takes some SDP that got passed to it and deals with it.
88
89
We'd use multiple Video streams in a single session, and some way to correlate them, probably piggibacking on what WebRTC already does with BUNDLE, for example.
90
91
I'm not sure if Janus supports simulcast. (sending one big picture and the rest as thumbnails)
92
93
94
h2. Streaming
95
96
This can probably be offloaded to Janus.