Initial commit
This commit is contained in:
parent
bd6f007136
commit
c9195b13cf
31
install
Executable file
31
install
Executable file
@ -0,0 +1,31 @@
|
||||
#! /usr/bin/env python3
|
||||
|
||||
import os
|
||||
from string import Template
|
||||
from subprocess import check_call
|
||||
|
||||
EXEC = 'wifi-keepalive.py'
|
||||
SERVICE = 'wifi-keepalive.service'
|
||||
SYSTEM_DIR = '/etc/systemd/system'
|
||||
|
||||
CURRENT_DIR = os.path.dirname(os.path.realpath(__file__))
|
||||
EXEC_PATH = os.path.join(CURRENT_DIR, EXEC)
|
||||
SERVICE_TEMPLATE = os.path.join(CURRENT_DIR, SERVICE)
|
||||
SERVICE_FILE = os.path.join(SYSTEM_DIR, SERVICE)
|
||||
EXEC_START = f'python3 {EXEC}'
|
||||
|
||||
with open(SERVICE_TEMPLATE) as f:
|
||||
serviceTemplate = Template(f.read())
|
||||
|
||||
serviceFile = serviceTemplate.substitute(
|
||||
workingDirectory=CURRENT_DIR,
|
||||
execStart=EXEC_START
|
||||
)
|
||||
|
||||
with open(SERVICE_FILE, 'w') as f:
|
||||
f.write(serviceFile)
|
||||
|
||||
check_call(['systemctl', 'daemon-reload'])
|
||||
check_call(['systemctl', 'enable', '--no-pager', SERVICE])
|
||||
check_call(['systemctl', 'restart', '--no-pager', SERVICE])
|
||||
check_call(['systemctl', 'status', '--no-pager', SERVICE])
|
32
wifi-keepalive.py
Normal file
32
wifi-keepalive.py
Normal file
@ -0,0 +1,32 @@
|
||||
from signal import SIGTERM, signal
|
||||
from subprocess import CalledProcessError, check_output
|
||||
from sys import exit
|
||||
from time import sleep
|
||||
|
||||
PING_INTERVAL_IN_SECONDS = 80
|
||||
|
||||
signal(SIGTERM, lambda signum, frame: exit(0))
|
||||
|
||||
|
||||
def getDefaultRoute():
|
||||
routes = check_output(['route', '-n']).decode('utf-8').splitlines()
|
||||
defaults = [r.split()[1] for r in routes if r.startswith('0.0.0.0')]
|
||||
|
||||
return defaults[0] if defaults else None
|
||||
|
||||
|
||||
def keepalive(defaultRoute):
|
||||
while True:
|
||||
sleep(PING_INTERVAL_IN_SECONDS)
|
||||
ping(defaultRoute)
|
||||
|
||||
|
||||
def ping(address):
|
||||
try:
|
||||
check_output(['ping', '-c', '1', address])
|
||||
except CalledProcessError as e:
|
||||
pass
|
||||
|
||||
|
||||
defaultRoute = getDefaultRoute()
|
||||
keepalive(defaultRoute) if defaultRoute else print('No default route')
|
13
wifi-keepalive.service
Normal file
13
wifi-keepalive.service
Normal file
@ -0,0 +1,13 @@
|
||||
[Unit]
|
||||
Description=Wifi Keepalive Service
|
||||
After=multi.user.target
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
WorkingDirectory=$workingDirectory
|
||||
ExecStart=$execStart
|
||||
Restart=on-failure
|
||||
SyslogIdentifier=wifi-keepalive
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
Loading…
Reference in New Issue
Block a user