2023-10-26 10:42:18 +00:00
# WireGuard Portal (v2 - testing)
2020-11-10 21:23:05 +00:00
2025-01-23 07:06:55 +00:00
[data:image/s3,"s3://crabby-images/aa8e6/aa8e6093495910b93a4f96c134e6490d528c63c8" alt="Build Status "](https://github.com/h44z/wg-portal/actions/workflows/docker-publish.yml)
2020-11-16 22:13:15 +00:00
[data:image/s3,"s3://crabby-images/97b9e/97b9eb32e1321c540e16d6c9c86763a230fb727e" alt="License: MIT "](https://opensource.org/licenses/MIT)
2025-01-23 07:06:55 +00:00
data:image/s3,"s3://crabby-images/37065/37065a158ab5b1557b1bb48b677ff3bed493437d" alt="GitHub last commit "
2021-02-26 22:13:11 +00:00
[data:image/s3,"s3://crabby-images/a40bf/a40bf35af825fe8241c9585b80c6c9cddbd97860" alt="Go Report Card "](https://goreportcard.com/report/github.com/h44z/wg-portal)
2020-11-16 22:13:15 +00:00
data:image/s3,"s3://crabby-images/58157/581570321509dae514ba28d04ec959e6ba43cb60" alt="GitHub go.mod Go version "
data:image/s3,"s3://crabby-images/2fab6/2fab6ecb24672db190a194d046eb7c3bb77905d5" alt="GitHub code size in bytes "
2023-10-26 10:42:18 +00:00
[data:image/s3,"s3://crabby-images/c664b/c664b8bfd51a0d9ca8b056ae6d3f05cf3e856fda" alt="Docker Pulls "](https://hub.docker.com/r/wgportal/wg-portal/)
2020-11-16 22:13:15 +00:00
2025-01-23 07:06:55 +00:00
> [!CAUTION]
> Version 2 is currently under development and may contain bugs and breaking changes.
> It is not advised to use this version in production. Use version [v1](https://github.com/h44z/wg-portal/tree/stable) instead.
2023-10-26 10:42:18 +00:00
2025-01-23 07:06:55 +00:00
> [!IMPORTANT]
> Since the project was accepted by the Docker-Sponsored Open Source Program, the Docker image location has moved to [wgportal/wg-portal](https://hub.docker.com/r/wgportal/wg-portal).
> Please update the Docker image from **h44z/wg-portal** to **wgportal/wg-portal**.
2023-08-04 11:34:18 +00:00
2025-01-23 07:06:55 +00:00
## Introduction
<!-- Text from this line # is included in docs/documentation/overview.md -->
**WireGuard Portal** is a simple, web-based configuration portal for [WireGuard ](https://wireguard.com ) server management.
2022-03-15 21:46:00 +00:00
The portal uses the WireGuard [wgctrl ](https://github.com/WireGuard/wgctrl-go ) library to manage existing VPN
2025-01-23 07:06:55 +00:00
interfaces. This allows for the seamless activation or deactivation of new users without disturbing existing VPN
2020-11-16 22:13:15 +00:00
connections.
2025-01-23 07:06:55 +00:00
The configuration portal supports using a database (SQLite, MySQL, MsSQL or Postgres), OAuth or LDAP
(Active Directory or OpenLDAP) as a user source for authentication and profile data.
2020-11-16 22:13:15 +00:00
## Features
2025-01-23 07:06:55 +00:00
* Self-hosted - the whole application is a single binary
* Responsive multi-language web UI written in Vue.JS
* Automatically selects IP from the network pool assigned to the client
* QR-Code for convenient mobile client configuration
* Sends email to the client with QR-code and client config
* Enable / Disable clients seamlessly
* Generation of wg-quick configuration file (`wgX.conf`) if required
* User authentication (database, OAuth, or LDAP)
* IPv6 ready
* Docker ready
* Can be used with existing WireGuard setups
* Support for multiple WireGuard interfaces
* Peer Expiry Feature
* Handles route and DNS settings like wg-quick does
* Exposes Prometheus metrics for monitoring and alertingt
* REST API for management and client deployment
<!-- Text to this line # is included in docs/documentation/overview.md -->
data:image/s3,"s3://crabby-images/868aa/868aada4cb772c5b1b21ca1638dbf520962d8e0c" alt="Screenshot "
## Documentation
For the complete documentation visit [wgportal.org ](https://wgportal.org ).
2022-11-11 16:10:41 +00:00
2023-08-04 11:34:18 +00:00
## V2 TODOs
2022-11-11 16:10:41 +00:00
2025-01-23 07:06:55 +00:00
* Audit UI
2021-04-26 20:00:50 +00:00
2020-11-16 22:13:15 +00:00
## What is out of scope
2023-08-04 11:34:18 +00:00
2025-01-23 07:06:55 +00:00
* Automatic generation or application of any `iptables` or `nftables` rules.
* Support for operating systems other than linux.
* Automatic import of private keys of an existing WireGuard setup.
2022-03-15 21:46:00 +00:00
2020-11-16 22:13:15 +00:00
## Application stack
2025-01-23 07:06:55 +00:00
* [wgctrl-go ](https://github.com/WireGuard/wgctrl-go ) and [netlink ](https://github.com/vishvananda/netlink ) for interface handling
* [Gin ](https://github.com/gin-gonic/gin ), HTTP web framework written in Go
* [Bootstrap ](https://getbootstrap.com/ ), for the HTML templates
* [Vue.JS ](https://vuejs.org/ ), for the frontend
2020-11-16 22:13:15 +00:00
## License
2025-01-23 07:06:55 +00:00
* MIT License. [MIT ](LICENSE.txt ) or < https: // opensource . org / licenses / MIT >