mod_UpgradeMgr.h 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. #ifndef RVC_MOD_UPGRADEMGR_H_
  2. #define RVC_MOD_UPGRADEMGR_H_
  3. #include "stdafx.h"
  4. #include "SpBase.h"
  5. #include "SimpleString.h"
  6. #include "UpgradeManager_server_g.h"
  7. #include "UpgradeManager_UserErrorCode.h"
  8. #ifdef RVC_OS_WIN
  9. #else
  10. #include "SpTest.h"
  11. #include "modVer.h"
  12. #endif
  13. #include "UpgradeTaskFSM.h"
  14. using namespace UpgradeManager;
  15. #define UPGRADE_MGR_NOT_IMPLEMENT 0xF0000000 // 新升级模式未实现
  16. // 升级管理 UpgradeManager 0x506
  17. class CUpgradeMgrEntity : public CEntityBase, public ISysVarListener, public ILogListener
  18. {
  19. public:
  20. CUpgradeMgrEntity(){
  21. m_IsSM3listSucc=0;
  22. m_beginSM3HashTime=0;
  23. m_strSM3Hash="";
  24. m_bStartUp=false;//首页是否进入
  25. m_initSucc=false;//状态机是否启动成功
  26. m_testResult=Error_Succeed;//默认是成功的
  27. m_iBlackFileSum=0;
  28. }
  29. virtual ~CUpgradeMgrEntity() {}
  30. virtual const char *GetEntityName() const { return "UpgradeManager"; }
  31. virtual bool IsService()const{return true;}
  32. #ifdef RVC_OS_WIN
  33. #else
  34. const char* GetEntityVersion() const override
  35. {
  36. return MODULE_VERSION_FULL;
  37. }
  38. ON_ENTITYT_TEST()
  39. #endif
  40. virtual void OnStarted();
  41. virtual void OnSelfTest(EntityTestEnum eTestType,CSmartPointer<ITransactionContext> pTransactionContext);
  42. virtual void OnPreClose(EntityCloseCauseEnum eCloseCause,CSmartPointer<ITransactionContext> pTransactionContext);
  43. virtual CServerSessionBase *OnNewSession(const char* /*pszRemoteEntityName*/, const char * /*pszParam*/);
  44. virtual void OnSysVarEvent(const char *pszKey, const char *pszValue,const char *pszOldValue,const char *pszEntityName);
  45. static char GetInstallStateVal(const InstallStateEnum enumVal);
  46. ErrorCodeEnum RegistLocalPack(const CSimpleStringA &strPackFile);
  47. DWORD RegistManualPack(const CSimpleStringA &strPackFile);
  48. DWORD GetManualPacks(CSimpleStringA &strManualPacks);
  49. ErrorCodeEnum CancelUpdate(const CSimpleStringA &strPackName);
  50. ErrorCodeEnum RollbackUpdate(const CSimpleStringA &strVersion);
  51. ErrorCodeEnum SwitchUpgrade(const CSimpleStringA &strPack);
  52. ErrorCodeEnum GetUpgradeState(bool &bInstalling, CSimpleStringA &strPackFile, CSimpleStringA &strExecID,
  53. char &nInstallState, bool &bSysInstall, bool &bLightPack, CSimpleStringA &strNewVersion);
  54. //检测active文件是否被锁
  55. ErrorCodeEnum testActive();
  56. //modify by lwt 新状态机加入方法
  57. ErrorCodeEnum NewStopMediaPlay();
  58. static void HttpsLogCallBack(const char* logtxt);
  59. virtual void OnLog(const CAutoArray<CUUID>& SubIDs, const CUUID nLogID, const LogTypeEnum eLogType, const SeverityLevelEnum eLevel,
  60. const DWORD dwSysError, const DWORD dwUserCode, const DWORD dwEntityInstanceID, const WORD wEntityDevelID,
  61. const CAutoArray<DWORD>& Param, const char* pszEntityName, const char* pszModuleName, const char* pszMessage, const linkContext& pLinkInfo);
  62. public:
  63. map<CSimpleStringA, CSimpleStringA> m_FileHashMap; // 版本文件hash值集合
  64. CSimpleStringA m_strMD5List;
  65. CSimpleStringA m_strSM3Hash;//SM3 32位hash
  66. int m_IsSM3listSucc;//获取SM3哈希list是否成功,0:还未计算完毕,1:表示成功 ,-1表示计算失败
  67. DWORD m_beginSM3HashTime;//开始计算sm3hahs时间
  68. bool m_bStartUp;//是否系统首页启动成功
  69. //bool m_bSystemStartUp;//框架启动成功
  70. CUpgradeTaskFSM m_taskFSM;
  71. bool bNewUpgradeMgr;//是否启用新状态机(很重要的变量)
  72. ErrorCodeEnum m_testResult;//实体级别握手变量
  73. CSimpleStringA m_grayLaunchUrl;//灰度发布url地址
  74. int m_CenterModel;//集中配置模式 0:旧模式 1:新旧并存模式 2:新模式
  75. bool m_initSucc;//状态机是否启动成功
  76. int m_iBlackFileSum;//黑名单文件数量
  77. private:
  78. CUUID m_uuidHeartBeat;
  79. };
  80. class CUpgradeMgrSession : public UpgradeMgrService_ServerSessionBase
  81. {
  82. public:
  83. CUpgradeMgrSession(CUpgradeMgrEntity *pEntity) : m_pEntity(pEntity) {}
  84. virtual ~CUpgradeMgrSession() {}
  85. virtual void Handle_RegistLocalPack(SpReqAnsContext<UpgradeMgrService_RegistLocalPack_Req, UpgradeMgrService_RegistLocalPack_Ans>::Pointer ctx)
  86. {
  87. DbgToBeidou(ctx->link, __FUNCTION__)();
  88. ErrorCodeEnum rc = m_pEntity->RegistLocalPack(ctx->Req.strPackFile);
  89. ctx->Answer(rc);
  90. }
  91. virtual void Handle_RegistManualPack(SpReqAnsContext<UpgradeMgrService_RegistManualPack_Req, UpgradeMgrService_RegistManualPack_Ans>::Pointer ctx)
  92. {
  93. LOG_FUNCTION();
  94. DbgToBeidou(ctx->link, __FUNCTION__)();
  95. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("RegistManualPack received!");
  96. DWORD dwRet = 0;
  97. CSimpleStringA strErrmsg="RegistManualPack new UpgradeMgr is not deal with";
  98. dwRet = m_pEntity->RegistManualPack(ctx->Req.strPackFile);
  99. ctx->Ans.Errcode = dwRet;
  100. ctx->Ans.ErrMsg = strErrmsg;
  101. ctx->Answer(Error_Succeed);
  102. }
  103. virtual void Handle_CancelUpdate(SpReqAnsContext<UpgradeMgrService_CancelUpdate_Req, UpgradeMgrService_CancelUpdate_Ans>::Pointer ctx)
  104. {
  105. DbgToBeidou(ctx->link, __FUNCTION__)();
  106. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("CancelUpdate received!");
  107. ErrorCodeEnum rc = m_pEntity->CancelUpdate(ctx->Req.strPackFile);
  108. ctx->Answer(rc);
  109. }
  110. virtual void Handle_RollbackUpdate(SpReqAnsContext<UpgradeMgrService_RollbackUpdate_Req, UpgradeMgrService_RollbackUpdate_Ans>::Pointer ctx)
  111. {
  112. DbgToBeidou(ctx->link, __FUNCTION__)();
  113. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("RollbackUpdate received!");
  114. auto rc = m_pEntity->RollbackUpdate(ctx->Req.strVersion);
  115. ctx->Answer(rc);
  116. }
  117. virtual void Handle_GetUpgradeState(SpReqAnsContext<UpgradeMgrService_GetUpgradeState_Req, UpgradeMgrService_GetUpgradeState_Ans>::Pointer ctx)
  118. {
  119. DbgToBeidou(ctx->link, __FUNCTION__)();
  120. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("GetUpgradeState received!");
  121. auto rc = m_pEntity->GetUpgradeState(ctx->Ans.bInstalling, ctx->Ans.strPackFile, ctx->Ans.strExecID,
  122. ctx->Ans.cInstallState, ctx->Ans.bSysInstall, ctx->Ans.bLightPack, ctx->Ans.strNewVersion);
  123. ctx->Answer(rc);
  124. }
  125. virtual void Handle_SwitchUpgrade(SpReqAnsContext<UpgradeMgrService_SwitchUpgrade_Req, UpgradeMgrService_SwitchUpgrade_Ans>::Pointer ctx)
  126. {
  127. DbgToBeidou(ctx->link, __FUNCTION__)();
  128. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("SwitchUpgrade received!");
  129. auto rc = m_pEntity->SwitchUpgrade(ctx->Req.strPackFile);
  130. ctx->Answer(rc);
  131. }
  132. virtual void Handle_GetManualPacks(SpReqAnsContext<UpgradeMgrService_GetManualPacks_Req, UpgradeMgrService_GetManualPacks_Ans>::Pointer ctx)
  133. {
  134. LOG_FUNCTION();
  135. DbgToBeidou(ctx->link, __FUNCTION__)();
  136. DbgWithLink(LOG_LEVEL_INFO, ctx->link.checkEmpty() ? LOG_TYPE_SYSTEM : LOG_TYPE_USER).setAPI(__FUNCTION__)("GetManualPacks received!");
  137. DWORD dwRet = 0;
  138. CSimpleStringA strErrmsg= "GetManualPacks new UpgradeMgr is not deal with";
  139. CSimpleStringA strPackList="";
  140. dwRet = m_pEntity->GetManualPacks(strPackList);
  141. ctx->Ans.Errcode = dwRet;
  142. ctx->Ans.ErrMsg = strErrmsg;
  143. ctx->Answer(Error_Succeed);
  144. }
  145. private:
  146. CUpgradeMgrEntity *m_pEntity;
  147. };
  148. #endif //RVC_MOD_UPGRADEMGR_H_