HealthManagerFSM.h 9.5 KB

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