2021-06-27 14:25:36 +05:30
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
"""Manage wifi adapter via iwd D-Bus api"""
|
|
|
|
|
2021-06-30 21:50:39 +05:30
|
|
|
from dasbus.connection import SystemMessageBus
|
|
|
|
|
|
|
|
IWD_BUS = "net.connman.iwd"
|
|
|
|
IWD_ROOT_PATH = "/"
|
2021-07-01 12:18:44 +05:30
|
|
|
IWD_DEVICE_INTERFACE = "net.connman.iwd.Device"
|
|
|
|
IWD_ADAPTER_INTERFACE = "net.connman.iwd.Adapter"
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
# If you are new to D-Bus, you might want to use a program
|
|
|
|
# such as D-Feet (https://wiki.gnome.org/Apps/DFeet) for reference.
|
|
|
|
|
2021-06-27 14:25:36 +05:30
|
|
|
|
|
|
|
class IWD:
|
|
|
|
"""Manage iwd via dbus"""
|
|
|
|
|
2021-06-30 21:50:39 +05:30
|
|
|
def __init__(self, bus=SystemMessageBus()):
|
|
|
|
self._bus = bus
|
|
|
|
self._proxy = self._bus.get_proxy(IWD_BUS, IWD_ROOT_PATH)
|
|
|
|
|
|
|
|
def get_name_from_path(self, path: str) -> str:
|
2021-07-01 12:18:44 +05:30
|
|
|
"""returns device or adapter name when d-bus path is given as arg"""
|
|
|
|
proxy = self._bus.get_proxy(IWD_BUS, path)
|
|
|
|
return proxy.Name
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
def get_device_path_from_name(self, name: str) -> str:
|
|
|
|
"""returns path of device as str"""
|
2021-07-01 12:18:44 +05:30
|
|
|
device_paths = self.get_all_device_paths()
|
|
|
|
for i in device_paths:
|
|
|
|
proxy = self._bus.get_proxy(IWD_BUS, i)
|
|
|
|
if proxy.Name == name:
|
|
|
|
return i
|
|
|
|
return None
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
def get_adapter_path_from_name(self, name: str) -> str:
|
|
|
|
"""returns path of adapter as str"""
|
2021-07-01 12:18:44 +05:30
|
|
|
adapter_paths = self.get_all_adapter_paths()
|
|
|
|
for i in adapter_paths:
|
|
|
|
proxy = self._bus.get_proxy(IWD_BUS, i)
|
|
|
|
if proxy.Name == name:
|
|
|
|
return i
|
|
|
|
return None
|
2021-06-27 14:25:36 +05:30
|
|
|
|
2021-06-30 21:50:39 +05:30
|
|
|
def get_all_device_paths(self) -> list:
|
|
|
|
"""returns list of paths of all devices"""
|
2021-07-01 12:18:44 +05:30
|
|
|
objects = self._proxy.GetManagedObjects()
|
|
|
|
paths = []
|
|
|
|
for key, value in objects.items():
|
|
|
|
# if value is a device, add its path to paths
|
|
|
|
if IWD_DEVICE_INTERFACE in value:
|
|
|
|
paths.append(key)
|
|
|
|
return paths
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
def get_all_adapter_paths(self) -> list:
|
|
|
|
"""returns list of paths of all adapters"""
|
2021-07-01 12:18:44 +05:30
|
|
|
objects = self._proxy.GetManagedObjects()
|
|
|
|
paths = []
|
|
|
|
|
|
|
|
for key, value in objects.items():
|
|
|
|
# if value is an adapter, add its path to paths
|
|
|
|
if IWD_ADAPTER_INTERFACE in value:
|
|
|
|
paths.append(key)
|
|
|
|
return paths
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
def get_devices(self) -> list:
|
2021-06-27 14:25:36 +05:30
|
|
|
"""
|
|
|
|
returns list of device names as str
|
|
|
|
example: ["wlan0", "wlan1"]
|
|
|
|
"""
|
2021-07-01 12:18:44 +05:30
|
|
|
devices = []
|
|
|
|
device_paths = self.get_all_device_paths()
|
|
|
|
|
|
|
|
for i in device_paths:
|
|
|
|
name = self.get_name_from_path(i)
|
|
|
|
devices.append(name)
|
|
|
|
return devices
|
2021-06-27 14:25:36 +05:30
|
|
|
|
2021-06-30 21:50:39 +05:30
|
|
|
def get_adapters(self) -> list:
|
2021-06-27 14:25:36 +05:30
|
|
|
"""
|
|
|
|
returns list of adapters
|
|
|
|
example: ["phy0","phy1"]
|
|
|
|
"""
|
2021-07-01 12:18:44 +05:30
|
|
|
adapters = []
|
|
|
|
adapter_paths = self.get_all_adapter_paths()
|
|
|
|
|
|
|
|
for i in adapter_paths:
|
|
|
|
name = self.get_name_from_path(i)
|
|
|
|
adapters.append(name)
|
|
|
|
return adapters
|
2021-06-27 14:25:36 +05:30
|
|
|
|
|
|
|
|
|
|
|
class Device:
|
|
|
|
"""control devices with iwd"""
|
|
|
|
|
2021-06-30 21:50:39 +05:30
|
|
|
def __init__(self, name: str, bus=SystemMessageBus()):
|
|
|
|
self._iwd = IWD(bus)
|
|
|
|
self._bus = self._iwd._bus
|
2021-07-01 12:18:44 +05:30
|
|
|
self._path = self._iwd.get_device_path_from_name(name)
|
2021-06-30 21:50:39 +05:30
|
|
|
self._proxy = self._bus.get_proxy(IWD_BUS, self._path)
|
|
|
|
self.name = self._proxy.Name
|
2021-07-01 12:18:44 +05:30
|
|
|
adapter_path = self._proxy.Adapter
|
|
|
|
self.adapter = self._iwd.get_name_from_path(adapter_path)
|
2021-06-30 21:50:39 +05:30
|
|
|
|
|
|
|
def get_mode(self) -> str:
|
|
|
|
"""
|
|
|
|
returns the mode in which the device is in
|
|
|
|
example: "ap"
|
|
|
|
"""
|
|
|
|
return self._proxy.Mode
|