X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-msg-json.c;h=25a9621433c773f0731e2a25b631ce3518b99737;hb=refs%2Fheads%2Fsandbox%2FDDTLK%2Fpakage;hp=dc096ac5cb88036f1ce78afa91ae27f4deae9cdc;hpb=694e6000719d2d003c3046683347f9388d5fb708;p=src%2Fapp-framework-binder.git diff --git a/src/afb-msg-json.c b/src/afb-msg-json.c index dc096ac5..25a96214 100644 --- a/src/afb-msg-json.c +++ b/src/afb-msg-json.c @@ -1,5 +1,5 @@ /* - * Copyright 2016 IoT.bzh + * Copyright (C) 2016, 2017, 2018 "IoT.bzh" * Author: José Bollo * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -17,29 +17,42 @@ #define _GNU_SOURCE -#include +#include #include "afb-msg-json.h" +#include "afb-context.h" +static const char _success_[] = "success"; -struct json_object *afb_msg_json_reply(const char *status, const char *info, struct json_object *resp, const char *token, const char *uuid) +struct json_object *afb_msg_json_reply(struct json_object *resp, const char *error, const char *info, struct afb_context *context) { json_object *msg, *request; + const char *token, *uuid; + json_object *type_reply = NULL; + + msg = json_object_new_object(); + if (resp != NULL) + json_object_object_add(msg, "response", resp); + + type_reply = json_object_new_string("afb-reply"); + json_object_object_add(msg, "jtype", type_reply); request = json_object_new_object(); - json_object_object_add(request, "status", json_object_new_string(status)); + json_object_object_add(msg, "request", request); + json_object_object_add(request, "status", json_object_new_string(error ?: _success_)); + if (info != NULL) json_object_object_add(request, "info", json_object_new_string(info)); - if (token != NULL) - json_object_object_add(request, "token", json_object_new_string(token)); - if (uuid != NULL) - json_object_object_add(request, "uuid", json_object_new_string(uuid)); - msg = json_object_new_object(); - json_object_object_add(msg, "jtype", json_object_new_string("afb-reply")); - json_object_object_add(msg, "request", request); - if (resp != NULL) - json_object_object_add(msg, "response", resp); + if (context != NULL) { + token = afb_context_sent_token(context); + if (token != NULL) + json_object_object_add(request, "token", json_object_new_string(token)); + + uuid = afb_context_sent_uuid(context); + if (uuid != NULL) + json_object_object_add(request, "uuid", json_object_new_string(uuid)); + } return msg; } @@ -47,13 +60,19 @@ struct json_object *afb_msg_json_reply(const char *status, const char *info, str struct json_object *afb_msg_json_event(const char *event, struct json_object *object) { json_object *msg; + json_object *type_event = NULL; msg = json_object_new_object(); - json_object_object_add(msg, "jtype", json_object_new_string("afb-event")); + json_object_object_add(msg, "event", json_object_new_string(event)); + if (object != NULL) json_object_object_add(msg, "data", object); + type_event = json_object_new_string("afb-event"); + json_object_object_add(msg, "jtype", type_event); + return msg; } +