2016-07-12 16:22:33 +00:00
|
|
|
.. Copyright 2016 OpenMarket Ltd
|
|
|
|
..
|
|
|
|
.. Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
.. you may not use this file except in compliance with the License.
|
|
|
|
.. You may obtain a copy of the License at
|
|
|
|
..
|
|
|
|
.. http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
..
|
|
|
|
.. Unless required by applicable law or agreed to in writing, software
|
|
|
|
.. distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
.. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
.. See the License for the specific language governing permissions and
|
|
|
|
.. limitations under the License.
|
|
|
|
|
2015-09-17 15:38:58 +00:00
|
|
|
Voice over IP
|
2015-09-30 16:32:44 +00:00
|
|
|
=============
|
2015-09-17 15:38:58 +00:00
|
|
|
|
2015-09-25 14:09:15 +00:00
|
|
|
.. _module:voip:
|
|
|
|
|
2015-09-30 16:32:44 +00:00
|
|
|
This module outlines how two users in a room can set up a Voice over IP (VoIP)
|
|
|
|
call to each other. Voice and video calls are built upon the WebRTC 1.0 standard.
|
2016-02-11 18:34:28 +00:00
|
|
|
Call signalling is achieved by sending `message events`_ to the room. In this
|
|
|
|
version of the spec, only two-party communication is supported (e.g. between two
|
|
|
|
peers, or between a peer and a multi-point conferencing unit).
|
|
|
|
This means that clients MUST only send call events to rooms with exactly two
|
|
|
|
participants.
|
2015-09-30 16:32:44 +00:00
|
|
|
|
|
|
|
.. _message events: `sect:events`_
|
2015-09-17 15:38:58 +00:00
|
|
|
|
2015-10-01 10:04:42 +00:00
|
|
|
Events
|
|
|
|
------
|
|
|
|
|
|
|
|
{{voip_events}}
|
|
|
|
|
|
|
|
Client behaviour
|
2015-09-30 16:32:44 +00:00
|
|
|
----------------
|
2015-10-01 10:04:42 +00:00
|
|
|
|
2015-09-30 16:32:44 +00:00
|
|
|
A call is set up with message events exchanged as follows:
|
2015-09-17 15:38:58 +00:00
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
Caller Callee
|
|
|
|
[Place Call]
|
|
|
|
m.call.invite ----------->
|
|
|
|
m.call.candidate -------->
|
|
|
|
[..candidates..] -------->
|
|
|
|
[Answers call]
|
|
|
|
<--------------- m.call.answer
|
|
|
|
[Call is active and ongoing]
|
|
|
|
<--------------- m.call.hangup
|
|
|
|
|
|
|
|
Or a rejected call:
|
|
|
|
|
|
|
|
::
|
|
|
|
|
|
|
|
Caller Callee
|
|
|
|
m.call.invite ------------>
|
|
|
|
m.call.candidate --------->
|
|
|
|
[..candidates..] --------->
|
|
|
|
[Rejects call]
|
|
|
|
<-------------- m.call.hangup
|
|
|
|
|
|
|
|
Calls are negotiated according to the WebRTC specification.
|
|
|
|
|
|
|
|
Glare
|
|
|
|
~~~~~
|
2015-09-30 16:32:44 +00:00
|
|
|
|
|
|
|
"Glare" is a problem which occurs when two users call each other at roughly the
|
|
|
|
same time. This results in the call failing to set up as there already is an
|
|
|
|
incoming/outgoing call. A glare resolution algorithm can be used to determine
|
|
|
|
which call to hangup and which call to answer. If both clients implement the
|
|
|
|
same algorithm then they will both select the same call and the call will be
|
|
|
|
successfully connected.
|
|
|
|
|
|
|
|
|
|
|
|
As calls are "placed" to rooms rather than users, the glare resolution algorithm
|
|
|
|
outlined below is only considered for calls which are to the same room. The
|
|
|
|
algorithm is as follows:
|
|
|
|
|
2015-10-23 09:51:31 +00:00
|
|
|
- If an ``m.call.invite`` to a room is received whilst the client is
|
|
|
|
**preparing to send** an ``m.call.invite`` to the same room:
|
2015-09-30 16:32:44 +00:00
|
|
|
|
2015-10-23 09:51:31 +00:00
|
|
|
* the client should cancel its outgoing call and instead
|
|
|
|
automatically accept the incoming call on behalf of the user.
|
2015-09-30 16:32:44 +00:00
|
|
|
|
2015-10-23 09:51:31 +00:00
|
|
|
- If an ``m.call.invite`` to a room is received **after the client has sent**
|
|
|
|
an ``m.call.invite`` to the same room and is waiting for a response:
|
2015-09-30 16:32:44 +00:00
|
|
|
|
2015-10-23 09:51:31 +00:00
|
|
|
* the client should perform a lexicographical comparison of the call IDs of
|
|
|
|
the two calls and use the *lesser* of the two calls, aborting the
|
|
|
|
greater. If the incoming call is the lesser, the client should accept
|
|
|
|
this call on behalf of the user.
|
2015-09-30 16:32:44 +00:00
|
|
|
|
2015-09-17 15:38:58 +00:00
|
|
|
|
|
|
|
The call setup should appear seamless to the user as if they had simply placed
|
2015-09-30 16:32:44 +00:00
|
|
|
a call and the other party had accepted. This means any media stream that had been
|
2015-09-17 15:38:58 +00:00
|
|
|
setup for use on a call should be transferred and used for the call that
|
|
|
|
replaces it.
|
2015-09-17 16:49:57 +00:00
|
|
|
|
2015-09-30 16:32:44 +00:00
|
|
|
Server behaviour
|
|
|
|
----------------
|
|
|
|
|
2015-10-01 10:11:08 +00:00
|
|
|
The homeserver MAY provide a TURN server which clients can use to contact the
|
|
|
|
remote party. The following HTTP API endpoints will be used by clients in order
|
|
|
|
to get information about the TURN server.
|
2015-10-01 10:04:42 +00:00
|
|
|
|
2016-03-08 17:42:41 +00:00
|
|
|
{{voip_cs_http_api}}
|
2015-10-01 10:04:42 +00:00
|
|
|
|
2015-09-30 16:32:44 +00:00
|
|
|
|
|
|
|
Security considerations
|
|
|
|
-----------------------
|
|
|
|
|
2015-10-01 10:04:42 +00:00
|
|
|
Calls should only be placed to rooms with one other user in them. If they are
|
|
|
|
placed to group chat rooms it is possible that another user will intercept and
|
|
|
|
answer the call.
|
2015-09-30 16:32:44 +00:00
|
|
|
|