 b682d6a73d
			
		
	
	
		b682d6a73d
		
	
	
	
	
		
			
			Four D-Bus scripts using python glib are added to perform the following operations: p2p_flush, p2p_group_add, p2p_listen and p2p_stop_find. Signed-hostap: Michael Naumov <michael.naumov@intel.com> Signed-hostap: Nirav Shah <nirav.j2.shah@intel.com>
		
			
				
	
	
		
			168 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
	
		
			4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/python
 | |
| # Tests P2P_Flush
 | |
| # Will flush the p2p interface
 | |
| # Then Program will exit
 | |
| ######### MAY NEED TO RUN AS SUDO #############
 | |
| 
 | |
| import dbus
 | |
| import sys, os
 | |
| import time
 | |
| import gobject
 | |
| import threading
 | |
| import getopt
 | |
| from dbus.mainloop.glib import DBusGMainLoop
 | |
| 
 | |
| def usage():
 | |
| 	print "Usage:"
 | |
| 	print "  %s -i <interface_name> \ " \
 | |
| 		% sys.argv[0]
 | |
| 	print "  		[-w <wpas_dbus_interface>]"
 | |
| 	print "Options:"
 | |
| 	print "  -i = interface name"
 | |
| 	print "  -w = wpas dbus interface = fi.w1.wpa_supplicant1"
 | |
| 	print "Example:"
 | |
| 	print "  %s -i wlan0" % sys.argv[0]
 | |
| 
 | |
| # Required Signals\
 | |
| def deviceLost(devicepath):
 | |
| 	print "Device lost: %s" % (devicepath)
 | |
| 
 | |
| class P2P_Flush (threading.Thread):
 | |
| 	# Needed Variables
 | |
| 	global bus
 | |
| 	global wpas_object
 | |
| 	global interface_object
 | |
| 	global p2p_interface
 | |
| 	global interface_name
 | |
| 	global wpas
 | |
| 	global wpas_dbus_interface
 | |
| 	global path
 | |
| 	global timeout
 | |
| 
 | |
| 	# Dbus Paths
 | |
| 	global wpas_dbus_opath
 | |
| 	global wpas_dbus_interfaces_opath
 | |
| 	global wpas_dbus_interfaces_interface
 | |
| 	global wpas_dbus_interfaces_p2pdevice
 | |
| 
 | |
| 	# Constructor
 | |
| 	def __init__(self,interface_name,wpas_dbus_interface,timeout):
 | |
| 		# Initializes variables and threads
 | |
| 		self.interface_name = interface_name
 | |
| 		self.wpas_dbus_interface = wpas_dbus_interface
 | |
| 		self.timeout = timeout
 | |
| 
 | |
| 		# Initializes thread and daemon allows for ctrl-c kill
 | |
| 		threading.Thread.__init__(self)
 | |
| 		self.daemon = True
 | |
| 
 | |
| 		# Generating interface/object paths
 | |
| 		self.wpas_dbus_opath = "/" + \
 | |
| 				self.wpas_dbus_interface.replace(".","/")
 | |
| 		self.wpas_wpas_dbus_interfaces_opath = self.wpas_dbus_opath + \
 | |
| 				"/Interfaces"
 | |
| 		self.wpas_dbus_interfaces_interface = \
 | |
| 				self.wpas_dbus_interface + ".Interface"
 | |
| 		self.wpas_dbus_interfaces_p2pdevice = \
 | |
| 				self.wpas_dbus_interfaces_interface \
 | |
| 				+ ".P2PDevice"
 | |
| 
 | |
| 		# Getting interfaces and objects
 | |
| 		DBusGMainLoop(set_as_default=True)
 | |
| 		self.bus = dbus.SystemBus()
 | |
| 		self.wpas_object = self.bus.get_object(
 | |
| 				self.wpas_dbus_interface,
 | |
| 				self.wpas_dbus_opath)
 | |
| 		self.wpas = dbus.Interface(self.wpas_object,
 | |
| 				self.wpas_dbus_interface)
 | |
| 
 | |
| 		# Try to see if supplicant knows about interface
 | |
| 		# If not, throw an exception
 | |
| 		try:
 | |
| 			self.path = self.wpas.GetInterface(
 | |
| 					self.interface_name)
 | |
| 		except dbus.DBusException, exc:
 | |
| 			error = 'Error:\n  Interface ' + self.interface_name \
 | |
| 				+ ' was not found'
 | |
| 			print error
 | |
| 			usage()
 | |
| 			os._exit(0)
 | |
| 
 | |
| 		self.interface_object = self.bus.get_object(
 | |
| 				self.wpas_dbus_interface, self.path)
 | |
| 		self.p2p_interface = dbus.Interface(self.interface_object,
 | |
| 				self.wpas_dbus_interfaces_p2pdevice)
 | |
| 
 | |
| 		# Signals
 | |
| 		self.bus.add_signal_receiver(deviceLost,
 | |
| 			dbus_interface=self.wpas_dbus_interfaces_p2pdevice,
 | |
| 			signal_name="DeviceLost")
 | |
| 
 | |
| 	# Runs p2p_flush
 | |
| 	def run(self):
 | |
| 		# Allows other threads to keep working while MainLoop runs
 | |
| 		# Required for timeout implementation
 | |
| 		gobject.MainLoop().get_context().iteration(True)
 | |
| 		gobject.threads_init()
 | |
| 		self.p2p_interface.Flush()
 | |
| 		gobject.MainLoop().run()
 | |
| 
 | |
| 
 | |
| if __name__ == "__main__":
 | |
| 	# Needed to show which devices were lost
 | |
| 	timeout = 5
 | |
| 	# Defaults for optional inputs
 | |
| 	wpas_dbus_interface = 'fi.w1.wpa_supplicant1'
 | |
| 
 | |
| 	# interface_name is required
 | |
| 	interface_name = None
 | |
| 
 | |
| 	# Using getopts to handle options
 | |
| 	try:
 | |
| 		options, args = getopt.getopt(sys.argv[1:],"hi:w:")
 | |
| 
 | |
| 	except getopt.GetoptError:
 | |
| 		usage()
 | |
| 		quit()
 | |
| 
 | |
| 	# If theres a switch, override default option
 | |
| 	for key, value in options:
 | |
| 		# Help
 | |
| 		if (key == "-h"):
 | |
| 			usage()
 | |
| 			quit()
 | |
| 		# Interface Name
 | |
| 		elif (key == "-i"):
 | |
| 			interface_name = value
 | |
| 		# Dbus interface
 | |
| 		elif (key == "-w"):
 | |
| 			wpas_dbus_interface = value
 | |
| 		else:
 | |
| 			assert False, "unhandled option"
 | |
| 
 | |
| 	# Interface name is required and was not given
 | |
| 	if (interface_name == None):
 | |
| 		print "Error:\n  interface_name is required"
 | |
| 		usage()
 | |
| 		quit()
 | |
| 
 | |
| 	# Constructor
 | |
| 	try:
 | |
| 		p2p_flush_test = P2P_Flush(interface_name, wpas_dbus_interface,timeout)
 | |
| 
 | |
| 	except:
 | |
| 		print "Error:\n  Invalid wpas_dbus_interface"
 | |
| 		usage()
 | |
| 		quit()
 | |
| 
 | |
| 	# Start P2P_Find
 | |
| 	p2p_flush_test.start()
 | |
| 
 | |
| 	try:
 | |
| 		time.sleep(int(p2p_flush_test.timeout))
 | |
| 
 | |
| 	except:
 | |
| 		pass
 | |
| 
 | |
| 	print "p2p_flush complete"
 | |
| 	quit()
 |