/Kali-xRDP

Kali xRDP GUI for WSL1 & WSL2

Primary LanguageBatchfile

Other distributions available: KDE Neon (kWSL) and Ubuntu 20.04 (xWSL)

Kali-xRDP is a script that installs xRDP and XFCE 4.16 on top of Kali Linux from the Windows Store. Win-KeX is the better-known method for running a GUI in WSL, but only works with Windows 10 1903+ on WSL2, whereas this project was created to work well in WSL1 or WSL2. It includes optimizations and visual tweaks for a smooth and responsive desktop experience. Display scaling is configured automatically and works on everything from standard unscaled displays all the way to xHiDPI (250%+) displays such as the Microsoft Surface.

ScreenShot

Kali-xRDP works with Windows 10 version 1809 onwards, Windows Server 2019/2022, Server Core, or Hyper-V Server. Running Kali in WSL1 may be useful for users on older hardware without VT-d, or in a virtual machine without nested virtualization support. Note that WSL1 has limitations in its networking stack that prevent some of Kali's included tools from working as they should, so it's advisable to run Kali in WSL2 unless you're prevented from doing so for the reasons listed above. That said, ZenMap is pre-installed and able to run TCP-only portscans in WSL1.

The install script is meant to be run on a new Kali Linux installation from the Microsoft Store. If Kali is not installed on your system it will download the .AppX image directly from Microsoft and install it for you.

INSTRUCTIONS: Open a NEW elevated command prompt window (admin rights are required to open firewall ports for RDP and SSH) then type/paste the following command:

PowerShell -executionpolicy bypass -command "wget https://github.com/DesktopECHO/Kali-xRDP/raw/main/Kali-xRDP.cmd -UseBasicParsing -OutFile Kali-xRDP.cmd ; .\Kali-xRDP.cmd"

You will be asked a few questions. The installer script determines the current Windows DPI scaling of your system but you may set your own if preferred:

 [Kali xRDP Installer 20210602]

 Hit Enter to use your current display scaling in Windows
 or set the desired value (1.0 to 3.0 in .25 increments) [1.5]: 1.25
 Port number for xRDP traffic or hit Enter for default [3399]:
 Port number for SSHd traffic or hit Enter for default [3322]:
 [Not recommended!] Type X to eXclude from Windows Defender:

The script will download the LxRunOffline distro manager to bootstrap the installation. Install times will vary depending on system performance and the presence of antivirus software. A fast system with broadband Internet can complete the install in under 10 minutes and most machines will complete within 20 minutes. Expect it to take 30+ minutes if Windows Defender is running. If you want to track progress logs are located in %TEMP%\Kali-xRDP.

 [22:18:12] Prepare Distro (~1m00s)
 [22:19:08] Install xRDP and Kali-Linux-Core packages (~3m00s)
 [22:22:53] Kali-Desktop-XFCE (~5m00s)
 [22:30:39] Additional Components (~1m00s)

At the end of the script you will be prompted to create a non-root user which will automatically be added to sudo'ers.

 Create a NEW user in Kali for xRDP GUI login. Enter username: kaliuser
 Enter password for kaliuser: **********

Open Windows Firewall Ports for xRDP, SSH, mDNS...
Building RDP Connection file, Init system...
Building Scheduled Task...
SUCCESS: The scheduled task "kali-linux" has successfully been created.

       Start: Thu 02/25/2021 @ 22:17
         End: Thu 02/25/2021 @ 22:31
    Packages: 1154

   - xRDP Server listening on port 3399 and SSHd on port 3322.

   - Link for GUI session has been placed on your desktop.

   - (Re)launch init from the Task Scheduler or by running the following command:
     schtasks.exe /run /tn kali-linux

  Installaion of xRDP GUI on "kali-linux" complete, graphical login will start in a few seconds...

A fullscreen remote desktop session will launch Kali using your stored credentials.

Configure Kali-xRDP to start at boot (like a service, no console window)

  • Open the Windows Task Scheduler
  • Right-click the task in Task Scheduler (kali-linux) and click properties
  • Click the checkbox for Run whether user is logged on or not and click OK
  • Enter your Windows credentials when prompted

Reboot your PC when complete and the xRDP service in Kali will startup automatically with your system.

Start/Stop Operation

  • Start (or restart) the instance: schtasks /run /tn kali-linux
  • Terminate the instance: wslconfig /t kali-linux

Convert to WSL2 instance

If your computer has virtualization support you can convert the instance to WSL2 (and back to WSL1 if needed.)

  • Terminate the instance: wslconfig /t kali-linux
  • Convert the instance to WSL2: wsl --set-version kali-linux 2
  • Restart the Instance: schtasks /run /tn kali-linux

Make it your own:

From a security perspective, you should fork this project so you control the packages and files in the repository. This also allows you to customize the installer in any way you prefer:

  • Sign into GitHub and fork this project
  • Edit Kali-xRDP.cmd. On line 2 you will see SET GITORG=DesktopECHO - Change DesktopECHO to the name of your own repository.
  • Customize the script any way you prefer.
  • Launch the script using your repository name: PowerShell -executionpolicy bypass -command "wget https://github.com/YOUR-ORG/Kali-xRDP/raw/main/Kali-xRDP.cmd -UseBasicParsing -OutFile Kali-xRDP.cmd ; .\Kali-xRDP.cmd"

Additional Info:

  • Rebuilt WebKitGTK 2.32 for WSL
  • When you log out out of a desktop session the entire WSL instance is restarted, equivalent to a clean-boot at every login.
  • Disconnected sessions continue to run in the background and resuming your session works reliably.
  • Enabled gksu for apps needing elevated rights (Synaptic, root console) to work around limitations in WSL1.
  • apt-fast added to improve download speed and reliability.
  • Mozilla Seamonkey included as a stable browser that's kept up to date via apt. Current versions of Chrome/Firefox do not work in WSL1.
  • Installed base image consumes approximately 3GB of storage
  • Minor visual tweaks were made and fonts in XFCE4 are supplied by the host OS (Segoe UI / Cascadia Code)

image image