FromWebAPI.cpp 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207
  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, 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::getOneTemplateData(QString templateName, QList<OnePlanItemInfo>& list)
  818. {
  819. if(m_httpApi == nullptr)
  820. {
  821. LH_WRITE_ERROR("WebAPI is nullptr");
  822. return false;
  823. }
  824. nJson json0;
  825. json0["opName"] = "TMS_GetExecPlanTemplateData";
  826. nJson json1;
  827. json1["templateName"] = templateName.toStdString();
  828. json0["paramList"] = json1;
  829. QString strCmd = QString::fromStdString(json0.dump());
  830. QString strRet;
  831. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  832. if(ret != 0)
  833. {
  834. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  835. return false;
  836. }
  837. /* 解析获取到的JSON数据 */
  838. try
  839. {
  840. nJson json2 = nJson::parse(strRet.toStdString());
  841. int retCode = json2["code"].get<int>();
  842. if(retCode != 0)
  843. {
  844. LH_WRITE_ERROR("获取模板失败");
  845. return false;
  846. }
  847. nJson result = json2["result"];
  848. for(auto& it : result)
  849. {
  850. OnePlanItemInfo info;
  851. info.ChannelID = it["channelID"].is_null() ? -1 : it["channelID"].get<int>();
  852. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  853. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  854. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  855. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  856. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  857. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  858. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  859. list.append(info);
  860. }
  861. LH_WRITE_LOG(QString("获取模板成功,数据数目:%1").arg(list.size()));
  862. }
  863. catch (const nJson::parse_error& e)
  864. {
  865. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  866. return false;
  867. }
  868. catch (const nJson::exception& e)
  869. {
  870. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  871. return false;
  872. }
  873. catch(...)
  874. {
  875. LH_WRITE_ERROR("解析模板失败");
  876. return false;
  877. }
  878. return true;
  879. }
  880. /* 获取多个模板的内容 */
  881. bool FromWebAPI::getTemplateData(QList<OneTemplateInfo>& listTemplate, QMap<int, QList<OnePlanItemInfo>>& mapPlan)
  882. {
  883. if(m_httpApi == nullptr)
  884. {
  885. LH_WRITE_ERROR("WebAPI is nullptr");
  886. return false;
  887. }
  888. nJson json0 = nJson::array();
  889. for(auto& it : listTemplate)
  890. {
  891. nJson json1;
  892. json1["opName"] = "TMS_GetExecPlanTemplateData";
  893. json1["Key"] = QUuid::createUuid().toString().toStdString();
  894. json1["templateName"] = it.templateName.toStdString();
  895. json0.push_back(json1);
  896. }
  897. QString strCmd = QString::fromStdString(json0.dump());
  898. QString strRet;
  899. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_BatchTransAction, strCmd, strRet, true);
  900. if(ret != 0)
  901. {
  902. LH_WRITE_ERROR(QString("获取模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  903. return false;
  904. }
  905. /* 解析获取到的JSON数据 */
  906. try
  907. {
  908. nJson jsonRet = nJson::parse(strRet.toStdString());
  909. int retCode = jsonRet["code"].get<int>();
  910. if(retCode != 0)
  911. {
  912. LH_WRITE_ERROR("获取模板失败");
  913. return false;
  914. }
  915. nJson result = jsonRet["result"];
  916. for(auto& it : result)
  917. {
  918. OnePlanItemInfo info;
  919. info.ChannelID = it["channelID"].is_null() ? -1 : it["channelID"].get<int>();
  920. info.ChannelName = QString::fromStdString(it["channelName"].get<std::string>());
  921. info.onWeekDay = static_cast<enum_WeekDay>(it["onWeekDay"].get<int>());
  922. info.onDateTime.setDate(QDate::fromString(QString::fromStdString(it["onDate"].get<std::string>()), "yyyy-MM-dd"));
  923. info.onDateTime.setTime(QTime::fromString(QString::fromStdString(it["onTime"].get<std::string>()), "hh:mm:ss"));
  924. info.offWeekDay = static_cast<enum_WeekDay>(it["offWeekDay"].get<int>());
  925. info.offDateTime.setDate(QDate::fromString(QString::fromStdString(it["offDate"].get<std::string>()), "yyyy-MM-dd"));
  926. info.offDateTime.setTime(QTime::fromString(QString::fromStdString(it["offTime"].get<std::string>()), "hh:mm:ss"));
  927. /* 查找该频率所属的列表 */
  928. auto list = mapPlan.find(info.ChannelID);
  929. if(list == mapPlan.end())
  930. {
  931. /* 创建一个新的列表 */
  932. QList<OnePlanItemInfo> listPlan;
  933. listPlan.append(info);
  934. mapPlan.insert(info.ChannelID, listPlan);
  935. }else {
  936. /* 找到对应的列表 */
  937. list->append(info);
  938. }
  939. }
  940. }
  941. catch (const nJson::parse_error& e)
  942. {
  943. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  944. return false;
  945. }
  946. catch (const nJson::exception& e)
  947. {
  948. LH_WRITE_ERROR(QString("解析模板失败:%1").arg(e.what()));
  949. return false;
  950. }
  951. catch(...)
  952. {
  953. LH_WRITE_ERROR("解析模板失败");
  954. return false;
  955. }
  956. return true;
  957. }
  958. /* 获取模板列表 */
  959. bool FromWebAPI::getTemplateList(QMultiMap<int, OneTemplateInfo>& mapTemplate)
  960. {
  961. if(m_httpApi == nullptr)
  962. {
  963. LH_WRITE_ERROR("WebAPI is nullptr");
  964. return false;
  965. }
  966. nJson json0;
  967. json0["opName"] = "TMS_GetExecPlanTemplateList";
  968. QString strCmd = QString::fromStdString(json0.dump());
  969. QString strRet;
  970. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  971. if(ret != 0)
  972. {
  973. LH_WRITE_ERROR(QString("获取模板列表失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  974. return false;
  975. }
  976. /* 解析获取到的JSON数据 */
  977. // LH_WRITE_LOG_DEBUG(strRet);
  978. try
  979. {
  980. nJson json1 = nJson::parse(strRet.toStdString());
  981. int retCode = json1["code"].get<int>();
  982. if(retCode != 0)
  983. {
  984. LH_WRITE_ERROR("获取模板列表失败");
  985. return false;
  986. }
  987. nJson result = json1["result"];
  988. for(auto& it : result)
  989. {
  990. OneTemplateInfo info;
  991. info.channelInfo.ChannelID = it["channelID"].get<int>();
  992. info.templateName = QString::fromStdString(it["templateName"].get<std::string>());
  993. mapTemplate.insert(info.channelInfo.ChannelID, info);
  994. }
  995. } catch (const nJson::parse_error& e) {
  996. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  997. return false;
  998. }
  999. catch (const nJson::exception& e)
  1000. {
  1001. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1002. return false;
  1003. }
  1004. catch(...)
  1005. {
  1006. LH_WRITE_ERROR("解析模板列表失败");
  1007. return false;
  1008. }
  1009. // for(auto it = list.begin(); it != list.end(); it++)
  1010. // {
  1011. // LH_WRITE_LOG_DEBUG(QString("模板名称:%1, 类型:%2").arg(it.key()).arg(it.value()));
  1012. // }
  1013. return true;
  1014. }
  1015. /* 获取某个频率的模版列表 */
  1016. bool FromWebAPI::getTemplateList(int chnID, QList<OneTemplateInfo>& listTemplate)
  1017. {
  1018. if(m_httpApi == nullptr)
  1019. {
  1020. LH_WRITE_ERROR("WebAPI is nullptr");
  1021. return false;
  1022. }
  1023. nJson json0;
  1024. json0["opName"] = "TMS_GetExecPlanOneTemplateList";
  1025. nJson jsonParam;
  1026. jsonParam["channelID"] = chnID;
  1027. json0["paramList"] = jsonParam;
  1028. /* 发送请求 */
  1029. QString strCmd = QString::fromStdString(json0.dump());
  1030. QString strRet;
  1031. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Select, strCmd, strRet, true);
  1032. if(ret != 0)
  1033. {
  1034. LH_WRITE_ERROR(QString("获取模板列表失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  1035. return false;
  1036. }
  1037. /* 解析获取到的JSON数据 */
  1038. // LH_WRITE_LOG_DEBUG(strRet);
  1039. try
  1040. {
  1041. nJson json1 = nJson::parse(strRet.toStdString());
  1042. int retCode = json1["code"].get<int>();
  1043. if(retCode != 0)
  1044. {
  1045. LH_WRITE_ERROR("获取模板列表失败");
  1046. return false;
  1047. }
  1048. nJson result = json1["result"];
  1049. for(auto& it : result)
  1050. {
  1051. OneTemplateInfo info;
  1052. info.channelInfo.ChannelID = it["channelID"].get<int>();
  1053. info.templateName = QString::fromStdString(it["templateName"].get<std::string>());
  1054. listTemplate.append(info);
  1055. }
  1056. } catch (const nJson::parse_error& e) {
  1057. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1058. return false;
  1059. }
  1060. catch (const nJson::exception& e)
  1061. {
  1062. LH_WRITE_ERROR(QString("解析模板列表失败:%1").arg(e.what()));
  1063. return false;
  1064. }
  1065. catch(...)
  1066. {
  1067. LH_WRITE_ERROR("解析模板列表失败");
  1068. return false;
  1069. }
  1070. return true;
  1071. }
  1072. /* 删除一个模板 */
  1073. bool FromWebAPI::deleteTemplate(const QString& name)
  1074. {
  1075. if(m_httpApi == nullptr)
  1076. {
  1077. LH_WRITE_ERROR("WebAPI is nullptr");
  1078. return false;
  1079. }
  1080. nJson json0;
  1081. json0["opName"] = "TMS_DeleteExecPlanTemplate";
  1082. nJson json1;
  1083. json1["templateName"] = name.toStdString();
  1084. json0["paramList"] = json1;
  1085. QString strCmd = QString::fromStdString(json0.dump());
  1086. QString strRet;
  1087. auto ret = m_httpApi->DBDoInterface(enDBOperatorType::EDBOT_Delete, strCmd, strRet, true);
  1088. if(ret != 0)
  1089. {
  1090. LH_WRITE_ERROR(QString("删除模板失败:%1, 错误信息:%2").arg(ret).arg(m_httpApi->DoGetLastError(&ret)));
  1091. return false;
  1092. }
  1093. return true;
  1094. }