From e52dbd2cfdd74040c012c70a1253b9031a085662 Mon Sep 17 00:00:00 2001
From: cheliequan <liequanche@126.com>
Date: 星期一, 16 一月 2023 19:49:33 +0800
Subject: [PATCH] 优化接口支持json是数组格式
---
util.cpp | 205 +++++++++++++++++++++++++++++++++++----------------
1 files changed, 140 insertions(+), 65 deletions(-)
diff --git a/util.cpp b/util.cpp
index d823797..26a0dda 100644
--- a/util.cpp
+++ b/util.cpp
@@ -54,6 +54,103 @@
return json;
}
+char *make_get_request(const char *topic, std::map<string, string> &query_params) {
+ yyjson_mut_doc *doc = yyjson_mut_doc_new(NULL);
+ yyjson_mut_val *root = yyjson_mut_obj(doc);
+ yyjson_mut_obj_add_strn(doc, root, "path", topic, strlen(topic));
+ yyjson_mut_obj_add_strn(doc, root, "method", "GET", 3);
+
+ // 濉厖璇锋眰鍙傛暟
+ if (!query_params.empty()) {
+ yyjson_mut_val *query_map = yyjson_mut_obj(doc);
+
+ // std::map<string, string> t_map = *query_params;
+ std::map<string, string>::iterator iter;
+ for (iter = query_params.begin(); iter != query_params.end(); iter++) {
+ yyjson_mut_val *_key = yyjson_mut_str(doc, iter->first.c_str());
+
+ yyjson_mut_val *param = yyjson_mut_arr(doc);
+ yyjson_mut_val *_val = yyjson_mut_str(doc, iter->second.c_str());
+ yyjson_mut_arr_append(param, _val);
+
+ yyjson_mut_obj_add(query_map, _key, param);
+ }
+
+ yyjson_mut_val *query_map_key = yyjson_mut_str(doc, "queryMap");
+ yyjson_mut_obj_add(root, query_map_key, query_map);
+ }
+
+ yyjson_mut_doc_set_root(doc, root);
+
+ size_t jsonl = 0;
+ char *json = yyjson_mut_val_write(root, 0, &jsonl);
+
+ yyjson_mut_doc_free(doc);
+
+ 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;
+ if ( NULL != data_name )
+ {
+ data = yyjson_obj_get(root, data_name);
+ }
+ else
+ {
+ data = root;
+ }
+
+
+ *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,
@@ -89,57 +186,38 @@
"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) {
const auto topicl = strlen(topic);
auto reqData = make_get_request(topic);
+ auto reqmsg = make_req_msg(topic, topicl, reqData, strlen(reqData));
+
+ if (bus_client_request(handle, reqmsg, pptr_repmsg)) {
+ printf("======>> bus_client_reqest [%s] get [%s]\n", topic, (*pptr_repmsg)->data);
+ } else {
+ free(reqData);
+ return false;
+ }
+
+ len = strlen((*pptr_repmsg)->data) + 1;
+
+ free(reqData);
+ return true;
+}
+
+bool bus_dbapi_get_topic_data(void *handle, const char *topic, crepmsg **pptr_repmsg, size_t len, std::map<string, string> ¶ms) {
+ const auto topicl = strlen(topic);
+ auto reqData = make_get_request(topic, params);
auto reqmsg = make_req_msg(topic, topicl, reqData, strlen(reqData));
if (bus_client_request(handle, reqmsg, pptr_repmsg)) {
@@ -247,36 +325,33 @@
淇敼鍐呭 : 鏂扮敓鎴愬嚱鏁�
*****************************************************************************/
-int get_value_by_key(char *json, const char *key, char **pptr_data)
-{
+int get_value_by_key(char *json, const char *key, char **pptr_data) {
size_t data_len = 0;
-
+
// Read JSON and get root
- yyjson_doc *doc = yyjson_read(json, strlen(json), 0);
- yyjson_val *root = yyjson_doc_get_root(doc);
-
- // Get root[key]
- yyjson_val *val = yyjson_obj_get(root, key);
-
- char * val_str = (char *)yyjson_get_str(val);
- printf("val: %s\n", val_str);
- if(NULL == val_str)
- {
- yyjson_doc_free(doc);
- return -1;
- }
+ yyjson_doc *doc = yyjson_read(json, strlen(json), 0);
+ yyjson_val *root = yyjson_doc_get_root(doc);
+ // Get root[key]
+ yyjson_val *val = yyjson_obj_get(root, key);
- char *ptr_value = yyjson_val_write(val, YYJSON_WRITE_NOFLAG, &data_len);
- printf("data: %s\n", ptr_value);
- printf("len: %lu\n", data_len);
+ char *val_str = (char *)yyjson_get_str(val);
+ printf("val: %s\n", val_str);
+ if (NULL == val_str) {
+ yyjson_doc_free(doc);
+ return -1;
+ }
- *pptr_data = (char *)malloc(data_len);
- memset(*pptr_data, 0, data_len);
- memcpy(*pptr_data, ptr_value, data_len);
-
- // Free the doc
- yyjson_doc_free(doc);
+ char *ptr_value = yyjson_val_write(val, YYJSON_WRITE_NOFLAG, &data_len);
+ printf("data: %s\n", ptr_value);
+ printf("len: %lu\n", data_len);
- return 0;
+ *pptr_data = (char *)malloc(data_len);
+ memset(*pptr_data, 0, data_len);
+ memcpy(*pptr_data, ptr_value, data_len);
+
+ // Free the doc
+ yyjson_doc_free(doc);
+
+ return 0;
}
--
Gitblit v1.8.0