From 946823215bac2c859df843f7b01636f5fda34ed4 Mon Sep 17 00:00:00 2001
From: cheliequan <liequanche@126.com>
Date: 星期五, 13 一月 2023 20:32:23 +0800
Subject: [PATCH] 重构util接口,支持按照key查找json,并转换vector list
---
rule.cpp | 24 ++++++++
dbapi.h | 2
util.cpp | 100 ++++++++++++++++++++-------------
util.h | 16 ++++
4 files changed, 101 insertions(+), 41 deletions(-)
diff --git a/dbapi.h b/dbapi.h
index 291f1bc..ff58ef4 100644
--- a/dbapi.h
+++ b/dbapi.h
@@ -13,6 +13,8 @@
bool dbapi_get_poll_config(void *handle, protomsg::PollConfig &message);
bool dbapi_get_stack_config(void *handle, protomsg::FileAnalysisSetting &message);
bool dbapi_get_time_rules(void *handle, std::vector<protomsg::CameraTimerule> &list);
+bool dbapi_get_dayctls(char *timeRules, std::vector<protomsg::DayCtl> & list);
+bool dbapi_get_timeranges(char *datactls, std::vector<protomsg::TimeRange> & list);
bool dbapi_get_camera_rules(void *handle, std::vector<protomsg::CameraAndRules> &list);
bool dbapi_get_cameras_by_runtype(void *handle, std::vector<protomsg::Camera> &list);
diff --git a/rule.cpp b/rule.cpp
index 23abaff..9215e4a 100644
--- a/rule.cpp
+++ b/rule.cpp
@@ -12,6 +12,30 @@
return ret;
}
+bool dbapi_get_dayctls(char *timeRules, std::vector<protomsg::DayCtl> & list)
+{
+ const char * flag_key = NULL;
+
+ const char * data_key = "time_rule";
+
+ bool ret = bus_dbapi_get_list(timeRules, flag_key, data_key, list);
+
+ return ret;
+
+}
+
+bool dbapi_get_timeranges(char *datactls, std::vector<protomsg::TimeRange> & list)
+{
+ const char * flag_key = NULL;
+
+ const char * data_key = "time_range";
+
+ bool ret = bus_dbapi_get_list(datactls, flag_key, data_key, list);
+
+ return ret;
+
+}
+
bool dbapi_get_camera_rules(void *handle, std::vector<protomsg::CameraAndRules> &list) {
const char *topic = DATA_URL_PREFIX("/camera/rule/findAll");
diff --git a/util.cpp b/util.cpp
index 50803e1..65c265e 100644
--- a/util.cpp
+++ b/util.cpp
@@ -90,6 +90,65 @@
return json;
}
+extern "C" int bus_dbapi_get_json_data_by_key(const char * json, const char *flag_key,
+ const char *data_key, char ** pptr_data,
+ yyjson_type *ptr_type)
+{
+ int ret = -1;
+ size_t data_len = 0;
+ const char * ptr_value = NULL;
+ const char * success_name = flag_key;
+ const char * data_name = data_key;
+ 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);
+
+ if ( NULL != success_name )
+ {
+ // 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_name);
+
+ *ptr_type = yyjson_get_type(data);
+ ptr_value = yyjson_val_write(data, YYJSON_WRITE_NOFLAG, &data_len);
+ printf("%s: %s\n", data_name, 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;
+}
+
extern "C" int bus_dbapi_get_json_data(const char *json, char **pptr_data, yyjson_type *ptr_type) {
/*{
"success": true,
@@ -125,52 +184,15 @@
"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";
+ const char * data_name = "data";
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_type = yyjson_get_type(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;
+ return bus_dbapi_get_json_data_by_key(json, success_name, data_name, pptr_data, ptr_type);
}
bool bus_dbapi_get_topic_data(void *handle, const char *topic, crepmsg **pptr_repmsg, size_t len) {
diff --git a/util.h b/util.h
index 93bc335..9e643b7 100644
--- a/util.h
+++ b/util.h
@@ -32,12 +32,15 @@
bool bus_dbapi_get(void *handle, const char *topic, google::protobuf::Message &message);
bool bus_dbapi_get_topic_data(void *handle, const char *topic, crepmsg **pptr_repmsg, size_t len);
+extern "C" int bus_dbapi_get_json_data_by_key(const char * json, const char *flag_key,
+ const char *data_key, char ** pptr_data,
+ yyjson_type *ptr_type);
extern "C" int bus_dbapi_get_json_data(const char *json, char **pptr_data, uint8_t *ptr_type);
bool bus_dbapi_get_str(void *handle, const char *topic, char **pptr_str);
int get_value_by_key(char *json, const char *key, char **pptr_data);
template <class T>
-bool bus_dbapi_get_list(char *json, T &list) {
+bool bus_dbapi_get_list(char *json, const char *flag_key, const char *data_key, T &list) {
char *ptr_value = NULL;
size_t data_len = 0;
//get the topic json data
@@ -51,7 +54,7 @@
char *msgdata = (char *)malloc(msglen);
memset(msgdata, 0, msglen);
- if (0 == bus_dbapi_get_json_data(json, &msgdata, &type)) {
+ if (0 == bus_dbapi_get_json_data_by_key(json, flag_key, data_key, &msgdata, &type)) {
printf("======>> protomsg: %s\n", msgdata);
}
@@ -95,6 +98,14 @@
}
template <class T>
+bool bus_dbapi_get_list(char *json, T &list) {
+ const char *success_name = "success";
+ const char *data_name = "data";
+
+ return bus_dbapi_get_list(json, success_name, data_name, list);
+}
+
+template <class T>
bool bus_dbapi_get_list(void *handle, const char *topic, T &list) {
crepmsg *repmsg = NULL;
size_t len = 0;
@@ -108,4 +119,5 @@
free_reply_msg(repmsg);
return iRet;
}
+
#endif
\ No newline at end of file
--
Gitblit v1.8.0