Skip to content
/ rustguac Public

Lightweight Rust replacement for Apache Guacamole — browser-based SSH, RDP, and web sessions via guacd

License

Notifications You must be signed in to change notification settings

sol1/rustguac

Repository files navigation

rustguac

A lightweight Rust replacement for the Apache Guacamole Java webapp. Provides browser-based SSH, RDP, and web browsing sessions through guacd (the Guacamole protocol daemon).

rustguac sits between web browsers and guacd, proxying the Guacamole protocol over WebSockets. It manages session lifecycle, authentication (API keys and OIDC SSO), session recording, and browser-based VNC sessions (Xvnc + Chromium).

Features

  • SSH sessions — browser-based SSH terminal via guacd, with ephemeral keypair or manual private key auth
  • RDP sessions — connect to Windows/RDP hosts via guacd
  • Web browser sessions — headless Chromium on Xvnc, streamed to the browser via VNC
  • OIDC single sign-on — authenticate users via any OpenID Connect provider (Authentik, Google, Okta, etc.)
  • Role-based access — admin, poweruser, operator, and viewer roles for both API key and OIDC users
  • Vault-backed address book — connection credentials stored in HashiCorp Vault / OpenBao, never reach the browser
  • TLS everywhere — HTTPS for clients, TLS between rustguac and guacd
  • Session recording — all sessions recorded in Guacamole format with playback UI
  • Session sharing — share tokens for read-only or collaborative access
  • Encrypted file transfer — LUKS-encrypted per-session drive storage for RDP
  • API key auth — SHA-256 hashed keys with IP allowlists and expiry
  • SQLite storage — no external database server needed
  • Single binary — just rustguac + guacd, no Java stack

Architecture

Browser (HTML/JS)
    |
    | WebSocket over HTTPS
    v
rustguac (Rust, axum)
    |
    | TLS (Guacamole protocol)
    v
guacd (C, from guacamole-server)
    |
    +---> SSH server (for SSH sessions)
    +---> RDP server (for RDP sessions)
    +---> Xvnc display (for web browser sessions)
              |
              +---> Chromium (kiosk mode)

Quick start

Debian 13 (.deb) — download from Releases:

sudo apt install ./rustguac_*.deb

Docker:

docker pull sol1/rustguac:latest
docker run -d -p 8089:8089 sol1/rustguac:latest

RPM (Rocky/RHEL 9):

sudo dnf install ./rustguac-*.rpm

After install, create an admin API key to get started:

/opt/rustguac/bin/rustguac --config /opt/rustguac/config.toml add-admin --name admin

API keys are intended for machine access and initial setup. Once you configure OIDC authentication, you can delete the API key — no credentials are stored in the database.

See the Installation guide for full details including bare-metal install, Docker Compose, TLS setup, and development builds.

Documentation

Commercial support

Commercial support for rustguac is available from Sol1.

License

Apache License 2.0 — see LICENSE for details.

About

Lightweight Rust replacement for Apache Guacamole — browser-based SSH, RDP, and web sessions via guacd

Topics

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •