wg-ops/wgop_generate.py

196 lines
7.3 KiB
Python
Raw Normal View History

2021-07-13 13:59:59 +08:00
# -*- coding: utf-8 -*-
2021-07-16 11:56:50 +08:00
import os
2021-07-31 02:32:08 +08:00
import uuid
2021-08-23 01:31:21 +08:00
from wgop_common import load_config, SimpleLogger
2021-07-13 13:59:59 +08:00
logger = SimpleLogger()
2021-07-31 02:32:08 +08:00
def write_tunnel_config(mode, listen_addr, remote_addr, password):
filename = "{}.conf".format(uuid.uuid4())
with open("local/tunnel/{}".format(filename), "w", encoding='utf-8') as f:
f.write('''
-{}
-l {}
-r {}
-k {}
--raw-mode faketcp
2021-08-15 17:07:03 +08:00
--fix-gro
2021-07-31 02:32:08 +08:00
-a
'''.format(mode, listen_addr, remote_addr, password))
return filename
2021-07-31 16:30:32 +08:00
tmux_path = os.getenv("TMUX_PATH")
config = load_config()
if not config:
logger.error("No valid config found.")
exit(1)
2021-07-13 13:59:59 +08:00
2021-07-16 15:19:56 +08:00
if "version" not in config or int(config["version"]) < 1:
logger.warn("[WARN] Legacy version of config found. This may cause issues.")
2021-07-16 15:19:56 +08:00
2021-07-13 15:16:10 +08:00
op_mode = config["mode"]
2021-07-13 13:59:59 +08:00
udp_clients = config["udp2raw"]["client"]
udp_servers = config["udp2raw"]["server"]
2021-07-16 15:19:56 +08:00
2021-07-31 03:06:58 +08:00
logger.info("Generating WireGuard config...")
2021-07-17 19:51:29 +08:00
with open("local/{}.conf".format(config["interface"]), "w", encoding='utf-8') as f:
2021-07-13 13:59:59 +08:00
f.write('''[Interface]
Address = {}
PrivateKey = {}
ListenPort = {}
MTU = {}
'''.format(config["ip"], config["prikey"], config["listen"], config["mtu"]))
2021-07-31 02:32:08 +08:00
# Generate PostUp
2021-07-31 16:30:32 +08:00
f.write('''PostUp={} new-session -s tunnel -d 'watch -n 1 --color WG_COLOR_MODE=always wg'
2021-07-31 02:32:08 +08:00
PostUp=sysctl net.core.default_qdisc=fq
PostUp=sysctl net.ipv4.tcp_congestion_control=bbr
2021-07-31 16:30:32 +08:00
'''.format(tmux_path))
2021-07-31 02:32:08 +08:00
if op_mode in ("s", "m"):
f.write("PostUp=sysctl net.ipv4.ip_forward=1\n")
current_dir = os.getcwd()
2021-08-23 01:15:40 +08:00
bin_tunnel = os.path.join(current_dir, "bin", "udp2raw_amd64")
bin_speeder = os.path.join(current_dir, "bin", "speederv2_amd64")
bin_demuxer = os.path.join(current_dir, "bin", "w2u")
2021-07-31 02:32:08 +08:00
2021-08-23 01:15:40 +08:00
cache_nb_config = []
2021-08-19 04:05:41 +08:00
cache_config = []
2021-08-23 01:15:40 +08:00
for client_info in udp_clients:
speeder_info = client_info["speeder"]
balancer_info = client_info["demuxer"]
if balancer_info:
# ... => Balancer => Tunnels
cache_nb_config.append("PostUp={} new-window -t tunnel -d '{} -f {} -l {} -t {} -s {}'".format(tmux_path, bin_demuxer, config["listen"], balancer_info["port"], client_info["port"], balancer_info["size"]))
if speeder_info:
if balancer_info:
# WG => Speeder => Balancer => Tunnels
cache_config.append("PostUp={} new-window -t tunnel -d '{} -c -l127.0.0.1:{} -r 127.0.0.1:{} -f{} --mode 0'".format(tmux_path, bin_speeder, speeder_info["port"], balancer_info["port"], speeder_info["ratio"]))
else:
# WG => Speeder => Tunnel
cache_config.append("PostUp={} new-window -t tunnel -d '{} -c -l127.0.0.1:{} -r 127.0.0.1:{} -f{} --mode 0'".format(tmux_path, bin_speeder, speeder_info["port"], client_info["port"], speeder_info["ratio"]))
if balancer_info:
# Generate multiple tunnels
for offset in range(balancer_info["size"]):
config_filename = write_tunnel_config("c", "127.0.0.1:{}".format(client_info["port"] + offset), client_info["remote"], client_info["password"])
filepath = os.path.join(current_dir, "local", "tunnel", config_filename)
cache_config.append("PostUp={} new-window -t tunnel -d '{} --conf-file {}'".format(tmux_path, bin_tunnel, filepath))
2021-07-31 02:32:08 +08:00
else:
2021-08-23 01:15:40 +08:00
config_filename = write_tunnel_config("c", "127.0.0.1:{}".format(client_info["port"]), client_info["remote"], client_info["password"])
filepath = os.path.join(current_dir, "local", "tunnel", config_filename)
cache_config.append("PostUp={} new-window -t tunnel -d '{} --conf-file {}'".format(tmux_path, bin_tunnel, filepath))
for server_info in udp_servers:
2021-09-11 16:30:27 +08:00
speeder_info = server_info["speeder"]
2021-08-19 04:05:41 +08:00
2021-08-23 01:15:40 +08:00
if speeder_info:
# RawTunnel => Speeder => WG
speeder = server_info["speeder"]
cache_config.append("PostUp={} new-window -t tunnel -d '{} -s -l127.0.0.1:{} -r 127.0.0.1:{} -f{} --mode 0'".format(tmux_path, bin_speeder, speeder["port"], config["listen"], speeder["ratio"]))
config_filename = write_tunnel_config("s", "0.0.0.0:{}".format(server_info["port"]), "127.0.0.1:{}".format(speeder["port"]), server_info["password"])
filepath = os.path.join(current_dir, "local", "tunnel", config_filename)
cache_config.append("PostUp={} new-window -t tunnel -d '{} --conf-file {}'".format(tmux_path, bin_tunnel, filepath))
else:
# RawTunnel => WG
config_filename = write_tunnel_config("s", "0.0.0.0:{}".format(server_info["port"]), "127.0.0.1:{}".format(config["listen"]), server_info["password"])
filepath = os.path.join(current_dir, "local", "tunnel", config_filename)
cache_config.append("PostUp={} new-window -t tunnel -d '{} --conf-file {}'".format(tmux_path, bin_tunnel, filepath))
# Add sleep interval
2021-08-19 04:05:41 +08:00
if cache_config:
for i in range(len(cache_config) - 1):
cache_config[i] = "{}; sleep 2".format(cache_config[i])
cache_config.append("")
f.write('\n'.join(cache_config))
2021-07-31 02:32:08 +08:00
2021-08-23 01:15:40 +08:00
if cache_nb_config:
cache_nb_config.append("")
f.write('\n'.join(cache_nb_config))
2021-07-31 02:32:08 +08:00
# Generate PostDown
2021-07-31 16:30:32 +08:00
f.write("PostDown={} kill-session -t tunnel\n".format(tmux_path))
2021-07-31 02:32:08 +08:00
2021-08-23 01:15:40 +08:00
for peer_info in config["peers"]:
2021-07-31 02:32:08 +08:00
f.write('''
[Peer]
2021-07-13 13:59:59 +08:00
PublicKey = {}
AllowedIPs = {}
2021-08-23 01:15:40 +08:00
'''.format(peer_info["pubkey"], peer_info["allowed"]))
if peer_info["endpoint"]:
client_info = udp_clients[int(peer_info["endpoint"]) - 1]
speeder_info = client_info["speeder"]
balancer_info = client_info["demuxer"]
if speeder_info:
# WG => Speeder => ...
f.write("Endpoint = 127.0.0.1:{}\n".format(speeder_info["port"]))
elif balancer_info:
# WG => Balancer => ...
f.write("Endpoint = 127.0.0.1:{}\n".format(balancer_info["port"]))
2021-07-16 15:19:56 +08:00
else:
2021-08-23 01:15:40 +08:00
# WG => ...
f.write("Endpoint = 127.0.0.1:{}\n".format(client_info["port"]))
if peer_info["keepalive"]:
f.write("PersistentKeepalive = {}\n".format(peer_info["keepalive"]))
2021-07-13 13:59:59 +08:00
os.system("chmod 600 local/{}.conf".format(config["interface"]))
2021-07-13 14:06:48 +08:00
logger.info("Generating start script...")
2021-07-13 13:59:59 +08:00
with open("start.sh", "w", encoding='utf-8') as f:
f.write('''#!/bin/bash
2021-07-13 14:06:48 +08:00
set -e
2021-07-13 14:03:49 +08:00
2021-07-31 02:51:31 +08:00
sudo cp local/{}.conf /etc/wireguard/
sudo wg-quick up {}
sudo tmux attach-session -t tunnel
2021-07-31 02:32:08 +08:00
'''.format(config["interface"], config["interface"]))
2021-07-13 15:16:10 +08:00
2021-07-17 19:51:29 +08:00
logger.info("Generating stop script...")
2021-07-17 19:51:29 +08:00
with open("stop.sh", "w", encoding='utf-8') as f:
f.write('''#!/bin/bash
set -x
2021-07-31 02:51:31 +08:00
sudo wg-quick down {}
2021-07-17 19:51:29 +08:00
'''.format(config["interface"]))
logger.info("Generating restart script...")
with open("restart.sh", "w", encoding='utf-8') as f:
f.write('''#!/bin/bash
set -x
./stop.sh
./start.sh
''')
2021-07-31 16:30:32 +08:00
logger.info("Generate reload script...")
with open("reload.sh", "w", encoding='utf-8') as f:
f.write('''#!/bin/bash
set -x
sudo cp local/{}.conf /etc/wireguard/
2021-08-19 04:05:41 +08:00
sudo -- bash -c "wg syncconf {} <(wg-quick strip {})"
2021-07-31 16:30:32 +08:00
'''.format(config["interface"], config["interface"], config["interface"]))
2021-08-23 01:15:40 +08:00
for peer_info in config["peers"]:
f.write("sudo ip -4 route add {} dev {}\n".format(peer_info["allowed"], config["interface"]))
2021-07-17 19:51:29 +08:00
logger.info('''[Done] Config generated. Before you run start.sh, besure to:
2021-07-16 11:56:50 +08:00
1. Disable SSH Server password login.
2. Enable UFW (or any other firewall)
Safety First.
''')