diff --git a/client/agent.c b/client/agent.c
index 6ab7cd4..31bbdd5 100644
--- a/client/agent.c
+++ b/client/agent.c
#define AGENT_INTERFACE "org.bluez.Agent1"
static gboolean agent_registered = FALSE;
+static DBusMessage *pending_message = NULL;
+
+dbus_bool_t agent_completion(void)
+{
+ if (!pending_message)
+ return FALSE;
+
+ return TRUE;
+}
+
+dbus_bool_t agent_input(DBusConnection *conn, const char *input)
+{
+ rl_clear_message();
+
+ if (!pending_message)
+ return FALSE;
+
+ g_dbus_send_reply(conn, pending_message, DBUS_TYPE_INVALID);
+
+ dbus_message_unref(pending_message);
+ pending_message = NULL;
+
+ return TRUE;
+}
static DBusMessage *release_agent(DBusConnection *conn,
DBusMessage *msg, void *user_data)
{
agent_registered = FALSE;
- begin_message();
- printf("Agent released\n");
- end_message();
+ rl_printf("Agent released\n");
+
+ if (pending_message) {
+ dbus_message_unref(pending_message);
+ pending_message = NULL;
+ }
g_dbus_unregister_interface(conn, AGENT_PATH, AGENT_INTERFACE);
return dbus_message_new_method_return(msg);
}
+static DBusMessage *request_confirmation(DBusConnection *conn,
+ DBusMessage *msg, void *user_data)
+{
+ const char *device;
+ dbus_uint32_t passkey;
+ char *str;
+
+ rl_printf("Request confirmation\n");
+
+ dbus_message_get_args(msg, NULL, DBUS_TYPE_OBJECT_PATH, &device,
+ DBUS_TYPE_UINT32, &passkey, DBUS_TYPE_INVALID);
+
+ str = g_strdup_printf("Confirm passkey %06u (yes/no): ", passkey);
+ rl_message(str);
+ g_free(str);
+
+ pending_message = dbus_message_ref(msg);
+
+ return NULL;
+}
+
+static DBusMessage *cancel_request(DBusConnection *conn,
+ DBusMessage *msg, void *user_data)
+{
+ rl_printf("Request canceled\n");
+
+ dbus_message_unref(pending_message);
+ pending_message = NULL;
+
+ return dbus_message_new_method_return(msg);
+}
+
static const GDBusMethodTable methods[] = {
{ GDBUS_METHOD("Release", NULL, NULL, release_agent) },
+ { GDBUS_ASYNC_METHOD("RequestConfirmation",
+ GDBUS_ARGS({ "device", "o"}, { "passkey", "u" }),
+ NULL, request_confirmation) },
+ { GDBUS_METHOD("Cancel", NULL, NULL, cancel_request) },
{ }
};
diff --git a/client/agent.h b/client/agent.h
index 41e166d..6e4536d 100644
--- a/client/agent.h
+++ b/client/agent.h
void agent_register(DBusConnection *conn, GDBusProxy *manager);
void agent_unregister(DBusConnection *conn, GDBusProxy *manager);
+
+dbus_bool_t agent_completion(void);
+dbus_bool_t agent_input(DBusConnection *conn, const char *input);