FromWebAPI.cpp 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062
  1. #include "FromWebAPI.h"
  2. #include <QVector>
  3. #include <QString>
  4. #include <QUuid>
  5. #include <QApplication>
  6. #include "LHQLogAPI.h"
  7. #include "TransmitterSwitchInfo.h"
  8. FromWebAPI::FromWebAPI()
  9. {
  10. }
  11. FromWebAPI::~FromWebAPI()
  12. {
  13. if(m_httpApi != nullptr)
  14. {
  15. delete m_httpApi;
  16. m_httpApi = nullptr;
  17. }
  18. }
  19. /* 初始化WebApi */
  20. bool FromWebAPI::initWebApi(const QString& url, const QString& serverID, const QString& serverKey)
  21. {
  22. if(m_httpApi == nullptr)
  23. {
  24. m_httpApi = new lhhttpapi;
  25. }
  26. #if defined(Q_OS_WIN)
  27. #ifdef QT_DEBUG
  28. QString libFile = QString("%1/LHSqlWebInterface.dll").arg(QApplication::applicationDirPath());
  29. #else
  30. QString libFile = QString("%1/LHSqlWebInterface.dll").arg(QApplication::applicationDirPath());
  31. #endif
  32. #elif defined(Q_OS_LINUX)
  33. #ifdef QT_DEBUG
  34. QString libFile = QString("%1/libLHSqlWebInterface.so").arg(QApplication::applicationDirPath());
  35. #else
  36. QString libFile = QString("%1/libLHSqlWebInterface.so").arg(QApplication::applicationDirPath());
  37. #endif
  38. #endif
  39. if(!m_httpApi->Load(libFile))
  40. {
  41. LH_WRITE_ERROR("Load WebAPI failed");
  42. return false;
  43. }
  44. LH_WRITE_LOG_DEBUG(QString("URL:%1").arg(url));
  45. LH_WRITE_LOG_DEBUG(QString("ServerID:%1").arg(serverID));
  46. LH_WRITE_LOG_DEBUG(QString("ServerKey:%1").arg(serverKey));
  47. auto pHttp = m_httpApi->DBInit(url.toStdString().c_str(), true);
  48. int ret = 0;
  49. #ifdef QT_DEBUG
  50. /* 获取服务器列表 */
  51. char serverList[8192]={0};
  52. ret = m_httpApi->DBGetServerList(serverList, 8192-1);
  53. if(ret != 0)
  54. {
  55. LH_WRITE_ERROR(QString("Get server list failed:%1, error info:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  56. return false;
  57. }
  58. // LH_WRITE_LOG(QString("\nGet server list success:%1").arg(serverList));
  59. #endif
  60. /* 登录,第二个参数是限制的服务 */
  61. // ret = m_httpApi->DBLogin("", serverID, serverKey, m_userToken, true, pHttp);
  62. ret = m_httpApi->DBLogin("", serverID, "ESM8C", m_userToken, true, pHttp);
  63. if(ret != 0)
  64. {
  65. LH_WRITE_ERROR(QString("Login failed:%1, error info:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  66. return false;
  67. }
  68. LH_WRITE_LOG("\n");
  69. LH_WRITE_LOG("WebAPI Login success!");
  70. return true;
  71. }
  72. /* 获取设备信息 */
  73. bool FromWebAPI::getDeviceInfo(QMap<QString, DeviceInfo>& mapDevice)
  74. {
  75. if(m_httpApi == nullptr)
  76. {
  77. LH_WRITE_ERROR("WebAPI is nullptr");
  78. return false;
  79. }
  80. nJson json0;
  81. json0["opName"] = "ESM8C_GetDevice";
  82. QString strCmd = QString::fromStdString(json0.dump());
  83. QString strRet;
  84. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  85. if(ret != 0)
  86. {
  87. LH_WRITE_ERROR(QString("从数据库获取设备失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  88. return false;
  89. }
  90. /* 解析获取到的JSON数据 */
  91. // LH_WRITE_LOG_DEBUG(strRet);
  92. try
  93. {
  94. nJson json1 = nJson::parse(strRet.toStdString());
  95. int retCode = json1["code"].get<int>();
  96. if(retCode != 0)
  97. {
  98. LH_WRITE_ERROR("获取设备数据失败");
  99. return false;
  100. }
  101. nJson result = json1["result"];
  102. for(auto& it : result)
  103. {
  104. DeviceInfo DevInfo;
  105. QString devName = QString::fromStdString(it["dname"].get<std::string>());
  106. DevInfo.devName = devName;
  107. DevInfo.DID = it["did"].is_null() ? -1 : it["did"].get<int>();
  108. DevInfo.DTID = it["dtid"].is_null() ? -1 : it["dtid"].get<int>();
  109. DevInfo.MPID = it["mpid"].is_null() ? -1 : it["mpid"].get<int>();
  110. DevInfo.PTTypeCode = it["pttypecode"].is_null() ? -1 : it["pttypecode"].get<int>();
  111. DevInfo.ChannelID = it["chnid"].is_null() ? -1 : it["chnid"].get<int>();
  112. if(DevInfo.ChannelID <= 0)
  113. {
  114. LH_WRITE_LOG_DEBUG(QString("通道ID错误:%1").arg(DevInfo.ChannelID));
  115. continue;
  116. }
  117. /* 查找对应的设备类型,根据PTTypeCode来查找,这个是唯一的 */
  118. auto devType = DevTypeContainer.getDevType(DevInfo.PTTypeCode);
  119. if(devType.PTTypeCode < 0)
  120. {
  121. LH_WRITE_LOG_DEBUG(QString("未找到设备类型:%1").arg(DevInfo.PTTypeCode));
  122. continue;
  123. }
  124. DevInfo.DevType = devType;
  125. /* 检查有没有设置主备 */
  126. int devMB = it["dClass"].is_null() ? -1 : it["dClass"].get<int>();
  127. if(devMB < 0)
  128. {
  129. LH_WRITE_ERROR(QString("设备类型:%1《主/备》 类型为空").arg(DevInfo.DevType.PTTypeCode));
  130. continue;
  131. }
  132. mapDevice.insert(DevInfo.devName, DevInfo);
  133. }
  134. LH_WRITE_LOG(QString("获取设备数据成功,设备数目:%1").arg(mapDevice.size()));
  135. } catch (const nJson::parse_error& e) {
  136. LH_WRITE_ERROR("解析ESM-8C设备数据失败");
  137. return false;
  138. }
  139. catch (const nJson::exception& e)
  140. {
  141. LH_WRITE_ERROR("解析ESM-8C设备数据失败");
  142. return false;
  143. }
  144. catch(...)
  145. {
  146. LH_WRITE_ERROR("解析ESM-8C设备数据失败");
  147. return false;
  148. }
  149. return true;
  150. }
  151. /* 获取频率信息 */
  152. bool FromWebAPI::getChannelInfo(QMap<int, ChannelInfo>& mapFreq)
  153. {
  154. /* 测试,创建几个频率 */
  155. // for(int i = 0; i < 12; i++)
  156. // {
  157. // ChannelInfo freqInfo;
  158. // freqInfo.ChannelID = i + 1;
  159. // freqInfo.ChannelName = QString("频率%1").arg(freqInfo.ChannelID);
  160. // mapFreq.insert(freqInfo.ChannelID, freqInfo);
  161. // }
  162. if(m_httpApi == nullptr)
  163. {
  164. LH_WRITE_ERROR("WebAPI is nullptr");
  165. return false;
  166. }
  167. nJson json0;
  168. json0["opName"] = "ESM8C_GetChannel";
  169. QString strCmd = QString::fromStdString(json0.dump());
  170. QString strRet;
  171. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  172. if(ret != 0)
  173. {
  174. LH_WRITE_ERROR(QString("从数据库获取频率信息失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  175. return false;
  176. }
  177. try
  178. {
  179. nJson json1 = nJson::parse(strRet.toStdString());
  180. int retCode = json1["code"].get<int>();
  181. if(retCode != 0)
  182. {
  183. LH_WRITE_ERROR("获取频率数据失败");
  184. return false;
  185. }
  186. nJson result = json1["result"];
  187. for(auto& it : result)
  188. {
  189. ChannelInfo freqInfo;
  190. freqInfo.ChannelID = it["chnid"].is_null() ? -1 : it["chnid"].get<int>();
  191. if(freqInfo.ChannelID <= 0)
  192. {
  193. LH_WRITE_LOG_DEBUG(QString("通道ID错误:%1").arg(freqInfo.ChannelID));
  194. continue;
  195. }
  196. freqInfo.ChannelName = QString::fromStdString(it["chnname"].get<std::string>());
  197. mapFreq.insert(freqInfo.ChannelID, freqInfo);
  198. }
  199. }
  200. catch (const nJson::parse_error& e) {
  201. LH_WRITE_ERROR("解析频率信息数据失败");
  202. return false;
  203. }
  204. catch (const nJson::exception& e)
  205. {
  206. LH_WRITE_ERROR("解析频率信息数据失败");
  207. return false;
  208. }
  209. catch(...)
  210. {
  211. LH_WRITE_ERROR("解析频率信息数据失败");
  212. return false;
  213. }
  214. LH_WRITE_LOG_DEBUG(QString("获取频率数据成功,频率数目:%1").arg(mapFreq.size()));
  215. return true;
  216. }
  217. /**
  218. * @brief 将数据写入EQM数据库
  219. *
  220. * @param chnID 频率ID
  221. * @param list
  222. * @return true
  223. * @return false
  224. */
  225. bool FromWebAPI::insertData(int chnID, QList<OnePlanItemInfo>& list)
  226. {
  227. if(m_httpApi == nullptr)
  228. {
  229. LH_WRITE_ERROR("WebAPI is nullptr");
  230. return false;
  231. }
  232. /* 先删除表格中的数据 */
  233. deleteOneChnPlan(chnID);
  234. QDate zeroDate(1970,1,1);
  235. /* 写入数据 */
  236. nJson json0 = nJson::array();
  237. try{
  238. for(auto& it : list)
  239. {
  240. nJson json1;
  241. json1["opName"] = "ESM8C_InsertDataToExecPlan";
  242. json1["Key"] = QUuid::createUuid().toString().toStdString();
  243. nJson json2;
  244. json2["channelID"] = it.ChannelID;
  245. json2["channelName"] = it.ChannelName.toStdString();
  246. json2["onWeekDay"] = it.onWeekDay;
  247. json2["onDate"] = it.onDateTime.date().toString("yyyy-MM-dd").toStdString();
  248. json2["onTime"] = it.onDateTime.time().toString("hh:mm:ss").toStdString();
  249. json2["offWeekDay"] = it.offWeekDay;
  250. json2["offDate"] = it.offDateTime.date().toString("yyyy-MM-dd").toStdString();
  251. json2["offTime"] = it.offDateTime.time().toString("hh:mm:ss").toStdString();
  252. json1["paramList"] = json2;
  253. json0.push_back(json1);
  254. }
  255. }catch (const nJson::parse_error& e) {
  256. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  257. return false;
  258. }
  259. catch (const nJson::exception& e)
  260. {
  261. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  262. return false;
  263. }
  264. catch (...)
  265. {
  266. SPDLOG_ERROR("生成json数据失败");
  267. return false;
  268. }
  269. /* 将json写入本地文件 */
  270. #ifdef C_DEBUG
  271. QString fileJson(QString::fromStdString(json0.dump(4)));
  272. // LH_WRITE_LOG_DEBUG("\n" + fileJson);
  273. // QString filePath = QApplication::applicationDirPath() + QString("ExecPlanData.json");
  274. // SPDLOG_LOGGER_DEBUG(m_logger,"To EQM Json写入文件:{}", filePath.toStdString());
  275. // QFile file(filePath);
  276. // if(file.open(QIODevice::WriteOnly | QIODevice::Truncate))
  277. // {
  278. // file.write(fileJson.toUtf8());
  279. // file.close();
  280. // }else {
  281. // SPDLOG_LOGGER_ERROR(m_logger,"打开文件失败:{}", filePath.toStdString());
  282. // }
  283. #endif
  284. /* 写入EQM数据库 */
  285. QString strCmd = QString::fromStdString(json0.dump());
  286. QString strRet;
  287. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  288. if(ret != 0)
  289. {
  290. LH_WRITE_ERROR(QString("写入EQM数据库失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  291. return false;
  292. }
  293. // LH_WRITE_LOG(QString("计划写入EQM数据库成功, 计划数目:%1").arg(QString::number(list.size())));
  294. return true;
  295. }
  296. /**
  297. * @brief 获取tExecPlan表格数据,获取到的数据会根据设备名查找对应的设备信息,如果没有查找到,就抛弃这个计划
  298. *
  299. * @param chnID 频率ID
  300. * @param mapPlan
  301. * @return true
  302. * @return false
  303. */
  304. bool FromWebAPI::getExecPlanData(int chnID, QList<OnePlanItemInfo>& list)
  305. {
  306. if(m_httpApi == nullptr)
  307. {
  308. LH_WRITE_ERROR("WebAPI is nullptr");
  309. return false;
  310. }
  311. nJson json0;
  312. json0["opName"] = "ESM8C_GetOneChnPlan";
  313. nJson json1;
  314. json1["channelID"] = chnID;
  315. json0["paramList"] = json1;
  316. QString strCmd = QString::fromStdString(json0.dump());
  317. QString strRet;
  318. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  319. if(ret != 0)
  320. {
  321. LH_WRITE_ERROR(QString("从EQM获取tExecPlan表格数据失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  322. return false;
  323. }
  324. /* 解析获取到的JSON数据 */
  325. // SPDLOG_LOGGER_DEBUG(m_logger,"获取执行计划:\n{}",strRet.toStdString());
  326. try
  327. {
  328. nJson json2 = nJson::parse(strRet.toStdString());
  329. int retCode = json2["code"].get<int>();
  330. if(retCode != 0)
  331. {
  332. LH_WRITE_ERROR("获取tExecPlan表格数据失败");
  333. return false;
  334. }
  335. nJson result = json2["result"];
  336. for(auto& it : result)
  337. {
  338. OnePlanItemInfo info;
  339. info.ChannelID = chnID;
  340. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  341. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  342. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  343. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  344. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  345. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  346. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  347. list.append(info);
  348. }
  349. } catch (const nJson::parse_error& e) {
  350. LH_WRITE_ERROR(QString("解析 tExecPlan 表格数据失败:%1").arg(e.what()));
  351. return false;
  352. }
  353. catch (const nJson::exception& e)
  354. {
  355. LH_WRITE_ERROR(QString("解析 tExecPlan 表格数据失败:%1").arg(e.what()));
  356. return false;
  357. }
  358. catch(...)
  359. {
  360. LH_WRITE_ERROR("解析 tExecPlan 表格数据失败");
  361. return false;
  362. }
  363. // LH_WRITE_LOG_DEBUG(QString("从 EQM.tExecPlan 表格获取数据成功,计划数目:%1").arg(list.size()));
  364. return true;
  365. }
  366. bool FromWebAPI::getExecPlanData(QMap<int, QList<OnePlanItemInfo>>& mapPlan)
  367. {
  368. if(m_httpApi == nullptr)
  369. {
  370. LH_WRITE_ERROR("WebAPI is nullptr");
  371. return false;
  372. }
  373. nJson json0;
  374. json0["opName"] = "ESM8C_GetExecPlan";
  375. nJson json1;
  376. json0["paramList"] = json1;
  377. QString strCmd = QString::fromStdString(json0.dump());
  378. QString strRet;
  379. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  380. if(ret != 0)
  381. {
  382. LH_WRITE_ERROR(QString("从EQM获取tExecPlan表格数据失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  383. return false;
  384. }
  385. /* 解析获取到的JSON数据 */
  386. // SPDLOG_LOGGER_DEBUG(m_logger,"获取执行计划:\n{}",strRet.toStdString());
  387. try
  388. {
  389. nJson json2 = nJson::parse(strRet.toStdString());
  390. int retCode = json2["code"].get<int>();
  391. if(retCode != 0)
  392. {
  393. LH_WRITE_ERROR("获取tExecPlan表格数据失败");
  394. return false;
  395. }
  396. nJson result = json2["result"];
  397. for(auto& it : result)
  398. {
  399. OnePlanItemInfo info;
  400. info.ChannelID = it["channelID"].is_null() ? -1 : it["channelID"].get<int>();
  401. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  402. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  403. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  404. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  405. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  406. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  407. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  408. /* 查找对应的设备列表 */
  409. auto list = mapPlan.find(info.ChannelID);
  410. if(list == mapPlan.end())
  411. {
  412. /* 创建一个新的列表 */
  413. QList<OnePlanItemInfo> listPlan;
  414. listPlan.append(info);
  415. mapPlan.insert(info.ChannelID, listPlan);
  416. }else {
  417. /* 找到对应的列表 */
  418. list->append(info);
  419. }
  420. }
  421. } catch (const nJson::parse_error& e) {
  422. LH_WRITE_ERROR(QString("解析 tExecPlan 表格数据失败:%1").arg(e.what()));
  423. return false;
  424. }
  425. catch (const nJson::exception& e)
  426. {
  427. LH_WRITE_ERROR(QString("解析 tExecPlan 表格数据失败:%1").arg(e.what()));
  428. return false;
  429. }
  430. catch(...)
  431. {
  432. LH_WRITE_ERROR("解析 tExecPlan 表格数据失败");
  433. return false;
  434. }
  435. return true;
  436. }
  437. /* 删除所有行 */
  438. bool FromWebAPI::deleteAllRow()
  439. {
  440. if(m_httpApi == nullptr)
  441. {
  442. LH_WRITE_ERROR("WebAPI is nullptr");
  443. return false;
  444. }
  445. nJson json0;
  446. json0["opName"] = "ESM8C_DeleteAllRow";
  447. QString strCmd = QString::fromStdString(json0.dump());
  448. QString strRet;
  449. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Delete, strCmd, strRet, true);
  450. if(ret != 0)
  451. {
  452. LH_WRITE_ERROR(QString("删除所有行失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  453. return false;
  454. }
  455. return true;
  456. }
  457. /* 删除一个发射机计划 */
  458. bool FromWebAPI::deleteOneChnPlan(int chnID)
  459. {
  460. if(m_httpApi == nullptr)
  461. {
  462. LH_WRITE_ERROR("WebAPI is nullptr");
  463. return false;
  464. }
  465. /* 查找出有多少发射机类型 */
  466. QList<int> listPttypeCodeID;
  467. for(auto& it : DevTypeContainer.getMapDevType())
  468. {
  469. listPttypeCodeID.append(it.PTTypeCode);
  470. }
  471. nJson json0;
  472. json0["opName"] = "ESM8C_DeleteOneChnPlan";
  473. json0["paramList"].clear();
  474. nJson json1;
  475. json1["channelID"] = chnID;
  476. json0["paramList"].push_back(json1);
  477. QString strCmd = QString::fromStdString(json0.dump());
  478. QString strRet;
  479. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Delete, strCmd, strRet, true);
  480. if(ret != 0)
  481. {
  482. LH_WRITE_ERROR(QString("删除频率: %3 计划失败: %1, 错误信息: %2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)).arg(chnID));
  483. }else {
  484. // LH_WRITE_LOG(QString("删除频率: %1 计划成功!").arg(chnID));
  485. }
  486. return true;
  487. }
  488. /**
  489. * @brief 将页面的配置写入数据库,主要是默认计划和执行模式
  490. *
  491. * @param mapConfig
  492. * @return true
  493. * @return false
  494. */
  495. bool FromWebAPI::insertConfigData(QMap<int, ConfigData>& list)
  496. {
  497. if(m_httpApi == nullptr)
  498. {
  499. LH_WRITE_ERROR("WebAPI is nullptr");
  500. return false;
  501. }
  502. deleteConfigData(list);
  503. nJson json0 = nJson::array();
  504. try{
  505. for(auto begin = list.begin(), end = list.end(); begin != end; begin++)
  506. {
  507. nJson json1;
  508. json1["opName"] = "ESM8C_InsertExecPlanConfig";
  509. json1["Key"] = QUuid::createUuid().toString().toStdString();
  510. nJson json2;
  511. json2["keyWord"] = begin->key;
  512. json2["value1"] = begin->value;
  513. json2["updateTime"] = begin->updateTime.toString("yyyy-MM-dd hh:mm:ss").toStdString();
  514. json2["notes"] = begin->notes.toStdString();
  515. json1["paramList"] = json2;
  516. json0.push_back(json1);
  517. }
  518. }catch (const nJson::parse_error& e) {
  519. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  520. return false;
  521. }
  522. catch (const nJson::exception& e)
  523. {
  524. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  525. return false;
  526. }
  527. catch (...)
  528. {
  529. SPDLOG_ERROR("生成json数据失败");
  530. return false;
  531. }
  532. /* 写入EQM数据库 */
  533. QString strCmd = QString::fromStdString(json0.dump());
  534. QString strRet;
  535. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  536. if(ret != 0)
  537. {
  538. LH_WRITE_ERROR(QString("写入tExecPlanConfig失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  539. return false;
  540. }
  541. LH_WRITE_LOG_DEBUG(QString("页面配置写入tExecPlanConfig成功, 数目:%1").arg(QString::number(list.size())));
  542. return true;
  543. }
  544. /* 删除配置数据 */
  545. bool FromWebAPI::deleteConfigData(QMap<int, ConfigData>& list)
  546. {
  547. if(m_httpApi == nullptr)
  548. {
  549. LH_WRITE_ERROR("WebAPI is nullptr");
  550. return false;
  551. }
  552. nJson json0 = nJson::array();
  553. try{
  554. for(auto begin = list.begin(), end = list.end(); begin != end; begin++)
  555. {
  556. nJson json1;
  557. json1["opName"] = "ESM8C_DeleteExecPlanConfig";
  558. json1["Key"] = QUuid::createUuid().toString().toStdString();
  559. nJson json2;
  560. json2["keyWord"] = begin->key;
  561. json1["paramList"] = json2;
  562. json0.push_back(json1);
  563. }
  564. }catch (const nJson::parse_error& e) {
  565. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  566. return false;
  567. }
  568. catch (const nJson::exception& e)
  569. {
  570. SPDLOG_ERROR("生成json数据失败:{}", e.what());
  571. return false;
  572. }
  573. catch (...)
  574. {
  575. SPDLOG_ERROR("生成json数据失败");
  576. return false;
  577. }
  578. /* 写入EQM数据库 */
  579. QString strCmd = QString::fromStdString(json0.dump());
  580. QString strRet;
  581. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  582. if(ret != 0)
  583. {
  584. LH_WRITE_ERROR(QString("删除tExecPlanConfig表格数据失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  585. return false;
  586. }
  587. LH_WRITE_LOG_DEBUG(QString("删除tExecPlanConfig表格数据成功, 计划数目:%1").arg(QString::number(list.size())));
  588. return true;
  589. }
  590. /* 获取配置数据 */
  591. bool FromWebAPI::getConfigData(QMap<int, ConfigData>& list)
  592. {
  593. if(m_httpApi == nullptr)
  594. {
  595. LH_WRITE_ERROR("WebAPI is nullptr");
  596. return false;
  597. }
  598. nJson json0;
  599. json0["opName"] = "ESM8C_GetExecPlanConfig";
  600. QString strCmd = QString::fromStdString(json0.dump());
  601. QString strRet;
  602. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  603. if(ret != 0)
  604. {
  605. LH_WRITE_ERROR(QString("获取tExecPlanConfig表格数据失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  606. return false;
  607. }
  608. /* 解析获取到的JSON数据 */
  609. LH_WRITE_LOG_DEBUG(QString("Ret:%1").arg(ret));
  610. LH_WRITE_LOG_DEBUG(strRet);
  611. try{
  612. nJson json1 = nJson::parse(strRet.toStdString());
  613. int retCode = json1["code"].get<int>();
  614. if(retCode != 0)
  615. {
  616. LH_WRITE_ERROR("获取tExecPlanConfig失败");
  617. return false;
  618. }
  619. nJson result = json1["result"];
  620. for(auto& it : result)
  621. {
  622. ConfigData data;
  623. data.key = it["keyWord"].get<int>();
  624. data.value = it["value1"].get<int>();
  625. data.updateTime = QDateTime::fromString(QString::fromStdString(it["updateTime"].get<std::string>()),"yyyy-MM-dd hh:mm:ss");
  626. data.notes = QString::fromStdString(it["notes"].get<std::string>());
  627. list.insert(data.key, data);
  628. }
  629. } catch (const nJson::parse_error& e) {
  630. LH_WRITE_ERROR(QString("解析tExecPlanConfig数据失败:%1").arg(e.what()));
  631. return false;
  632. }
  633. catch (const nJson::exception& e)
  634. {
  635. LH_WRITE_ERROR(QString("解析tExecPlanConfig数据失败:%1").arg(e.what()));
  636. return false;
  637. }
  638. catch(...)
  639. {
  640. LH_WRITE_ERROR("解析tExecPlanConfig数据失败");
  641. return false;
  642. }
  643. LH_WRITE_LOG_DEBUG(QString("获取tExecPlanConfig表格数据成功,数据数目:%1").arg(list.size()));
  644. return true;
  645. }
  646. /* 单独获取某个关键字的数据 */
  647. bool FromWebAPI::getConfigData(int key, ConfigData& data)
  648. {
  649. if(m_httpApi == nullptr)
  650. {
  651. LH_WRITE_ERROR("WebAPI is nullptr");
  652. return false;
  653. }
  654. nJson json0;
  655. json0["opName"] = "ESM8C_GetExecPlanConfigOfKeyWord";
  656. nJson json1;
  657. json1["keyWord"] = key;
  658. json0["paramList"] = json1;
  659. QString strCmd = QString::fromStdString(json0.dump());
  660. QString strRet;
  661. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  662. if(ret != 0)
  663. {
  664. LH_WRITE_ERROR(QString("获取tExecPlanConfig表格数据失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  665. return false;
  666. }
  667. /* 解析获取到的JSON数据 */
  668. LH_WRITE_LOG_DEBUG(strRet);
  669. try{
  670. nJson json1 = nJson::parse(strRet.toStdString());
  671. int retCode = json1["code"].get<int>();
  672. if(retCode != 0)
  673. {
  674. LH_WRITE_ERROR("获取tExecPlanConfig失败");
  675. return false;
  676. }
  677. nJson result = json1["result"];
  678. for(auto& it : result)
  679. {
  680. data.key = it["keyWord"].get<int>();
  681. if(data.key != key)
  682. {
  683. LH_WRITE_ERROR("获取到的数据和传入的关键字不匹配");
  684. continue;
  685. }
  686. data.value = it["value1"].get<int>();
  687. data.updateTime = QDateTime::fromString(QString::fromStdString(it["updateTime"].get<std::string>()),"yyyy-MM-dd hh:mm:ss");
  688. data.notes = QString::fromStdString(it["notes"].get<std::string>());
  689. break;
  690. }
  691. } catch (const nJson::parse_error& e) {
  692. LH_WRITE_ERROR(QString("解析tExecPlanConfig数据失败:%1").arg(e.what()));
  693. return false;
  694. }
  695. catch (const nJson::exception& e)
  696. {
  697. LH_WRITE_ERROR(QString("解析tExecPlanConfig数据失败:%1").arg(e.what()));
  698. return false;
  699. }
  700. catch(...)
  701. {
  702. LH_WRITE_ERROR("解析tExecPlanConfig数据失败");
  703. return false;
  704. }
  705. if(data.key != key)
  706. {
  707. LH_WRITE_ERROR("获取到的数据和传入的关键字不匹配");
  708. return false;
  709. }
  710. return true;
  711. }
  712. /* 获取EQM数据库中的模版编号 */
  713. bool FromWebAPI::getEQMTemplateID(QList<int>& listId)
  714. {
  715. if(m_httpApi == nullptr)
  716. {
  717. LH_WRITE_ERROR("WebAPI is nullptr");
  718. return false;
  719. }
  720. nJson json0;
  721. json0["opName"] = "ESMC_GetTemplateNumFromExecPlan";
  722. QString strCmd = QString::fromStdString(json0.dump());
  723. QString strRet;
  724. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  725. if(ret != 0)
  726. {
  727. LH_WRITE_ERROR(QString("从EQM获取模版编号失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  728. return false;
  729. }
  730. /* 解析获取到的JSON数据 */
  731. LH_WRITE_LOG_DEBUG(strRet);
  732. try
  733. {
  734. nJson json1 = nJson::parse(strRet.toStdString());
  735. int retCode = json1["code"].get<int>();
  736. if(retCode != 0)
  737. {
  738. LH_WRITE_ERROR("获取模版编号失败");
  739. return false;
  740. }
  741. nJson result = json1["result"];
  742. for(auto& it : result)
  743. {
  744. if(it["templateNum"].is_null())
  745. {
  746. LH_WRITE_ERROR("模版编号为空");
  747. continue;
  748. }
  749. auto id = it["templateNum"].get<int>();
  750. if(listId.contains(id))
  751. {
  752. continue;
  753. }
  754. listId.append(id);
  755. }
  756. } catch (const nJson::parse_error& e) {
  757. LH_WRITE_ERROR(QString("解析模版编号失败:%1").arg(e.what()));
  758. return false;
  759. }
  760. catch (const nJson::exception& e)
  761. {
  762. LH_WRITE_ERROR(QString("解析模版编号失败:%1").arg(e.what()));
  763. return false;
  764. }
  765. catch(...)
  766. {
  767. LH_WRITE_ERROR("解析模版编号失败");
  768. return false;
  769. }
  770. return true;
  771. }
  772. /* 保存到模板 */
  773. bool FromWebAPI::saveTemplate(const QString& templateName, const int type, QList<OnePlanItemInfo>& list)
  774. {
  775. if(m_httpApi == nullptr)
  776. {
  777. LH_WRITE_ERROR("WebAPI is nullptr");
  778. return false;
  779. }
  780. nJson json0 = nJson::array();
  781. for(const auto& it : list)
  782. {
  783. nJson json1;
  784. json1["opName"] = "TMS_ExecPlanSaveToTemplate";
  785. json1["Key"] = QUuid::createUuid().toString().toStdString();
  786. nJson json2;
  787. // json2["templateName"] = templateName.toStdString();
  788. // json2["templateType"] = type;
  789. // json2["execDate"] = it.dateTime.date().toString("yyyy-MM-dd").toStdString();
  790. // json2["execTime"] = it.dateTime.time().toString("hh:mm:ss").toStdString();
  791. // json2["deviceName"] = it.devName.toStdString();
  792. // json2["actionName"] = it.actionName.toStdString();
  793. // json2["actionID"] = static_cast<int>(it.actionID);
  794. json1["paramList"] = json2;
  795. json0.push_back(json1);
  796. }
  797. /* 将json写入本地文件 */
  798. #ifdef C_DEBUG
  799. // QString fileJson(QString::fromStdString(json0.dump(4)));
  800. // LH_WRITE_LOG_DEBUG("\n" + fileJson);
  801. #endif
  802. /* 写入EQM数据库 */
  803. QString strCmd = QString::fromStdString(json0.dump());
  804. QString strRet;
  805. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  806. if(ret != 0)
  807. {
  808. LH_WRITE_ERROR(QString("保存到模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  809. return false;
  810. }
  811. LH_WRITE_LOG("保存到模板成功,模板名称:" + templateName + ", 类型:" + QString::number(type) + ", 计划数目:" + QString::number(list.size()));
  812. return true;
  813. }
  814. /* 获取模板内容 */
  815. bool FromWebAPI::getTemplate(QString templateName, QList<OnePlanItemInfo>& list)
  816. {
  817. if(m_httpApi == nullptr)
  818. {
  819. LH_WRITE_ERROR("WebAPI is nullptr");
  820. return false;
  821. }
  822. nJson json0;
  823. json0["opName"] = "TMS_GetExecPlanTemplateData";
  824. nJson json1;
  825. json1["templateName"] = templateName.toStdString();
  826. json0["paramList"] = json1;
  827. QString strCmd = QString::fromStdString(json0.dump());
  828. QString strRet;
  829. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  830. if(ret != 0)
  831. {
  832. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  833. return false;
  834. }
  835. /* 解析获取到的JSON数据 */
  836. try
  837. {
  838. nJson json2 = nJson::parse(strRet.toStdString());
  839. int retCode = json2["code"].get<int>();
  840. if(retCode != 0)
  841. {
  842. LH_WRITE_ERROR("获取模板失败");
  843. return false;
  844. }
  845. nJson result = json2["result"];
  846. for(auto& it : result)
  847. {
  848. OnePlanItemInfo info;
  849. // info.devName = QString::fromStdString(it["deviceName"].get<std::string>());
  850. // if(!DeviceContainer.findDevice(info.devName))
  851. // {
  852. // LH_WRITE_LOG(QString("未找到设备:%1").arg(info.devName));
  853. // continue;
  854. // }
  855. // auto tmpDate = it["execDate"].is_null() ? "" : it["execDate"].get<std::string>();
  856. // if(!tmpDate.empty())
  857. // {
  858. // info.dateTime.setDate(QDate::fromString(QString::fromStdString(tmpDate),"yyyy-MM-dd"));
  859. // }
  860. // info.dateTime.setTime(QTime::fromString(QString::fromStdString(it["execTime"].get<std::string>()),"hh:mm:ss"));
  861. // info.actionName = QString::fromStdString(it["actionName"].get<std::string>());
  862. // info.actionID = it["actionID"].get<int>();
  863. list.append(info);
  864. }
  865. LH_WRITE_LOG(QString("获取模板成功,数据数目:%1").arg(list.size()));
  866. }
  867. catch (const nJson::parse_error& e)
  868. {
  869. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  870. return false;
  871. }
  872. catch (const nJson::exception& e)
  873. {
  874. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  875. return false;
  876. }
  877. catch(...)
  878. {
  879. LH_WRITE_ERROR("解析模板失败");
  880. return false;
  881. }
  882. return true;
  883. }
  884. /* 获取模板列表 */
  885. bool FromWebAPI::getTemplateList(QMultiMap<int, TemplateInfo>& mapTemplate)
  886. {
  887. if(m_httpApi == nullptr)
  888. {
  889. LH_WRITE_ERROR("WebAPI is nullptr");
  890. return false;
  891. }
  892. nJson json0;
  893. json0["opName"] = "TMS_GetExecPlanTemplateList";
  894. QString strCmd = QString::fromStdString(json0.dump());
  895. QString strRet;
  896. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  897. if(ret != 0)
  898. {
  899. LH_WRITE_ERROR(QString("获取模板列表失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  900. return false;
  901. }
  902. /* 解析获取到的JSON数据 */
  903. LH_WRITE_LOG_DEBUG(strRet);
  904. try
  905. {
  906. nJson json1 = nJson::parse(strRet.toStdString());
  907. int retCode = json1["code"].get<int>();
  908. if(retCode != 0)
  909. {
  910. LH_WRITE_ERROR("获取模板列表失败");
  911. return false;
  912. }
  913. nJson result = json1["result"];
  914. for(auto& it : result)
  915. {
  916. TemplateInfo info;
  917. info.channelInfo.ChannelID = it["channelID"].get<int>();
  918. info.templateName = QString::fromStdString(it["templateName"].get<std::string>());
  919. mapTemplate.insert(info.channelInfo.ChannelID, info);
  920. }
  921. } catch (const nJson::parse_error& e) {
  922. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  923. return false;
  924. }
  925. catch (const nJson::exception& e)
  926. {
  927. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  928. return false;
  929. }
  930. catch(...)
  931. {
  932. LH_WRITE_ERROR("解析模板列表失败");
  933. return false;
  934. }
  935. // for(auto it = list.begin(); it != list.end(); it++)
  936. // {
  937. // LH_WRITE_LOG_DEBUG(QString("模板名称:%1, 类型:%2").arg(it.key()).arg(it.value()));
  938. // }
  939. return true;
  940. }
  941. /* 删除一个模板 */
  942. bool FromWebAPI::deleteTemplate(const QString& name)
  943. {
  944. if(m_httpApi == nullptr)
  945. {
  946. LH_WRITE_ERROR("WebAPI is nullptr");
  947. return false;
  948. }
  949. nJson json0;
  950. json0["opName"] = "TMS_DeleteExecPlanTemplate";
  951. nJson json1;
  952. json1["templateName"] = name.toStdString();
  953. json0["paramList"] = json1;
  954. QString strCmd = QString::fromStdString(json0.dump());
  955. QString strRet;
  956. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Delete, strCmd, strRet, true);
  957. if(ret != 0)
  958. {
  959. LH_WRITE_ERROR(QString("删除模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  960. return false;
  961. }
  962. return true;
  963. }