From 88178aed18f9f1a42b8429e500b8431952f87f4d Mon Sep 17 00:00:00 2001 From: zhangzengfei <zhangzengfei@smartai.com> Date: 星期四, 12 一月 2023 17:38:13 +0800 Subject: [PATCH] 添加时间规则接口定义 --- util.cpp | 112 ++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 100 insertions(+), 12 deletions(-) diff --git a/util.cpp b/util.cpp index 087a031..6f7b235 100644 --- a/util.cpp +++ b/util.cpp @@ -51,6 +51,88 @@ return json; } +extern "C" int bus_dbapi_get_json_data(const char * json, char ** pptr_data) +{ + /*{ + "success": true, + "msg": "", + "data": { + "alarm_ip": "192.168.20.189", + "alarm_port": 9200, + } + }*/ + + /*{ + "code": 200, + "data": [ + { + "id": "295F36D6-7489-30AC-3263-335B4660AA79", + "name": "鍏ㄥぉ", + "time_rule": "[{\"day\":1,\"time_range\":[{\"start\":\"05:31\",\"end\":\"21:07\"}]},{\"day\":2,\"time_range\":[{\"start\":\"01:42\",\"end\":\"23:59\"}]},{\"day\":3,\"time_range\":[{\"start\":\"00:00\",\"end\":\"23:59\"}]},{\"day\":4,\"time_range\":[{\"start\":\"00:00\",\"end\":\"23:59\"}]},{\"day\":5,\"time_range\":[{\"start\":\"00:00\",\"end\":\"23:59\"}]},{\"day\":6,\"time_range\":[{\"start\":\"00:00\",\"end\":\"23:59\"}]},{\"day\":7,\"time_range\":[{\"start\":\"00:00\",\"end\":\"23:59\"}]}]" + }, + { + "id": "21FA488C-2858-F366-4587-CE0661BFAD60", + "name": "SAAS", + "time_rule": "[{\"day\":1,\"time_range\":[{\"start\":\"00:00\",\"end\":\"17:04\"}]},{\"day\":2,\"time_range\":[{\"start\":\"00:00\",\"end\":\"17:25\"}]},{\"day\":3,\"time_range\":[{\"start\":\"00:00\",\"end\":\"17:22\"}]},{\"day\":4,\"time_range\":[{\"start\":\"00:00\",\"end\":\"15:33\"}]},{\"day\":5,\"time_range\":[{\"start\":\"00:00\",\"end\":\"17:40\"}]},{\"day\":6,\"time_range\":[{\"start\":\"00:00\",\"end\":\"18:04\"}]},{\"day\":7,\"time_range\":[{\"start\":\"00:00\",\"end\":\"13:51\"}]}]" + }, + { + "id": "37B82C8F-3BDB-A247-3683-F045190D2991", + "name": "116", + "time_rule": "[{\"day\":1,\"time_range\":[{\"start\":\"03:28\",\"end\":\"23:59\"}]},{\"day\":2,\"time_range\":[{\"start\":\"04:04\",\"end\":\"23:59\"}]},{\"day\":3,\"time_range\":[{\"start\":\"04:40\",\"end\":\"23:59\"}]},{\"day\":4,\"time_range\":[{\"start\":\"04:46\",\"end\":\"23:59\"}]},{\"day\":5,\"time_range\":[{\"start\":\"04:58\",\"end\":\"23:59\"}]},{\"day\":6,\"time_range\":[{\"start\":\"06:16\",\"end\":\"23:59\"}]},{\"day\":7,\"time_range\":[{\"start\":\"05:52\",\"end\":\"23:59\"}]}]" + } + ], + "msg": "", + "success": true +}*/ + int ret = -1; + size_t data_len = 0; + const char * ptr_value = NULL; + const char * success_name = "success"; + const char * msg_name = "msg"; + + if(NULL == *pptr_data) + { + return -1; + } + + + // Read JSON and get root + yyjson_doc *doc = yyjson_read(json, strlen(json), 0); + yyjson_val *root = yyjson_doc_get_root(doc); + + // Get root["success"] + yyjson_val *success = yyjson_obj_get(root, success_name); + + int success_val = yyjson_get_bool(success); + printf("success: %d\n", success_val); + if(!success_val) + { + yyjson_doc_free(doc); + return -1; + } + + // Get root["msg"] + //yyjson_val *msg = yyjson_obj_get(root, "msg"); + yyjson_val *msg = yyjson_obj_get(root, "msg"); + printf("msg: %s\n", yyjson_get_str(msg)); + + // Get root["data"] + //yyjson_val *msg = yyjson_obj_get(root, "data"); + yyjson_val *data = yyjson_obj_get(root, "data"); + ptr_value = yyjson_val_write(data, YYJSON_WRITE_NOFLAG, &data_len); + printf("data: %s\n", ptr_value); + printf("len: %lu\n", data_len); + + memcpy(*pptr_data, ptr_value, data_len); + ret = 0; + + // Free the doc + yyjson_doc_free(doc); + + // All functions accept NULL input, and return NULL on error. + return ret; +} + bool bus_dbapi_get(void *handle, const char* topic, google::protobuf::Message& message) { const auto topicl = strlen(topic); @@ -65,21 +147,27 @@ return false; } - char* msgdata = repmsg->data + 32; - msgdata[strlen(msgdata) -1] = '\0'; - printf("======>> protomsg: %s\n", msgdata); - - std::string jsonString = msgdata; - if (json_to_proto(jsonString, message)) { - printf("======>> json_to_proto done\n"); - - } else { - printf("======>> json_to_proto fail\n"); - return false; + int msglen = strlen(repmsg->data); + char* msgdata = (char *)malloc(msglen); + memset(msgdata, 0 , msglen); + + if(0 == bus_dbapi_get_json_data((const char *)repmsg->data, &msgdata)) + { + printf("======>> protomsg: %s\n", msgdata); + std::string jsonString = msgdata; + if (json_to_proto(jsonString, message)) + { + printf("======>> json_to_proto done\n"); + } + else + { + printf("======>> json_to_proto fail\n"); + return false; + } } + free(msgdata); free_reqmsg(reqmsg); - free(reqData); return true; -- Gitblit v1.8.0