projectinfomanger.cpp 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. #include "projectinfomanger.h"
  2. #include <QTimer>
  3. #include "globalinfo.h"
  4. #include <QSet>
  5. #include <pqQtlib/utils/pqfileutils.h>
  6. #include <QJsonDocument>
  7. ProjectInfoManger::ProjectInfoManger(PackInfoManger *manger, QObject *parent) : QObject(parent),_manger(manger)
  8. {
  9. connect(&_requst,&HttpRequest::result,this,&ProjectInfoManger::result);
  10. _nowJob = 0;
  11. }
  12. bool ProjectInfoManger::loadServerList(bool local)
  13. {
  14. if(_status != IDIL) return false;
  15. _serverInfo.clear();
  16. _cacheInfo.clear();
  17. if(local){
  18. auto dt = PQ::CacheFile::readFile("ProjectInfoList.cache");
  19. auto ary = QJsonDocument::fromJson(dt).array();
  20. hanldeServerList(ary,false);
  21. return true;
  22. }
  23. _oneSyncError = 0;
  24. _netErrorCount = 0;
  25. _nowJob = 1;
  26. QTimer::singleShot(0,this,&ProjectInfoManger::doSendLoad);
  27. return true;
  28. }
  29. bool ProjectInfoManger::syncLocalList()
  30. {
  31. if(_status != IDIL) return false;
  32. auto info = _manger->getLocalProjectInfo();
  33. _serverInfo.clear();
  34. _cacheInfo.clear();
  35. _pushQueue.clear();
  36. _nowJob = 2;
  37. for(int i = 0; i < info.size(); ++i){
  38. _pushQueue.append(info.at(i));
  39. }
  40. QTimer::singleShot(0,this,&ProjectInfoManger::doSendCreate);
  41. return true;
  42. }
  43. void ProjectInfoManger::doSendLoad()
  44. {
  45. _status = Load_Server_List;
  46. // docs: http://doc.vanlai.net:3001/web/#/1?page_id=60
  47. QString url = GlobalInfo::this_()->config()->baseUrl+"/v1/goods/list?page=0&limit=10000";
  48. _requst.setUserToken(QString::number(GlobalInfo::this_()->user().accountId),GlobalInfo::this_()->user().acessToken);
  49. _requst.get(url);
  50. }
  51. void ProjectInfoManger::doSendCreate()
  52. {
  53. if(!_pushQueue.isEmpty()){
  54. _status = Sync_Local_List;
  55. QSharedPointer<ProjectInfo> info = _pushQueue.first();
  56. // test: 调用新建批号的接口
  57. // docs: http://doc.vanlai.net:3001/web/#/1?page_id=59
  58. QString url = GlobalInfo::this_()->config()->baseUrl+"/v1/goods/add";
  59. _requst.setUserToken(QString::number(GlobalInfo::this_()->user().accountId),GlobalInfo::this_()->user().acessToken);
  60. _requst.post(url,info->toObject());
  61. } else {
  62. _status = IDIL;
  63. QTimer::singleShot(0,this,&ProjectInfoManger::doSendLoad);
  64. }
  65. }
  66. void ProjectInfoManger::handleList()
  67. {
  68. QSet<QString> remoted;
  69. for(int i = 0; i < _serverInfo.size(); ++i){
  70. remoted.insert(_serverInfo.at(i)->batch_no);
  71. }
  72. _cacheInfo.clear();
  73. auto list = _manger->getLocalProjectInfo();
  74. for(int i = 0; i < list.size(); ++i){
  75. auto info = list.at(i);
  76. if(!remoted.contains(info->batch_no)){
  77. _cacheInfo.append(info);
  78. }
  79. }
  80. _manger->syncLocalProjectInfo(_cacheInfo);
  81. if(_nowJob == 1)
  82. emit inited(this,true);
  83. else
  84. emit synced(this,true);
  85. }
  86. void ProjectInfoManger::result(int code, const QJsonObject & body)
  87. {
  88. qDebug()<<body;
  89. switch (_status) {
  90. case Load_Server_List:
  91. handleGetList(code,body);
  92. break;
  93. case Sync_Local_List:
  94. handlSync(code,body);
  95. break;
  96. default:
  97. break;
  98. }
  99. }
  100. void ProjectInfoManger::handlSync(int code, const QJsonObject & body)
  101. {
  102. if(code != 200){
  103. _netErrorCount ++;
  104. if(_netErrorCount > 3) {
  105. emit synced(this,false);
  106. } else {
  107. QTimer::singleShot(500,this,&ProjectInfoManger::syncLocalList);
  108. }
  109. return;
  110. }
  111. // auto error = body.value("code").toInt();
  112. // if(error == 200){
  113. _pushQueue.dequeue();
  114. QTimer::singleShot(50,this,&ProjectInfoManger::syncLocalList);
  115. // } else {
  116. // _pushQueue.dequeue();
  117. // QTimer::singleShot(50,this,&ProjectInfoManger::syncLocalList);
  118. // }
  119. }
  120. void ProjectInfoManger::handleGetList(int code, const QJsonObject & body)
  121. {
  122. if(code != 200){
  123. _netErrorCount ++;
  124. if(_netErrorCount > 3) {
  125. auto dt = PQ::CacheFile::readFile("ProjectInfoList.cache");
  126. auto ary = QJsonDocument::fromJson(dt).array();
  127. hanldeServerList(ary,false);
  128. } else {
  129. QTimer::singleShot(500,this,&ProjectInfoManger::syncLocalList);
  130. }
  131. return;
  132. }
  133. auto error = body.value("code").toInt();
  134. if(error == 200){
  135. _oneSyncError = 0;
  136. auto ary = body.value("data").toArray();
  137. hanldeServerList(ary);
  138. } else {
  139. _oneSyncError ++;
  140. if(_oneSyncError > 3) {
  141. auto dt = PQ::CacheFile::readFile("ProjectInfoList.cache");
  142. auto ary = QJsonDocument::fromJson(dt).array();
  143. hanldeServerList(ary,false);
  144. } else {
  145. QTimer::singleShot(50,this,&ProjectInfoManger::syncLocalList);
  146. }
  147. }
  148. }
  149. void ProjectInfoManger::hanldeServerList(QJsonArray & ary,bool inServer)
  150. {
  151. if(inServer){
  152. auto dt = QJsonDocument(ary).toJson();
  153. PQ::CacheFile::writeFile("ProjectInfoList.cache",dt);
  154. }
  155. //TEST: 解析返回的到 _serverInfo
  156. // docs: http://doc.vanlai.net:3001/web/#/1?page_id=60
  157. for(int i = 0;i<ary.size();i++){
  158. _serverInfo.append(ProjectInfo::fromObject(ary.at(i).toObject()));
  159. }
  160. handleList();
  161. }