Files
Wireguard-Peer-Manager/README.md

38 lines
1.3 KiB
Markdown
Raw Normal View History

2021-05-06 17:36:18 +03:00
# Wireguard-Peer-Manager
2021-05-06 08:30:51 -07:00
![image](https://user-images.githubusercontent.com/4666566/117325184-56f7f800-ae45-11eb-9003-b85aadbf5ff0.png)
2021-05-06 07:56:00 -07:00
Adds Wireguard peers to config, reload it and send client config back via Telegram.
2021-05-06 07:57:21 -07:00
2021-05-06 07:56:00 -07:00
**FYI: That tool stores client private keys into server config as comments.**
2021-05-06 08:58:05 -07:00
Is a good idea to update https://github.com/house-of-vanity/Wireguard-Peer-Manager/blob/b914707e06f807b4e57f1c1fa0ffcf903347b013/gen.py#L89
2021-05-06 07:57:21 -07:00
2021-05-06 07:56:00 -07:00
How to use:
```shell
# create initial wg config or use your own.
# P.S. Keep in mind that WPM can't manage peers created my hands
# due to absence of client private key.
$ cd /etc/wireguard && mkdir clients
$ cat > wg0.conf <<EOF
[Interface]
Address = 10.150.200.1/24
ListenPort = 51820
PrivateKey = $(wg genkey)
PostUp = iptables -A FORWARD -i %i -o %i -j ACCEPT
PostDown = iptables -D FORWARD -i %i -o %i -j ACCEPT
SaveConfig = false
EOF
# install python and system requirements.
$ pip3 install -r requirements.txt
$ apt install qrencode
# CLI usage. Client configs saved into `clients/peer_name.{conf,-qr.png,-qr.txt}`
$ python3 gen.py --peer my-pc # add a new peer `my-pc`
$ python3 gen.py --update # just regenerate all configs in `clients/`
# Telegram bot usage
$ TG_TOKEN=1292121488:AAG... TG_ADMIN=<your_username> python3 bot.py
```