Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/embarkstudios/wg-ui
WireGuard Web UI for self-serve client configurations, with optional auth.
https://github.com/embarkstudios/wg-ui
go svelte ui vpn web web-ui wg-ui wireguard
Last synced: 1 day ago
JSON representation
WireGuard Web UI for self-serve client configurations, with optional auth.
- Host: GitHub
- URL: https://github.com/embarkstudios/wg-ui
- Owner: EmbarkStudios
- License: apache-2.0
- Archived: true
- Created: 2019-04-30T10:17:09.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2023-04-12T08:45:42.000Z (almost 2 years ago)
- Last Synced: 2024-10-31T06:34:54.644Z (3 months ago)
- Topics: go, svelte, ui, vpn, web, web-ui, wg-ui, wireguard
- Language: Go
- Homepage:
- Size: 1.55 MB
- Stars: 1,497
- Watchers: 32
- Forks: 130
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE-APACHE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# WG UI
![Build Status](https://github.com/EmbarkStudios/wg-ui/actions/workflows/push_master.yaml/badge.svg)
[![Embark](https://img.shields.io/badge/embark-open%20source-blueviolet.svg)](https://github.com/EmbarkStudios)
[![Contributor Covenant](https://img.shields.io/badge/contributor%20covenant-v1.4%20adopted-ff69b4.svg)](CODE_OF_CONDUCT.md)A basic, self-contained management service for [WireGuard](https://wireguard.com) with a self-serve web UI.
Current stable release: [v1.3.0](https://github.com/EmbarkStudios/wg-ui/releases/tag/v1.3.0)## Features
* Self-serve and web based
* QR-Code for convenient mobile client configuration
* Optional multi-user support behind an authenticating proxy
* Simple authentication support
* Zero external dependencies - just a single binary using the wireguard kernel module
* Binary and container deployment![Screenshot](wireguard-ui.png)
## Running
The easiest way to run wg-ui is using the container image. To test it, run:
```docker run --rm -it --privileged --entrypoint "/wireguard-ui" -v /tmp/wireguard-ui:/data -p 8080:8080 embarkstudios/wireguard-ui:latest --data-dir=/data --log-level=debug```
When running in production, we recommend using the latest release as opposed to `latest`.
Important to know is that you need to have WireGuard installed on the machine in order for this to work, as this is 'just' a UI to manage WireGuard configs.
### Configuration
You can configure wg-ui using commandline flags or environment variables.
To see all available flags run:```
docker run --rm -it embarkstudios/wireguard-ui:latest -h
./wireguard-ui -h
```You can alternatively specify each flag through an environment variable of the form `WIREGUARD_UI_`, where `` is replaced with the flag name transformed to `CONSTANT_CASE`, e.g.
```docker run --rm -it embarkstudios/wireguard-ui:latest --log-level=debug```
and
```docker run --rm -it -e WIREGUARD_UI_LOG_LEVEL=debug embarkstudios/wireguard-ui:latest```
are the same.
### Authentication
You can configure basic authentication using the flags/environment variables `--auth-basic-user=` and `--auth-basic-pass=` The password is
a bcrypt hash that you can generate yourself using the docker container:
```
$ docker run -it embarkstudios/wireguard-ui:latest passwd mySecretPass
INFO[0001] Password Hash: $2a$14$D2jsPnpJixC0U0lyaGUd0OatV7QGzQ08yKV.gsmITVZgNevfZXj36
```## Docker images
There are two ways to run wg-ui today, you can run it with kernel module installed on your host which is the best way to do it if you want performance.
```
docker pull embarkstudios/wireguard-ui:latest
```If you however do not have the possibility or interest in having kernel module loaded on your host, there is now a solution for that using a docker image based on wireguard-go. Keep in mind that this runs in userspace and not in kernel module.
```
docker pull embarkstudios/wireguard-ui:userspace
```Both images are built for `linux/amd64`, `linux/arm64` and `linux/arm/v7`. If you would need it for any other platform you can build wg-ui binaries with help from the documentation.
## Install without Docker
You need to have WireGuard installed on the machine running `wg-ui`.
Unless you use the userspace version with docker you're required to have WireGuard installed on your host machine.
A few installation guides:
[Ubuntu 20.04 LTS](https://www.cyberciti.biz/faq/ubuntu-20-04-set-up-wireguard-vpn-server/)
[CentOS 8](https://www.cyberciti.biz/faq/centos-8-set-up-wireguard-vpn-server/)
[Debian 10](https://www.cyberciti.biz/faq/debian-10-set-up-wireguard-vpn-server/)### Go installation (Debian)
Install latest version of Go from (https://golang.org/dl/)```
sudo tar -C /usr/local -xzf go$VERSION.$OS-$ARCH.tar.gz
```### Setup environment
Bash: ~/.bash_profile
ZSH: ~/.zshrc```
export PATH=$PATH:/usr/local/go/bin:$HOME/go/bin
export GOPATH=$HOME/go
```### Install LTS version of nodejs for frontend.
```
sudo apt-get install curl software-properties-common
curl -sL https://deb.nodesource.com/setup_12.x | sudo bash -
sudo apt-get install nodejs
```### Fetch wg-ui
```
git clone https://github.com/EmbarkStudios/wg-ui.git && cd wg-ui
```### Build binary with ui
```
make build
```### Crosscompiling
```
make build-amd64
``````
make build-armv5
``````
make build-armv6
``````
make build-armv7
```### Build step by step
```
make ui
make build
```## Developing
### Start frontend server
```
npm install --prefix=ui
npm run --prefix=ui dev
```### Use frontend server when running the server
```
make build
sudo ./bin/wireguard-ui --log-level=debug --dev-ui-server http://localhost:5000
```## Contributing
We welcome community contributions to this project.
Please read our [Contributor Guide](CONTRIBUTING.md) for more information on how to get started.
## License
Licensed under either of* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.