ExpelDevice.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * @Description:
  3. * @Version: 1.0
  4. * @Autor: lishengyin
  5. * @Date: 2022-02-16 15:25:46
  6. * @LastEditors: lishengyin
  7. * @LastEditTime: 2022-08-23 17:44:35
  8. */
  9. #ifndef __EXPELDEVICE_H_
  10. #define __EXPELDEVICE_H_
  11. #include <iostream>
  12. #include <rapidjson/document.h>
  13. #include <rapidjson/rapidjson.h>
  14. #include <rapidjson/stringbuffer.h>
  15. #include <rapidjson/writer.h>
  16. #include "Util/SqlPool.h"
  17. #include "UtilBase.hpp"
  18. using namespace toolkit;
  19. using namespace std;
  20. using namespace gsd;
  21. enum DeviceType {
  22. DevicePlayerV1 = 0,
  23. DeviceGasV1 = 1,
  24. DevicePlayerV2 = 2,
  25. DevicePlayerV3 = 3,
  26. DevicePlayerV4 = 4,
  27. };
  28. class ExpelDevice
  29. {
  30. public:
  31. int Id;
  32. std::string DeviceId;
  33. enum ContorlGear::DeviceTools tool = ContorlGear::DeviceTools::serial;
  34. enum DeviceType deviceType;
  35. std::string UpdateTime;
  36. std::string ServerIp;
  37. std::string ServerCname;
  38. std::string ServerCpwd;
  39. public:
  40. ExpelDevice(){}
  41. ~ExpelDevice(){}
  42. /**
  43. * @description: json转换为对象
  44. * @param {string&} json
  45. * @return {*}
  46. */
  47. bool JsonToObject(std::string& json){
  48. rapidjson::Document doc;
  49. if (doc.Parse<rapidjson::kParseCommentsFlag>(json.c_str()).HasParseError()) {
  50. return false;
  51. }
  52. // get members
  53. const auto end = doc.MemberEnd();
  54. // json_type
  55. if(end == doc.FindMember("DeviceId") || !doc["DeviceId"].IsString()) {
  56. return false;
  57. }else{
  58. DeviceId = doc["DeviceId"].GetString();
  59. }
  60. // json_type
  61. if(end == doc.FindMember("DeviceToken") || !doc["DeviceToken"].IsString()) {
  62. return false;
  63. }else{
  64. tool = (enum ContorlGear::DeviceTools)atoi(doc["DeviceToken"].GetString());
  65. }
  66. if (end == doc.FindMember("DeviceType") || !doc["DeviceType"].IsString()) {
  67. return false;
  68. } else {
  69. deviceType = (enum DeviceType)atoi(doc["DeviceType"].GetString());
  70. }
  71. if (end == doc.FindMember("ServerIp") || !doc["ServerIp"].IsString()) {
  72. return false;
  73. } else {
  74. ServerIp = doc["ServerIp"].GetString();
  75. }
  76. if (end == doc.FindMember("ServerCname") || !doc["ServerCname"].IsString()) {
  77. return false;
  78. } else {
  79. ServerCname = doc["ServerCname"].GetString();
  80. }
  81. if (end == doc.FindMember("ServerCpwd") || !doc["ServerCpwd"].IsString()) {
  82. return false;
  83. } else {
  84. ServerCpwd = doc["ServerCpwd"].GetString();
  85. }
  86. return true;
  87. }
  88. /**
  89. * @description: object转换为sql
  90. * @param {*}
  91. * @return {*}
  92. */
  93. std::string ObjectToSql(){
  94. SqlStream sqlStream("insert into gsdDB.`DeviceList` (Id, DeviceId, DeviceToken, DeviceType, ServerIp, ServerCname, ServerCpwd, UpdateTime,ISDELETE)\
  95. values ('?','?','?','?','?','?','?','?','0')\
  96. on duplicate key update Id=VALUES(Id), DeviceId=VALUES(DeviceId),\
  97. DeviceToken=VALUES(DeviceToken), DeviceType=VALUES(DeviceType), \
  98. ServerIp=VALUES(ServerIp), ServerCname=VALUES(ServerCname), \
  99. ServerCpwd=VALUES(ServerCpwd), UpdateTime=VALUES(UpdateTime),\
  100. ISDELETE=VALUES(ISDELETE)");
  101. sqlStream << Id << DeviceId << tool << deviceType << ServerIp << ServerCname << ServerCpwd << UpdateTime;
  102. return (std::string)sqlStream;
  103. }
  104. };
  105. #endif