A feature-complete Web UI for Headscale
Go to file
David Gillespie dbdb759a7e
Some checks failed
Build / native (push) Has been cancelled
Build / nix (push) Has been cancelled
Release / Docker Release (push) Has been cancelled
Automated / flake-inputs (push) Has been cancelled
update tailwind
2025-05-09 23:44:57 -06:00
.github ci: skip ci build on certain paths 2025-04-05 12:07:31 -04:00
.zed feat: rework github actions 2025-03-24 16:49:54 -04:00
agent feat: switch agent fetching to the server side 2025-03-24 16:15:38 -04:00
app feat: add filtering by container label for Docker integration (#194) 2025-04-24 19:03:33 -04:00
assets docs: redo docs 2025-02-27 15:31:16 -05:00
docs feat: add filtering by container label for Docker integration (#194) 2025-04-24 19:03:33 -04:00
nix chore: update nix hash 2025-04-02 13:40:50 -04:00
patches fix: serve css and js assets correctly 2025-04-02 14:27:23 -04:00
public chore: initial commit from create-remix 2024-03-25 17:50:10 -04:00
.dockerignore feat: add docker build 2024-03-26 10:10:34 -04:00
.envrc feat: add a nix flake (#132) 2025-03-18 00:31:37 -04:00
.gitignore chore: update to headscale 0.25.1 2025-04-03 12:57:06 -04:00
.npmrc fix: allow hostname passthrough for hono node 2025-03-24 16:15:38 -04:00
.tool-versions chore: update dep tooling 2025-04-04 16:06:22 -04:00
agent.Dockerfile feat: containerize agent 2025-01-15 10:17:30 +05:30
biome.json chore: update dep tooling 2025-04-04 16:06:22 -04:00
CHANGELOG.md chore: v0.5.10 2025-04-03 23:44:19 -04:00
compose.yaml feat: add filtering by container label for Docker integration (#194) 2025-04-24 19:03:33 -04:00
config.example.yaml feat: add filtering by container label for Docker integration (#194) 2025-04-24 19:03:33 -04:00
Dockerfile chore: auto-create /var/lib/headscale in docker 2025-04-03 12:57:55 -04:00
flake.lock chore: update flake.lock (#202) 2025-05-04 15:25:02 -04:00
flake.nix feat: add a nix flake (#132) 2025-03-18 00:31:37 -04:00
go.mod feat: create initial agent for localapi 2024-12-30 13:48:49 +05:30
go.sum feat: create initial agent for localapi 2024-12-30 13:48:49 +05:30
lefthook.yml chore: add lefthook for lint staged 2025-01-20 08:26:00 +00:00
LICENSE chore: add license and readme again 2024-03-26 10:24:28 -04:00
package.json update tailwind 2025-05-09 23:44:57 -06:00
pnpm-lock.yaml fix: serve css and js assets correctly 2025-04-02 14:27:23 -04:00
postcss.config.js update tailwind 2025-05-09 23:44:57 -06:00
react-router.config.ts feat: bundle node_modules into the server 2025-03-24 16:15:38 -04:00
README.md docs: mention versioning policy 2025-04-04 15:44:16 -04:00
tailwind.config.ts chore: switch tailwind fonts 2025-01-20 08:15:14 +00:00
tsconfig.json chore: switch to vite for server dev 2025-01-17 08:33:22 +00:00
vite.config.ts fix: only use basename in ssr build 2025-04-03 12:57:06 -04: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