kupferbootstrap/forwarding.py

49 lines
1.1 KiB
Python
Raw Normal View History

import click
import subprocess
from logger import logging
2021-10-01 12:31:08 +02:00
from ssh import run_ssh_command
from wrapper import check_programs_wrap
@click.command(name='forwarding')
def cmd_forwarding():
check_programs_wrap(['syctl', 'iptables'])
2021-08-08 18:32:42 +02:00
result = subprocess.run([
'sysctl',
'net.ipv4.ip_forward=1',
])
if result.returncode != 0:
logging.fatal(f'Failed to enable ipv4 forward via sysctl')
exit(1)
2021-08-08 18:32:42 +02:00
result = subprocess.run([
'iptables',
'-P',
'FORWARD',
'ACCEPT',
])
if result.returncode != 0:
logging.fatal(f'Failed set iptables rule')
exit(1)
2021-08-08 18:32:42 +02:00
result = subprocess.run([
'iptables',
'-A',
'POSTROUTING',
'-t',
'nat',
'-j',
'MASQUERADE',
'-s',
'172.16.42.0/24',
])
if result.returncode != 0:
logging.fatal(f'Failed set iptables rule')
exit(1)
2021-10-01 12:31:08 +02:00
result = run_ssh_command(cmd=['sudo -S route add default gw 172.16.42.2'])
if result.returncode != 0:
logging.fatal(f'Failed to add gateway over ssh')
exit(1)