ExpelDevice.h 3.4 KB

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