HealthManagerFSM.h 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. #ifndef __HEALTHMANAGER_FSM_H
  2. #define __HEALTHMANAGER_FSM_H
  3. #pragma once
  4. #include "stdafx.h"
  5. #include "SpFSM.h"
  6. #include <map>
  7. #include <vector>
  8. using namespace std;
  9. #include "CommEntityUtil.hpp"
  10. #include "HealthManager_msg_g.h"
  11. #include "HealthManager_def_g.h"
  12. #include "AccessAuthorization_client_g.h"
  13. #include "PinPad_client_g.h"
  14. using namespace HealthManager;
  15. using namespace AccessAuthorization;
  16. #include "ResourceWatcher_client_g.h"
  17. using namespace ResourceWatcher;
  18. #include "json/json.h"
  19. #if defined(RVC_OS_WIN)
  20. #include <xstring>
  21. #endif //RVC_OS_WIN
  22. using namespace PinPad;
  23. enum HealthManger_UserErrorCode {
  24. HealthManager_UserErrorCode_Start = 0x50100200,
  25. HealthManager_UserErrorCode_GetAuthAddr_Fail = 0x50100201, //获取准入地址失败
  26. //
  27. HealthManager_UserErrorCode_Enum_OSVersion = 0x50100204, //枚举os版本
  28. HealthManager_UserErrorCode_Enum_AsianInfo_Start = 0x50100205, //查询是否安装亚信
  29. HealthManager_UserErrorCode_Enum_AsianInfo_End = 0x50100206, //查询是否安装亚信
  30. HealthManager_UserErrorCode_Enter_SafeLoad_State = 0x50100207, //用于后台判定启动次数 0x50100207
  31. HealthManager_UserErrorCode_PinPad_Dev_SP_SM = 0x50100208, //密码键盘硬件支持国密
  32. HealthManager_UserErrorCode_PinPad_Dev_NOT_SP_SM = 0x50100209, //密码键盘硬件不支持国密
  33. HealthManager_UserErrorCode_PinPad_HaveLoad_SM = 0x5010020A, //密码键盘已加载国密密钥
  34. HealthManager_UserErrorCode_PinPad_HaveNotLoad_SM = 0x5010020B, //密码键盘未加载国密密钥
  35. HealthManager_UserErrorCode_Receive_Browser_Idle = 0x5010020C, //健康收到浏览器Idle事件 0x5010020c
  36. HealthManager_UserErrorCode_First_Info_AboutTerm = 0x5010020D, //健康启动结束后第一次终端信息上送 0x5010020d
  37. //
  38. //
  39. HealthManager_UserErrorCode_Need_Guardian = 0x50100210, //健康需要启动guardian
  40. HealthManager_UserErrorCode_Need_No_Guardian = 0x50100211, //健康不需要启动guardian
  41. HealthManager_UserErrorCode_WaitForAccessAuthEntityIdle = 0x50100212, //健康等待准入启动正常
  42. HealthManager_UserErrorCode_TerminalAppLoadInfo = 0x50100213, //终端应用启动过程信息
  43. //
  44. HealthManager_UserErrorCode_PrivilegeCMD = 0x50100215, //上送终端收到的启动、重启事件(非关门页、用户桌面?需要调查后理清楚)
  45. HealthManager_UserErrorCode_SogouInput_UsingSys = 0x50100216, // 使用普通调用的搜狗输入法
  46. HealthManager_UserErrorCode_SogouInput_UsingSDK = 0x50100217 // 使用SDK版本调用的搜狗输入法
  47. };
  48. #define HealthManager_UserErrorCode_EntityLost_Start 0x50100300
  49. enum EvtType
  50. {
  51. USER_EVT_TEST = EVT_USER+1,
  52. USER_EVT_QUIT,
  53. USER_EVT_INIT,
  54. USER_EVT_WAIT_DEAMON_FINISHED,
  55. USER_EVT_ACCESSAUTH_FINISHED,
  56. USER_EVT_MAITAIN,
  57. USER_EVT_MAITAIN_FINISHED,
  58. USER_EVT_ENTER_CUSTOMER_MANAGER,
  59. USER_EVT_SWITCH_BACK_TO_RVC,
  60. USER_EVT_VTMLOADER_FINISHED,
  61. };
  62. enum HealthManagerFSMState
  63. {
  64. HM_FSM_INIT,
  65. HM_FSM_STATE_IDLE,
  66. HM_FSM_STATE_FAULT,
  67. HM_FSM_STATE_MAINTAINING,
  68. HM_FSM_STATE_CMS,
  69. };
  70. enum VtmLoadResult
  71. {
  72. VtmLoad_AccessAuth_Init = 0,
  73. VtmLoad_AccessAuth_Suc,
  74. VtmLoad_AccessAuth_Fail,
  75. VtmLoad_AccessAuth_servFail,
  76. VtmLoad_MediaLoadFail,
  77. VtmLoad_OtherSyncEntityLoadFail,
  78. };
  79. struct callback_entry : public IReleasable
  80. {
  81. virtual ~callback_entry() {}
  82. CSimpleStringA EntityName;
  83. union {
  84. void *pRawData;
  85. int state;
  86. };
  87. int op;
  88. ErrorCodeEnum ErrorResult;
  89. };
  90. class CHealthManagerEntity;
  91. class CHealthManagerFSM : public FSMImpl<CHealthManagerFSM>, public ICallbackListener
  92. {
  93. public:
  94. enum {s0,s4,s5,s6,s11};
  95. BEGIN_FSM_STATE(CHealthManagerFSM)
  96. FSM_STATE_ENTRY(s0,"Init",s0_on_entry,s0_on_exit,s0_on_event)
  97. FSM_STATE_ENTRY(s4,"Operating",s4_on_entry,s4_on_exit,s4_on_event)
  98. FSM_STATE_ENTRY(s5,"Fault",s5_on_entry,s5_on_exit,s5_on_event)
  99. FSM_STATE_ENTRY(s6,"Maintaining",s6_on_entry,s6_on_exit,s6_on_event)
  100. FSM_STATE_ENTRY(s11,"CustomerManager",s11_on_entry,s11_on_exit,s11_on_event)
  101. END_FSM_STATE()
  102. BEGIN_FSM_RULE(CHealthManagerFSM,s0)
  103. FSM_RULE_ENTRY(s0,s4, USER_EVT_WAIT_DEAMON_FINISHED,0)
  104. FSM_RULE_ENTRY(s4,s5,USER_EVT_ACCESSAUTH_FINISHED,1)
  105. FSM_RULE_ENTRY(s4, s5, USER_EVT_VTMLOADER_FINISHED, 1)
  106. FSM_RULE_ENTRY(s4, s5, USER_EVT_VTMLOADER_FINISHED, 2)
  107. FSM_RULE_ENTRY(s4,s6,USER_EVT_MAITAIN,0)
  108. FSM_RULE_ENTRY(s4,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  109. FSM_RULE_ENTRY(s5,s6,USER_EVT_MAITAIN,0)
  110. FSM_RULE_ENTRY(s5,s11,USER_EVT_ENTER_CUSTOMER_MANAGER,0)
  111. FSM_RULE_ENTRY(s5,s4, USER_EVT_ACCESSAUTH_FINISHED, 0)
  112. FSM_RULE_ENTRY(s6,s4,USER_EVT_MAITAIN_FINISHED,4)
  113. FSM_RULE_ENTRY(s6,s5,USER_EVT_MAITAIN_FINISHED,5)
  114. FSM_RULE_ENTRY(s11, s6, USER_EVT_MAITAIN, 0)
  115. FSM_RULE_ENTRY(s11,s4,USER_EVT_SWITCH_BACK_TO_RVC,4)
  116. FSM_RULE_ENTRY(s11,s5,USER_EVT_SWITCH_BACK_TO_RVC,5)
  117. FSM_RULE_ENTRY(s11,s6,USER_EVT_SWITCH_BACK_TO_RVC,6)
  118. END_FSM_RULE()
  119. CHealthManagerFSM() :m_SysState("I"), m_pACClient(NULL)
  120. , m_iAccessAuth(VtmLoad_AccessAuth_Init), m_bHasAuthEver(false)
  121. , m_checkCode(""), m_bFirstAccessAuth(true), m_bRebooting(false)
  122. , m_bIEBeforeHealth(false), m_bInAccessAuthDoWork(false)
  123. , m_bEntityNewStart(true), m_iDoNotUpdateWKDaily(0)
  124. , m_wkUpdatePeriod(1), m_bPinPadOpenSuc(false), m_LoadEntityList(""), m_cpuInfo(""), m_ullAccessAuthCost(0), m_ullSIPPhoneCost(0), m_ullTokenKeeperCost(0)
  125. , m_ullWaitForPinPad(0){}
  126. ~CHealthManagerFSM(){}
  127. virtual ErrorCodeEnum OnInit();
  128. virtual ErrorCodeEnum OnExit();
  129. void s0_on_entry();
  130. void s0_on_exit();
  131. unsigned int s0_on_event(FSMEvent* pEvt);
  132. void s4_on_entry();
  133. void s4_on_exit();
  134. unsigned int s4_on_event(FSMEvent* pEvt);
  135. void s5_on_entry();
  136. void s5_on_exit();
  137. unsigned int s5_on_event(FSMEvent* pEvt);
  138. void s6_on_entry();
  139. void s6_on_exit();
  140. unsigned int s6_on_event(FSMEvent* pEvt);
  141. void s11_on_entry();
  142. void s11_on_exit();
  143. unsigned int s11_on_event(FSMEvent* pEvt);
  144. ErrorCodeEnum Initial();
  145. int AccessAuthDoWork();
  146. void SetVtmLoadResult(int bResult);
  147. bool CheckIfAccessAuthSuc();
  148. int GetFSMState(){return m_fsmState;}
  149. void ToReAccessAuth(bool bEver=false);
  150. //oilyang@20250313 这个函数只有GetNetworkState,用来干嘛?而且在健康lost之后失效
  151. int QueryAccessAuthStatus()
  152. {
  153. if (m_iAccessAuth == VtmLoad_AccessAuth_Suc)
  154. return 0;
  155. else
  156. {
  157. if (m_bHasAuthEver)
  158. return 1;
  159. else
  160. return 2;
  161. }
  162. }
  163. bool QueryHaveAuthEver() { return m_bHasAuthEver; }
  164. void QueryDeviceInfo(std::map<std::string, std::string> &info);
  165. bool IfIEBeforeHealth(){ return m_bIEBeforeHealth; }
  166. int QuitFrameworkAndSaveInfo(RebootTriggerEnum eTrigger, RebootWayEnum eWay = RebootWay_Unknown);
  167. void PostProcessAfterUpgrade();
  168. void ToCallAccessAuthDoWork();
  169. void ToLogWarnTermAboutInfo();
  170. bool IfInUpgradeProcess();
  171. void WaitToCallAccessAuthDoWork();
  172. void WKUpdatePeriod();
  173. CSimpleStringA GetAuthErrMsg();
  174. void QueryHardwareInfo(SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx);
  175. void SetPinPadOpenSuc() { m_bPinPadOpenSuc = true; }
  176. void SetLoadEntityList(CSimpleStringA csEntityList) { m_LoadEntityList = csEntityList; }
  177. void CheckIfPinPadOK();
  178. bool CheckIsRebooting() { return m_bRebooting; }
  179. private:
  180. virtual ErrorCodeEnum AsyncStartEntity(const char *entity_name, const char *cmdline, void *pData);
  181. virtual ErrorCodeEnum AsyncStopEntity(const char *entity_name, void *pData);
  182. virtual ErrorCodeEnum AsyncPauseEntity(const char *entity_name, void *pData);
  183. virtual ErrorCodeEnum AsyncContinueEntity(const char *entity_name, void *pData);
  184. virtual ErrorCodeEnum AsyncTerminateEntity(const char *entity_name, void *pData);
  185. virtual void OnAnswer(CSmartPointer<IAsynWaitSp> pAsynWaitSp);
  186. CSimpleStringA GetOsVersion();
  187. int sumday(int year,int month,int day);//计算天数
  188. bool CheckProcessExistByName(CSimpleStringA procName);
  189. void QueryAndSaveDNS();
  190. void QueryAndSendCPUInfo();
  191. void QueryAndSendDisplayInfo();
  192. string QueryHarddiskInfo();
  193. private:
  194. CSimpleStringA m_SysState, m_checkCode, m_LoadEntityList, m_cpuInfo;
  195. int m_fsmState, m_stateBeforeMaintain, m_preFsmState
  196. ,m_iAccessAuth/*-1 未准入; 0 准入失败;1 准入成功*/, m_iDoNotUpdateWKDaily, m_wkUpdatePeriod/*if exceed the period time,we should update key*/
  197. ,m_maxWaitForPinPad/*ms*/;
  198. AccessAuthService_ClientBase *m_pACClient;
  199. bool m_bHasAuthEver, m_bFirstAccessAuth, m_bIEBeforeHealth, m_bInAccessAuthDoWork, m_bEntityNewStart, m_bPinPadOpenSuc, m_bRebooting;
  200. DWORD m_elapseTimeFromOSStart;
  201. ULONGLONG m_ullElapseFromOSStart, m_ullAuthStart, m_ullAccessAuthCost, m_ullTotalCost, m_ullSIPPhoneCost, m_ullTokenKeeperCost, m_ullWaitForPinPad;
  202. CSystemStaticInfo m_sysInfo;
  203. std::map<string, string> m_computerInfo;
  204. CAutoArray<string> m_dns;
  205. CAutoArray<SP::Module::Net::NetworkAdapterItem> m_netList;
  206. };
  207. struct AccessAuthTask : public ITaskSp
  208. {
  209. CHealthManagerFSM* fsm;
  210. AccessAuthTask(CHealthManagerFSM* f) : fsm(f) {}
  211. void Process()
  212. {
  213. LOG_FUNCTION();
  214. FSMEvent *e = new FSMEvent(USER_EVT_ACCESSAUTH_FINISHED);
  215. e->param1 = fsm->AccessAuthDoWork();
  216. fsm->PostEventFIFO(e);
  217. }
  218. };
  219. struct LogTermInfoTask : public ITaskSp
  220. {
  221. CHealthManagerFSM* fsm;
  222. LogTermInfoTask(CHealthManagerFSM* f) : fsm(f) {}
  223. void Process()
  224. {
  225. fsm->ToLogWarnTermAboutInfo();
  226. }
  227. };
  228. struct WaitToCallAccessAuthTask : public ITaskSp
  229. {
  230. CHealthManagerFSM* fsm;
  231. WaitToCallAccessAuthTask(CHealthManagerFSM* f) : fsm(f) {}
  232. void Process()
  233. {
  234. fsm->WaitToCallAccessAuthDoWork();
  235. }
  236. };
  237. struct WKUpdatePeriodTask : public ITaskSp
  238. {
  239. CHealthManagerFSM* fsm;
  240. WKUpdatePeriodTask(CHealthManagerFSM* f) : fsm(f) {}
  241. void Process()
  242. {
  243. fsm->WKUpdatePeriod();
  244. }
  245. };
  246. struct QueryHardwareInfoTask : public ITaskSp
  247. {
  248. CHealthManagerFSM* fsm;
  249. SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx;
  250. QueryHardwareInfoTask(CHealthManagerFSM* f) : fsm(f) {}
  251. void Process()
  252. {
  253. fsm->QueryHardwareInfo(ctx);
  254. }
  255. };
  256. #endif // __HEALTHMANAGER_FSM_H