Diff between dae938bcbddb3452f850fef9a783d0b566b6b307 and 5557e7b453d9f14b67462e3072517cf971a4b51e

Changed Files

File Additions Deletions Status
client/agent.c +66 -3 modified
client/agent.h +3 -0 modified

Full Patch

diff --git a/client/agent.c b/client/agent.c
index 6ab7cd4..31bbdd5 100644
--- a/client/agent.c
+++ b/client/agent.c
@@ -36,23 +36,86 @@
 #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
@@ -23,3 +23,6 @@
 
 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);