2021-04-06 04:41:55 +02:00
< h1 align = "center" > Wireguard Dashboard< / h1 >
2021-04-13 04:28:30 +02:00
2021-04-07 18:15:45 +02:00
< p align = "center" >
< img src = "http://ForTheBadge.com/images/badges/made-with-python.svg" >
< / p >
< p align = "center" >
2021-04-07 18:19:23 +02:00
< a href = "https://github.com/donaldzou/wireguard-dashboard/releases/latest" > < img src = "https://img.shields.io/github/v/release/donaldzou/wireguard-dashboard" > < / a >
2021-04-07 18:15:45 +02:00
< / p >
2021-04-06 22:51:37 +02:00
< p align = "center" > Monitoring Wireguard is not convinient, need to login into server and type < code > wg show< / code > . That's why this platform is being created, to view all configurations in a more straight forward way.< / p >
2021-04-03 03:12:46 +02:00
2021-04-07 23:25:21 +02:00
## 💡 Features
2021-04-03 03:12:46 +02:00
- Add peers in configuration
- Manage peer names
- Delete peers
- And many more coming up! Welcome to contribute to this project!
2021-04-07 23:25:21 +02:00
## 📝 Requirement
2021-04-03 03:12:46 +02:00
2020-10-23 23:51:11 +02:00
- Ubuntu 18.04.1 LTS, other OS might work, but haven't test yet.
2021-04-06 21:03:49 +02:00
- ‼️ Make sure you have **Wireguard** installed.‼️ < a href = "https://www.wireguard.com/install/" > How to install?</ a >
2020-10-18 08:09:14 +02:00
- Configuration files under ** /etc/wireguard**
2021-04-07 23:25:21 +02:00
** *Example `.conf` file***
```
[Interface]
Address = 192.168.0.1/24
SaveConfig = true
PostUp = iptables -A FORWARD -i wg0 -j ACCEPT; iptables -A FORWARD -o wg0 -j ACCEPT; iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
PostDown = iptables -D FORWARD -i wg0 -j ACCEPT; iptables -D FORWARD -o wg0 -j ACCEPT; iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE
ListenPort = 12345
PrivateKey = ABCDEFGHIJKLMNOPQRSTUVWXYZ1234
[Peer]
PublicKey = HABCDEFGHIJKLMNOPQRSTUVWXYZ123123123123
AllowedIPs = 192.168.0.2/32
...
```
2021-04-10 06:49:32 +02:00
**Note: For peers, `PublicKey` & `AllowedIPs` is required.**
2021-04-07 21:58:00 +02:00
- Python 3.7+ & Pip3
```
$ sudo apt-get install python3 python3-pip
```
2020-10-18 08:09:14 +02:00
2021-04-07 23:25:21 +02:00
## 🛠 Install
2021-04-03 03:12:46 +02:00
**1. Install Python Dependencies**
```
2021-04-03 03:15:28 +02:00
$ python3 -m pip install flask tinydb
2021-04-03 03:12:46 +02:00
```
**2. Install Wireguard Dashboard**
```
2021-04-03 03:14:51 +02:00
$ git clone https://github.com/donaldzou/Wireguard-Dashboard.git
2021-04-03 03:15:28 +02:00
$ cd Wireguard-Dashboard/src
$ python3 dashboard.py
2021-04-03 03:12:46 +02:00
```
Access your server with port `10086` ! e.g (http://your_server_ip:10086)
2021-04-12 17:05:19 +02:00
**3. Install with Production Mode (Optional), not tested yet. ‼️ Proceed with caution. ‼️**
2021-04-03 03:12:46 +02:00
```
2021-04-03 03:15:28 +02:00
$ cd Wireguard-Dashboard/src
$ export FLASK_APP=dashboard.py
$ export FLASK_RUN_HOST=0.0.0.0
$ export FLASK_ENV=development
$ export FLASK_DEBUG=0
$ flask run
2021-04-03 03:12:46 +02:00
```
2020-10-18 08:09:14 +02:00
2021-04-09 06:42:42 +02:00
## 🔍 Example
2020-10-22 02:30:16 +02:00
![Index Image ](https://github.com/donaldzou/Wireguard-Dashboard/raw/main/src/static/index.png )
2021-04-03 03:14:51 +02:00
![Conf Image ](https://github.com/donaldzou/Wireguard-Dashboard/raw/main/src/static/configuration.png )
2021-04-07 01:51:50 +02:00
2021-04-13 04:26:55 +02:00
## Contributors ✨
2021-04-13 04:28:30 +02:00
<!-- ALL - CONTRIBUTORS - BADGE:START - Do not remove or modify this section -->
2021-04-13 04:29:47 +02:00
[![All Contributors ](https://img.shields.io/badge/all_contributors-2-orange.svg?style=flat-square )](#contributors-)
2021-04-13 04:28:30 +02:00
<!-- ALL - CONTRIBUTORS - BADGE:END -->
2021-04-13 04:26:55 +02:00
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
<!-- ALL - CONTRIBUTORS - LIST:START - Do not remove or modify this section -->
<!-- prettier - ignore - start -->
<!-- markdownlint - disable -->
< table >
< tr >
< td align = "center" > < a href = "https://github.com/antonioag95" > < img src = "https://avatars.githubusercontent.com/u/30556866?v=4?s=100" width = "100px;" alt = "" / > < br / > < sub > < b > antonioag95< / b > < / sub > < / a > < br / > < a href = "https://github.com/donaldzou/wireguard-dashboard/commits?author=antonioag95" title = "Tests" > ⚠️< / a > < a href = "https://github.com/donaldzou/wireguard-dashboard/commits?author=antonioag95" title = "Code" > 💻< / a > < / td >
2021-04-13 04:29:47 +02:00
< td align = "center" > < a href = "https://github.com/tonjo" > < img src = "https://avatars.githubusercontent.com/u/4726289?v=4?s=100" width = "100px;" alt = "" / > < br / > < sub > < b > tonjo< / b > < / sub > < / a > < br / > < a href = "https://github.com/donaldzou/wireguard-dashboard/commits?author=tonjo" title = "Code" > 💻< / a > < / td >
2021-04-13 04:26:55 +02:00
< / tr >
< / table >
<!-- markdownlint - restore -->
<!-- prettier - ignore - end -->
<!-- ALL - CONTRIBUTORS - LIST:END -->
2021-04-13 04:28:30 +02:00
This project follows the [all-contributors ](https://github.com/all-contributors/all-contributors ) specification. Contributions of any kind welcome!