--- test/simple-oobprovider | 57 +++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 57 insertions(+), 0 deletions(-) create mode 100755 test/simple-oobprovider diff --git a/test/simple-oobprovider b/test/simple-oobprovider new file mode 100755 index 0000000..e5181f3 --- /dev/null +++ b/test/simple-oobprovider @@ -0,0 +1,57 @@ +#!/usr/bin/python +# Copyright (C) 2010 ST-Ericsson SA +# Author: Szymon Janc <szymon.janc@xxxxxxxxx> for ST-Ericsson + +import gobject + +import sys +import dbus +import dbus.service +import dbus.mainloop.glib + +class NoOobData(dbus.DBusException): + _dbus_error_name = "org.bluez.Error.NoData" + + +class Provider(dbus.service.Object): + + remotedata = None + + @dbus.service.method("org.bluez.OobProvider", + in_signature="s", out_signature="ayay") + + def RequestRemoteOobData(self, device): + print "RequestRemoteOobData for %s" % (device) + if (self.remotedata != None): + return self.remotedata + raise NoOobData("No OOB data present") + +if __name__ == '__main__': + dbus.mainloop.glib.DBusGMainLoop(set_as_default=True) + + bus = dbus.SystemBus() + + manager = dbus.Interface(bus.get_object("org.bluez", "/"), + "org.bluez.Manager") + + adapter_path = manager.DefaultAdapter() + adapter = dbus.Interface(bus.get_object("org.bluez", + adapter_path), "org.bluez.OobManager") + path = "/test/oobprovider" + provider = Provider(bus, path) + + mainloop = gobject.MainLoop() + + adapter.RegisterProvider(path) + + print "Local data for %s:" % (adapter_path) + print adapter.ReadLocalOobData() + + provider.remotedata = input("Provide remote data (in python syntax):\n") + + print "You may try pairing now" + + mainloop.run() + + #adapter.UnregisterProvider(path) + #print "Provider unregistered" -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html