summaryrefslogtreecommitdiff
path: root/bin/ssh_tunnels_config_util.py
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
committerEvgeny Zinoviev <me@ch1p.io>2023-09-27 00:54:57 +0300
commitd3a295872c49defb55fc8e4e43e55550991e0927 (patch)
treeb9dca15454f9027d5a9dad0d4443a20de04dbc5d /bin/ssh_tunnels_config_util.py
parentb7cbc2571c1870b4582ead45277d0aa7f961bec8 (diff)
parentbdbb296697f55f4c3a07af43c9aaf7a9ea86f3d0 (diff)
Merge branch 'master' of ch1p.io:homekit
Diffstat (limited to 'bin/ssh_tunnels_config_util.py')
-rwxr-xr-xbin/ssh_tunnels_config_util.py35
1 files changed, 35 insertions, 0 deletions
diff --git a/bin/ssh_tunnels_config_util.py b/bin/ssh_tunnels_config_util.py
new file mode 100755
index 0000000..d08a4f4
--- /dev/null
+++ b/bin/ssh_tunnels_config_util.py
@@ -0,0 +1,35 @@
+#!/usr/bin/env python3
+import __py_include
+from homekit.config import config
+
+if __name__ == '__main__':
+ config.load_app('ssh_tunnels_config_util')
+
+ network_prefix = config['network']
+ hostnames = []
+
+ for k, v in config.app_config.get().items():
+ if type(v) is not dict:
+ continue
+ hostnames.append(k)
+
+ for host in hostnames:
+ buf = []
+ i = 0
+ for tun_host in hostnames:
+ http_bind_port = config['http_bind_base'] + config[host]['bind_slot'] * 10 + i
+ ssh_bind_port = config['ssh_bind_base'] + config[host]['bind_slot'] * 10 + i
+
+ if tun_host == host:
+ target_host = '127.0.0.1'
+ else:
+ target_host = f'{network_prefix}.{config[tun_host]["ipv4"]}'
+
+ buf.append(f'-R 127.0.0.1:{http_bind_port}:{target_host}:{config[tun_host]["http_port"]}')
+ buf.append(f'-R 127.0.0.1:{ssh_bind_port}:{target_host}:{config[tun_host]["ssh_port"]}')
+
+ i += 1
+
+ print(host)
+ print(' '.join(buf))
+ print()