mod_ResourceWatcher.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430
  1. #pragma once
  2. #include "modVer.h"
  3. #include "ResourceWatcherFSM.h"
  4. #include "UOSTools.hpp"
  5. #include "fileutil.h"
  6. #include "UpgradeManager_msg_g.h"
  7. class ResourceWatcherEntity;
  8. #define ENT_TIMERID_CHECK_SOGOU_INPUT_INSTALLED_STATE 1
  9. #define ENT_TIMERINTERVAL_CHECK_SOGOU_INPUT_INSTALLED_STATE 60 * 1000
  10. #define ENT_TIMERID_CHECK_SOGOU_INPUT_PROCESS_STATUS_CHANGE 3
  11. #define ENT_TIMERINTERVAL_CHECK_SOGOU_INPUT_PROCESS_STATUS_CHANGE 30 * 1000
  12. #define ENT_TIMERID_PROCESS_CHECK 66
  13. #define ENT_TIMERINTERVAL_PROCESS_CHECK 60 * 60 * 1000 //进程检测间隔默认一小时
  14. #define ENCODING (X509_ASN_ENCODING | PKCS_7_ASN_ENCODING)
  15. class ResourceWatcherServiceSession : public ResourceWatcherService_ServerSessionBase
  16. {
  17. public:
  18. ResourceWatcherServiceSession(ResourceWatcherEntity* pEntity) : m_pEntity(pEntity) {}
  19. virtual ~ResourceWatcherServiceSession() {}
  20. virtual void Handle_GetDevInfo(SpReqAnsContext<ResourceWatcherService_GetDevInfo_Req,
  21. ResourceWatcherService_GetDevInfo_Ans>::Pointer ctx);
  22. virtual void Handle_OperateFile(SpReqAnsContext<ResourceWatcherService_OperateFile_Req, ResourceWatcherService_OperateFile_Ans>::Pointer ctx);
  23. virtual void Handle_BizLinkDetect(SpReqAnsContext<ResourceWatcherService_BizLinkDetect_Req, ResourceWatcherService_BizLinkDetect_Ans>::Pointer ctx);
  24. virtual void Handle_CheckNetType(SpReqAnsContext<ResourceWatcherService_CheckNetType_Req, ResourceWatcherService_CheckNetType_Ans>::Pointer ctx);
  25. virtual void Handle_GetBizLinks(SpReqAnsContext<ResourceWatcherService_GetBizLinks_Req, ResourceWatcherService_GetBizLinks_Ans>::Pointer ctx);
  26. virtual void Handle_GetThirdPartyInstallState(SpReqAnsContext<ResourceWatcherService_GetThirdPartyInstallState_Req, ResourceWatcherService_GetThirdPartyInstallState_Ans>::Pointer ctx);
  27. virtual void Handle_InstallThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_InstallThirdPartyProgram_Req, ResourceWatcherService_InstallThirdPartyProgram_Ans>::Pointer ctx);
  28. virtual void Handle_UninstallThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_UninstallThirdPartyProgram_Req, ResourceWatcherService_UninstallThirdPartyProgram_Ans>::Pointer ctx);
  29. virtual void Handle_RestartThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_RestartThirdPartyProgram_Req, ResourceWatcherService_RestartThirdPartyProgram_Ans>::Pointer ctx);
  30. virtual void Handle_ProcessDetectThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_ProcessDetectThirdPartyProgram_Req, ResourceWatcherService_ProcessDetectThirdPartyProgram_Ans>::Pointer ctx);
  31. virtual void Handle_FilesClean(SpReqAnsContext<ResourceWatcherService_FilesClean_Req, ResourceWatcherService_FilesClean_Ans>::Pointer ctx);
  32. virtual void Handle_FetchSystemSnapshot(SpReqAnsContext<ResourceWatcherService_FetchSystemSnapshot_Req, ResourceWatcherService_FetchSystemSnapshot_Ans>::Pointer ctx);
  33. private:
  34. ResourceWatcherEntity* m_pEntity;
  35. };
  36. class ResourceWatcherEntity : public CEntityBase, public IBroadcastListener, public ITimerListener, public ISysVarListener
  37. {
  38. public:
  39. ResourceWatcherEntity(){}
  40. virtual ~ResourceWatcherEntity() {}
  41. virtual const char* GetEntityName() const { return "ResourceWatcher"; }
  42. const char* GetEntityVersion() const { return MODULE_VERSION_FULL; }
  43. virtual CServerSessionBase* OnNewSession(const char*, const char*)
  44. {
  45. LOG_FUNCTION();
  46. return new ResourceWatcherServiceSession(this);
  47. }
  48. virtual void OnPreStart(CAutoArray<CSimpleStringA> strArgs,
  49. CSmartPointer<ITransactionContext> pTransactionContext)
  50. {
  51. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Version %s; Complied at: %s %s", MOD_VERSION, __DATE__, __TIME__);
  52. ErrorCodeEnum errorCode = Error_Succeed;
  53. errorCode = m_fsm.Init(this);
  54. if (errorCode == Error_Succeed) {
  55. CSmartPointer<IEntityFunction> spEntityFunction = GetFunction();
  56. CSystemStaticInfo staticInfo;
  57. spEntityFunction->GetSystemStaticInfo(staticInfo);
  58. updateShowFlag = false;
  59. newestSogouInstall = false;
  60. lastUpgradeInstallTime = 0; //上次升级安装时间
  61. lastUpgradeSwitchTime = 0; //上次升级切换时间
  62. lastSogouChangeEndTime = 0; //上一次切换结束判定的时间
  63. lastSogouChangeWarn = ""; //上一次搜狗告警信息
  64. sogouProcessRun = 0; //搜狗进程是否启动
  65. errorCode = spEntityFunction->SubscribeBroadcast("UpgradeManager", NULL, this, m_uuidUpgradeStateEventListener);
  66. if (errorCode != Error_Succeed)
  67. {
  68. LOG_TRACE("Subscribe UpgradeManager evt failed 0x%x", errorCode);
  69. pTransactionContext->SendAnswer(errorCode);
  70. return;
  71. }
  72. }
  73. pTransactionContext->SendAnswer(errorCode);
  74. }
  75. void OnStarted()
  76. {
  77. m_fsm.AfterInit();
  78. CSmartPointer<IEntityFunction> spEntityFunction = GetFunction();
  79. spEntityFunction->SetTimer(ENT_TIMERID_CHECK_SOGOU_INPUT_INSTALLED_STATE,
  80. this, ENT_TIMERINTERVAL_CHECK_SOGOU_INPUT_INSTALLED_STATE);
  81. CSimpleStringA uiState;
  82. spEntityFunction->GetSysVar("UIState", uiState);
  83. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("NETWORK_PROBE Timer GetUIState %s", (LPCTSTR)uiState);
  84. if (uiState[0] == 'M') {
  85. m_fsm.TriggerAtStatusChanged(true);
  86. }
  87. spEntityFunction->RegistSysVarEvent("UIState", this);
  88. CSmartPointer<IConfigInfo> spCtSettingConfig;
  89. GetFunction()->OpenConfig(Config_CenterSetting, spCtSettingConfig);
  90. int procFlag = 0;
  91. int closeSecCheck = 0;
  92. #if defined(RVC_OS_WIN)
  93. spCtSettingConfig->ReadConfigValueInt("ResourceWatcher", "ProcDetectFlag", procFlag);
  94. #else
  95. spCtSettingConfig->ReadConfigValueInt("ResourceWatcher", "ProcDetectFlag4UOS", procFlag);
  96. #endif //RVC_OS_WIN
  97. if (procFlag > 0)
  98. {
  99. CheckProcessStatus(); //启动时检测一次进程
  100. spCtSettingConfig->ReadConfigValueInt("ResourceWatcher", "CloseSecProcDetect", closeSecCheck);
  101. if (!closeSecCheck)
  102. {
  103. SecProcCheck(); //检测一次安全软件
  104. }
  105. int tTime = 0;
  106. spCtSettingConfig->ReadConfigValueInt("ResourceWatcher", "ProcCheckTime", tTime);
  107. if (tTime >= 0)
  108. {
  109. if (tTime == 0) tTime = ENT_TIMERINTERVAL_PROCESS_CHECK; //没设置时间的话默认一小时间隔
  110. spEntityFunction->SetTimer(ENT_TIMERID_PROCESS_CHECK, this, tTime);
  111. }
  112. else
  113. {
  114. DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Invalid proccess check time:%d", tTime);
  115. }
  116. }
  117. #if defined(RVC_OS_WIN)
  118. ReadFileContent();
  119. ReadFileInfo();
  120. #endif //RVC_OS_WIN
  121. }
  122. /*ignore*/
  123. virtual void OnPrePause(CSmartPointer<ITransactionContext> pTransactionContext)
  124. {
  125. OnTimeout(ENT_TIMERID_CHECK_SOGOU_INPUT_INSTALLED_STATE);
  126. pTransactionContext->SendAnswer(Error_Succeed);
  127. }
  128. /*ignore*/
  129. virtual void OnPreContinue(CSmartPointer<ITransactionContext> pTransactionContext)
  130. {
  131. pTransactionContext->SendAnswer(Error_Succeed);
  132. }
  133. /*invoke fsm.onExit(), invoked when entity will be closed*/
  134. virtual void OnPreClose(EntityCloseCauseEnum eCloseCause, CSmartPointer<ITransactionContext>pTransactionContext)
  135. {
  136. ErrorCodeEnum errorCode = m_fsm.OnExit();
  137. pTransactionContext->SendAnswer(errorCode);
  138. }
  139. virtual void OnSelfTest(EntityTestEnum eTestType,
  140. CSmartPointer<ITransactionContext>pTransactionContext)
  141. {
  142. m_fsm.SelfTest(eTestType, pTransactionContext);
  143. }
  144. virtual bool IsService() const
  145. {
  146. return true;
  147. }
  148. virtual bool IsMultiThread() const
  149. {
  150. return false;
  151. }
  152. void GetDevInfo(SpReqAnsContext<ResourceWatcherService_GetDevInfo_Req,
  153. ResourceWatcherService_GetDevInfo_Ans>::Pointer ctx)
  154. {
  155. LOG_FUNCTION();
  156. SystemBasicInfo info;
  157. ErrorCodeEnum result = m_fsm.CatchSystemBasicInfo(info);
  158. if (Error_Succeed == result) {
  159. ctx->Ans.type = info.strProductName;
  160. ctx->Ans.model = info.strManufacturer;
  161. ctx->Ans.version = info.strSerialNumber;
  162. ctx->Ans.state = 0;
  163. }
  164. ctx->Answer(result);
  165. }
  166. void BizLinkDetect(SpReqAnsContext<ResourceWatcherService_BizLinkDetect_Req,
  167. ResourceWatcherService_BizLinkDetect_Ans>::Pointer ctx)
  168. {
  169. m_fsm.BizLinkDetect(ctx);
  170. }
  171. void CheckNetType(SpReqAnsContext<ResourceWatcherService_CheckNetType_Req,
  172. ResourceWatcherService_CheckNetType_Ans>::Pointer ctx)
  173. {
  174. m_fsm.CheckNetType(ctx);
  175. }
  176. void GetBizLinks(SpReqAnsContext<ResourceWatcherService_GetBizLinks_Req,
  177. ResourceWatcherService_GetBizLinks_Ans>::Pointer ctx)
  178. {
  179. m_fsm.GetBizLinks(ctx);
  180. }
  181. void OperateFile(
  182. SpReqAnsContext<ResourceWatcherService_OperateFile_Req,
  183. ResourceWatcherService_OperateFile_Ans>::Pointer ctx)
  184. {
  185. ctx->Answer(Error_NotSupport);
  186. }
  187. void GetThirdPartyInstallState(SpReqAnsContext<ResourceWatcherService_GetThirdPartyInstallState_Req,
  188. ResourceWatcherService_GetThirdPartyInstallState_Ans>::Pointer ctx);
  189. void InstallThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_InstallThirdPartyProgram_Req,
  190. ResourceWatcherService_InstallThirdPartyProgram_Ans>::Pointer ctx);
  191. void UninstallThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_UninstallThirdPartyProgram_Req,
  192. ResourceWatcherService_UninstallThirdPartyProgram_Ans>::Pointer ctx);
  193. void RestartThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_RestartThirdPartyProgram_Req,
  194. ResourceWatcherService_RestartThirdPartyProgram_Ans>::Pointer ctx);
  195. void ProcessDetectThirdPartyProgram(SpReqAnsContext<ResourceWatcherService_ProcessDetectThirdPartyProgram_Req,
  196. ResourceWatcherService_ProcessDetectThirdPartyProgram_Ans>::Pointer ctx);
  197. void FilesClean(SpReqAnsContext<ResourceWatcherService_FilesClean_Req,
  198. ResourceWatcherService_FilesClean_Ans>::Pointer ctx);
  199. void FetchSystemSnapshot(SpReqAnsContext<ResourceWatcherService_FetchSystemSnapshot_Req, ResourceWatcherService_FetchSystemSnapshot_Ans>::Pointer ctx);
  200. void InstallSogou(SpReqAnsContext<ResourceWatcherService_InstallThirdPartyProgram_Req,
  201. ResourceWatcherService_InstallThirdPartyProgram_Ans>::Pointer ctx);
  202. void UninstallSogou(SpReqAnsContext<ResourceWatcherService_UninstallThirdPartyProgram_Req,
  203. ResourceWatcherService_UninstallThirdPartyProgram_Ans>::Pointer ctx);
  204. #if defined(_MSC_VER)
  205. SP_BEGIN_MSG_DISPATCH_MAP(ResourceWatcherEntity)
  206. SP_BEGIN_ENTITY_MSG("UpgradeManager")
  207. SP_MSG_HANDLE_NS(UpgradeManager, UpgradeStateEvent, OnUpgradeStateEvent)
  208. SP_END_ENTITY_MSG()
  209. SP_END_MSG_DISPATCH_MAP()
  210. #else
  211. virtual void OnBroadcastEvent(CUUID SubID, const char* pszEntityName, DWORD dwMessageId, DWORD dwMessageSignature, CAutoBuffer Buffer) \
  212. {
  213. if (!pszEntityName) {
  214. LOG_TRACE("pszEntityName cannot empty!");
  215. }
  216. else if (_stricmp("UpgradeManager", pszEntityName) == 0) {
  217. switch (dwMessageId) {
  218. case eMsg_UpgradeStateEvent:
  219. if (eMsgSig_UpgradeStateEvent == dwMessageSignature) {
  220. UpgradeManager::UpgradeStateEvent t;
  221. ErrorCodeEnum Error = SpBuffer2Object(Buffer, t);
  222. if (Error == Error_Succeed)
  223. OnUpgradeStateEvent(pszEntityName, dwMessageId, dwMessageSignature, t);
  224. }
  225. else {
  226. LOG_TRACE("%s signature mismatched!", "UpgradeStateEvent");
  227. }
  228. break;
  229. default:
  230. LOG_TRACE("msg id %d ignored!", dwMessageId);
  231. break;
  232. }
  233. }
  234. else {
  235. LOG_TRACE("ignore pszEntityName");
  236. }
  237. }
  238. #endif //_MSC_VER
  239. void OnSysVarEvent(const char* pszKey, const char* pszValue, const char* pszOldValue, const char* pszEntityName)
  240. {
  241. if ((_strnicmp(pszKey, "UIState", strlen("UIState")) == 0)) {
  242. m_fsm.TriggerAtStatusChanged(_strnicmp(pszValue, "M", strlen("M")) == 0);
  243. }
  244. }
  245. private:
  246. void OnUpgradeStateEvent(const char* pszEntityName, DWORD dwMessageId, DWORD dwMessageSignature, UpgradeManager::UpgradeStateEvent& evt);
  247. //report sogou input software install state and installed information
  248. ErrorCodeEnum ReportSogouInstallState();
  249. void OnTimeout(DWORD dwTimerID)
  250. {
  251. if (dwTimerID == ENT_TIMERID_CHECK_SOGOU_INPUT_INSTALLED_STATE) {
  252. CSimpleStringA strState;
  253. auto err = GetFunction()->GetSysVar("UIState", strState);
  254. if (err == Error_Succeed && strState == "M") {
  255. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("to check Sogou input install state...");
  256. if (Error_Succeed == ReportSogouInstallState()) {//如果安装了搜狗输入法,就去除检测搜狗输入法安装的定时器,并设置进程检测的定时器。
  257. GetFunction()->KillTimer(ENT_TIMERID_CHECK_SOGOU_INPUT_INSTALLED_STATE);
  258. GetFunction()->SetTimer(ENT_TIMERID_CHECK_SOGOU_INPUT_PROCESS_STATUS_CHANGE,
  259. this, ENT_TIMERINTERVAL_CHECK_SOGOU_INPUT_PROCESS_STATUS_CHANGE);
  260. ///**TODO(Gifur@10/9/2023): 等普通调用版本的输入法全行推广后,这块很多功能逻辑可以下线了 */
  261. #if defined(_MSC_VER)
  262. //进入主页面后,检测安装状态,安装成功则执行一次启动脚本
  263. ///**TODO(Gifur@10/9/2023): 这段逻辑有点奇怪,上面的接口并不是安装输入法的功能,只是检测输入法的状态,这里每次都运行一次启动逻辑??*/
  264. //答:这段定时器在检测到安装了输入法之后就只会执行一次,定时器被KILL掉了,之后只会检测搜狗进程的变化
  265. CSimpleStringA csBinPath;
  266. ErrorCodeEnum eErrPath = GetFunction()->GetPath("Bin", csBinPath);
  267. if (eErrPath != Error_Succeed) {
  268. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("GetBasePath failed.");
  269. }
  270. else {
  271. CSimpleStringA startPath = csBinPath + SPLIT_SLASH_STR + "spScript" + SPLIT_SLASH_STR + "SogouServStarter.bat";
  272. int startFlag = WinExec(startPath.GetData(), SW_HIDE);
  273. if (startFlag > 31) {
  274. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("检测到已安装搜狗输入法,执行搜狗启动脚本!路径:%s。", startPath.GetData());
  275. }
  276. else {
  277. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("执行启动脚本异常!路径:%s。", startPath.GetData());
  278. }
  279. }
  280. #endif //_MSC_VER
  281. }
  282. }
  283. else {
  284. DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Get UIState result: %s, %s", SpStrError(err), strState.GetData());
  285. }
  286. }
  287. else if (dwTimerID == ENT_TIMERID_CHECK_SOGOU_INPUT_PROCESS_STATUS_CHANGE) {
  288. DoCheckSogouProcessStatus();
  289. }
  290. else if (dwTimerID == ENT_TIMERID_PROCESS_CHECK) {
  291. CheckProcessStatus();
  292. }
  293. else {
  294. DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("Unkonwn timer id: %u", dwTimerID);
  295. }
  296. }
  297. void DoCheckSogouProcessStatus();
  298. std::string DoCheckCertainProcessStatus(const CAutoArray<CSimpleStringA>& pName);
  299. void SecProcCheck(); //检测终端安全软件应用
  300. ErrorCodeEnum UnzipPack(const char* unZipPackName);//解压文件
  301. CSimpleStringA GetFilePathWithDir(CSimpleStringA dir, CSimpleStringA fileName);
  302. std::vector<std::string> GetUserNameList(bool bExcludeRoot = false);
  303. ErrorCodeEnum RunShellScript(LPCTSTR cmdline);
  304. ErrorCodeEnum DeleteUnzipDir();//清理临时解压包文件
  305. BOOL KillProcessFromName(const CSimpleStringA& strProcessName);
  306. bool is_str_utf8(const char* str);
  307. /// <summary>
  308. /// 通过集中配置检测指定进程是否存在
  309. /// </summary>
  310. void CheckProcessStatus();
  311. #if defined(RVC_OS_WIN)
  312. void ReadFileContent();
  313. void ReadFileInfo();
  314. void ChcekDiskFileSpace();
  315. #else
  316. ErrorCodeEnum GetSogouPkgDirPath(CSimpleStringA& strPkgPath);
  317. #endif //RVC_OS_WIN
  318. private:
  319. ResourceWatcherFSM m_fsm;
  320. CUUID m_uuidUpgradeStateEventListener;
  321. BOOL updateShowFlag;
  322. BOOL newestSogouInstall; //最近一次安装的标志
  323. time_t lastUpgradeInstallTime; //上次升级安装时间
  324. time_t lastUpgradeSwitchTime; //上次升级切换时间
  325. time_t lastSogouChangeEndTime; //上一次进程切换时间
  326. CSimpleStringA lastSogouChangeWarn; //上一次搜狗告警信息
  327. BOOL isSogouUpdateChange;
  328. int sogouProcessRun;
  329. vector<CSimpleStringA> sogouChangeWarn;
  330. vector<time_t> sogouChangeTime;
  331. };
  332. struct InstallSogouTask : public ITaskSp
  333. {
  334. SpReqAnsContext<ResourceWatcherService_InstallThirdPartyProgram_Req,
  335. ResourceWatcherService_InstallThirdPartyProgram_Ans>::Pointer ctx;
  336. ResourceWatcherEntity* m_pEntity;
  337. InstallSogouTask(ResourceWatcherEntity* entity) :m_pEntity(entity) {}
  338. void Process()
  339. {
  340. m_pEntity->InstallSogou(ctx);
  341. }
  342. };
  343. struct UninstallSogouTask : public ITaskSp
  344. {
  345. SpReqAnsContext<ResourceWatcherService_UninstallThirdPartyProgram_Req,
  346. ResourceWatcherService_UninstallThirdPartyProgram_Ans>::Pointer ctx;
  347. ResourceWatcherEntity* m_pEntity;
  348. UninstallSogouTask(ResourceWatcherEntity* entity) :m_pEntity(entity) {}
  349. void Process()
  350. {
  351. m_pEntity->UninstallSogou(ctx);
  352. }
  353. };