This project was originally developed as part of the 2-IMMERSE project, co-funded by the European Commission’s Horizon 2020 Research Programme
An implementation of a Media Synchronisation Service and its client library (intended for use in the browser).
Cloud-Sync is a frame-accurate inter-destination media synchronisation service that supports a number of timing control schemes and asynchrony reduction algorithms:
- Synchronisation Master (or Maestro)
- Distributed (no master)
- Latest Master (Last node to change timeline is Master)
It is compatible with DVB-CSS in that it uses the notion of timelines to model the progress of media presentation and uses a time synchronisation scheme (CSS-WC) and timeline correlations to export timeline progress estimates.
It allows a client to register a timing source and for other clients to discover that timing source, and use it as a synchronisation timeline for time-aligning the presentation of their own media objects.
Cloud-Sync provides a registered timing source to a client (upon request) via a Timeline Shadow. This is a local estimate of the timeline on the client device and is manifested by the cloud-sync client API as a software clock object.
Cloud-Sync supports the following features:
- LAN-local interdevice and inter-destination media synchronisation with frame synchronisation accuracy
- Synchronisation Maestro, Distributed, Latest Master timing control schemes
- A lightweight time synchronisation scheme that can run in browser environments
- Dynamic master node election
- Dynamic sync error monitoring and alerts
- Arbitratry timing sources (e.g. media players, artificial clocks, broadcast timelines)
- Sync protocols over multiple transports: WebSockets, UDP, TCP
- Client Sync-Controllers for local media playback adaptation
The documentation for the API and usage instructions for the client library can be found in client-api.md
The Cloud-Sync service exposes 2 endpoints:
- a Wallclock-Service endpoint (UDP or WebSocket) for time-synchronisation (via the CSS-WC protocol), and
- a Synchronisation-Service endpoint (MQTT over WebSocket) for registering clients, registering timelines, responding to timeline queries and advertising synchronisation timelines.
These endpoint are:
- WallClock-Service WebSocket endpoint:
ws://<SERVER_IP>:6676
- WallClock-Service UDP endpoint:
udp://<SERVER_IP>:6677
- Sync-Service WebSocket endpoint:
ws://<SERVER_IP>:9001
First download and then install dependencies:
$ cd cloudsync
$ npm install
Note that NPM install might fail if NPM is not able to access your credentials for the project repository.
If you wish to build it into a single JS file suitable for the browser (i.e. for including in a webpage) then do this:
$ grunt
The resulting JS client library is placed in dist/browser/Cloud-SyncKit.js
.
Usage instructions for the client library can be found in client-api.md
-
Make sure docker and docker-compose are installed:
docker-compose installation instructions are available here:
https://docs.docker.com/compose/install/
-
Edit the
.env
file (a .env_test file is available for local testing)-
To change WallClock service endpoint advertised to the cloud-sync service clients Set
WALLCLOCK_SERVICE_WS_URL
with a websocket address e.g.ws://localhost:6676
. If running locally, the WallClock-Service websocket endpoint is exposed atws://<YOUR_MACHINE_IP>:6676
-
Set
INSTANCE_NAME
to represent the name of the service used in stats collection -
Set
STATS_WRITE_FLAG
to either ON or OFF to enable/disable stats collection Stats collection pushes measurements to an InfluxDB endppint. IfSTATS_WRITE_FLAG=ON
, you'll need to specify values forINFLUX_URL
andINFLUX_TOKEN
INFLUX_URL="http://localhost:9999" INFLUX_TOKEN="<a secret token>"
-
-
Build microservice images and instantiate containers using the docker-compose tool.
The
docker-compose.yml
YAML file specifies the microservices in the cloud-sync service:- WallClock service
- SessionController service
- SyncController service
- Redis
- Mosquitto (MQTT broker)
- TimelineObserver service
- Consul
- Registrator
Run the following script:
$ ./start_service.sh
If using a different .env
file, you can run the service as follows:
$ docker-compose -f docker-compose-local.yml --env-file ./.env_local up
-
Check that your containers have started successfully and are discoverable:
Open the web UI at this URL in your browser:
http://<YOUR_MACHINE_IP>:8500/
-
Check if the sync service is working by loading this demo app on a browser:
http://<YOUR_MACHINE_IP>:3000?video=https://download.blender.org/durian/trailer/sintel_trailer-720p.mp4
-
Enter a session id value e.g.
123
-
Select the 'Dynamic' synchronisation option to allow any client to change the timeline position
-
Wait for video to start playing.
If video does not start playing, check if these config settings are correct:
- the
WALLCLOCK_SERVICE_WS_URL
fields indocker-compose.yml
are set to point to the correct WallClock service endpoint - the client config file
examples/synchronisedvideo/config/config.js
contains the correct URL for the Sync-Service endpoint.
- the
-
Open another client. When the video starts to play, click on the share button on the video scrubber to
-
start another instance of the demo app in another window
-
obtain a QR code to open a client on an Android phone
Alternatively, make another client join the sync session by opening the above URL and specifying the same
session id
andsync-timeline-election algorithm
options.
-
JSDoc documentation can be built:
$ grunt jsdoc
Documentation is generated and output as HTML into the doc
subfolder.
Unit tests are written using the jasmine unit test framework.
$ grunt test
All code and documentation is licensed by the original author and contributors under the Apache License v2.0:
- British Broadcasting Corporation (original author)
- Centrum Wiskunde & Informatica
See AUTHORS.md file for a full list of individuals and organisations that have contributed to this code.
If you wish to contribute to this project, please get in touch with the authors.