Skip to content

An inter-destination media synchronisation service that uses software clocks to provide media timeline estimates

License

Notifications You must be signed in to change notification settings

bbc/cloud-sync

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cloud-Sync Media Synchronisation Service

This project was originally developed as part of the 2-IMMERSE project, co-funded by the European Commission’s Horizon 2020 Research Programme

Overview

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:

  1. Synchronisation Master (or Maestro)
  2. Distributed (no master)
  3. 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

Cloud-Sync Service Endpoints

The Cloud-Sync service exposes 2 endpoints:

  1. a Wallclock-Service endpoint (UDP or WebSocket) for time-synchronisation (via the CSS-WC protocol), and
  2. 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

Getting started

1. Clone the repository and install dependencies

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.

2. EITHER: Build the client library for the browser

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

OR: build the synchronisation service and run it on a server machine or cloud platform

  1. Make sure docker and docker-compose are installed:

    docker-compose installation instructions are available here: https://docs.docker.com/compose/install/

  2. Edit the .env file (a .env_test file is available for local testing)

    1. 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 at ws://<YOUR_MACHINE_IP>:6676

    2. Set INSTANCE_NAME to represent the name of the service used in stats collection

    3. Set STATS_WRITE_FLAG to either ON or OFF to enable/disable stats collection Stats collection pushes measurements to an InfluxDB endppint. If STATS_WRITE_FLAG=ON , you'll need to specify values for INFLUX_URL and INFLUX_TOKEN

      INFLUX_URL="http://localhost:9999"
      INFLUX_TOKEN="<a secret token>"
      
  3. 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:

    1. WallClock service
    2. SessionController service
    3. SyncController service
    4. Redis
    5. Mosquitto (MQTT broker)
    6. TimelineObserver service
    7. Consul
    8. 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
  1. 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/

  2. 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

    1. Enter a session id value e.g. 123

    2. Select the 'Dynamic' synchronisation option to allow any client to change the timeline position

    3. 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 in docker-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.
    4. 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 and sync-timeline-election algorithm options.

Documentation

JSDoc documentation can be built:

$ grunt jsdoc

Documentation is generated and output as HTML into the doc subfolder.

Unit tests

Unit tests are written using the jasmine unit test framework.

$ grunt test

Licence and Authors

All code and documentation is licensed by the original author and contributors under the Apache License v2.0:

See AUTHORS.md file for a full list of individuals and organisations that have contributed to this code.

Contributing

If you wish to contribute to this project, please get in touch with the authors.

About

An inter-destination media synchronisation service that uses software clocks to provide media timeline estimates

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 86.0%
  • Java 6.7%
  • HTML 5.2%
  • Dockerfile 1.4%
  • Other 0.7%