diff mbox series

[BlueZ,v2,3/3] client: Display disconnection reason

Message ID 20250520162621.190769-4-frederic.danis@collabora.com
State New
Headers show
Series Propagate disconnection reason | expand

Commit Message

Frédéric Danis May 20, 2025, 4:26 p.m. UTC
The new org.bluez.Device1.Disconnected signal propagates the
disconnection reason.
---
v1->v2: Display disconnect reason in numerical and text

 client/main.c | 40 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 40 insertions(+)
diff mbox series

Patch

diff --git a/client/main.c b/client/main.c
index 57d71f2b6..274d02c9e 100644
--- a/client/main.c
+++ b/client/main.c
@@ -706,9 +706,49 @@  static void property_changed(GDBusProxy *proxy, const char *name,
 	}
 }
 
+static const char *disconnect_reason(uint8_t reason)
+{
+	switch (reason) {
+	case 0:
+		return "unknown";
+	case 1:
+		return "timeout";
+	case 2:
+		return "local host";
+	case 3:
+		return "remote";
+	case 4:
+		return "authentication failure";
+	case 5:
+		return "local suspend";
+	default:
+		return "unknown value";
+	}
+}
+
 static void message_handler(DBusConnection *connection,
 					DBusMessage *message, void *user_data)
 {
+	if (!strcmp(dbus_message_get_member(message), "Disconnected")) {
+		DBusMessageIter iter;
+		u_int8_t reason;
+
+		if (!dbus_message_iter_init(message, &iter))
+			goto failed;
+
+		if (dbus_message_iter_get_arg_type(&iter) != DBUS_TYPE_BYTE)
+			goto failed;
+
+		dbus_message_iter_get_basic(&iter, &reason);
+
+		bt_shell_printf("[SIGNAL] %s.%s %u (%s)\n",
+					dbus_message_get_interface(message),
+					dbus_message_get_member(message),
+					reason, disconnect_reason(reason));
+		return;
+	}
+
+failed:
 	bt_shell_printf("[SIGNAL] %s.%s\n", dbus_message_get_interface(message),
 					dbus_message_get_member(message));
 }