backendapimanager.cpp 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. #include "backendapimanager.h"
  2. #include <QtCore/qlogging.h>
  3. #include <QEventLoop>
  4. #include <QUrlQuery>
  5. #include "logger.h"
  6. backendAPIManager *backendAPIManager::s_instance = nullptr;
  7. void backendAPIManager::initialize(const QString &backendUrl) {
  8. if (!s_instance) {
  9. s_instance = new backendAPIManager(backendUrl);
  10. }
  11. }
  12. void backendAPIManager::cleanup() {
  13. if (s_instance) {
  14. delete s_instance;
  15. s_instance = nullptr;
  16. }
  17. }
  18. void backendAPIManager::setAuthToken(const QString &token) {
  19. if (s_instance) {
  20. s_instance->authToken = token;
  21. }
  22. }
  23. backendAPIManager::backendAPIManager(const QString &backendUrl, QObject *parent)
  24. : QObject(parent), backendUrl(backendUrl), requestSuccess(false) {
  25. networkManager = new QNetworkAccessManager(this);
  26. }
  27. backendAPIManager::~backendAPIManager() {
  28. if (networkManager) {
  29. delete networkManager;
  30. networkManager = nullptr;
  31. }
  32. }
  33. void backendAPIManager::setupRequest(QNetworkRequest &request, const QString &endpoint) {
  34. request.setUrl(QUrl(backendUrl + endpoint));
  35. request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");
  36. if (!s_instance->authToken.isEmpty()) {
  37. request.setRawHeader("Authorization", s_instance->authToken.toUtf8());
  38. }
  39. }
  40. QNetworkReply *backendAPIManager::sendRequest(const QString &endpoint, const QJsonObject &data, const QString &method) {
  41. QNetworkRequest request;
  42. setupRequest(request, endpoint);
  43. QJsonDocument doc(data);
  44. QByteArray jsonData = doc.toJson();
  45. QNetworkReply *reply = nullptr;
  46. if (method == "GET") {
  47. if (!data.isEmpty()) {
  48. QUrl url = request.url();
  49. QUrlQuery query;
  50. for (const QString &key : data.keys()) {
  51. query.addQueryItem(key, data.value(key).toString());
  52. }
  53. url.setQuery(query);
  54. request.setUrl(url);
  55. }
  56. reply = networkManager->get(request);
  57. } else if (method == "POST") {
  58. reply = networkManager->post(request, jsonData);
  59. } else if (method == "PUT") {
  60. reply = networkManager->put(request, jsonData);
  61. } else if (method == "DELETE") {
  62. reply = networkManager->deleteResource(request);
  63. }
  64. return reply;
  65. }
  66. QJsonObject backendAPIManager::getBlastRecords(int page, int pageSize, QJsonObject params) {
  67. if (!s_instance) return QJsonObject();
  68. s_instance->requestSuccess = false;
  69. params.insert("page", page);
  70. params.insert("pageSize", pageSize);
  71. QNetworkReply *reply = s_instance->sendRequest("blastrecord", params, "GET");
  72. QEventLoop loop;
  73. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  74. loop.exec();
  75. QJsonObject result;
  76. if (reply->error() == QNetworkReply::NoError) {
  77. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  78. result = response.object()["data"].toObject();
  79. }
  80. reply->deleteLater();
  81. return result;
  82. }
  83. // TODO: not use any more 上传爆破记录完整记录. 包含设备和雷管记录
  84. bool backendAPIManager::uploadBlastProjectFull(const QJsonObject &projectData) {
  85. if (!s_instance) return false;
  86. s_instance->requestSuccess = false;
  87. QNetworkReply *reply = s_instance->sendRequest("blastrecord/pc", projectData, "POST");
  88. // 使用事件循环等待响应
  89. QEventLoop loop;
  90. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  91. loop.exec();
  92. if (reply->error() == QNetworkReply::NoError) {
  93. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  94. s_instance->handleReponseOKFinished(response, reply->url());
  95. } else {
  96. Logger::getInstance().error(QString("UploadBlastProjectFull request failed. uuid: %1 error message: %2")
  97. .arg(projectData.value("uuid").toString())
  98. .arg(reply->errorString()));
  99. s_instance->handleResponseError(reply->errorString());
  100. }
  101. reply->deleteLater();
  102. return s_instance->requestSuccess;
  103. }
  104. QJsonArray backendAPIManager::getSysUsers() {
  105. if (!s_instance) return QJsonArray();
  106. QNetworkReply *reply = s_instance->sendRequest("sys-user", QJsonObject(), "GET");
  107. QEventLoop loop;
  108. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  109. loop.exec();
  110. QJsonArray result;
  111. if (reply->error() == QNetworkReply::NoError) {
  112. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  113. result = response.object()["data"].toObject()["list"].toArray();
  114. }
  115. reply->deleteLater();
  116. return result;
  117. }
  118. QJsonArray backendAPIManager::getDailyBlastedCount(int days) {
  119. if (!s_instance) return QJsonArray();
  120. QJsonObject params;
  121. params.insert("days", QString::number(days));
  122. QNetworkReply *reply = s_instance->sendRequest("blastrecord/daily_counts", params, "GET");
  123. QEventLoop loop;
  124. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  125. loop.exec();
  126. QJsonArray result;
  127. if (reply->error() == QNetworkReply::NoError) {
  128. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  129. result = response.object()["data"].toArray();
  130. } else {
  131. Logger::getInstance().error(
  132. QString("GetDailyBlastedCount request failed. error message: %1").arg(reply->errorString()));
  133. }
  134. reply->deleteLater();
  135. return result;
  136. }
  137. QJsonArray backendAPIManager::getHAddresses() {
  138. if (!s_instance) return QJsonArray();
  139. QNetworkReply *reply = s_instance->sendRequest("h-address/pc", QJsonObject(), "GET");
  140. QEventLoop loop;
  141. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  142. loop.exec();
  143. QJsonArray result;
  144. if (reply->error() == QNetworkReply::NoError) {
  145. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  146. result = response.object()["data"].toArray();
  147. }
  148. reply->deleteLater();
  149. return result;
  150. }
  151. bool backendAPIManager::uploadBlastProject(const QJsonObject &projectData) {
  152. if (!s_instance) return false;
  153. s_instance->requestSuccess = false;
  154. QNetworkReply *reply = s_instance->sendRequest("blastrecord", projectData, "POST");
  155. // 使用事件循环等待响应
  156. QEventLoop loop;
  157. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  158. loop.exec();
  159. if (reply->error() == QNetworkReply::NoError) {
  160. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  161. s_instance->handleReponseOKFinished(response, reply->url());
  162. } else {
  163. s_instance->handleResponseError(reply->errorString());
  164. }
  165. reply->deleteLater();
  166. return s_instance->requestSuccess;
  167. }
  168. bool backendAPIManager::uploadBlastProjectDets(const QJsonObject &detsData) {
  169. if (!s_instance) return false;
  170. s_instance->requestSuccess = false;
  171. QNetworkReply *reply = s_instance->sendRequest("blastrecorddet/batch", detsData, "POST");
  172. // 使用事件循环等待响应
  173. QEventLoop loop;
  174. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  175. loop.exec();
  176. if (reply->error() == QNetworkReply::NoError) {
  177. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  178. s_instance->handleReponseOKFinished(response, reply->url());
  179. } else {
  180. s_instance->handleResponseError(reply->errorString());
  181. }
  182. reply->deleteLater();
  183. return s_instance->requestSuccess;
  184. }
  185. bool backendAPIManager::uploadBlastEquipments(const QJsonObject &regDetsData) {
  186. if (!s_instance) return false;
  187. s_instance->requestSuccess = false;
  188. QNetworkReply *reply = s_instance->sendRequest("blastrecordequipment", regDetsData, "POST");
  189. // 使用事件循环等待响应
  190. QEventLoop loop;
  191. QObject::connect(reply, &QNetworkReply::finished, &loop, &QEventLoop::quit);
  192. loop.exec();
  193. if (reply->error() == QNetworkReply::NoError) {
  194. QJsonDocument response = QJsonDocument::fromJson(reply->readAll());
  195. s_instance->handleReponseOKFinished(response, reply->url());
  196. } else {
  197. s_instance->handleResponseError(reply->errorString());
  198. }
  199. reply->deleteLater();
  200. return s_instance->requestSuccess;
  201. }
  202. void backendAPIManager::handleReponseOKFinished(const QJsonDocument &response, const QUrl &url) {
  203. // Check response status
  204. if (response.object().contains("code")) {
  205. int code = response.object()["code"].toInt();
  206. requestSuccess = (code == 200);
  207. } else {
  208. requestSuccess = false;
  209. }
  210. emit uploadFinished(response);
  211. }
  212. void backendAPIManager::handleResponseError(const QString &error) {
  213. requestSuccess = false;
  214. emit uploadError(error);
  215. }