From 4137e7f3b9f0bcb633724878c7f19e55c8273982 Mon Sep 17 00:00:00 2001 From: Matt Ranostay Date: Mon, 10 Dec 2018 08:17:16 -0800 Subject: binding: bluetooth: add MediaTransport1 to managed_objects output To allow initial reporting of MediaTransport1 of audio transports add them to the managed_objects verb. Bug-AGL: SPEC-1630 SPEC-1986 Change-Id: Icc09ae063e5dfc52e5396b9ea7149178b1d8aaac Signed-off-by: Matt Ranostay --- binding/bluetooth-bluez.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) (limited to 'binding/bluetooth-bluez.c') diff --git a/binding/bluetooth-bluez.c b/binding/bluetooth-bluez.c index a52d225..60be18a 100644 --- a/binding/bluetooth-bluez.c +++ b/binding/bluetooth-bluez.c @@ -350,7 +350,7 @@ json_object *bluez_get_properties(struct bluetooth_state *ns, GVariant *var = NULL; const char *interface, *interface2, *path2 = NULL; const gchar *key = NULL; - json_object *jarray = NULL, *jarray2 = NULL; + json_object *jarray = NULL, *jarray2 = NULL, *jarray3 = NULL; json_object *jprop = NULL, *jresp = NULL, *jtype = NULL; gboolean is_config; @@ -415,13 +415,14 @@ json_object *bluez_get_properties(struct bluetooth_state *ns, g_variant_unref(reply); jresp = jprop; } else if (!strcmp(access_type, BLUEZ_AT_OBJECT)) { - jarray = json_object_new_array(); jarray2 = json_object_new_array(); + jarray3 = json_object_new_array(); jresp = json_object_new_object(); json_object_object_add(jresp, "adapters", jarray); json_object_object_add(jresp, "devices", jarray2); + json_object_object_add(jresp, "transports", jarray3); g_variant_get(reply, "(a{oa{sa{sv}}})", &array); while (g_variant_iter_loop(array, "{oa{sa{sv}}}", &path2, &array2)) { @@ -443,6 +444,17 @@ json_object *bluez_get_properties(struct bluetooth_state *ns, access_type = BLUEZ_AT_DEVICE; array = jarray2; + json_process_path(jtype, path2); + } else if (!strcmp(interface, BLUEZ_MEDIATRANSPORT_INTERFACE)) { + gchar *endpoint = find_index(path2, 5); + + access_type = BLUEZ_AT_MEDIATRANSPORT; + array = jarray3; + + json_object_object_add(jtype, "endpoint", + json_object_new_string(endpoint)); + g_free(endpoint); + json_process_path(jtype, path2); } else { json_object_put(jtype); -- cgit 1.2.3-korg