client
parent
a409db3e0d
commit
91b430e409
@ -1,11 +1,28 @@
|
|||||||
|
import hashlib
|
||||||
from time import sleep
|
from time import sleep
|
||||||
import yaml
|
import yaml
|
||||||
import requests
|
import requests
|
||||||
|
from wgconfig import WireGuardConfig, wg_showconf, wg_syncconf
|
||||||
with open("wg-p2p-client.conf") as f:
|
with open("wg-p2p-client.conf") as f:
|
||||||
cfg = yaml.safe_load(f)
|
cfg = yaml.safe_load(f)
|
||||||
last_hash = ""
|
last_hash = ""
|
||||||
|
last_local_hash = ""
|
||||||
url = f"{cfg['url']}/hash/{cfg['remote_wg']}"
|
url = f"{cfg['url']}/hash/{cfg['remote_wg']}"
|
||||||
|
urlpat2 = f"{cfg['url']}/peers/{cfg['remote_wg']}"
|
||||||
while True:
|
while True:
|
||||||
new_hash = requests.get(url).text
|
new_hash = requests.get(url).text
|
||||||
print(new_hash)
|
new_local_hash = hashlib.sha256(wg_showconf(
|
||||||
|
cfg["local_wg"]).encode()).hexdigest()
|
||||||
|
if last_hash != new_hash or last_local_hash != new_local_hash:
|
||||||
|
print(f"update hash to {new_hash}")
|
||||||
|
print(f"update local_hash to {new_local_hash}")
|
||||||
|
local_cfg = WireGuardConfig.get_from_interface(cfg["local_wg"])
|
||||||
|
for peer in cfg["peers"]:
|
||||||
|
if p := local_cfg.get_peer(peer):
|
||||||
|
url2 = f"{urlpat2}/{peer}"
|
||||||
|
res = requests.get(url2).json()
|
||||||
|
p["Endpoint"] = res["Endpoint"]
|
||||||
|
wg_syncconf(cfg["local_wg"], str(local_cfg))
|
||||||
|
last_hash = new_hash
|
||||||
|
last_local_hash = new_local_hash
|
||||||
sleep(5)
|
sleep(5)
|
||||||
Loading…
Reference in new issue