bluez/test/simple-agent

145 lines
3.8 KiB
Plaintext
Raw Normal View History

#!/usr/bin/python
from __future__ import absolute_import, print_function, unicode_literals
from gi.repository import GObject
2008-06-08 21:23:35 +08:00
import sys
import dbus
import dbus.service
import dbus.mainloop.glib
from optparse import OptionParser
def ask(prompt):
try:
return raw_input(prompt)
except:
return input(prompt)
2008-06-09 22:10:51 +08:00
class Rejected(dbus.DBusException):
2008-06-09 22:09:15 +08:00
_dbus_error_name = "org.bluez.Error.Rejected"
class Agent(dbus.service.Object):
exit_on_release = True
def set_exit_on_release(self, exit_on_release):
self.exit_on_release = exit_on_release
@dbus.service.method("org.bluez.Agent",
2008-03-15 07:44:23 +08:00
in_signature="", out_signature="")
def Release(self):
print("Release")
if self.exit_on_release:
mainloop.quit()
@dbus.service.method("org.bluez.Agent",
in_signature="os", out_signature="")
def Authorize(self, device, uuid):
print("Authorize (%s, %s)" % (device, uuid))
authorize = ask("Authorize connection (yes/no): ")
if (authorize == "yes"):
return
raise Rejected("Connection rejected by user")
@dbus.service.method("org.bluez.Agent",
2008-03-15 07:44:23 +08:00
in_signature="o", out_signature="s")
2008-05-30 22:17:42 +08:00
def RequestPinCode(self, device):
print("RequestPinCode (%s)" % (device))
return ask("Enter PIN Code: ")
@dbus.service.method("org.bluez.Agent",
in_signature="o", out_signature="u")
2008-06-04 16:07:24 +08:00
def RequestPasskey(self, device):
print("RequestPasskey (%s)" % (device))
passkey = ask("Enter passkey: ")
2008-06-09 12:06:15 +08:00
return dbus.UInt32(passkey)
@dbus.service.method("org.bluez.Agent",
in_signature="ou", out_signature="")
2008-06-04 16:07:24 +08:00
def DisplayPasskey(self, device, passkey):
print("DisplayPasskey (%s, %06d)" % (device, passkey))
2012-04-06 06:29:40 +08:00
@dbus.service.method("org.bluez.Agent",
in_signature="os", out_signature="")
def DisplayPinCode(self, device, pincode):
print("DisplayPinCode (%s, %s)" % (device, pincode))
2012-04-06 06:29:40 +08:00
@dbus.service.method("org.bluez.Agent",
in_signature="ou", out_signature="")
2008-06-04 16:07:24 +08:00
def RequestConfirmation(self, device, passkey):
print("RequestConfirmation (%s, %06d)" % (device, passkey))
confirm = ask("Confirm passkey (yes/no): ")
2008-06-09 22:09:15 +08:00
if (confirm == "yes"):
return
raise Rejected("Passkey doesn't match")
@dbus.service.method("org.bluez.Agent",
2008-03-15 07:44:23 +08:00
in_signature="s", out_signature="")
def ConfirmModeChange(self, mode):
print("ConfirmModeChange (%s)" % (mode))
authorize = ask("Authorize mode change (yes/no): ")
if (authorize == "yes"):
return
raise Rejected("Mode change by user")
@dbus.service.method("org.bluez.Agent",
2008-03-15 07:44:23 +08:00
in_signature="", out_signature="")
def Cancel(self):
print("Cancel")
2008-06-11 16:44:38 +08:00
def create_device_reply(device):
print("New device (%s)" % (device))
mainloop.quit()
2008-06-11 16:44:38 +08:00
def create_device_error(error):
print("Creating device failed: %s" % (error))
mainloop.quit()
if __name__ == '__main__':
dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
bus = dbus.SystemBus()
2008-03-15 07:44:23 +08:00
manager = dbus.Interface(bus.get_object("org.bluez", "/"),
"org.bluez.Manager")
capability = "KeyboardDisplay"
parser = OptionParser()
parser.add_option("-c", "--capability", action="store",
type="string", dest="capability")
(options, args) = parser.parse_args()
if options.capability:
capability = options.capability
if len(args) > 0:
path = manager.FindAdapter(args[0])
else:
path = manager.DefaultAdapter()
2008-03-15 07:44:23 +08:00
adapter = dbus.Interface(bus.get_object("org.bluez", path),
"org.bluez.Adapter")
2008-03-15 07:44:23 +08:00
path = "/test/agent"
agent = Agent(bus, path)
mainloop = GObject.MainLoop()
if len(args) > 1:
if len(args) > 2:
device = adapter.FindDevice(args[1])
adapter.RemoveDevice(device)
agent.set_exit_on_release(False)
adapter.CreatePairedDevice(args[1], path, capability,
timeout=60000,
reply_handler=create_device_reply,
2008-06-11 16:44:38 +08:00
error_handler=create_device_error)
else:
adapter.RegisterAgent(path, capability)
print("Agent registered")
mainloop.run()
#adapter.UnregisterAgent(path)
#print("Agent unregistered")