mirror of
https://github.com/Kiritow/wg-ops.git
synced 2024-03-22 13:11:37 +08:00
Better tunnel config creation logic
This commit is contained in:
parent
3ca839f378
commit
75a6b0106b
|
@ -3,8 +3,15 @@ import logging
|
||||||
import json
|
import json
|
||||||
import traceback
|
import traceback
|
||||||
import base64
|
import base64
|
||||||
|
import hashlib
|
||||||
|
|
||||||
|
|
||||||
|
# Constants
|
||||||
|
WGOP_USPEEDER_S_PBEGIN = 27100
|
||||||
|
WGOP_USPEEDER_C_PBEGIN = 28100
|
||||||
|
WGOP_LB_PBEGIN = 29000
|
||||||
|
WGOP_UC_PBEGIN = 29100
|
||||||
|
|
||||||
class SimpleLogger(object):
|
class SimpleLogger(object):
|
||||||
def __init__(self, name=None, filename=None, fileonly=False,
|
def __init__(self, name=None, filename=None, fileonly=False,
|
||||||
level=logging.INFO,
|
level=logging.INFO,
|
||||||
|
@ -65,3 +72,7 @@ def json_to_base64(content):
|
||||||
|
|
||||||
def base64_to_json(content):
|
def base64_to_json(content):
|
||||||
return json.loads(base64.b64decode(content).decode('utf-8'))
|
return json.loads(base64.b64decode(content).decode('utf-8'))
|
||||||
|
|
||||||
|
|
||||||
|
def get_sha256(content):
|
||||||
|
return hashlib.sha256(content).hexdigest()
|
||||||
|
|
177
tool_create.py
177
tool_create.py
|
@ -1,7 +1,8 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
import os
|
import os
|
||||||
import getpass
|
import getpass
|
||||||
from tool_common import load_config, save_config, json_to_base64
|
from tool_common import load_config, save_config, json_to_base64, get_sha256
|
||||||
|
from tool_common import WGOP_LB_PBEGIN, WGOP_UC_PBEGIN, WGOP_USPEEDER_C_PBEGIN, WGOP_USPEEDER_S_PBEGIN
|
||||||
|
|
||||||
|
|
||||||
config = load_config()
|
config = load_config()
|
||||||
|
@ -22,17 +23,79 @@ if op_mode not in ("c", "s", "m"):
|
||||||
print("Invalid node mode. Please try again.")
|
print("Invalid node mode. Please try again.")
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
udp2raw_config = {
|
|
||||||
"server": [],
|
class UConfigController:
|
||||||
"client": [],
|
next_port_speeder_server = WGOP_USPEEDER_S_PBEGIN
|
||||||
"demuxer": [], # w2u
|
next_port_speeder_client = WGOP_USPEEDER_C_PBEGIN
|
||||||
}
|
next_port_balancer = WGOP_LB_PBEGIN
|
||||||
|
next_port_client = WGOP_UC_PBEGIN
|
||||||
|
udp2raw_config = {
|
||||||
|
"server": [],
|
||||||
|
"client": []
|
||||||
|
}
|
||||||
|
|
||||||
|
def add_server(self, port_required, password, speeder_info):
|
||||||
|
self.udp2raw_config["server"].append({
|
||||||
|
"port": port_required,
|
||||||
|
"password": get_sha256(password),
|
||||||
|
"speeder": speeder_info
|
||||||
|
})
|
||||||
|
|
||||||
|
def add_client(self, remote, password, port, speeder_info, demuxer_info):
|
||||||
|
if port is None:
|
||||||
|
port = self.next_port_client
|
||||||
|
if demuxer_info:
|
||||||
|
self.next_port_client += demuxer_info["size"]
|
||||||
|
else:
|
||||||
|
self.next_port_client += 1
|
||||||
|
|
||||||
|
self.udp2raw_config["client"].append({
|
||||||
|
"remote": remote,
|
||||||
|
"password": get_sha256(password),
|
||||||
|
"port": port,
|
||||||
|
"speeder": speeder_info,
|
||||||
|
"demuxer": demuxer_info
|
||||||
|
})
|
||||||
|
|
||||||
|
def new_server_speeder(self, port, ratio):
|
||||||
|
if port is None:
|
||||||
|
port = self.next_port_speeder_server
|
||||||
|
self.next_port_speeder_server += 1
|
||||||
|
|
||||||
|
return {
|
||||||
|
"port": port,
|
||||||
|
"ratio": ratio
|
||||||
|
}
|
||||||
|
|
||||||
|
def new_client_speeder(self, port, ratio):
|
||||||
|
if port is None:
|
||||||
|
port = self.next_port_speeder_client
|
||||||
|
self.next_port_speeder_client += 1
|
||||||
|
|
||||||
|
return {
|
||||||
|
"port": port,
|
||||||
|
"ratio": ratio
|
||||||
|
}
|
||||||
|
|
||||||
|
def new_demuxer(self, port, size):
|
||||||
|
if port is None:
|
||||||
|
port = self.next_port_balancer
|
||||||
|
self.next_port_balancer += 1
|
||||||
|
|
||||||
|
return {
|
||||||
|
"port": port,
|
||||||
|
"size": size
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
ucontrol = UConfigController()
|
||||||
|
|
||||||
|
|
||||||
if op_mode in ("s", "m"):
|
if op_mode in ("s", "m"):
|
||||||
print("====== Configuring udp2raw server ======")
|
print("====== Configuring udp2raw server ======")
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
print("====== Adding UDP2RAW Server {} ======".format(len(udp2raw_config["server"]) + 1))
|
print("====== Adding UDP2RAW Server #{} ======".format(len(ucontrol.udp2raw_config["server"]) + 1))
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
udp_server_port = input("Please select an Internet-Facing port for incoming udp2raw connection: ").strip()
|
udp_server_port = input("Please select an Internet-Facing port for incoming udp2raw connection: ").strip()
|
||||||
|
@ -56,21 +119,11 @@ if op_mode in ("s", "m"):
|
||||||
is_enable_speeder = input("Enable UDP Speeder for this tunnel? [y/N]: ").strip()
|
is_enable_speeder = input("Enable UDP Speeder for this tunnel? [y/N]: ").strip()
|
||||||
if is_enable_speeder and is_enable_speeder.lower() in ('y', 'yes'):
|
if is_enable_speeder and is_enable_speeder.lower() in ('y', 'yes'):
|
||||||
speeder_ratio = input("Enter UDP Speeder Ratio (default to 20:10. Use 2:4 for gaming usage): ").strip() or "20:10"
|
speeder_ratio = input("Enter UDP Speeder Ratio (default to 20:10. Use 2:4 for gaming usage): ").strip() or "20:10"
|
||||||
speeder_info = {
|
speeder_info = ucontrol.new_server_speeder(None, speeder_ratio)
|
||||||
"enable": True,
|
|
||||||
"port": 27100 + len(udp2raw_config["server"]),
|
|
||||||
"ratio": speeder_ratio
|
|
||||||
}
|
|
||||||
else:
|
else:
|
||||||
speeder_info = {
|
speeder_info = None
|
||||||
"enable": False
|
|
||||||
}
|
|
||||||
|
|
||||||
udp2raw_config["server"].append({
|
ucontrol.add_server(udp_server_port, udp_server_password, speeder_info)
|
||||||
"port": udp_server_port,
|
|
||||||
"password": udp_server_password,
|
|
||||||
"speeder": speeder_info
|
|
||||||
})
|
|
||||||
|
|
||||||
if not input("Add more udp2raw server? (Keep empty to finish): ").strip():
|
if not input("Add more udp2raw server? (Keep empty to finish): ").strip():
|
||||||
break
|
break
|
||||||
|
@ -80,7 +133,7 @@ if op_mode in ("c", "m"):
|
||||||
print("====== Configuring udp2raw client ======")
|
print("====== Configuring udp2raw client ======")
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
print("====== Adding UDP2RAW Client {} ======".format(len(udp2raw_config["client"]) + 1))
|
print("====== Adding UDP2RAW Client {} ======".format(len(ucontrol.udp2raw_config["client"]) + 1))
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
udp_server_address = input("Please input remote node internet-facing udp2raw ip:port : ").strip()
|
udp_server_address = input("Please input remote node internet-facing udp2raw ip:port : ").strip()
|
||||||
|
@ -104,47 +157,24 @@ if op_mode in ("c", "m"):
|
||||||
is_enable_speeder = input("Enable UDP Speeder for this tunnel? [y/N]: ").strip()
|
is_enable_speeder = input("Enable UDP Speeder for this tunnel? [y/N]: ").strip()
|
||||||
if is_enable_speeder and is_enable_speeder.lower() in ('y', 'yes'):
|
if is_enable_speeder and is_enable_speeder.lower() in ('y', 'yes'):
|
||||||
speeder_ratio = input("Enter UDP Speeder Ratio (default to 20:10. Use 2:4 for gaming usage): ").strip() or "20:10"
|
speeder_ratio = input("Enter UDP Speeder Ratio (default to 20:10. Use 2:4 for gaming usage): ").strip() or "20:10"
|
||||||
speeder_info = {
|
speeder_info = ucontrol.new_client_speeder(None, speeder_ratio)
|
||||||
"enable": True,
|
|
||||||
"port": 28100 + len(udp2raw_config["server"]),
|
|
||||||
"ratio": speeder_ratio
|
|
||||||
}
|
|
||||||
else:
|
else:
|
||||||
speeder_info = {
|
speeder_info = None
|
||||||
"enable": False
|
|
||||||
}
|
|
||||||
|
|
||||||
is_enable_balance = input("Enable Load Balance? [y/N]: ").strip()
|
is_enable_balance = input("Enable Load Balance? [y/N]: ").strip()
|
||||||
if is_enable_balance and is_enable_balance.lower() in ('y', 'yes'):
|
if is_enable_balance and is_enable_balance.lower() in ('y', 'yes'):
|
||||||
balance_count = input("Enter Balance Underlay Connection counts (default to 10): ").strip() or "10"
|
balance_count = input("Enter Balance Underlay Connection counts (default to 10): ").strip() or "10"
|
||||||
balance_count = int(balance_count)
|
balance_count = int(balance_count)
|
||||||
|
|
||||||
default_balancer_port = 29000 + len(udp2raw_config["demuxer"])
|
if balance_count > 1:
|
||||||
balancer_port = input("Enter Balancer Listen Port (default to {}): ".format(default_balancer_port)).strip() or default_balancer_port
|
balancer_info = ucontrol.new_demuxer(None, balance_count)
|
||||||
balancer_port = int(balancer_port)
|
else:
|
||||||
|
print("[WARN] Only one target, skipped balancer creation.")
|
||||||
udp2raw_config["demuxer"].append({
|
balancer_info = None
|
||||||
"port": balancer_port,
|
|
||||||
"forward": 29100 + len(udp2raw_config["client"]),
|
|
||||||
"size": balance_count
|
|
||||||
})
|
|
||||||
|
|
||||||
for i in range(balance_count):
|
|
||||||
udp2raw_config["client"].append({
|
|
||||||
"remote": udp_server_address,
|
|
||||||
"password": udp_server_password,
|
|
||||||
"port": 29100 + len(udp2raw_config["client"]),
|
|
||||||
"speeder": speeder_info,
|
|
||||||
"balanced": True
|
|
||||||
})
|
|
||||||
else:
|
else:
|
||||||
udp2raw_config["client"].append({
|
balancer_info = None
|
||||||
"remote": udp_server_address,
|
|
||||||
"password": udp_server_password,
|
ucontrol.add_client(udp_server_address, udp_server_password, None, speeder_info, balancer_info)
|
||||||
"port": 29100 + len(udp2raw_config["client"]),
|
|
||||||
"speeder": speeder_info,
|
|
||||||
"balanced": False
|
|
||||||
})
|
|
||||||
|
|
||||||
if not input("Add more udp2raw client? (Keep empty to finish)").strip():
|
if not input("Add more udp2raw client? (Keep empty to finish)").strip():
|
||||||
break
|
break
|
||||||
|
@ -190,11 +220,12 @@ config = {
|
||||||
"ip": ifip,
|
"ip": ifip,
|
||||||
"listen": listen_port,
|
"listen": listen_port,
|
||||||
"peers": [],
|
"peers": [],
|
||||||
"udp2raw": udp2raw_config
|
"udp2raw": ucontrol.udp2raw_config
|
||||||
}
|
}
|
||||||
save_config(config)
|
save_config(config)
|
||||||
|
|
||||||
|
|
||||||
|
# Display Quick Config
|
||||||
if op_mode in ("s", "m"):
|
if op_mode in ("s", "m"):
|
||||||
if ifip.endswith(".1"):
|
if ifip.endswith(".1"):
|
||||||
suggest_allowed = "{}.0/24".format('.'.join(ifip.split('.')[:-1]))
|
suggest_allowed = "{}.0/24".format('.'.join(ifip.split('.')[:-1]))
|
||||||
|
@ -202,24 +233,22 @@ if op_mode in ("s", "m"):
|
||||||
suggest_allowed = ifip
|
suggest_allowed = ifip
|
||||||
|
|
||||||
print("===== Quick Import =====")
|
print("===== Quick Import =====")
|
||||||
for info in udp2raw_config["server"]:
|
for server_info in ucontrol.udp2raw_config["server"]:
|
||||||
target_quick_config = {
|
speeder_info = server_info["speeder"]
|
||||||
"udp2raw_client": {
|
|
||||||
"remote": "{}:{}".format(wg_public_ip, info["port"]),
|
quick_config = {
|
||||||
"password": "",
|
"pubkey": wg_pubk,
|
||||||
"port": "29100",
|
"allowed": suggest_allowed,
|
||||||
"speeder": info["speeder"]
|
"remote": "{}:{}".format(wg_public_ip, server_info["port"]),
|
||||||
},
|
"password": server_info["password"],
|
||||||
"server_pubkey": wg_pubk,
|
"ratio": speeder_info["ratio"] if speeder_info else ""
|
||||||
"suggest_allowed": suggest_allowed
|
|
||||||
}
|
}
|
||||||
|
|
||||||
print("Connect to this server via tunnel at port {}: (credential excluded) \n".format(info["port"]))
|
print("Connect to this server via tunnel at port {}: (credential included) \n".format(server_info["port"]))
|
||||||
print("#QCS#{}\n".format(json_to_base64(target_quick_config)))
|
print("#QCS#{}\n".format(json_to_base64(quick_config)))
|
||||||
|
|
||||||
|
|
||||||
# Configure Peer
|
# Configure Peer
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
print("====== Adding Peer {} ======".format(len(config["peers"]) + 1))
|
print("====== Adding Peer {} ======".format(len(config["peers"]) + 1))
|
||||||
while True:
|
while True:
|
||||||
|
@ -235,10 +264,16 @@ while True:
|
||||||
continue
|
continue
|
||||||
break
|
break
|
||||||
|
|
||||||
if config["udp2raw"]["client"]:
|
if ucontrol.udp2raw_config["client"]:
|
||||||
print(">>> Choose from following udp2raw clients <<<")
|
print(">>> Choose from following udp2raw clients <<<")
|
||||||
for index, client_info in enumerate(config["udp2raw"]["client"]):
|
for index, client_info in enumerate(ucontrol.udp2raw_config["client"]):
|
||||||
print("[{}] UDP2Raw Tunnel to Remote {}".format(index + 1, client_info["remote"]))
|
speeder_info = client_info["speeder"]
|
||||||
|
balancer_info = client_info["demuxer"]
|
||||||
|
|
||||||
|
print("[{}] {} {} {}".format(index + 1, client_info["remote"],
|
||||||
|
"SpeederRatio: {}".format(speeder_info["ratio"]) if speeder_info else "",
|
||||||
|
"Load-Balanced over {} tunnels".format(balancer_info["size"]) if balancer_info else ""
|
||||||
|
))
|
||||||
|
|
||||||
peer_endpoint = input("Enter WireGuard Peer Endpoint (ID from list, default to 1): ").strip() or "1"
|
peer_endpoint = input("Enter WireGuard Peer Endpoint (ID from list, default to 1): ").strip() or "1"
|
||||||
peer_keepalive = input("Enter WireGuard Peer Keep Alive seconds (default to 30): ").strip() or "30"
|
peer_keepalive = input("Enter WireGuard Peer Keep Alive seconds (default to 30): ").strip() or "30"
|
||||||
|
|
Loading…
Reference in New Issue
Block a user