diff options
author | Matt Ranostay <matt.ranostay@konsulko.com> | 2018-12-10 08:17:16 -0800 |
---|---|---|
committer | Scott Murray <scott.murray@konsulko.com> | 2018-12-10 19:46:13 +0000 |
commit | cd2515ae2c85d915010653d2dcd7e83711ad7533 (patch) | |
tree | 73283b844fb159bdbe43a03e2d465e440fa45672 /binding | |
parent | c12208f529d44410051d91c7f14513a3edf92117 (diff) |
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 <matt.ranostay@konsulko.com>
Diffstat (limited to 'binding')
-rw-r--r-- | binding/bluetooth-bluez.c | 16 |
1 files changed, 14 insertions, 2 deletions
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)) { @@ -444,6 +445,17 @@ json_object *bluez_get_properties(struct bluetooth_state *ns, 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); continue; /* TODO: Maybe display other interfaces */ |