diff options
author | Romain Forlot <romain.forlot@iot.bzh> | 2018-07-25 14:37:48 +0200 |
---|---|---|
committer | Romain Forlot <romain.forlot@iot.bzh> | 2018-07-25 14:37:58 +0200 |
commit | b79a76136974423445f647db9f04c236938401ce (patch) | |
tree | 6b4364896e9a752e8bbd9bab7d1a47f7ba614e4a /ctl-lib/ctl-config.c | |
parent | c3d7de27a97f4d4ba7de818d2da3775a85973ee7 (diff) |
Split loading JSON controller file.
This make possible to load from a binding either a file
or directly a JSON object.
Change-Id: If3f3edb8aaed066922982250dd162d483a7dc47a
Signed-off-by: Romain Forlot <romain.forlot@iot.bzh>
Diffstat (limited to 'ctl-lib/ctl-config.c')
-rw-r--r-- | ctl-lib/ctl-config.c | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/ctl-lib/ctl-config.c b/ctl-lib/ctl-config.c index a98cb34..339b14c 100644 --- a/ctl-lib/ctl-config.c +++ b/ctl-lib/ctl-config.c @@ -161,21 +161,11 @@ int CtlConfigExec(AFB_ApiT apiHandle, CtlConfigT *ctlConfig) { return errcount; } -CtlConfigT *CtlLoadMetaDataUsingPrefix(AFB_ApiT apiHandle,const char* filepath, const char *prefix) { - json_object *ctlConfigJ; +CtlConfigT *CtlLoadMetaDataJson(AFB_ApiT apiHandle, json_object *ctlConfigJ, const char *prefix) { + json_object *metadataJ; CtlConfigT *ctlHandle=NULL; int err; - // Load JSON file - ctlConfigJ = json_object_from_file(filepath); - if (!ctlConfigJ) { - AFB_ApiError(apiHandle, "CTL-LOAD-CONFIG Not invalid JSON %s ", filepath); - return NULL; - } - - AFB_ApiInfo(apiHandle, "CTL-LOAD-CONFIG: loading config filepath=%s", filepath); - - json_object *metadataJ; int done = json_object_object_get_ex(ctlConfigJ, "metadata", &metadataJ); if (done) { ctlHandle = calloc(1, sizeof (CtlConfigT)); @@ -199,8 +189,20 @@ CtlConfigT *CtlLoadMetaDataUsingPrefix(AFB_ApiT apiHandle,const char* filepath, return ctlHandle; } -CtlConfigT *CtlLoadMetaData(AFB_ApiT apiHandle, const char* filepath) { - return CtlLoadMetaDataUsingPrefix(apiHandle, filepath, NULL); +CtlConfigT *CtlLoadMetaDataUsingPrefix(AFB_ApiT apiHandle,const char* filepath, const char *prefix) { + json_object *ctlConfigJ; + + + // Load JSON file + ctlConfigJ = json_object_from_file(filepath); + if (!ctlConfigJ) { + AFB_ApiError(apiHandle, "CTL-LOAD-CONFIG Not invalid JSON %s ", filepath); + return NULL; + } + + AFB_ApiInfo(apiHandle, "CTL-LOAD-CONFIG: loading config filepath=%s", filepath); + + return CtlLoadMetaDataJson(apiHandle, ctlConfigJ, prefix); } void wrap_json_array_add(void* array, json_object *val) { |