video-companion
Stream webcams and share screens in Qubes OS.
Table of Contents
Description
Installation procedures to stream webcams and share screens across qubes. The sender/server owns the screen or webcam and the receiver/client wants to access them without compromising the domains.
Installation
- Top:
sudo qubesctl top.enable video-companion
sudo qubesctl state.apply
sudo qubesctl top.disable video-companion
- State:
sudo qubesctl state.apply video-companion.create
Installation on the server (sender) template:
sudo qubesctl --skip-dom0 --targets=QUBE state.apply video-companion.install-sender
Installation on the client (receiver) template:
sudo qubesctl --skip-dom0 --targets=QUBE state.apply video-companion.install-receiver
Installation for debugging on the client (receiver) template:
sudo qubesctl --skip-dom0 --targets=QUBE state.apply video-companion.install-receiver-debug
Usage
Basic usage
The sender has the screen you want to share of the webcam you want to access.
The receiver the is client that requests access to the screen of webcam, therefore the client is responsible to initiate the call.
On the client, to get the screen of another qube:
qubes-video-companion screenshare
On the client, to get the webcam of another qube:
qubes-video-companion webcam
On the client, if you installed the debug utilities, call cheese to access the shared screen or webcam:
cheese
Refer to upstream usage guide for more information.
Remote support usage
If you need to give or receive remote support, Qubes Video Companion is an excellent option for an easy to setup, view-only connection.
The qubes-remote-support is an option where the receiver exposes dom0 desktop to the support provider, it requires running a lot of code in dom0, such as Wormhole, tor (with Onion Authentication), an SSH server (with public key) and an X2Go server. It has some major downsides, network latency is capped by onion routing, shares the whole dom0 screen and has access to the shell, runs too many servers in the most privileged domain and Wormhole package was orphaned from Fedora repositories, meaning it doesn't work at this moment and fixes requires a maintainer upstream.
If you need a simple solution that is view-only, from which you can choose
which monitor to share, which qube to share the windows from, which network
chain to establish for the connection by choosing the netvm
, which
software to use to share the screen to such as pre-installed applications
(Firefox browser), qubes-video-companion is a great option for that.
Consider the following qube setup on the receiver side:
video-conference
: qube which you will run the conference applicationbroken
: qube which requires assistance
- On the qube
video-conference
, start the companion withqubes-video-companion screenshare
and choose thebroken
qube. - On the qube
video-conference
, start the conference application, can be from the web browser or a desktop application. Click to allow camera access, it will instead share thebroken
qube windows. The camera can appear mirrored/inverted for you, don't worry, the person on the other end will see the video correctly. - From the qube where you communicate with your remote support provider, share the necessary information for them to connect to the call.
The remote support provider only needs to connect to the call with the same application used by the client, which can be a web or desktop application. The intended use case is for visual diagnostics and instructional based support where the remote support recipient does the actions and the provider guides them.
There are also downsides to this method. The remote support provider can't do any tasks that requires write capabilities. The readability of the video might be low, depending on how many monitors are connected (the few, the better to set the correct resolution automatically without the user having to configure it), the font size. In case the receiver disconnects the screenshare or connects to the call before the starting the screenshare, they might need to exit and enter the call, reload the web page or disable and enable the camera permissions for the conference software to detect the camera.