HealthManagerFSM.h 10 KB

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