l autowifi: convert to submodule
This commit is contained in:
parent
62a59ad233
commit
7f41109bc9
6
.gitmodules
vendored
6
.gitmodules
vendored
@ -4,3 +4,9 @@
|
|||||||
[submodule "submodules/krops"]
|
[submodule "submodules/krops"]
|
||||||
path = submodules/krops
|
path = submodules/krops
|
||||||
url = https://cgit.krebsco.de/krops
|
url = https://cgit.krebsco.de/krops
|
||||||
|
[submodule "lass/5pkgs/autowifi"]
|
||||||
|
path = lass/5pkgs/autowifi
|
||||||
|
url = https://github.com/Lassulus/autowifi
|
||||||
|
[submodule "lass/5pkgs/--force"]
|
||||||
|
path = lass/5pkgs/--force
|
||||||
|
url = https://github.com/Lassulus/autowifi
|
||||||
|
1
lass/5pkgs/autowifi
Submodule
1
lass/5pkgs/autowifi
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit cf3ae8f6fe285eab67db4f36f9a3da3762c35317
|
@ -1,228 +0,0 @@
|
|||||||
import subprocess
|
|
||||||
import time
|
|
||||||
import urllib.request
|
|
||||||
import logging
|
|
||||||
import argparse
|
|
||||||
import socket
|
|
||||||
import struct
|
|
||||||
import signal
|
|
||||||
import os
|
|
||||||
|
|
||||||
wifiDB = ''
|
|
||||||
logger = logging.getLogger()
|
|
||||||
got_signal = False
|
|
||||||
|
|
||||||
|
|
||||||
def signal_handler(signum, frame):
|
|
||||||
global got_signal
|
|
||||||
got_signal = True
|
|
||||||
|
|
||||||
|
|
||||||
def get_default_gateway() -> str:
|
|
||||||
"""Read the default gateway directly from /proc."""
|
|
||||||
with open("/proc/net/route") as fh:
|
|
||||||
for line in fh:
|
|
||||||
fields = line.strip().split()
|
|
||||||
if fields[1] != '00000000' or not int(fields[3], 16) & 2:
|
|
||||||
continue
|
|
||||||
|
|
||||||
return socket.inet_ntoa(struct.pack("<L", int(fields[2], 16)))
|
|
||||||
|
|
||||||
|
|
||||||
def connect(ssid, psk=None):
|
|
||||||
subprocess.run(
|
|
||||||
["nmcli", "connection", "delete", "autowifi"],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
)
|
|
||||||
logging.info('connecting to %s', ssid)
|
|
||||||
if psk is None:
|
|
||||||
subprocess.run(
|
|
||||||
[
|
|
||||||
"nmcli",
|
|
||||||
"device",
|
|
||||||
"wifi",
|
|
||||||
"connect",
|
|
||||||
ssid,
|
|
||||||
"name",
|
|
||||||
"autowifi",
|
|
||||||
],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
subprocess.run(
|
|
||||||
[
|
|
||||||
"nmcli",
|
|
||||||
"device",
|
|
||||||
"wifi",
|
|
||||||
"connect",
|
|
||||||
ssid,
|
|
||||||
"name",
|
|
||||||
"autowifi",
|
|
||||||
"password",
|
|
||||||
psk,
|
|
||||||
],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
)
|
|
||||||
time.sleep(5)
|
|
||||||
|
|
||||||
|
|
||||||
def scan():
|
|
||||||
logging.debug('scanning wifis')
|
|
||||||
wifis_raw = subprocess.check_output([
|
|
||||||
"nmcli",
|
|
||||||
"-t",
|
|
||||||
"device",
|
|
||||||
"wifi",
|
|
||||||
"list",
|
|
||||||
"--rescan",
|
|
||||||
"yes",
|
|
||||||
])
|
|
||||||
wifis_list = wifis_raw.split(b'\n')
|
|
||||||
logging.debug('scanning wifis finished')
|
|
||||||
wifis = []
|
|
||||||
for line in wifis_list:
|
|
||||||
logging.debug(line)
|
|
||||||
ls = line.split(b':')
|
|
||||||
if len(ls) == 8:
|
|
||||||
wifis.append({
|
|
||||||
"ssid": ls[1],
|
|
||||||
"signal": int(ls[5]),
|
|
||||||
"crypto": ls[7]
|
|
||||||
})
|
|
||||||
return wifis
|
|
||||||
|
|
||||||
|
|
||||||
def get_known_wifis():
|
|
||||||
wifis_lines = []
|
|
||||||
with open(wifiDB) as f:
|
|
||||||
wifis_lines = f.read().splitlines()
|
|
||||||
wifis = []
|
|
||||||
for line in wifis_lines:
|
|
||||||
ls = line.split('/')
|
|
||||||
wifis.append({"ssid": ls[0].encode(), "psk": ls[1].encode()})
|
|
||||||
return wifis
|
|
||||||
|
|
||||||
|
|
||||||
def check_network():
|
|
||||||
logging.debug('checking network')
|
|
||||||
|
|
||||||
global got_signal
|
|
||||||
if got_signal:
|
|
||||||
logging.info('got disconnect signal')
|
|
||||||
got_signal = False
|
|
||||||
return False
|
|
||||||
else:
|
|
||||||
gateway = get_default_gateway()
|
|
||||||
if gateway:
|
|
||||||
response = subprocess.run(
|
|
||||||
[
|
|
||||||
'ping',
|
|
||||||
'-q',
|
|
||||||
'-c',
|
|
||||||
'1',
|
|
||||||
gateway,
|
|
||||||
],
|
|
||||||
stdout=subprocess.PIPE,
|
|
||||||
)
|
|
||||||
if response.returncode == 0:
|
|
||||||
logging.debug('host %s is up', gateway)
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
logging.debug('host %s is down', gateway)
|
|
||||||
return False
|
|
||||||
else:
|
|
||||||
logging.debug('no gateway')
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def check_internet():
|
|
||||||
logging.debug('checking internet')
|
|
||||||
|
|
||||||
try:
|
|
||||||
with open('./dummy_internet') as f:
|
|
||||||
dummy_content = f.read()
|
|
||||||
if dummy_content == 'xxx\n':
|
|
||||||
return True
|
|
||||||
beacon = urllib.request.urlopen('http://krebsco.de/secret')
|
|
||||||
except Exception as e: # noqa
|
|
||||||
logging.debug(e)
|
|
||||||
logging.info('no internet exc')
|
|
||||||
return False
|
|
||||||
if beacon.read() == b'1337\n':
|
|
||||||
return True
|
|
||||||
logging.info('no internet oh')
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def is_wifi_open(wifi):
|
|
||||||
if wifi['crypto'] == b'':
|
|
||||||
return True
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def is_wifi_seen(wifi, seen_wifis):
|
|
||||||
for seen_wifi in seen_wifis:
|
|
||||||
if seen_wifi["ssid"] == wifi["ssid"]:
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
parser = argparse.ArgumentParser()
|
|
||||||
|
|
||||||
parser.add_argument(
|
|
||||||
'-c', '--config',
|
|
||||||
dest='config',
|
|
||||||
help='wifi config file to use',
|
|
||||||
default='/etc/wifis',
|
|
||||||
)
|
|
||||||
|
|
||||||
parser.add_argument(
|
|
||||||
'-l', '--loglevel',
|
|
||||||
dest='loglevel',
|
|
||||||
help='loglevel to use',
|
|
||||||
default=logging.INFO,
|
|
||||||
)
|
|
||||||
|
|
||||||
parser.add_argument(
|
|
||||||
'-p', '--pidfile',
|
|
||||||
dest='pidfile',
|
|
||||||
help='file to write the pid to',
|
|
||||||
default=None,
|
|
||||||
)
|
|
||||||
|
|
||||||
args = parser.parse_args()
|
|
||||||
|
|
||||||
global wifiDB
|
|
||||||
wifiDB = args.config
|
|
||||||
logger.setLevel(args.loglevel)
|
|
||||||
|
|
||||||
signal.signal(signal.SIGUSR1, signal_handler)
|
|
||||||
|
|
||||||
if args.pidfile:
|
|
||||||
with open(args.pidfile, 'w+') as f:
|
|
||||||
f.write(str(os.getpid()))
|
|
||||||
|
|
||||||
while True:
|
|
||||||
if not check_network():
|
|
||||||
wifis = scan()
|
|
||||||
known_wifis = get_known_wifis()
|
|
||||||
known_seen_wifis = [
|
|
||||||
wifi for wifi in known_wifis if is_wifi_seen(wifi, wifis)
|
|
||||||
]
|
|
||||||
for wifi in known_seen_wifis:
|
|
||||||
connect(wifi['ssid'], wifi['psk'])
|
|
||||||
if check_network():
|
|
||||||
break
|
|
||||||
open_wifis = filter(is_wifi_open, wifis)
|
|
||||||
for wifi in open_wifis:
|
|
||||||
connect(wifi['ssid'])
|
|
||||||
|
|
||||||
if check_network():
|
|
||||||
break
|
|
||||||
time.sleep(10)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
@ -1 +0,0 @@
|
|||||||
pkgs.writers.writePython3Bin "autowifi" {} ./autowifi.py
|
|
Loading…
Reference in New Issue
Block a user