mirror of
https://github.com/h44z/wg-portal
synced 2025-02-26 05:49:14 +00:00
* [docs] big bang update * Simplified polluted README.md by moving parts to the documentation * Removed duplicates with `pymdownx.snippets` extension * Enabled code copy * Extended "Getting Started" * Added "Monitoring" page * Separated "Upgrade" page * Added default config yaml to docs Signed-off-by: Dmytro Bondar <git@bonddim.dev> * Update sources.md Co-authored-by: h44z <christoph.h@sprinternet.at> --------- Signed-off-by: Dmytro Bondar <git@bonddim.dev> Co-authored-by: h44z <christoph.h@sprinternet.at>
75 lines
3.6 KiB
Markdown
75 lines
3.6 KiB
Markdown
# WireGuard Portal (v2 - testing)
|
|
|
|
[data:image/s3,"s3://crabby-images/8bed3/8bed32dfbddf61fcd43f6560a6321a22e2cfa323" alt="Build Status"](https://github.com/h44z/wg-portal/actions/workflows/docker-publish.yml)
|
|
[data:image/s3,"s3://crabby-images/a6d36/a6d36c750f205f1b0294ad766af3fb3737f99c6f" alt="License: MIT"](https://opensource.org/licenses/MIT)
|
|
data:image/s3,"s3://crabby-images/bfae7/bfae76daf07ae49eccfa7c9ccfe4248d83498721" alt="GitHub last commit"
|
|
[data:image/s3,"s3://crabby-images/9cc63/9cc6314aca1c016324fbc9c0bb20b9573c7536bf" alt="Go Report Card"](https://goreportcard.com/report/github.com/h44z/wg-portal)
|
|
data:image/s3,"s3://crabby-images/25465/25465741a005bf228f68bd071fce058cfd4d6265" alt="GitHub go.mod Go version"
|
|
data:image/s3,"s3://crabby-images/0f0bc/0f0bc0abba2e45a5721bc141fe6221080e8aef11" alt="GitHub code size in bytes"
|
|
[data:image/s3,"s3://crabby-images/371c9/371c9b1875b38d2adadefab5502ab56b31ea4667" alt="Docker Pulls"](https://hub.docker.com/r/wgportal/wg-portal/)
|
|
|
|
> [!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.
|
|
|
|
> [!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**.
|
|
|
|
## 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.
|
|
The portal uses the WireGuard [wgctrl](https://github.com/WireGuard/wgctrl-go) library to manage existing VPN
|
|
interfaces. This allows for the seamless activation or deactivation of new users without disturbing existing VPN
|
|
connections.
|
|
|
|
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.
|
|
|
|
## Features
|
|
|
|
* 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/633cb/633cb5d74023edd90705ccba678f540fd6fa1f02" alt="Screenshot"
|
|
|
|
## Documentation
|
|
|
|
For the complete documentation visit [wgportal.org](https://wgportal.org).
|
|
|
|
## V2 TODOs
|
|
|
|
* Audit UI
|
|
|
|
## What is out of scope
|
|
|
|
* 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.
|
|
|
|
## Application stack
|
|
|
|
* [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
|
|
|
|
## License
|
|
|
|
* MIT License. [MIT](LICENSE.txt) or <https://opensource.org/licenses/MIT>
|