# WireGuard UI [![Build Status](https://github.com/EmbarkStudios/wg-ui/workflows/Build%20&%20Release/badge.svg?branch=master)](https://github.com/EmbarkStudios/wg-ui/actions) [![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.1.0](https://github.com/EmbarkStudios/wg-ui/releases/tag/v1.1.0) ## Features * Self-serve and web based * QR-Code for convenient mobile client configuration * Optional multi-user support behind an authenticating proxy * 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 -p 5555:5555 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. ## Install without Docker You need to have WireGuard installed on the machine running `wg-ui`. ### 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 - ``` ### 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 assets 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. [![FOSSA Status](https://app.fossa.io/api/projects/git%2Bgithub.com%2FEmbarkStudios%2Fwireguard-ui.svg?type=large)](https://app.fossa.io/projects/git%2Bgithub.com%2FEmbarkStudios%2Fwireguard-ui?ref=badge_large)