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