2019-12-31 10:50:02 +00:00
|
|
|
# wayvnc
|
2019-12-25 11:25:09 +00:00
|
|
|
|
|
|
|
## Introduction
|
2021-12-27 17:04:08 +00:00
|
|
|
This is a VNC server for wlroots-based Wayland compositors (:no_entry: Gnome
|
2021-12-27 17:07:52 +00:00
|
|
|
and KDE are **not** supported). It attaches to a running Wayland session,
|
2021-12-27 17:04:08 +00:00
|
|
|
creates virtual input devices, and exposes a single display via the RFB
|
|
|
|
protocol. The Wayland session may be a headless one, so it is also possible
|
|
|
|
to run wayvnc without a physical display attached.
|
2019-12-25 11:25:09 +00:00
|
|
|
|
2020-02-18 22:16:03 +00:00
|
|
|
Please check the [FAQ](FAQ.md) for answers to common questions. For further
|
2021-05-28 11:09:50 +00:00
|
|
|
support, join the #wayvnc IRC channel on libera.chat, or ask your questions on the
|
2020-12-31 13:25:07 +00:00
|
|
|
GitHub [discussion forum](https://github.com/any1/wayvnc/discussions) for the
|
|
|
|
project.
|
2020-01-25 20:40:43 +00:00
|
|
|
|
2020-03-21 16:43:02 +00:00
|
|
|
## Installing
|
|
|
|
```
|
2021-11-01 10:33:25 +00:00
|
|
|
# Arch Linux
|
2021-04-10 12:45:00 +00:00
|
|
|
pacman -S wayvnc
|
2020-03-21 16:43:02 +00:00
|
|
|
|
2020-11-03 23:33:23 +00:00
|
|
|
# FreeBSD
|
2020-04-10 12:48:04 +00:00
|
|
|
pkg install wayvnc
|
|
|
|
|
2020-11-03 23:33:23 +00:00
|
|
|
# Fedora
|
2020-05-06 22:00:03 +00:00
|
|
|
dnf install wayvnc
|
|
|
|
|
2022-02-26 01:03:55 +00:00
|
|
|
# Debian (unstable / testing)
|
|
|
|
apt install wayvnc
|
|
|
|
|
2020-11-03 23:33:23 +00:00
|
|
|
# openSUSE Tumbleweed
|
2020-08-18 10:35:41 +00:00
|
|
|
zypper install wayvnc
|
|
|
|
|
2020-11-03 23:33:23 +00:00
|
|
|
# Void Linux
|
2020-08-21 23:45:39 +00:00
|
|
|
xbps-install wayvnc
|
|
|
|
```
|
|
|
|
|
2019-12-25 11:25:09 +00:00
|
|
|
## Building
|
|
|
|
### Runtime Dependencies
|
2020-03-21 16:56:30 +00:00
|
|
|
* aml
|
2020-06-25 21:40:04 +00:00
|
|
|
* drm
|
2020-11-03 23:35:53 +00:00
|
|
|
* gbm (optional)
|
2019-12-25 11:25:09 +00:00
|
|
|
* libxkbcommon
|
|
|
|
* neatvnc
|
2020-11-03 23:35:53 +00:00
|
|
|
* pam (optional)
|
2019-12-25 11:25:09 +00:00
|
|
|
* pixman
|
|
|
|
|
|
|
|
### Build Dependencies
|
|
|
|
* GCC
|
|
|
|
* meson
|
|
|
|
* ninja
|
|
|
|
* pkg-config
|
|
|
|
|
2021-11-01 10:33:25 +00:00
|
|
|
#### For Arch Linux
|
2020-03-21 16:38:34 +00:00
|
|
|
```
|
2020-03-21 16:56:30 +00:00
|
|
|
pacman -S base-devel libglvnd libxkbcommon pixman gnutls
|
2020-03-21 16:38:34 +00:00
|
|
|
```
|
|
|
|
|
2021-11-01 10:33:25 +00:00
|
|
|
#### For Fedora 31
|
2020-03-15 18:28:05 +00:00
|
|
|
```
|
2020-03-21 16:31:55 +00:00
|
|
|
dnf install -y meson gcc ninja-build pkg-config egl-wayland egl-wayland-devel \
|
|
|
|
mesa-libEGL-devel mesa-libEGL libwayland-egl libglvnd-devel \
|
|
|
|
libglvnd-core-devel libglvnd mesa-libGLES-devel mesa-libGLES \
|
2020-03-21 16:38:34 +00:00
|
|
|
libxkbcommon-devel libxkbcommon libwayland-client libwayland \
|
2020-03-21 16:31:55 +00:00
|
|
|
wayland-devel gnutls-devel
|
2020-03-15 18:28:05 +00:00
|
|
|
```
|
|
|
|
|
2022-02-26 01:03:55 +00:00
|
|
|
#### For Debian (unstable / testing)
|
|
|
|
```
|
|
|
|
apt build-dep wayvnc
|
|
|
|
```
|
2020-03-21 16:56:30 +00:00
|
|
|
The easiest way to satisfy the neatvnc and aml dependencies is to link to them
|
|
|
|
in the subprojects directory:
|
2019-12-25 11:25:09 +00:00
|
|
|
```
|
2020-03-21 16:56:30 +00:00
|
|
|
git clone https://github.com/any1/wayvnc.git
|
|
|
|
git clone https://github.com/any1/neatvnc.git
|
|
|
|
git clone https://github.com/any1/aml.git
|
|
|
|
|
|
|
|
mkdir wayvnc/subprojects
|
|
|
|
cd wayvnc/subprojects
|
|
|
|
ln -s ../../neatvnc .
|
|
|
|
ln -s ../../aml .
|
|
|
|
cd -
|
|
|
|
|
|
|
|
mkdir neatvnc/subprojects
|
|
|
|
cd neatvnc/subprojects
|
|
|
|
ln -s ../../aml .
|
|
|
|
cd -
|
2019-12-25 11:25:09 +00:00
|
|
|
|
2020-04-17 23:30:29 +00:00
|
|
|
meson build
|
2019-12-25 11:25:09 +00:00
|
|
|
ninja -C build
|
|
|
|
```
|
|
|
|
|
2019-12-31 10:50:02 +00:00
|
|
|
## Running
|
2019-12-25 11:25:09 +00:00
|
|
|
Wayvnc can be run from the build directory like so:
|
|
|
|
```
|
|
|
|
./build/wayvnc
|
|
|
|
```
|
2019-12-31 10:50:02 +00:00
|
|
|
|
|
|
|
:radioactive: The server only accepts connections from localhost by default. To
|
|
|
|
accept connections via any interface, set the address to `0.0.0.0` like this:
|
|
|
|
```
|
|
|
|
./build/wayvnc 0.0.0.0
|
|
|
|
```
|
|
|
|
|
2020-01-18 20:48:46 +00:00
|
|
|
:warning: Do not do this on a public network or the internet without
|
|
|
|
user authentication enabled. The best way to protect your VNC connection is to
|
|
|
|
use SSH tunneling while listening on localhost, but users can also be
|
2021-11-01 10:33:25 +00:00
|
|
|
authenticated when connecting to wayvnc.
|
2020-01-18 20:48:46 +00:00
|
|
|
|
2020-01-29 21:20:14 +00:00
|
|
|
### Encryption & Authentication
|
2021-11-01 10:33:25 +00:00
|
|
|
You'll need a private X509 key and a certificate. A self-signed key with a
|
2020-01-18 20:48:46 +00:00
|
|
|
certificate can be generated like so:
|
|
|
|
```
|
|
|
|
openssl req -x509 -newkey rsa:4096 -sha256 -days 3650 -nodes \
|
|
|
|
-keyout key.pem -out cert.pem -subj /CN=localhost \
|
|
|
|
-addext subjectAltName=DNS:localhost,DNS:localhost,IP:127.0.0.1
|
|
|
|
```
|
|
|
|
Replace `localhost` and `127.0.0.1` in the command above with your public facing
|
|
|
|
host name and IP address, respectively, or just keep them as is if you're
|
|
|
|
testing locally.
|
|
|
|
|
|
|
|
Create a config with the authentication info and load it using the `--config`
|
|
|
|
command line option or place it at the default location
|
|
|
|
`$HOME/.config/wayvnc/config`.
|
|
|
|
```
|
|
|
|
address=0.0.0.0
|
|
|
|
enable_auth=true
|
|
|
|
username=luser
|
|
|
|
password=p455w0rd
|
|
|
|
private_key_file=/path/to/key.pem
|
|
|
|
certificate_file=/path/to/cert.pem
|
|
|
|
```
|
2020-01-25 20:29:42 +00:00
|
|
|
|
|
|
|
## Compatible Software
|
|
|
|
See https://github.com/any1/neatvnc#client-compatibility
|