HealthManagerFSM.h 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  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_First_Info_AboutPC = 0x50100213, //健康启动结束后第一次上送计算机信息(主要是确定pad的归属厂商信息)
  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)
  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. //该函数建议废弃
  147. int WaitDeamonFinish();
  148. int AccessAuthDoWork();
  149. void SetVtmLoadResult(int bResult);
  150. bool GetAccessAuthFlag(){return m_iAccessAuth == VtmLoad_AccessAuth_Suc;}
  151. int GetFSMState(){return m_fsmState;}
  152. void ToReAccessAuth(bool bEver=false);
  153. int QueryAccessAuthStatus()
  154. {
  155. if (m_iAccessAuth == VtmLoad_AccessAuth_Suc)
  156. return 0;
  157. else
  158. {
  159. if (m_bHasAuthEver)
  160. return 1;
  161. else
  162. return 2;
  163. }
  164. }
  165. bool QueryHaveAuthEver() { return m_bHasAuthEver; }
  166. void QueryDeviceInfo(std::map<std::string, std::string> &info);
  167. bool IfIEBeforeHealth(){ return m_bIEBeforeHealth; }
  168. int QuitFrameworkAndSaveInfo(RebootTriggerEnum eTrigger, RebootWayEnum eWay = RebootWay_Unknown);
  169. void PostProcessAfterUpgrade();
  170. void ToCallAccessAuthDoWork();
  171. void ToLogWarnTermAboutInfo();
  172. bool IfInUpgradeProcess();
  173. void WaitToCallAccessAuthDoWork();
  174. void WKUpdatePeriod();
  175. CSimpleStringA GetAuthErrMsg();
  176. void QueryHardwareInfo(SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx);
  177. void SetPinPadOpenSuc() { m_bPinPadOpenSuc = true; }
  178. void SetLoadEntityList(CSimpleStringA csEntityList) { m_LoadEntityList = csEntityList; }
  179. void CheckIfPinPadOK();
  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
  202. , m_bIEBeforeHealth, m_bInAccessAuthDoWork, m_bEntityNewStart, m_bPinPadOpenSuc;
  203. DWORD m_elapseTimeFromOSStart;
  204. ULONGLONG m_ullElapseFromOSStart, m_ullAuthStart, m_ullAccessAuthCost, m_ullTotalCost, m_ullSIPPhoneCost, m_ullTokenKeeperCost, m_ullWaitForPinPad;
  205. CSystemStaticInfo m_sysInfo;
  206. std::map<string, string> m_computerInfo;
  207. CAutoArray<string> m_dns;
  208. CAutoArray<SP::Module::Net::NetworkAdapterItem> m_netList;
  209. };
  210. struct WaitDeamonFinishTask : public ITaskSp
  211. {
  212. CHealthManagerFSM* fsm;
  213. WaitDeamonFinishTask(CHealthManagerFSM* f) : fsm(f) {}
  214. void Process()
  215. {
  216. LOG_FUNCTION();
  217. FSMEvent *e = new FSMEvent(USER_EVT_WAIT_DEAMON_FINISHED);
  218. e->param1 = fsm->WaitDeamonFinish();
  219. fsm->PostEventFIFO(e);
  220. }
  221. };
  222. struct AccessAuthTask : public ITaskSp
  223. {
  224. CHealthManagerFSM* fsm;
  225. AccessAuthTask(CHealthManagerFSM* f) : fsm(f) {}
  226. void Process()
  227. {
  228. LOG_FUNCTION();
  229. FSMEvent *e = new FSMEvent(USER_EVT_ACCESSAUTH_FINISHED);
  230. e->param1 = fsm->AccessAuthDoWork();
  231. fsm->PostEventFIFO(e);
  232. }
  233. };
  234. struct LogTermInfoTask : public ITaskSp
  235. {
  236. CHealthManagerFSM* fsm;
  237. LogTermInfoTask(CHealthManagerFSM* f) : fsm(f) {}
  238. void Process()
  239. {
  240. fsm->ToLogWarnTermAboutInfo();
  241. }
  242. };
  243. struct WaitToCallAccessAuthTask : public ITaskSp
  244. {
  245. CHealthManagerFSM* fsm;
  246. WaitToCallAccessAuthTask(CHealthManagerFSM* f) : fsm(f) {}
  247. void Process()
  248. {
  249. fsm->WaitToCallAccessAuthDoWork();
  250. }
  251. };
  252. struct WKUpdatePeriodTask : public ITaskSp
  253. {
  254. CHealthManagerFSM* fsm;
  255. WKUpdatePeriodTask(CHealthManagerFSM* f) : fsm(f) {}
  256. void Process()
  257. {
  258. fsm->WKUpdatePeriod();
  259. }
  260. };
  261. struct QueryHardwareInfoTask : public ITaskSp
  262. {
  263. CHealthManagerFSM* fsm;
  264. SpReqAnsContext<HealthManagerService_QueryHardwareInfo_Req, HealthManagerService_QueryHardwareInfo_Ans>::Pointer ctx;
  265. QueryHardwareInfoTask(CHealthManagerFSM* f) : fsm(f) {}
  266. void Process()
  267. {
  268. fsm->QueryHardwareInfo(ctx);
  269. }
  270. };
  271. #endif // __HEALTHMANAGER_FSM_H