headplane_headscale_nix/headplane
2025-12-02 00:31:02 -07:00
..
.github chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.zed chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
agent chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
app chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
assets chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
docs chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
nix chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
patches chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
public chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.dockerignore chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.envrc chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.gitignore chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.npmrc chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
.tool-versions chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
agent.Dockerfile chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
biome.json chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
CHANGELOG.md chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
compose.yaml chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
config.example.yaml chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
Dockerfile chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
flake.lock chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
flake.nix chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
go.mod chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
go.sum chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
lefthook.yml chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
LICENSE chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
package.json chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
pnpm-lock.yaml chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
postcss.config.js chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
react-router.config.ts chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
README.md chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
tailwind.config.ts chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
tsconfig.json chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00
vite.config.ts chore: Cleanup unnecessary files and commit headplane patches 2025-12-02 00:31:02 -07:00

Headplane

A feature-complete web UI for Headscale

Preview

Headscale is the de-facto self-hosted version of Tailscale, a popular Wireguard based VPN service. By default, it does not ship with a web UI, which is where Headplane comes in. Headplane is a feature-complete web UI for Headscale, allowing you to manage your nodes, networks, and ACLs with ease.

Headplane aims to replicate the functionality offered by the official Tailscale product and dashboard, being one of the most feature complete Headscale UIs available. These are some of the features that Headplane offers:

  • Machine management, including expiry, network routing, name, and owner management
  • Access Control List (ACL) and tagging configuration for ACL enforcement
  • Support for OpenID Connect (OIDC) as a login provider
  • The ability to edit DNS settings and automatically provision Headscale
  • Configurability for Headscale's settings

Deployment

Headplane runs as a server-based web-application, meaning you'll need a server to run it. It's available as a Docker image (recommended) or through a manual installation. There are 2 ways to deploy Headplane:

  • Integrated Mode (Recommended)

    Integrated mode unlocks all the features of Headplane and is the most feature-complete deployment method. It communicates with Headscale directly.

  • Simple Mode

    Simple mode does not include the automatic management of DNS and Headplane settings, requiring manual editing and reloading when making changes.

Versioning

Headplane uses semantic versioning for its releases (since v0.6.0). Pre-release builds are available under the next tag and get updated when a new release PR is opened and actively in testing.

Contributing

Headplane is an open-source project and contributions are welcome! If you have any suggestions, bug reports, or feature requests, please open an issue. Also refer to the contributor guidelines for more info.


ACLs Machine Management

Copyright (c) 2025 Aarnav Tale