3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2024-12-31 23:42:52 +01:00

auto-t: iwd.py: add DPP utilities

This commit is contained in:
James Prestwood 2022-01-04 10:18:55 -08:00 committed by Denis Kenzior
parent 88f2309796
commit 7ef165035e

View File

@ -40,6 +40,7 @@ IWD_P2P_PEER_INTERFACE = 'net.connman.iwd.p2p.Peer'
IWD_P2P_SERVICE_MANAGER_INTERFACE = 'net.connman.iwd.p2p.ServiceManager' IWD_P2P_SERVICE_MANAGER_INTERFACE = 'net.connman.iwd.p2p.ServiceManager'
IWD_P2P_WFD_INTERFACE = 'net.connman.iwd.p2p.Display' IWD_P2P_WFD_INTERFACE = 'net.connman.iwd.p2p.Display'
IWD_STATION_DEBUG_INTERFACE = 'net.connman.iwd.StationDebug' IWD_STATION_DEBUG_INTERFACE = 'net.connman.iwd.StationDebug'
IWD_DPP_INTERFACE = 'net.connman.iwd.DeviceProvisioning'
IWD_AGENT_MANAGER_PATH = '/net/connman/iwd' IWD_AGENT_MANAGER_PATH = '/net/connman/iwd'
IWD_TOP_LEVEL_PATH = '/' IWD_TOP_LEVEL_PATH = '/'
@ -270,6 +271,20 @@ class StationDebug(IWDDBusAbstract):
self._last_event_data = None self._last_event_data = None
self._last_event = None self._last_event = None
class DeviceProvisioning(IWDDBusAbstract):
'''
Class represents net.connman.iwd.DeviceProvisioning
'''
_iface_name = IWD_DPP_INTERFACE
def start_enrollee(self):
return self._iface.StartEnrollee()
def start_configurator(self):
return self._iface.StartConfigurator()
def stop(self):
self._iface.Stop()
class Device(IWDDBusAbstract): class Device(IWDDBusAbstract):
''' '''
@ -283,6 +298,7 @@ class Device(IWDDBusAbstract):
self._station_if = None self._station_if = None
self._station_props = None self._station_props = None
self._station_debug_obj = None self._station_debug_obj = None
self._dpp_obj = None
IWDDBusAbstract.__init__(self, *args, **kwargs) IWDDBusAbstract.__init__(self, *args, **kwargs)
@ -303,6 +319,17 @@ class Device(IWDDBusAbstract):
IWD_STATION_INTERFACE) IWD_STATION_INTERFACE)
return self._station_if return self._station_if
@property
def _device_provisioning(self):
if self._properties['Mode'] != 'station':
self._prop_proxy.Set(IWD_DEVICE_INTERFACE, 'Mode', 'station')
if self._dpp_obj is None:
self._dpp_obj = DeviceProvisioning(object_path=self._object_path,
namespace=self._namespace)
return self._dpp_obj
@property @property
def _station_debug(self): def _station_debug(self):
if self._properties['Mode'] != 'station': if self._properties['Mode'] != 'station':
@ -637,6 +664,15 @@ class Device(IWDDBusAbstract):
def wait_for_event(self, event, timeout=10): def wait_for_event(self, event, timeout=10):
self._station_debug.wait_for_event(event, timeout) self._station_debug.wait_for_event(event, timeout)
def dpp_start_enrollee(self):
return self._device_provisioning.start_enrollee()
def dpp_start_configurator(self):
return self._device_provisioning.start_configurator()
def dpp_stop(self):
return self._device_provisioning.stop()
def __str__(self, prefix = ''): def __str__(self, prefix = ''):
return prefix + 'Device: ' + self.device_path + '\n'\ return prefix + 'Device: ' + self.device_path + '\n'\
+ prefix + '\tName:\t\t' + self.name + '\n'\ + prefix + '\tName:\t\t' + self.name + '\n'\