anetwork.cpp 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. #include "app.h"
  2. #include "filesystem.h"
  3. #include "lotromanager.h"
  4. #include <QtNetwork/QNetworkAccessManager>
  5. #include <QUrl>
  6. #include <QUrlQuery>
  7. #include <QNetworkRequest>
  8. #include <QNetworkReply>
  9. #include <QObject>
  10. #include <QEventLoop>
  11. #include <QDir>
  12. #include <QMap>
  13. ANetwork::ANetwork(QObject*) {
  14. }
  15. QString ANetwork::query(QUrl url){
  16. App *app = &App::getInstance();
  17. QNetworkAccessManager* manager = new QNetworkAccessManager(app->window);
  18. QNetworkRequest request(url);
  19. QNetworkReply* reply = manager->get(request);
  20. QEventLoop loop;
  21. QObject::connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
  22. loop.exec();
  23. QString content = reply->readAll();
  24. if (reply->error() != QNetworkReply::NoError){
  25. content = "error";
  26. qDebug() << reply->errorString();
  27. }
  28. reply->deleteLater();
  29. return content;
  30. }
  31. QByteArray ANetwork::query_binary(QUrl url){
  32. App *app = &App::getInstance();
  33. QNetworkAccessManager* manager = new QNetworkAccessManager(app->window);
  34. QNetworkRequest request(url);
  35. QNetworkReply* reply = manager->get(request);
  36. QEventLoop loop;
  37. QObject::connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
  38. loop.exec();
  39. QByteArray bytes = reply->readAll();
  40. return bytes;
  41. }
  42. QString ANetwork::getCoupon(){
  43. App *app = &App::getInstance();
  44. app->logSectionStart("Код купона");
  45. QString content = this->query(app->config->getValue("Network", "coupon") + ".txt");
  46. if (content != "error"){
  47. app->config->setValue("Values", "coupon", content);
  48. qInfo("%s:%i: %s%s", __FILE__, __LINE__, "Ответ сервера: ", content.toLocal8Bit().data());
  49. qInfo("%s:%i: %s", __FILE__, __LINE__, "Данные получены. Производим установку значений.");
  50. } else {
  51. qWarning("%s:%i: %s", __FILE__, __LINE__, "Не удалось получить информацию с сервера");
  52. content = app->config->getValue("Values", "coupon");
  53. }
  54. app->window->ui->couponButton->setText(content);
  55. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  56. app->logSectionEnd();
  57. return content;
  58. }
  59. QString ANetwork::getFootMessage(){
  60. App *app = &App::getInstance();
  61. app->logSectionStart("Информация о профилактике");
  62. // app->window->ui->footRed->setText("Профилактика. Все сервера отключены. Примерное время окончания работ - 40:00 (МСК).");
  63. QString content = this->query(app->config->getValue("Network", "foot") + ".txt");
  64. if (content != "error"){
  65. qInfo("%s:%i: %s", __FILE__, __LINE__, "Данные получены");
  66. app->config->setValue("Values", "foot", content);
  67. qInfo("%s:%i: %s%s", __FILE__, __LINE__, "Ответ сервера: ", content.toLocal8Bit().data());
  68. } else {
  69. qWarning("%s:%i: %s", __FILE__, __LINE__, "Не удалось получить информацию с сервера");
  70. content = app->config->getValue("Values", "foot");
  71. app->logSectionEnd();
  72. return content;
  73. }
  74. if(content != ""){
  75. qInfo("%s:%i: %s", __FILE__, __LINE__, "Есть сообщения о профилактике. Производим разбор и установку значений");
  76. QStringList list = content.split(":::");
  77. //QStringList date = list[2].split(" ");
  78. QString day = list[2];
  79. QString month = " " + list[3];
  80. app->window->ui->footYellow->show();
  81. app->window->ui->footYellow->setText("Профилактика игровых серверов состоится " + day + month + " с " + list[0] +" до " + list[1] + " (МСК).");
  82. } else {
  83. qInfo("%s:%i: %s", __FILE__, __LINE__, "Сообщения о профилактике отсутствуют.");
  84. }
  85. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  86. app->logSectionEnd();
  87. return content;
  88. }
  89. QString ANetwork::getServers(){
  90. App *app = &App::getInstance();
  91. QString time = "";
  92. app->logSectionStart("Статусы серверов");
  93. QString content = this->query(app->config->getValue("Network", "servers") + ".txt");
  94. if (content != "error"){
  95. qInfo("%s:%i: %s%s", __FILE__, __LINE__, "Ответ сервера: ", content.toLocal8Bit().data());
  96. qInfo("%s:%i: %s", __FILE__, __LINE__, "Данные получены. Производим установку значений.");
  97. app->config->setValue("Values", "servers", content);
  98. qDebug() << content;
  99. } else {
  100. qWarning("%s:%i: %s", __FILE__, __LINE__, "Не удалось получить информацию с сервера.");
  101. content = app->config->getValue("Values", "servers");
  102. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  103. app->logSectionEnd();
  104. return content;
  105. }
  106. if(content == "profilaktika"){
  107. qInfo("%s:%i: %s", __FILE__, __LINE__, "По данным сервера в данный момент идут техработы.");
  108. foreach(QObject * obj, app->window->ui->serversbox->children()){
  109. if (obj != nullptr && obj->objectName() != ""){
  110. QLabel * label = dynamic_cast<QLabel*>(obj);
  111. label->setStyleSheet("QLabel{ background-color:#8A0808; }");
  112. }
  113. }
  114. qInfo("%s:%i: %s", __FILE__, __LINE__, "Парсим данные о профилактике.");
  115. content = app->config->getValue("Values", "foot");
  116. if(content != ""){
  117. QStringList list = content.split(":::");
  118. time = "Примерное время окончания работ - " + list[1] + " (МСК)";
  119. }
  120. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выводим сообщение о профилактике.");
  121. app->window->ui->footRed->show();
  122. app->window->ui->footRed->setText("Профилактика. Все сервера отключены. " + time);
  123. if(app->window->ui->footYellow->text() != "") app->window->ui->footYellow->setText("");
  124. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  125. app->logSectionEnd();
  126. return content;
  127. }
  128. qInfo("%s:%i: %s", __FILE__, __LINE__, "Раскрашиваем индикаторы серверов.");
  129. QStringList data = content.split("|||");
  130. foreach(QString item, data){
  131. QStringList server = item.split(":::");
  132. QString color = server[1] == "on" ? "#173B0B" : "#8A0808";
  133. QLabel* obj = app->window->ui->serversbox->findChild<QLabel*>(server[0]);
  134. if (obj != nullptr){
  135. obj->setStyleSheet("QLabel{ background-color:" + color + "; }");
  136. }
  137. }
  138. qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  139. app->logSectionEnd();
  140. return content;
  141. }
  142. void ANetwork::UpdatePatches() {
  143. App *app = &App::getInstance();
  144. if (app->state == "busy") {
  145. qInfo("%s:%i: %s", __FILE__, __LINE__, "Проверка актуальности патчей запущена во время выполения операции. Прерываю проверку");
  146. return;
  147. }
  148. app->helper->setState("busy");
  149. emit changeHint("Проверка обновлений патчей", "Выполняется поиск обновлений патчей...");
  150. app->downloader->resetDownloadedCount();
  151. QUrlQuery query;
  152. QStringList names;
  153. QString version;
  154. qInfo("%s:%i: %s", __FILE__, __LINE__, "Начинаем проверку актуальности патчей.");
  155. names << "sounds" << "texts" << "images" << "videos" << "loadscreens" << "textures" << "fonts";
  156. QUrl url(app->config->getValue("Network", "releases"));
  157. QString datafolder = QApplication::applicationDirPath() + "/data";
  158. QDir dir(datafolder);
  159. if (!dir.exists())
  160. QDir().mkdir(datafolder);
  161. foreach(QString s, names) {
  162. emit changeHint("Проверка обновлений патчей", "Проверка патча " + LotroManager::getInstance().patchTitleFromName(s) + "...");
  163. if(app->config->getValue("Editor", s) == "false") {
  164. emit changePatchStatus(s, "Не выбран");
  165. continue;
  166. }
  167. QStringList paths = dir.entryList(QStringList(s + "*"));
  168. qDebug("%s:%i: %s%s", __FILE__, __LINE__, "Найденные патчи: ", QString(paths.join(' ')).toLocal8Bit().data());
  169. QString dateline = app->config->getValue("Datetime", s);
  170. if (dateline != "-1") {
  171. qDebug("%s:%i: %s", __FILE__, __LINE__, "Проставляем даты патчей.");
  172. QStringList date = dateline.split(" ");
  173. emit changePatchStatus(s, date[0]);
  174. }
  175. if (paths.empty()) {
  176. qDebug("%s:%i: %s%s", __FILE__, __LINE__, "Патч отсутствует: ", s.toLocal8Bit().data());
  177. version = "100";
  178. emit changePatchStatus(s, "В очереди");
  179. query.addQueryItem(s.left(s.length() - 1), version);
  180. continue;
  181. }
  182. version = QString::number(app->helper->getVersion(paths.first()));
  183. QString hash = FileSystem::fileHash(datafolder + "/" + paths.first(), QCryptographicHash::Md5);
  184. if(hash != app->config->getValue("Hashes", s)) {
  185. qDebug("%s:%i: %s\n%s%s\n%s%s\n%s%s", __FILE__, __LINE__, "Неверный хэш файла! (удаляю файл)",
  186. "Файл: " , paths.first().toLocal8Bit().data(),
  187. "Высчитанный хэш: ", hash.toLocal8Bit().data(),
  188. "Хэш конфигурации: ", app->config->getValue("Hashes", s).toLocal8Bit().data()
  189. );
  190. QFile base(datafolder + "/" + paths.first());
  191. base.remove();
  192. version="100";
  193. emit changePatchStatus(s, "В очереди");
  194. }
  195. query.addQueryItem(s.left(s.length() - 1), version);
  196. }
  197. url.setQuery(query.query());
  198. qDebug("%s:%i: %s%s", __FILE__, __LINE__, "Запрашиваем информацию о патчах: ", url.fileName().toLocal8Bit().data());
  199. qDebug() << "\nЗапрос на сервер: " << url;
  200. QString content = this->query(url);
  201. if(content == "error"){
  202. qInfo("%s:%i: %s", __FILE__, __LINE__, "Отсутствует связь с сервером. Прервано.");
  203. app->logSectionEnd();
  204. emit changeHint("Ошибка проверки обновлений", "Отсутствует связь с сервером. Проверка обновлений прервана.");
  205. app->helper->setState("free");
  206. return;
  207. }
  208. qDebug() << "\nОтвет сервера: " << content;
  209. if (content == "Запросы GET или POST отсутствуют!!!!") {
  210. qInfo("%s:%i: %s", __FILE__, __LINE__, "Отсутствуют запросы к серверу.");
  211. app->helper->setState("free");
  212. return;
  213. }
  214. if (content == "") {
  215. qInfo("%s:%i: %s", __FILE__, __LINE__, "Все версии патчей соответствуют актуальным.");
  216. emit changeHint("Проверка завершена", "Все версии патчей соответствуют актуальным.");
  217. app->helper->setState("free");
  218. return;
  219. }
  220. qInfo("%s:%i: %s", __FILE__, __LINE__, "Составляем список загрузок.");
  221. QStringList downloads = content.split( "|" );
  222. foreach (QString item, downloads){
  223. QStringList values = item.split( ":::" );
  224. QStringList pathline = values[0].split( "_" );
  225. pathline = pathline[0].split( "/" );
  226. QUrl url = values[0];
  227. app->config->setValue("Hashes", pathline.last(), values[1]);
  228. app->config->setValue("Datetime", pathline.last(), values[2]);
  229. // Удаляем устаревшие патчи
  230. QStringList old = dir.entryList(QStringList(pathline.last() + "*"));
  231. if(old.count() > 0){
  232. foreach(QString filename, old){
  233. QFile::remove(QApplication::applicationDirPath() + "/data/" + filename);
  234. }
  235. }
  236. // Добавляем новый файл в список закачек
  237. app->downloader->append(url);
  238. }
  239. qInfo("%s:%i: %s", __FILE__, __LINE__, "Начинаем загрузку патчей.");
  240. app->helper->setState("free");
  241. app->downloader->startDownloads();
  242. }
  243. QString ANetwork::getMicroPath(int timestamp){
  244. App *app = &App::getInstance();
  245. app->logSectionStart("Загрузка последних обновлений");
  246. qInfo("%s:%i: %s", __FILE__, __LINE__, "Уточняем наличие обновлений");
  247. QString microfolder = QApplication::applicationDirPath() + "/data/micro/";
  248. QDir dir(microfolder);
  249. if(!dir.exists()) QDir().mkdir(microfolder);
  250. QString baseurl = app->config->getValue("Network", "update");
  251. QString url = baseurl + "/1/" + QString::number(timestamp);
  252. qInfo("%s:%i: %s%s", __FILE__, __LINE__, "Стартуем загрузку ", url.toStdString().c_str());
  253. QNetworkAccessManager m_NetworkMngr;
  254. QNetworkReply *reply= m_NetworkMngr.get(QNetworkRequest(url));
  255. QEventLoop loop;
  256. QObject::connect(reply, SIGNAL(finished()),&loop, SLOT(quit()));
  257. loop.exec();
  258. QUrl aUrl(url);
  259. QFileInfo fileInfo=aUrl.path();
  260. QString filename = micropatch;
  261. QFile file(filename);
  262. file.open(QIODevice::WriteOnly);
  263. file.write(reply->readAll());
  264. delete reply;
  265. qInfo("%s:%i: %s", __FILE__, __LINE__, "Загрузка микропатча завершена.");
  266. //LotroManager::getInstance().database_.InitDatabase(filename.toLocal8Bit().data());
  267. //int indb = LotroManager::getInstance().database_.CountRows();
  268. //qInfo("%s:%i: %s%i", __FILE__, __LINE__, "Патч содержит строк: ", indb);
  269. //for(int i = 0; i<=indb; i++) LotroManager::getInstance().processFile();
  270. //qInfo("%s:%i: %s", __FILE__, __LINE__, "Выполнено.");
  271. //LotroManager::getInstance().saveDatFiles();
  272. //LotroManager::getInstance().database_.CloseDatabase();
  273. //app->logSectionEnd();
  274. return filename;
  275. }