aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorManuel Bachmann <manuel.bachmann@iot.bzh>2016-01-25 14:48:02 +0100
committerManuel Bachmann <manuel.bachmann@iot.bzh>2016-01-25 14:48:02 +0100
commitd809e9b8fc03a0a08060034c6ddbd4b4c4176399 (patch)
tree1c84b6941eabe68fb3ac4187bbf488ae6b87bccf
parente3320f303c4eb8f7fe0fac69bfa9ce36d9916930 (diff)
Media Plugin list API now returns a JSON object
We now return a JSON object instead of an arbitrary string with the "list" API. Signed-off-by: Manuel Bachmann <manuel.bachmann@iot.bzh>
-rw-r--r--plugins/media/media-rygel.c24
1 files changed, 19 insertions, 5 deletions
diff --git a/plugins/media/media-rygel.c b/plugins/media/media-rygel.c
index 9e94a9e7..be8cb96d 100644
--- a/plugins/media/media-rygel.c
+++ b/plugins/media/media-rygel.c
@@ -91,7 +91,8 @@ PUBLIC void _rygel_free (mediaCtxHandleT *ctx) {
PUBLIC char* _rygel_list (mediaCtxHandleT *ctx) {
dev_ctx_T *dev_ctx_c = (dev_ctx_T*)ctx->media_server;
- char *raw, *start, *end, *title, *result = NULL;
+ json_object *json_o, *json_a;
+ char *raw, *start, *end, *id, *title;
int length, i = 0;
if (!dev_ctx_c)
@@ -105,24 +106,37 @@ PUBLIC char* _rygel_list (mediaCtxHandleT *ctx) {
if (!start)
return NULL;
- result = strdup("");
+ json_o = json_object_new_object ();
+ json_a = json_object_new_array ();
while (start) {
+ json_object *json_i, *json_id, *json_title;
+
start = strstr (start, "<dc:title>");
if (!start) break;
end = strstr (start, "</dc:title>");
start += 10;
length = end - start;
+ asprintf (&id, "%02d", i);
+
title = (char*) malloc (length+1);
strncpy (title, start, length);
title[length] = '\0';
- asprintf (&result, "%s%02d:%s::", result, i, title);
+ json_i = json_object_new_object ();
+ json_id = json_object_new_string (id);
+ json_title = json_object_new_string (title);
+ json_object_object_add (json_i, "id", json_id);
+ json_object_object_add (json_i, "title", json_title);
+ json_object_array_add (json_a, json_i);
- free (title); i++;
+ free (id); free (title);
+ i++;
}
- return result;
+ json_object_object_add (json_o, "list", json_a);
+
+ return (char*) json_object_to_json_string (json_o);
}
PUBLIC unsigned char _rygel_select (mediaCtxHandleT *ctx, unsigned int index) {