Proxmox based VDI client
Go to file
2023-10-15 11:39:54 -05:00
dist Add HTTP config download option 2023-10-15 11:39:54 -05:00
screenshots Initial Commit 2022-03-07 16:56:54 -06:00
.gitignore Initial Commit 2022-03-07 16:56:54 -06:00
build_vdiclient.bat DPI Scaling Issue Fix 2022-03-14 21:24:36 -05:00
LICENSE Create LICENSE 2022-03-07 16:31:23 -06:00
README.md Add HTTP config download option 2023-10-15 11:39:54 -05:00
requirements.bat Remove PySimpleGuiQT support 2023-02-01 11:06:05 -06:00
requirements.sh Remove PySimpleGuiQT support 2023-02-01 11:06:05 -06:00
vdiclient.ini.example Add ability to disable remote-viewer kiosk mode 2023-10-13 16:04:19 -05:00
vdiclient.png Initial Commit 2022-03-07 16:56:54 -06:00
vdiclient.py Add HTTP config download option 2023-10-15 11:39:54 -05:00
vdiicon.ico Initial Commit 2022-03-07 16:56:54 -06:00

PVE VDI Client

This project's focus is to create a simple VDI client intended for mass deployment. This VDI client connects directly to Proxmox VE and allows users to connect (via Spice) to any VMs they have permission to access.

Login Screen

Login Screen with OTP

VDI View

Command Line Usage

No command line options are required for default behavior. The following command line options are available:

usage: vdiclient.py [-h] [--list_themes] [--config_type {file,http}] [--config_location CONFIG_LOCATION]
                    [--config_username CONFIG_USERNAME] [--config_password CONFIG_PASSWORD] [--ignore_ssl]

Proxmox VDI Client

options:
  -h, --help            show this help message and exit
  --list_themes         List all available themes
  --config_type {file,http}
                        Select config type (default: file)
  --config_location CONFIG_LOCATION
                        Specify the config location (default: search for config file)
  --config_username CONFIG_USERNAME
                        HTTP basic authentication username (default: None)
  --config_password CONFIG_PASSWORD
                        HTTP basic authentication password (default: None)
  --ignore_ssl          HTTPS ignore SSL certificate errors (default: False)

Windows Installation

You MUST install virt-viewer prior to using PVE VDI client, you may download it from the official Virtual Machine Manager site.

Please visit the releases section to download a prebuilt MSI package

If you need to customize the installation, such as to sign the executable and MSI, you may download and install the WIX toolset and use the build_vdiclient.bat file to build a new MSI.

you will need to download the latest 3.10 python release, and run the following commands to install the necessary packages:

requirements.bat

Linux Installation

Run the following commands on a Debian/Ubuntu Linux system to install the appropriate prerequisites

apt install python3-pip python3-tk virt-viewer git
git clone https://github.com/joshpatten/PVE-VDIClient.git
cd ./PVE-VDIClient/
chmod +x requirements.sh
./requirements.sh
cp vdiclient.py /usr/local/bin
chmod +x /usr/local/bin/vdiclient.py

Build Debian/Ubuntu Linux Binary

Run the following commands if you wish to build a binary on a Debian/Ubuntu Linux system

apt install python3-pip python3-tk virt-viewer git
git clone https://github.com/joshpatten/PVE-VDIClient.git
cd ./PVE-VDIClient/
chmod +x requirements.sh
./requirements.sh
pip3 install pyinstaller
pyinstaller --onefile --noconsole --noconfirm --hidden-import proxmoxer.backends --hidden-import proxmoxer.backends.https --hidden-import proxmoxer.backends.https.AuthenticationError --hidden-import proxmoxer.core --hidden-import proxmoxer.core.ResourceException --hidden-import subprocess.TimeoutExpired --hidden-import subprocess.CalledProcessError --hidden-import requests.exceptions --hidden-import requests.exceptions.ReadTimeout --hidden-import requests.exceptions.ConnectTimeout --hidden-import requests.exceptions.ConnectionError vdiclient.py

Once pyinstaller has finished your binary will be located in dist/vdiclient

Configuration File

PVE VDI Client REQUIRES a configuration file to function. The client searches for this file in the following locations unless --config is specified on the commmand line:

  • Windows
    • %APPDATA%\VDIClient\vdiclient.ini
    • %PROGRAMFILES%\VDIClient\vdiclient.ini
  • Linux
    • ~/.config/VDIClient/vdiclient.ini
    • /etc/vdiclient/vdiclient.ini
    • /usr/local/etc/vdiclient/vdiclient.ini

Please refer to vdiclient.ini.example for all available config file options

If you encounter any issues feel free to submit an issue report.

Proxmox Permission Requirements

Users that are accessing VDI instances need to have the following permissions assigned for each VM they access:

  • VM.PowerMgmt
  • VM.Console
  • VM.Audit