mod_healthmanager.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. #ifndef __MOD_HEALTHMANAGER_H
  2. #define __MOD_HEALTHMANAGER_H
  3. #include <map>
  4. #include "SpBase.h"
  5. #include "modVer.h"
  6. #include "SpTest.h"
  7. #include "HealthManagerFSM.h"
  8. #include "EventCode.h"
  9. #include "HealthManager_server_g.h"
  10. using namespace HealthManager;
  11. #include "WatchDog_client_g.h"
  12. #include "Ups_client_g.h"
  13. #include "UpsClass.h"
  14. #include "InteractionContext_client_g.h"
  15. #include "UpgradeManager_client_g.h"
  16. #include "CardSwiper_client_g.h"
  17. using namespace std;
  18. using namespace WatchDog;
  19. using namespace Ups;
  20. using namespace InteractionContext;
  21. using namespace UpgradeManager;
  22. using namespace CardSwiper;
  23. #include "GuardianBase.h"
  24. typedef int (*pfShakeHands)(WorkStateEnum &eState);
  25. typedef int (*pfPushUpdateTask)(const char *pszPackName);
  26. typedef bool (*pfIsInstalling)();
  27. typedef int (*pfUpgradeRestart)(const DWORD dwParam1,const DWORD dwParam2);
  28. typedef int (*pfFrameworkQuit)(RebootTriggerEnum eReason);
  29. enum WatchDogOp
  30. {
  31. WD_OP_START,
  32. WD_OP_STOP,
  33. WD_OP_REFRESH
  34. };
  35. enum ModuleReMode
  36. {
  37. RESTART_MODE_DEFAULT,
  38. RESTART_MODE_LOW,
  39. RESTART_MODE_HIGH,
  40. };
  41. struct ModuleRunInfo
  42. {
  43. DWORD dwStart;
  44. int count;
  45. };
  46. struct RestartModeInfo
  47. {
  48. DWORD dwTimes;
  49. DWORD dwInternal;
  50. };
  51. typedef CAutoArray<CSimpleStringA> NetworkAddressesList;
  52. #define MACSESION 6
  53. #include <winpr/sysinfo.h>
  54. static void GetLocalTimeRVC(SYSTEMTIME& stTime)
  55. {
  56. GetLocalTime(&stTime);
  57. }
  58. class HealthManagerSession : public HealthManagerService_ServerSessionBase
  59. {
  60. public:
  61. HealthManagerSession(CHealthManagerEntity *pEntity):m_pEntity(pEntity){}
  62. virtual ~HealthManagerSession(){}
  63. virtual void Handle_EnterState(SpReqAnsContext<HealthManagerService_EnterState_Req, HealthManagerService_EnterState_Ans>::Pointer ctx);
  64. virtual void Handle_ExitState(SpReqAnsContext<HealthManagerService_ExitState_Req, HealthManagerService_ExitState_Ans>::Pointer ctx);
  65. virtual void Handle_DoEvent(SpReqAnsContext<HealthManagerService_DoEvent_Req, HealthManagerService_DoEvent_Ans>::Pointer ctx);
  66. virtual void Handle_GetEntityCfgInfo(SpReqAnsContext<HealthManagerService_GetEntityCfgInfo_Req, HealthManagerService_GetEntityCfgInfo_Ans>::Pointer ctx);
  67. virtual void Handle_GetNetworkState(SpReqAnsContext<HealthManagerService_GetNetworkState_Req, HealthManagerService_GetNetworkState_Ans>::Pointer ctx);
  68. virtual void Handle_QueryHardwareInfo(SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx);
  69. virtual void Handle_ReadCenterConfigStr(SpReqAnsContext<HealthManagerService_ReadCenterConfigStr_Req, HealthManagerService_ReadCenterConfigStr_Ans>::Pointer ctx);
  70. void Handle_ControlTerminalLife(SpReqAnsContext<HealthManagerService_ControlTerminalLife_Req, HealthManagerService_ControlTerminalLife_Ans>::Pointer ctx);
  71. virtual void Handle_DeployTerminal(SpReqAnsContext<HealthManagerService_DeployTerminal_Req, HealthManagerService_DeployTerminal_Ans>::Pointer ctx);
  72. private:
  73. CHealthManagerEntity *m_pEntity;
  74. };
  75. class CHealthManagerEntity : public CEntityBase, public ILogListener, public ISysVarListener, public IBroadcastListener
  76. {
  77. public:
  78. CHealthManagerEntity() :m_bInit(true), m_pWatchDogClient(NULL), m_bWatchDog(false), m_pUpsClient(NULL)
  79. , m_pSync(NULL), xxx(0), m_MCStart(0), m_bWaitRestartPC(false)
  80. , m_upsStateCount(0), m_bUpsWaitLock(false), m_bScreenLock(false), m_bToRestart(false)
  81. , m_upsNoElectorCount(0), m_bSayIdle(false), m_bGuardianRun(false), m_bHealthInit(false), m_pUpgMgr(NULL)
  82. , m_bVerRollback(false), m_eRebootTrigger(RebootTrigger_Unknown), m_eRebootWay(RebootWay_Unknown)
  83. , m_bGetUpsStateFlag(false), m_menuChoice(""), m_menuPre(""), m_netState("N"), m_bFisrtEnterMainPage(true)
  84. , m_bNeedToRestartPAD(false), m_preDay(99), m_bNeedToRestartIE(false), m_bInMainPage(false), m_maxRunDays(7)
  85. , m_bEnterMainPageEver(false), m_connectStatus(0), m_bAccessSuc(false), m_pfShake(NULL),m_pfUpgradeRestart(NULL){}
  86. virtual ~CHealthManagerEntity() {}
  87. virtual const char *GetEntityName() const { return "HealthManager"; }
  88. const char* GetEntityVersion() const { return MODULE_VERSION_FULL; }
  89. virtual void OnPreStart(CAutoArray<CSimpleStringA> strArgs,CSmartPointer<ITransactionContext> pTransactionContext)
  90. {
  91. DoRestart();
  92. ErrorCodeEnum eErrCode = m_fsm.Init(this);
  93. Dbg("");
  94. GetFunction()->SubscribeLog(m_uuidUpdate,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"UpgradeManager");
  95. GetFunction()->SubscribeLog(m_uuidAccessAuth,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"AccessAuthorization");
  96. GetFunction()->SubscribeLog(m_uuidAccessAuth,this,Log_Error,Severity_Middle,Error_IgnoreAll,-1,"AccessAuthorization");
  97. GetFunction()->SubscribeLog(m_uuidInitializer,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"Initializer");
  98. GetFunction()->SubscribeLog(m_uuidInitializer,this,Log_Error,Severity_Middle,Error_IgnoreAll,-1,"Initializer");
  99. GetFunction()->SubscribeLog(m_uuidFaceTracking,this,Log_Error,Severity_High,Error_IgnoreAll,-1,"FaceTracking");
  100. GetFunction()->SubscribeLog(m_uuidMediaController,this,Log_Error,Severity_High,Error_IgnoreAll,-1,"MediaController");
  101. GetFunction()->SubscribeLog(m_uuidSelfChecker,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"SelfChecker");
  102. GetFunction()->SubscribeLog(m_uuidRemoteController,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"RemoteController");
  103. GetFunction()->SubscribeLog(m_uuidGUIConsole,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"GUIConsole");
  104. GetFunction()->SubscribeLog(m_uuidHeartBeat,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"HeartBeat",false);
  105. GetFunction()->SubscribeLog(m_uuidMaintainWatch,this,Log_Event,Severity_Middle,Error_IgnoreAll,-1,"MaintainWatcher");
  106. GetFunction()->SubscribeLog(m_uuidIE, this, Log_Event, Severity_Middle, Error_IgnoreAll, -1, "IEBrowser");
  107. GetFunction()->SubscribeLog(m_uuidCenterS, this, Log_Event, Severity_Middle, Error_IgnoreAll, -1, "CenterSetting");
  108. GetFunction()->SubscribeLog(m_uuidCardSwiper, this, Log_Error, Severity_Middle, Error_IgnoreAll, -1, "CardSwiper");
  109. GetFunction()->SubscribeLog(m_uuidPublic, this, Log_Event, Severity_Middle, Error_IgnoreAll, -1, "systemcustomization");
  110. GetFunction()->SubscribeLog(m_uuidPublic, this, Log_Event, Severity_Middle, Error_IgnoreAll, -1, "Chromium");
  111. GetFunction()->RegistSysVarEvent("UIState", this);
  112. //UpgradeManager
  113. GetFunction()->SubscribeBroadcast("CardSwiper", "", this, m_uuidCardSwiper);
  114. pTransactionContext->SendAnswer(eErrCode) ;
  115. }
  116. virtual void OnPreClose(EntityCloseCauseEnum eCloseCause,CSmartPointer<ITransactionContext> pTransactionContext)
  117. {
  118. pTransactionContext->SendAnswer(Error_Succeed);
  119. }
  120. void EnterState(SpReqAnsContext<HealthManagerService_EnterState_Req, HealthManagerService_EnterState_Ans>::Pointer ctx)
  121. {
  122. if (ctx->Req.state == "M")
  123. {
  124. FSMEvent *pEvt = new FSMEvent(USER_EVT_MAITAIN);
  125. m_fsm.PostEventFIFO(pEvt);
  126. }
  127. ctx->Answer(Error_Succeed);
  128. }
  129. void ExitState(SpReqAnsContext<HealthManagerService_ExitState_Req, HealthManagerService_ExitState_Ans>::Pointer ctx)
  130. {
  131. if (ctx->Req.state == "M")
  132. {
  133. FSMEvent *pEvt = new FSMEvent(USER_EVT_MAITAIN_FINISHED);
  134. m_fsm.PostEventFIFO(pEvt);
  135. }
  136. ctx->Answer(Error_Succeed);
  137. }
  138. void DoEvent(SpReqAnsContext<HealthManagerService_DoEvent_Req, HealthManagerService_DoEvent_Ans>::Pointer ctx)
  139. {
  140. }
  141. void GetEntityCfgInfo(SpReqAnsContext<HealthManagerService_GetEntityCfgInfo_Req, HealthManagerService_GetEntityCfgInfo_Ans>::Pointer ctx)
  142. {
  143. ctx->Ans.reserved2 = m_fsm.GetEntityCfgInfo(ctx->Req.name,ctx->Ans.loadOpt);
  144. ctx->Answer(Error_Succeed);
  145. }
  146. void GetNetworkState(SpReqAnsContext<HealthManagerService_GetNetworkState_Req, HealthManagerService_GetNetworkState_Ans>::Pointer ctx)
  147. {
  148. ctx->Ans.netDeviceState = m_netState;
  149. ctx->Ans.reserved1 = m_fsm.QueryAccessAuthStatus();
  150. Dbg("current net state %s,auth state:%d", (LPCTSTR)m_netState, ctx->Ans.reserved1);
  151. ctx->Answer(Error_Succeed);
  152. }
  153. virtual CServerSessionBase *OnNewSession(const char* /*pszRemoteEntityName*/, const char * /*pszParam*/)
  154. {
  155. return new HealthManagerSession(this);
  156. }
  157. virtual bool IsService()const{return true;}
  158. virtual bool IsMultiThread()const{return true;}
  159. bool DoWatchDog(WatchDogOp eOp);
  160. int SystemRestart(bool bPeriod,bool bUpsImmediately,bool bNow=false);
  161. int SystemShutdown(BOOL bReboot=FALSE);
  162. ErrorCodeEnum SystemShutdownThroughUPS(DWORD msPreShutdown = 5, DWORD msPreRestart = 5);
  163. int FrameworkShutdown(bool bRestart=true);
  164. int GetNetDeviceState();
  165. int UpdateSiteChangeFlag();
  166. int UpdateSiteToRuncfg(bool bWriteSite=true,bool bClearSiteFlag = false);
  167. int WriteSiteToRootIni();
  168. void QueryHardwareInfo(SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx);
  169. void ReadCenterConfigStr(SpReqAnsContext<HealthManagerService_ReadCenterConfigStr_Req, HealthManagerService_ReadCenterConfigStr_Ans>::Pointer ctx);
  170. void ControlTerminalLife(SpReqAnsContext<HealthManagerService_ControlTerminalLife_Req, HealthManagerService_ControlTerminalLife_Ans>::Pointer ctx);
  171. virtual void OnLog(const CAutoArray<CUUID> &SubIDs, const CUUID nLogID,const LogTypeEnum eLogType, const SeverityLevelEnum eLevel,
  172. const DWORD dwSysError,const DWORD dwUserCode,const DWORD dwEntityInstanceID, const WORD wEntityDevelID,
  173. const CAutoArray<DWORD> &Param, const char *pszEntityName, const char *pszModuleName,const char *pszMessage);
  174. virtual void OnSysVarEvent(const char *pszKey,
  175. const char *pszValue, const char *pszOldValue, const char *pszEntityName);
  176. virtual void OnBroadcastEvent(CUUID SubID, const char *pszEntityName, DWORD dwMessageId, DWORD dwMessageSignature, CAutoBuffer Buffer);
  177. void DeployTerminal(SpReqAnsContext<HealthManagerService_DeployTerminal_Req, HealthManagerService_DeployTerminal_Ans>::Pointer ctx);
  178. private:
  179. CHealthManagerFSM m_fsm;
  180. //the following is useless?just one var is ok? oiltmp
  181. CUUID m_uuidUpdate,m_uuidMediaController,m_uuidFaceTracking,m_uuidAccessAuth,m_uuidInitializer,m_uuidSelfChecker
  182. , m_uuidRemoteController, m_uuidGUIConsole, m_uuidHeartBeat, m_uuidMaintainWatch, m_uuidIE, m_uuidCenterS;
  183. CUUID m_uuidCardSwiper,m_uuidPublic;
  184. int m_devCfgNum,m_connectStatus;
  185. int m_restartHour, m_restartMinute, m_lastHour, m_restartTimes, m_maxRestartTimes, m_preDay, m_dayNum, m_maxRunDays;
  186. bool m_bInit,m_bWatchDog,m_bWaitRestartPC,m_bUpsWaitLock,m_bScreenLock,m_bToRestart,m_testFlag,m_bSayIdle
  187. , m_bGuardianRun, m_bHealthInit, m_bVerRollback, m_bFisrtEnterMainPage, m_bNeedToRestartPAD,m_bNeedToRestartIE
  188. , m_bInMainPage, m_bEnterMainPageEver,m_bAccessSuc;
  189. DWORD m_wDayOfWeek,m_MCStart,m_MCEnd;
  190. int xxx,m_upsStateCount,m_upsNoElectorCount;
  191. RebootTriggerEnum m_eRebootTrigger;
  192. RebootWayEnum m_eRebootWay;
  193. CSimpleStringA m_menuChoice,m_currentVer,m_menuPre,m_netState;
  194. map<CSimpleStringA,ModuleRunInfo> m_modRunInfo;
  195. map<CSimpleStringA,ModuleReMode> m_modCfgInfo;
  196. map<ModuleReMode,RestartModeInfo> m_restartMode;
  197. WatchDogService_ClientBase *m_pWatchDogClient;
  198. UpsService_ClientBase *m_pUpsClient;
  199. SyncService_ClientBase *m_pSync;
  200. UpgradeMgrService_ClientBase *m_pUpgMgr;
  201. pfShakeHands m_pfShake;
  202. pfUpgradeRestart m_pfUpgradeRestart;
  203. bool m_bGetUpsStateFlag;
  204. CSystemStaticInfo m_sysStaticInfo;
  205. bool DoRestart();
  206. void OnCheckTimeTimeout();
  207. void OnWatchDogTimeout();
  208. ErrorCodeEnum RestartModule(const char* pEntityName);
  209. void AfterWaitRestartPC();
  210. void UpsSupplyLockScreen();
  211. int ConnectUps();
  212. void SplitModuleNames(CSimpleStringA csLine,ModuleReMode eMode);
  213. bool SaveCurrentVersion();
  214. bool SaveFrameStartTimeForUpgrade();
  215. bool CheckGuardianIsRun(bool bStart=false);
  216. bool StopGuardian();
  217. bool StartGuardian();
  218. bool VersionRollBack(const char *pVerion);
  219. //int QuitFrameworkAndSaveInfo(RebootTriggerEnum eTrigger = RebootTrigger_Unknown,RebootWayEnum eWay = RebootWay_Unknown);
  220. void ReadMachineDataBySyncSerivce();
  221. int RestartIE();
  222. void GetINETMacAddresses(NetworkAddressesList &macList, NetworkAddressesList &ipList);
  223. CSimpleStringA __ReadCenterConfigStr(CSimpleStringA key, CSimpleStringA entityName);
  224. bool IsTestMode();
  225. };
  226. #endif // __MOD_HEALTHMANAGER_H