X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-msg-json.c;h=6d8f73272d03c1341a3049e1161ac8023f9a7caa;hb=ca9807f73646f536ac58c002d963a8bb8d245f5d;hp=164a6e8ff8de493dd78147f1f28d6fc671e88797;hpb=8112056eecede587bf884f56629858c8b21bdbec;p=src%2Fapp-framework-binder.git diff --git a/src/afb-msg-json.c b/src/afb-msg-json.c index 164a6e8f..6d8f7327 100644 --- a/src/afb-msg-json.c +++ b/src/afb-msg-json.c @@ -1,5 +1,5 @@ /* - * Copyright (C) 2016 "IoT.bzh" + * Copyright (C) 2016, 2017 "IoT.bzh" * Author: José Bollo * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -19,41 +19,100 @@ #include +#include + #include "afb-msg-json.h" +#include "afb-context.h" -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(const char *status, const char *info, struct json_object *resp, struct afb_context *context, const char *reqid) { 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(msg, "request", request); json_object_object_add(request, "status", json_object_new_string(status)); + 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 (reqid != NULL) + json_object_object_add(request, "reqid", json_object_new_string(reqid)); + + 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; } +struct json_object *afb_msg_json_reply_ok(const char *info, struct json_object *resp, struct afb_context *context, const char *reqid) +{ + return afb_msg_json_reply("success", info, resp, context, reqid); +} + +struct json_object *afb_msg_json_reply_error(const char *status, const char *info, struct afb_context *context, const char *reqid) +{ + return afb_msg_json_reply(status, info, NULL, context, reqid); +} + 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; } +struct afb_arg afb_msg_json_get_arg(struct json_object *object, const char *name) +{ + struct afb_arg arg; + struct json_object *value; + + if (json_object_object_get_ex(object, name, &value)) { + arg.name = name; + arg.value = json_object_get_string(value); + } else { + arg.name = NULL; + arg.value = NULL; + } + arg.path = NULL; + return arg; +} + +struct json_object *afb_msg_json_internal_error() +{ + static struct json_object *obj; + + if (obj == NULL) + obj = afb_msg_json_reply_error("failed", "internal error", NULL, NULL); + + return obj; +} + +