FromWebAPI.cpp 41 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301
  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/LHSqlWebInterfaced.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, 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_InsertToExecPlanTemplate";
  785. json1["Key"] = QUuid::createUuid().toString().toStdString();
  786. nJson json2;
  787. json2["templateName"] = templateName.toStdString();
  788. json2["channelID"] = it.ChannelID;
  789. json2["channelName"] = it.ChannelName.toStdString();
  790. json2["onWeekDay"] = it.onWeekDay;
  791. json2["onDate"] = it.onDateTime.date().toString("yyyy-MM-dd").toStdString();
  792. json2["onTime"] = it.onDateTime.time().toString("hh:mm:ss").toStdString();
  793. json2["offWeekDay"] = it.offWeekDay;
  794. json2["offDate"] = it.offDateTime.date().toString("yyyy-MM-dd").toStdString();
  795. json2["offTime"] = it.offDateTime.time().toString("hh:mm:ss").toStdString();
  796. json1["paramList"] = json2;
  797. json0.push_back(json1);
  798. }
  799. /* 将json写入本地文件 */
  800. #ifdef C_DEBUG
  801. // QString fileJson(QString::fromStdString(json0.dump(4)));
  802. // LH_WRITE_LOG_DEBUG("\n" + fileJson);
  803. #endif
  804. /* 写入EQM数据库 */
  805. QString strCmd = QString::fromStdString(json0.dump());
  806. QString strRet;
  807. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  808. if(ret != 0)
  809. {
  810. LH_WRITE_ERROR(QString("保存到模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  811. return false;
  812. }
  813. // LH_WRITE_LOG("保存到模板成功,模板名称:" + templateName + ", 计划数目:" + QString::number(list.size()));
  814. return true;
  815. }
  816. /* 批量写入模版数据 */
  817. bool FromWebAPI::saveTemplateList(const QMap<OneTemplateInfo, QList<OnePlanItemInfo>>& mapTemplate)
  818. {
  819. if(m_httpApi == nullptr)
  820. {
  821. LH_WRITE_ERROR("WebAPI is nullptr");
  822. return false;
  823. }
  824. }
  825. /* 获取模板内容 */
  826. bool FromWebAPI::getOneTemplateData(QString templateName, QList<OnePlanItemInfo>& list)
  827. {
  828. if(m_httpApi == nullptr)
  829. {
  830. LH_WRITE_ERROR("WebAPI is nullptr");
  831. return false;
  832. }
  833. nJson json0;
  834. json0["opName"] = "TMS_GetExecPlanTemplateData";
  835. nJson json1;
  836. json1["templateName"] = templateName.toStdString();
  837. json0["paramList"] = json1;
  838. QString strCmd = QString::fromStdString(json0.dump());
  839. QString strRet;
  840. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  841. if(ret != 0)
  842. {
  843. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  844. return false;
  845. }
  846. /* 解析获取到的JSON数据 */
  847. try
  848. {
  849. nJson json2 = nJson::parse(strRet.toStdString());
  850. int retCode = json2["code"].get<int>();
  851. if(retCode != 0)
  852. {
  853. LH_WRITE_ERROR("获取模板失败");
  854. return false;
  855. }
  856. nJson result = json2["result"];
  857. for(auto& it : result)
  858. {
  859. OnePlanItemInfo info;
  860. info.ChannelID = it["channelID"].is_null() ? -1 : it["channelID"].get<int>();
  861. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  862. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  863. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  864. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  865. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  866. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  867. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  868. list.append(info);
  869. }
  870. LH_WRITE_LOG(QString("获取模板成功,数据数目:%1").arg(list.size()));
  871. }
  872. catch (const nJson::parse_error& e)
  873. {
  874. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  875. return false;
  876. }
  877. catch (const nJson::exception& e)
  878. {
  879. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  880. return false;
  881. }
  882. catch(...)
  883. {
  884. LH_WRITE_ERROR("解析模板失败");
  885. return false;
  886. }
  887. return true;
  888. }
  889. /* 获取多个模板的内容 */
  890. bool FromWebAPI::getTemplateData(QList<OneTemplateInfo>& listTemplate, QMap<int, QList<OnePlanItemInfo>>& mapPlan)
  891. {
  892. if(m_httpApi == nullptr)
  893. {
  894. LH_WRITE_ERROR("WebAPI is nullptr");
  895. return false;
  896. }
  897. nJson jsonArry = nJson::array();
  898. for(auto& it : listTemplate)
  899. {
  900. jsonArry.push_back(it.templateName.toStdString());
  901. }
  902. nJson json0;
  903. json0["opName"] = "TMS_GetExecPlanTemplateData";
  904. nJson json1;
  905. json1["templateName"] = jsonArry;
  906. json0["paramList"] = json1;
  907. /* 打印生成的JSON */
  908. // LH_WRITE_LOG_DEBUG(QString::fromStdString(json0.dump(4)));
  909. QString strCmd = QString::fromStdString(json0.dump());
  910. QString strRet;
  911. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  912. if(ret != 0)
  913. {
  914. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  915. return false;
  916. }
  917. // LH_WRITE_LOG_DEBUG(strRet);
  918. /* 解析获取到的JSON数据 */
  919. try
  920. {
  921. nJson jsonRet = nJson::parse(strRet.toStdString());
  922. int retCode = jsonRet["code"].get<int>();
  923. if(retCode != 0)
  924. {
  925. LH_WRITE_ERROR("获取模板失败");
  926. return false;
  927. }
  928. nJson result = jsonRet["result"];
  929. for(auto& it : result)
  930. {
  931. OnePlanItemInfo info;
  932. info.ChannelID = it["channelID"].is_null() ? -1 : it["channelID"].get<int>();
  933. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  934. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  935. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  936. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  937. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  938. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  939. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  940. /* 查找该频率所属的列表 */
  941. auto list = mapPlan.find(info.ChannelID);
  942. if(list == mapPlan.end())
  943. {
  944. /* 创建一个新的列表 */
  945. QList<OnePlanItemInfo> listPlan;
  946. listPlan.append(info);
  947. mapPlan.insert(info.ChannelID, listPlan);
  948. }else {
  949. /* 找到对应的列表 */
  950. list->append(info);
  951. }
  952. }
  953. }
  954. catch (const nJson::parse_error& e)
  955. {
  956. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  957. return false;
  958. }
  959. catch (const nJson::exception& e)
  960. {
  961. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  962. return false;
  963. }
  964. catch(...)
  965. {
  966. LH_WRITE_ERROR("解析模板失败");
  967. return false;
  968. }
  969. LH_WRITE_LOG_DEBUG(QString("获取多个频率模板成功,频率数目:%1").arg(mapPlan.size()));
  970. return true;
  971. }
  972. /* 获取模板列表 */
  973. bool FromWebAPI::getTemplateList(QMultiMap<int, OneTemplateInfo>& mapTemplate)
  974. {
  975. if(m_httpApi == nullptr)
  976. {
  977. LH_WRITE_ERROR("WebAPI is nullptr");
  978. return false;
  979. }
  980. nJson json0;
  981. json0["opName"] = "TMS_GetExecPlanTemplateList";
  982. QString strCmd = QString::fromStdString(json0.dump());
  983. QString strRet;
  984. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  985. if(ret != 0)
  986. {
  987. LH_WRITE_ERROR(QString("获取模板列表失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  988. return false;
  989. }
  990. /* 解析获取到的JSON数据 */
  991. // LH_WRITE_LOG_DEBUG(strRet);
  992. try
  993. {
  994. nJson json1 = nJson::parse(strRet.toStdString());
  995. int retCode = json1["code"].get<int>();
  996. if(retCode != 0)
  997. {
  998. LH_WRITE_ERROR("获取模板列表失败");
  999. return false;
  1000. }
  1001. nJson result = json1["result"];
  1002. for(auto& it : result)
  1003. {
  1004. OneTemplateInfo info;
  1005. info.channelInfo.ChannelID = it["channelID"].get<int>();
  1006. info.templateName = QString::fromStdString(it["templateName"].get<std::string>());
  1007. mapTemplate.insert(info.channelInfo.ChannelID, info);
  1008. }
  1009. } catch (const nJson::parse_error& e) {
  1010. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1011. return false;
  1012. }
  1013. catch (const nJson::exception& e)
  1014. {
  1015. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1016. return false;
  1017. }
  1018. catch(...)
  1019. {
  1020. LH_WRITE_ERROR("解析模板列表失败");
  1021. return false;
  1022. }
  1023. // for(auto it = list.begin(); it != list.end(); it++)
  1024. // {
  1025. // LH_WRITE_LOG_DEBUG(QString("模板名称:%1, 类型:%2").arg(it.key()).arg(it.value()));
  1026. // }
  1027. return true;
  1028. }
  1029. /* 获取某个频率的模版列表 */
  1030. bool FromWebAPI::getTemplateList(int chnID, QList<OneTemplateInfo>& listTemplate)
  1031. {
  1032. if(m_httpApi == nullptr)
  1033. {
  1034. LH_WRITE_ERROR("WebAPI is nullptr");
  1035. return false;
  1036. }
  1037. nJson json0;
  1038. json0["opName"] = "TMS_GetExecPlanOneTemplateList";
  1039. nJson jsonParam;
  1040. jsonParam["channelID"] = chnID;
  1041. json0["paramList"] = jsonParam;
  1042. /* 发送请求 */
  1043. QString strCmd = QString::fromStdString(json0.dump());
  1044. QString strRet;
  1045. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  1046. if(ret != 0)
  1047. {
  1048. LH_WRITE_ERROR(QString("获取模板列表失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  1049. return false;
  1050. }
  1051. /* 解析获取到的JSON数据 */
  1052. // LH_WRITE_LOG_DEBUG(strRet);
  1053. try
  1054. {
  1055. nJson json1 = nJson::parse(strRet.toStdString());
  1056. int retCode = json1["code"].get<int>();
  1057. if(retCode != 0)
  1058. {
  1059. LH_WRITE_ERROR("获取模板列表失败");
  1060. return false;
  1061. }
  1062. nJson result = json1["result"];
  1063. for(auto& it : result)
  1064. {
  1065. OneTemplateInfo info;
  1066. info.channelInfo.ChannelID = it["channelID"].get<int>();
  1067. info.templateName = QString::fromStdString(it["templateName"].get<std::string>());
  1068. listTemplate.append(info);
  1069. }
  1070. } catch (const nJson::parse_error& e) {
  1071. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1072. return false;
  1073. }
  1074. catch (const nJson::exception& e)
  1075. {
  1076. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1077. return false;
  1078. }
  1079. catch(...)
  1080. {
  1081. LH_WRITE_ERROR("解析模板列表失败");
  1082. return false;
  1083. }
  1084. return true;
  1085. }
  1086. /* 删除一个模板 */
  1087. bool FromWebAPI::deleteTemplate(const OneTemplateInfo& info)
  1088. {
  1089. if(m_httpApi == nullptr)
  1090. {
  1091. LH_WRITE_ERROR("WebAPI is nullptr");
  1092. return false;
  1093. }
  1094. nJson json0;
  1095. json0["opName"] = "TMS_DeleteExecPlanTemplate";
  1096. nJson json1;
  1097. json1["channelID"] = info.channelInfo.ChannelID;
  1098. json1["templateName"] = info.templateName.toStdString();
  1099. json0["paramList"] = json1;
  1100. QString strCmd = QString::fromStdString(json0.dump());
  1101. QString strRet;
  1102. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Delete, strCmd, strRet, true);
  1103. if(ret != 0)
  1104. {
  1105. LH_WRITE_ERROR(QString("删除模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  1106. return false;
  1107. }
  1108. return true;
  1109. }
  1110. /* 一次删除多个模版 */
  1111. bool FromWebAPI::deleteTemplateList(const QList<OneTemplateInfo>& listTemplate)
  1112. {
  1113. if(m_httpApi == nullptr)
  1114. {
  1115. LH_WRITE_ERROR("WebAPI is nullptr");
  1116. return false;
  1117. }
  1118. nJson json0 = nJson::array();
  1119. for(auto& it : listTemplate)
  1120. {
  1121. nJson json1;
  1122. json1["opName"] = "TMS_DeleteExecPlanTemplate";
  1123. json1["Key"] = QUuid::createUuid().toString().toStdString();
  1124. nJson json2;
  1125. json2["channelID"] = it.channelInfo.ChannelID;
  1126. json2["templateName"] = it.templateName.toStdString();
  1127. json1["paramList"] = json2;
  1128. json0.push_back(json1);
  1129. }
  1130. /* 打印生成的JSON */
  1131. LH_WRITE_LOG_DEBUG(QString::fromStdString(json0.dump(4)));
  1132. QString strCmd = QString::fromStdString(json0.dump());
  1133. QString strRet;
  1134. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  1135. if(ret != 0)
  1136. {
  1137. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  1138. return false;
  1139. }
  1140. // LH_WRITE_LOG_DEBUG(strRet);
  1141. return true;
  1142. }
  1143. /**
  1144. * @brief 修改模版,先删除该频率相同名称的模版,再插入新的模版
  1145. *
  1146. * @param info
  1147. * @param list 新的模版计划
  1148. * @return true
  1149. * @return false
  1150. */
  1151. bool FromWebAPI::modifyTemplate(const OneTemplateInfo& info, QList<OnePlanItemInfo>& list)
  1152. {
  1153. if(deleteTemplate(info) == false)
  1154. {
  1155. LH_WRITE_ERROR("删除模版失败");
  1156. return false;
  1157. }
  1158. if(saveTemplate(info.templateName, list) == false)
  1159. {
  1160. LH_WRITE_ERROR("保存模版失败");
  1161. return false;
  1162. }
  1163. return true;
  1164. }
  1165. /* 批量修改模版 */
  1166. bool FromWebAPI::modifyTemplateList(const QMap<OneTemplateInfo, QList<OnePlanItemInfo>>& mapTemplate)
  1167. {
  1168. /* 先批量删除模版 */
  1169. if(deleteTemplateList(mapTemplate.keys()) == false)
  1170. {
  1171. LH_WRITE_ERROR("批量删除模版失败");
  1172. return false;
  1173. }
  1174. /* 再批量插入模版 */
  1175. }