@jshookmcp/jshook 0.2.9 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (316) hide show
  1. package/README.md +25 -50
  2. package/README.zh.md +25 -48
  3. package/dist/AntiCheatDetector-CGVGNfy5.mjs +1 -0
  4. package/dist/CacheAdapters-CdAxBmVW.mjs +1 -0
  5. package/dist/CodeInjector-BlgyqTOk.mjs +1 -0
  6. package/dist/ConsoleMonitor-Dkqc0HNi.mjs +490 -0
  7. package/dist/DOMInspector-BYY_EJ0C.mjs +95 -0
  8. package/dist/DarwinAPI-DC4HGGLl.mjs +1 -0
  9. package/dist/DetailedDataManager-BniBJlVv.mjs +1 -0
  10. package/dist/EventBus-DgciURGg.mjs +1 -0
  11. package/dist/EvidenceGraphBridge-BIfgB7HP.mjs +1 -0
  12. package/dist/ExtensionManager-erMpqcLk.mjs +1 -0
  13. package/dist/FingerprintManager-N7BZqjxP.mjs +1 -0
  14. package/dist/HardwareBreakpoint-OcJqNFVc.mjs +1 -0
  15. package/dist/HeapAnalyzer-CqAxZzeS.mjs +1 -0
  16. package/dist/{HookGeneratorBuilders.core.generators.storage-CtcdK78Q.mjs → HookGeneratorBuilders.core.generators.storage-Bf1fbrNK.mjs} +66 -174
  17. package/dist/InstrumentationSession-DxXs0sCp.mjs +1 -0
  18. package/dist/MCPServer.search.handlers.domain-DVbWL1bT.mjs +1 -0
  19. package/dist/MemoryController-BaqstM5w.mjs +2 -0
  20. package/dist/MemoryScanSession-CaxAjZJf.mjs +1 -0
  21. package/dist/MemoryScanner-BLYnMJy6.mjs +1 -0
  22. package/dist/NativeMemoryManager.impl-CI554XbY.mjs +1 -0
  23. package/dist/NativeMemoryManager.utils-DM4NC3FE.mjs +1 -0
  24. package/dist/PEAnalyzer-DJyaJTQJ.mjs +1 -0
  25. package/dist/PageController-D9jVkH0i.mjs +1 -0
  26. package/dist/PointerChainEngine-5nF9eNlu.mjs +1 -0
  27. package/dist/PrerequisiteError-Bl3dK8XA.mjs +1 -0
  28. package/dist/ProcessRegistry-Hf12LlR9.mjs +1 -0
  29. package/dist/ResponseBuilder-B2lu4KEl.mjs +1 -0
  30. package/dist/ReverseEvidenceGraph-B931HeoW.mjs +2 -0
  31. package/dist/ScriptManager-fgqiALgj.mjs +7 -0
  32. package/dist/Speedhack-l6s8L2Qw.mjs +1 -0
  33. package/dist/StealthVerifier-Dhbj4B4P.mjs +1 -0
  34. package/dist/StructureAnalyzer-A-WamfYE.mjs +2 -0
  35. package/dist/ToolCatalog-D_IKl1Hu.mjs +1 -0
  36. package/dist/ToolError-DWU_z7gp.mjs +1 -0
  37. package/dist/ToolProbe-xsfALmN3.mjs +1 -0
  38. package/dist/ToolRegistry-B0Zs-phN.mjs +1 -0
  39. package/dist/ToolRouter.policy-CFHoN_Lw.mjs +4 -0
  40. package/dist/TraceRecorder-Dd8jLXpi.mjs +272 -0
  41. package/dist/VersionDetector-DMoUWyNm.mjs +9 -0
  42. package/dist/Win32API-Bhi5xFBe.mjs +1 -0
  43. package/dist/Win32Debug-CQteFL4F.mjs +1 -0
  44. package/dist/WorkflowEngine-CxEp2WXH.mjs +1 -0
  45. package/dist/analysis-BuR-NgX8.mjs +5 -0
  46. package/dist/{antidebug-CqDTB_uk.mjs → antidebug-BOTZH6-0.mjs} +8 -259
  47. package/dist/artifactRetention-NBdncOEW.mjs +1 -0
  48. package/dist/artifacts-B5xQuEa_.mjs +1 -0
  49. package/dist/authorization-schema-B40obG1A.mjs +1 -0
  50. package/dist/betterSqlite3-CGaxz4AX.mjs +1 -0
  51. package/dist/binary-instrument-Cf9qqLlM.mjs +7 -0
  52. package/dist/bind-helpers-BlAOQrFQ.mjs +1 -0
  53. package/dist/boringssl-inspector-BST5vtKx.mjs +2 -0
  54. package/dist/browser-C4Le3xqA.mjs +11 -0
  55. package/dist/capabilities-DbYCv-HF.mjs +1 -0
  56. package/dist/chunk-C_pMuVsO.mjs +1 -0
  57. package/dist/collector-CKO8RPK8.mjs +1 -0
  58. package/dist/concurrency-CcK46d0h.mjs +1 -0
  59. package/dist/constants-Cp6hBrrx.mjs +1 -0
  60. package/dist/coordination-BbijHEHH.mjs +1 -0
  61. package/dist/debugger-CRJq_krh.mjs +1 -0
  62. package/dist/definitions-BGobEDQa.mjs +1 -0
  63. package/dist/definitions-BGwNSkVm.mjs +1 -0
  64. package/dist/definitions-BbxOUiP-.mjs +1 -0
  65. package/dist/definitions-CCP9gphV.mjs +1 -0
  66. package/dist/definitions-CIO9O-Sw.mjs +1 -0
  67. package/dist/definitions-CYFbewnd.mjs +1 -0
  68. package/dist/definitions-CdWEuIkI.mjs +1 -0
  69. package/dist/definitions-CoQFbggH.mjs +1 -0
  70. package/dist/definitions-CuJRsJ6N.mjs +1 -0
  71. package/dist/definitions-DI9YXsJk.mjs +1 -0
  72. package/dist/definitions-DJklW2sS.mjs +1 -0
  73. package/dist/definitions-DZ8uKusP.mjs +1 -0
  74. package/dist/definitions-Dds_zrWx.mjs +1 -0
  75. package/dist/definitions-Dgrg7f3D.mjs +1 -0
  76. package/dist/definitions-DtE0XLrT.mjs +1 -0
  77. package/dist/definitions-LaYTuwQd.mjs +26 -0
  78. package/dist/definitions-NoVp_9Pm.mjs +1 -0
  79. package/dist/definitions-OvGsfxdt.mjs +1 -0
  80. package/dist/definitions-jXPaVy4P.mjs +1 -0
  81. package/dist/encoding-DGcr6Aj_.mjs +2 -0
  82. package/dist/ensure-browser-core-Buls24LQ.mjs +1 -0
  83. package/dist/evidence-graph-bridge-B0yhGPcs.mjs +1 -0
  84. package/dist/factory-Cx_1LorX.mjs +1 -0
  85. package/dist/flat-target-session-CO5g78k3.mjs +1 -0
  86. package/dist/formatAddress-C7j2fDlM.mjs +1 -0
  87. package/dist/graphql-HLf3MS8H.mjs +62 -0
  88. package/dist/handlers-BLMa4X7l.mjs +54 -0
  89. package/dist/handlers-BP12ZsWc.mjs +4 -0
  90. package/dist/handlers-BZoPla6E.mjs +1 -0
  91. package/dist/handlers-BggKiVx9.mjs +2 -0
  92. package/dist/handlers-D3iev8g1.mjs +1 -0
  93. package/dist/handlers-D49r1-1P.mjs +1 -0
  94. package/dist/handlers-DCE45Ww8.mjs +2 -0
  95. package/dist/handlers-DW5AbYs5.mjs +5 -0
  96. package/dist/handlers-De5u62Ga2.mjs +1 -0
  97. package/dist/handlers-DmQzIc44.mjs +31 -0
  98. package/dist/handlers-DnJRGp7t.mjs +302 -0
  99. package/dist/handlers-Dv_runVv.mjs +2 -0
  100. package/dist/handlers-S9Ws0IGy.mjs +2 -0
  101. package/dist/{handlers-Bl8zkwz1.mjs → handlers-pVNpaw4A.mjs} +144 -841
  102. package/dist/handlers.impl-CD2_kOcC.mjs +1 -0
  103. package/dist/hooks-DDKppogd.mjs +600 -0
  104. package/dist/index.mjs +12 -5225
  105. package/dist/logger-sBC6IdRT.mjs +1 -0
  106. package/dist/maintenance-CutEO84j.mjs +1 -0
  107. package/dist/manifest-BFGxlDRh.mjs +123 -0
  108. package/dist/manifest-BPuE6oH2.mjs +1 -0
  109. package/dist/manifest-BXry5N09.mjs +1 -0
  110. package/dist/manifest-BeP_zJGb2.mjs +1 -0
  111. package/dist/manifest-C0g67k6U.mjs +1 -0
  112. package/dist/manifest-C1nZkTkO.mjs +1 -0
  113. package/dist/manifest-C7qV1z7F.mjs +1 -0
  114. package/dist/manifest-CDeUZGUZ.mjs +1 -0
  115. package/dist/manifest-CDiCtaQT.mjs +1 -0
  116. package/dist/manifest-CFn0359q2.mjs +1 -0
  117. package/dist/manifest-CGq4NpqH2.mjs +1 -0
  118. package/dist/manifest-CJMGt7Qy.mjs +1 -0
  119. package/dist/manifest-CRIJq4Hs.mjs +1 -0
  120. package/dist/manifest-C_hEIjSx.mjs +1 -0
  121. package/dist/manifest-CeQmtQOY.mjs +1 -0
  122. package/dist/manifest-Cq0j7GZt.mjs +1 -0
  123. package/dist/manifest-CtPmHAdn.mjs +1 -0
  124. package/dist/manifest-Cx2IVMUY.mjs +1 -0
  125. package/dist/manifest-D16xPXro.mjs +1 -0
  126. package/dist/manifest-D44TaRJU.mjs +1 -0
  127. package/dist/manifest-D610kxZr.mjs +2 -0
  128. package/dist/manifest-DC-SMF6b.mjs +1 -0
  129. package/dist/manifest-DD3rtxvV.mjs +1 -0
  130. package/dist/manifest-DKUorv5M.mjs +1 -0
  131. package/dist/manifest-DMJlcsTR.mjs +1 -0
  132. package/dist/manifest-DWUUWBz0.mjs +1 -0
  133. package/dist/manifest-De-6Wf2R.mjs +1 -0
  134. package/dist/manifest-Dgh0uDW-.mjs +1 -0
  135. package/dist/manifest-Dm0o3i2U.mjs +1 -0
  136. package/dist/manifest-DsVh7Y4U.mjs +1 -0
  137. package/dist/manifest-DtEFSRaq.mjs +1 -0
  138. package/dist/manifest-H-EpAyZQ.mjs +1 -0
  139. package/dist/manifest-ais9Afrw.mjs +1 -0
  140. package/dist/manifest-tmb54wmA.mjs +1 -0
  141. package/dist/manifest-yu2xiQqe.mjs +1 -0
  142. package/dist/manifest-zrbrpKCC.mjs +1 -0
  143. package/dist/matchesWildcardPattern-BGqLSmEs.mjs +1 -0
  144. package/dist/modules-p-PUNv9r.mjs +332 -0
  145. package/dist/mojo-ipc-VGlv3Qyp.mjs +9 -0
  146. package/dist/network-BjZ1Y-GB.mjs +7 -0
  147. package/dist/outputPaths-BonGThuc.mjs +2 -0
  148. package/dist/parse-args-Cuk7-xUt.mjs +1 -0
  149. package/dist/platform-C446Lf97.mjs +93 -0
  150. package/dist/playwright-cdp-fallback-BwVR-_T3.mjs +1 -0
  151. package/dist/process-C9f2A5zk.mjs +962 -0
  152. package/dist/proxy-CvRepxgV.mjs +1 -0
  153. package/dist/registry-DUHIPE-v.mjs +1 -0
  154. package/dist/response-C7rKQst4.mjs +1 -0
  155. package/dist/search-defaults-D2bY-rzH.mjs +1 -0
  156. package/dist/server/plugin-api.mjs +1 -293
  157. package/dist/shared-state-board-Cyg-xh_k.mjs +1 -0
  158. package/dist/sourcemap-D6Q1UuAp.mjs +1 -0
  159. package/dist/ssrf-policy-T96MR3r6.mjs +1 -0
  160. package/dist/streaming-CTX58tbb.mjs +1 -0
  161. package/dist/tool-builder-CI9914Tf.mjs +1 -0
  162. package/dist/transform-Cv9P2vVD.mjs +103 -0
  163. package/dist/types-CuyefmGT.mjs +1 -0
  164. package/dist/types-DtThH00r.mjs +1 -0
  165. package/dist/wasm-DaJa8J0V.mjs +174 -0
  166. package/dist/webcrack-CsLLJIs9.mjs +46 -0
  167. package/dist/workflow-CYIXtrWD.mjs +101 -0
  168. package/package.json +12 -7
  169. package/dist/AntiCheatDetector-BNk-EoBt.mjs +0 -244
  170. package/dist/CacheAdapters-CDe5WPSV.mjs +0 -80
  171. package/dist/CodeInjector-Cq8q01kp.mjs +0 -150
  172. package/dist/ConsoleMonitor-CPVQW1Y-.mjs +0 -2201
  173. package/dist/DarwinAPI-BNPxu0RH.mjs +0 -363
  174. package/dist/DetailedDataManager-BQQcxh64.mjs +0 -217
  175. package/dist/EventBus-DgPmwpeu.mjs +0 -141
  176. package/dist/EvidenceGraphBridge-SFesNera.mjs +0 -153
  177. package/dist/ExtensionManager-CWYgw0YW.mjs +0 -714
  178. package/dist/FingerprintManager-gzWtkKuf.mjs +0 -96
  179. package/dist/HardwareBreakpoint-B9gZCdFP.mjs +0 -239
  180. package/dist/HeapAnalyzer-BLDH0dCv.mjs +0 -284
  181. package/dist/InstrumentationSession-CvPC7Jwy.mjs +0 -244
  182. package/dist/MemoryController-CbVdCIJF.mjs +0 -167
  183. package/dist/MemoryScanSession-BsDZbLYm.mjs +0 -278
  184. package/dist/MemoryScanner-Bcpml6II.mjs +0 -425
  185. package/dist/NativeMemoryManager.impl-dZtA1ZGn.mjs +0 -482
  186. package/dist/NativeMemoryManager.utils-B-FjA2mJ.mjs +0 -165
  187. package/dist/PEAnalyzer-D1lzJ_VG.mjs +0 -385
  188. package/dist/PageController-Bqm2kZ_X.mjs +0 -417
  189. package/dist/PointerChainEngine-BOhyVsjx.mjs +0 -322
  190. package/dist/PrerequisiteError-Dl33Svkz.mjs +0 -20
  191. package/dist/ResponseBuilder-D3iFYx2N.mjs +0 -143
  192. package/dist/ReverseEvidenceGraph-Dlsk94LC.mjs +0 -269
  193. package/dist/ScriptManager-aHHq0X7U.mjs +0 -3000
  194. package/dist/Speedhack-CqdIFlQl.mjs +0 -156
  195. package/dist/StealthVerifier-Bo4T3bz8.mjs +0 -135
  196. package/dist/StructureAnalyzer-DhFaPvRO.mjs +0 -426
  197. package/dist/ToolCatalog-C0JGZoOm.mjs +0 -582
  198. package/dist/ToolError-jh9whhMd.mjs +0 -15
  199. package/dist/ToolProbe-oC7aPrkv.mjs +0 -45
  200. package/dist/ToolRegistry-BjaF4oNz.mjs +0 -131
  201. package/dist/ToolRouter.policy-BWV67ZK-.mjs +0 -304
  202. package/dist/TraceRecorder-DgxyVbdQ.mjs +0 -519
  203. package/dist/VersionDetector-CwVLVdDM.mjs +0 -104
  204. package/dist/Win32API-CePkipZY.mjs +0 -340
  205. package/dist/Win32Debug-BvKs-gxc.mjs +0 -274
  206. package/dist/WorkflowEngine-CuvkZtWu.mjs +0 -598
  207. package/dist/analysis-CL9uACt9.mjs +0 -463
  208. package/dist/artifactRetention-CFEprwPw.mjs +0 -591
  209. package/dist/artifacts-Bk2-_uPq.mjs +0 -59
  210. package/dist/betterSqlite3-0pqusHHH.mjs +0 -74
  211. package/dist/binary-instrument-CXfpx6fT.mjs +0 -979
  212. package/dist/bind-helpers-xFfRF-qm.mjs +0 -22
  213. package/dist/boringssl-inspector-BH2D3VKc.mjs +0 -180
  214. package/dist/browser-BpOr5PEx.mjs +0 -4082
  215. package/dist/chunk-CjcI7cDX.mjs +0 -15
  216. package/dist/concurrency-Bt0yv1kJ.mjs +0 -41
  217. package/dist/constants-B0OANIBL.mjs +0 -519
  218. package/dist/coordination-qUbyF8KU.mjs +0 -259
  219. package/dist/debugger-gnKxRSN0.mjs +0 -1271
  220. package/dist/definitions-6M-eejaT.mjs +0 -53
  221. package/dist/definitions-B18eyf0B.mjs +0 -18
  222. package/dist/definitions-B3QdlrHv.mjs +0 -34
  223. package/dist/definitions-B4rAvHNZ.mjs +0 -63
  224. package/dist/definitions-BB_4jnmy.mjs +0 -37
  225. package/dist/definitions-BMfYXoNC.mjs +0 -43
  226. package/dist/definitions-Beid2EB3.mjs +0 -27
  227. package/dist/definitions-C1UvM5Iy.mjs +0 -126
  228. package/dist/definitions-CXEI7QC72.mjs +0 -216
  229. package/dist/definitions-C_4r7Fo-2.mjs +0 -14
  230. package/dist/definitions-CkFDALoa.mjs +0 -26
  231. package/dist/definitions-Cke7zEb8.mjs +0 -94
  232. package/dist/definitions-ClJLzsJQ.mjs +0 -25
  233. package/dist/definitions-Cq-zroAU.mjs +0 -28
  234. package/dist/definitions-Cy3Sl6gV.mjs +0 -34
  235. package/dist/definitions-D3VsGcvz.mjs +0 -47
  236. package/dist/definitions-DVGfrn7y.mjs +0 -96
  237. package/dist/definitions-LKpC3-nL.mjs +0 -9
  238. package/dist/definitions-bAhHQJq9.mjs +0 -359
  239. package/dist/encoding-Bvz5jLRv.mjs +0 -1065
  240. package/dist/evidence-graph-bridge-C_fv9PuC.mjs +0 -135
  241. package/dist/factory-DxlGh9Xf.mjs +0 -575
  242. package/dist/formatAddress-DVkj9kpI.mjs +0 -17
  243. package/dist/graphql-DYWzJ29s.mjs +0 -1026
  244. package/dist/handlers-9sAbfIg-.mjs +0 -2552
  245. package/dist/handlers-C67ktuRN.mjs +0 -710
  246. package/dist/handlers-C87g8oCe.mjs +0 -276
  247. package/dist/handlers-CTsDAO6p.mjs +0 -681
  248. package/dist/handlers-Cgyg6c0U.mjs +0 -645
  249. package/dist/handlers-D6j6yka7.mjs +0 -2124
  250. package/dist/handlers-DdFzXLvF.mjs +0 -446
  251. package/dist/handlers-DeLOCd5m.mjs +0 -799
  252. package/dist/handlers-DlCJN4Td.mjs +0 -757
  253. package/dist/handlers-DxGIq15_2.mjs +0 -917
  254. package/dist/handlers-U6L4xhuF.mjs +0 -585
  255. package/dist/handlers-tB9Mp9ZK.mjs +0 -84
  256. package/dist/handlers-tiy7EIBp.mjs +0 -572
  257. package/dist/handlers.impl-DS0d9fUw.mjs +0 -761
  258. package/dist/hooks-CzCWByww.mjs +0 -898
  259. package/dist/logger-Dh_xb7_2.mjs +0 -93
  260. package/dist/maintenance-P7ePRXQC.mjs +0 -830
  261. package/dist/manifest-2ToTpjv8.mjs +0 -106
  262. package/dist/manifest-3g71z6Bg.mjs +0 -79
  263. package/dist/manifest-82baTv4U.mjs +0 -45
  264. package/dist/manifest-B3QVVeBS.mjs +0 -82
  265. package/dist/manifest-BB2J8IMJ.mjs +0 -149
  266. package/dist/manifest-BKbgbSiY.mjs +0 -60
  267. package/dist/manifest-Bcf-TJzH.mjs +0 -848
  268. package/dist/manifest-BmtZzQiQ2.mjs +0 -45
  269. package/dist/manifest-Bnd7kqEY.mjs +0 -55
  270. package/dist/manifest-BqQX6OQC2.mjs +0 -65
  271. package/dist/manifest-BqrQ4Tpj.mjs +0 -81
  272. package/dist/manifest-Br4RPFt5.mjs +0 -370
  273. package/dist/manifest-C5qDjysN.mjs +0 -107
  274. package/dist/manifest-C9RT5nk32.mjs +0 -34
  275. package/dist/manifest-CAhOuvSl.mjs +0 -204
  276. package/dist/manifest-CBYWCUBJ.mjs +0 -51
  277. package/dist/manifest-CFADCRa1.mjs +0 -37
  278. package/dist/manifest-CQVhavRF.mjs +0 -114
  279. package/dist/manifest-CT7zZBV1.mjs +0 -48
  280. package/dist/manifest-CV12bcrF.mjs +0 -121
  281. package/dist/manifest-CXsRWjjI.mjs +0 -224
  282. package/dist/manifest-CZLUCfG02.mjs +0 -95
  283. package/dist/manifest-D6phHKFd.mjs +0 -131
  284. package/dist/manifest-DCyjf4n2.mjs +0 -294
  285. package/dist/manifest-DHsnKgP6.mjs +0 -60
  286. package/dist/manifest-Df_dliIe.mjs +0 -55
  287. package/dist/manifest-Dh8WBmEW.mjs +0 -129
  288. package/dist/manifest-DhKRAT8_.mjs +0 -92
  289. package/dist/manifest-DlpTj4ic2.mjs +0 -193
  290. package/dist/manifest-DrbmZcFl2.mjs +0 -253
  291. package/dist/manifest-DuwHjUa5.mjs +0 -70
  292. package/dist/manifest-DzwvxPJX.mjs +0 -38
  293. package/dist/manifest-NXctwWQq.mjs +0 -68
  294. package/dist/manifest-Sc_0JQ13.mjs +0 -418
  295. package/dist/manifest-gZ4s_UtG.mjs +0 -96
  296. package/dist/manifest-qSleDqdO.mjs +0 -1023
  297. package/dist/modules-C184v-S9.mjs +0 -11365
  298. package/dist/mojo-ipc-B_H61Afw.mjs +0 -525
  299. package/dist/network-671Cw6hV.mjs +0 -3346
  300. package/dist/outputPaths-B1uGmrWZ.mjs +0 -1145
  301. package/dist/parse-args-BlRjqlkL.mjs +0 -39
  302. package/dist/platform-WmNn8Sxb.mjs +0 -2070
  303. package/dist/process-QcbIy5Zq.mjs +0 -1401
  304. package/dist/proxy-DqNs0bAd.mjs +0 -170
  305. package/dist/registry-D-6e18lB.mjs +0 -34
  306. package/dist/response-BQVP-xUn.mjs +0 -28
  307. package/dist/shared-state-board-DV-dpHFJ.mjs +0 -586
  308. package/dist/sourcemap-Dq8ez8vS.mjs +0 -650
  309. package/dist/ssrf-policy-ZaUfvhq7.mjs +0 -166
  310. package/dist/streaming-BUQ0VJsg.mjs +0 -725
  311. package/dist/tool-builder-DCbIC5Eo.mjs +0 -186
  312. package/dist/transform-CiYJfNX0.mjs +0 -1007
  313. package/dist/types-Bx92KJfT.mjs +0 -4
  314. package/dist/types-CPhOReNX.mjs +0 -37
  315. package/dist/wasm-DQTnHDs4.mjs +0 -531
  316. package/dist/workflow-f3xJOcjx.mjs +0 -725
@@ -1,710 +0,0 @@
1
- //#region src/modules/syscall-hook/SyscallMonitor.ts
2
- const SUPPORTED_BACKENDS = [
3
- "etw",
4
- "strace",
5
- "dtrace"
6
- ];
7
- const SYNTHETIC_EVENT_SEEDS = {
8
- etw: [
9
- {
10
- syscall: "NtCreateFile",
11
- args: ["C:\\Windows\\Temp\\jshookmcp.log", "GENERIC_READ"],
12
- returnValue: 0,
13
- duration: .7
14
- },
15
- {
16
- syscall: "NtReadFile",
17
- args: ["handle=0x90", "buffer=4096"],
18
- returnValue: 512,
19
- duration: .2
20
- },
21
- {
22
- syscall: "NtWriteFile",
23
- args: ["handle=0x90", "buffer=128"],
24
- returnValue: 128,
25
- duration: .3
26
- },
27
- {
28
- syscall: "NtDeviceIoControlFile",
29
- args: ["handle=0x44", "code=0x222004"],
30
- returnValue: 0,
31
- duration: 1.1
32
- }
33
- ],
34
- strace: [
35
- {
36
- syscall: "openat",
37
- args: ["/tmp/jshookmcp.log", "O_RDONLY"],
38
- returnValue: 3,
39
- duration: .4
40
- },
41
- {
42
- syscall: "read",
43
- args: ["fd=3", "count=4096"],
44
- returnValue: 256,
45
- duration: .1
46
- },
47
- {
48
- syscall: "write",
49
- args: ["fd=3", "count=128"],
50
- returnValue: 128,
51
- duration: .2
52
- },
53
- {
54
- syscall: "connect",
55
- args: ["fd=18", "127.0.0.1:9222"],
56
- returnValue: 0,
57
- duration: 1.4
58
- }
59
- ],
60
- dtrace: [
61
- {
62
- syscall: "open_nocancel",
63
- args: ["/private/tmp/jshookmcp.log", "O_RDONLY"],
64
- returnValue: 3,
65
- duration: .5
66
- },
67
- {
68
- syscall: "read_nocancel",
69
- args: ["fd=3", "count=4096"],
70
- returnValue: 320,
71
- duration: .1
72
- },
73
- {
74
- syscall: "write_nocancel",
75
- args: ["fd=3", "count=128"],
76
- returnValue: 128,
77
- duration: .2
78
- },
79
- {
80
- syscall: "connect",
81
- args: ["fd=21", "127.0.0.1:9222"],
82
- returnValue: 0,
83
- duration: 1.3
84
- }
85
- ]
86
- };
87
- function isBackendSupportedOnCurrentPlatform(backend) {
88
- if (backend === "etw") return process.platform === "win32";
89
- if (backend === "strace") return process.platform === "linux";
90
- if (backend === "dtrace") return process.platform === "darwin";
91
- return false;
92
- }
93
- function chooseDefaultBackend() {
94
- if (process.platform === "win32") return "etw";
95
- if (process.platform === "linux") return "strace";
96
- if (process.platform === "darwin") return "dtrace";
97
- return "etw";
98
- }
99
- function cloneEvent(event) {
100
- return {
101
- timestamp: event.timestamp,
102
- pid: event.pid,
103
- syscall: event.syscall,
104
- args: [...event.args],
105
- returnValue: event.returnValue,
106
- duration: event.duration
107
- };
108
- }
109
- function matchesFilter(event, filter) {
110
- if (!filter) return true;
111
- if (filter.pid !== void 0 && event.pid !== filter.pid) return false;
112
- if (filter.name && filter.name.length > 0 && !filter.name.includes(event.syscall)) return false;
113
- return true;
114
- }
115
- /**
116
- * Parse a strace output line into a SyscallEvent.
117
- *
118
- * Example strace line:
119
- * 12345 14:30:00.123456 openat(AT_FDCWD, "/tmp/foo", O_RDONLY) = 3 <0.000123>
120
- */
121
- function parseStraceLine(line, targetPid) {
122
- const match = /^(\d+)\s+([\d:.]+)\s+(\w+)\(([^)]*)\)\s*=\s*(-?\d+)(?:\s+<([\d.]+)>)?$/u.exec(line.trim());
123
- if (!match) return null;
124
- const syscall = match[3] ?? "unknown";
125
- const rawArgs = match[4] ?? "";
126
- const returnValue = Number(match[5]);
127
- const duration = match[6] ? Number(match[6]) : void 0;
128
- const args = rawArgs.split(",").map((a) => a.trim()).filter((a) => a.length > 0);
129
- return {
130
- timestamp: Date.now(),
131
- pid: targetPid,
132
- syscall,
133
- args,
134
- returnValue: Number.isFinite(returnValue) ? returnValue : void 0,
135
- duration: duration !== void 0 && Number.isFinite(duration) ? duration * 1e3 : void 0
136
- };
137
- }
138
- /**
139
- * Parse an ETW trace line (simplified from logman/wpr output).
140
- *
141
- * Example ETW line:
142
- * [2024-01-15 14:30:00.123] PID=1234 NtCreateFile Handle=0x90 Status=0x00000000
143
- */
144
- function parseETWLine(line, targetPid) {
145
- const match = /^\[([^\]]+)\]\s+PID=(\d+)\s+(\w+)\s+(.*)$/u.exec(line.trim());
146
- if (!match) return null;
147
- const syscall = match[3] ?? "unknown";
148
- const rawArgs = match[4] ?? "";
149
- const pid = Number(match[2]);
150
- const args = rawArgs.split(/\s+/u).filter((a) => a.length > 0);
151
- return {
152
- timestamp: Date.now(),
153
- pid: Number.isFinite(pid) ? pid : targetPid,
154
- syscall,
155
- args
156
- };
157
- }
158
- /**
159
- * Parse a dtrace output line.
160
- *
161
- * Example dtrace line:
162
- * 1234 0 12345 open_nocancel:entry /private/tmp/foo O_RDONLY
163
- */
164
- function parseDTraceLine(line, targetPid) {
165
- const match = /^\s*(\d+)\s+\d+\s+(\d+)\s+(\w+):\w+\s+(.*)$/u.exec(line.trim());
166
- if (!match) return null;
167
- const syscall = match[3] ?? "unknown";
168
- const rawArgs = match[4] ?? "";
169
- const pid = Number(match[2]);
170
- const args = rawArgs.split(/\s+/u).filter((a) => a.length > 0);
171
- return {
172
- timestamp: Date.now(),
173
- pid: Number.isFinite(pid) ? pid : targetPid,
174
- syscall,
175
- args
176
- };
177
- }
178
- var SyscallMonitor = class {
179
- activeState;
180
- capturedEvents = [];
181
- lastBackend = chooseDefaultBackend();
182
- subprocessError;
183
- async start(options) {
184
- const requestedBackend = options?.backend ?? chooseDefaultBackend();
185
- if (!isBackendSupportedOnCurrentPlatform(requestedBackend)) throw new Error(`Backend "${requestedBackend}" is not available on platform "${process.platform}"`);
186
- if (options?.simulate ?? process.env["JSHOOK_SIMULATE"] === "1") {
187
- this.activeState = {
188
- backend: requestedBackend,
189
- pid: options?.pid,
190
- startedAt: Date.now(),
191
- generatedEvents: 0
192
- };
193
- this.lastBackend = requestedBackend;
194
- this.capturedEvents.length = 0;
195
- this.generateSyntheticEvents();
196
- return;
197
- }
198
- const pid = options?.pid ?? process.pid;
199
- let subprocess;
200
- try {
201
- if (requestedBackend === "strace") subprocess = await this.captureWithStrace(pid);
202
- else if (requestedBackend === "etw") subprocess = await this.captureWithETW(pid);
203
- else if (requestedBackend === "dtrace") subprocess = await this.captureWithDTrace(pid);
204
- } catch (error) {
205
- this.subprocessError = error instanceof Error ? error.message : String(error);
206
- this.activeState = {
207
- backend: requestedBackend,
208
- pid: options?.pid,
209
- startedAt: Date.now(),
210
- generatedEvents: 0
211
- };
212
- this.lastBackend = requestedBackend;
213
- this.capturedEvents.length = 0;
214
- this.generateSyntheticEvents();
215
- return;
216
- }
217
- this.activeState = {
218
- backend: requestedBackend,
219
- pid: options?.pid,
220
- startedAt: Date.now(),
221
- generatedEvents: 0,
222
- subprocess
223
- };
224
- this.lastBackend = requestedBackend;
225
- this.capturedEvents.length = 0;
226
- this.subprocessError = void 0;
227
- }
228
- async stop() {
229
- if (this.activeState?.subprocess) {
230
- this.activeState.subprocess.kill("SIGTERM");
231
- this.activeState.subprocess = void 0;
232
- }
233
- this.activeState = void 0;
234
- }
235
- async captureEvents(filter) {
236
- if (this.activeState && !this.activeState.subprocess) this.generateSyntheticEvents();
237
- return this.capturedEvents.filter((event) => matchesFilter(event, filter)).map(cloneEvent);
238
- }
239
- getStats() {
240
- const backend = this.activeState?.backend ?? this.lastBackend;
241
- const uptime = this.activeState ? Date.now() - this.activeState.startedAt : 0;
242
- return {
243
- eventsCaptured: this.capturedEvents.length,
244
- uptime,
245
- backend,
246
- subprocessActive: !!this.activeState?.subprocess,
247
- subprocessError: this.subprocessError
248
- };
249
- }
250
- getSupportedBackends() {
251
- return SUPPORTED_BACKENDS.filter((backend) => isBackendSupportedOnCurrentPlatform(backend));
252
- }
253
- isRunning() {
254
- return this.activeState !== void 0;
255
- }
256
- /**
257
- * Spawn strace for syscall tracing on Linux.
258
- * Parses stdout into SyscallEvent objects.
259
- */
260
- async captureWithStrace(pid) {
261
- const { spawn } = await import("node:child_process");
262
- return new Promise((resolve, reject) => {
263
- const subprocess = spawn("strace", [
264
- "-p",
265
- String(pid),
266
- "-f",
267
- "-e",
268
- "trace=all",
269
- "-t"
270
- ], { stdio: [
271
- "ignore",
272
- "pipe",
273
- "pipe"
274
- ] });
275
- let stderrBuffer = "";
276
- let lineAccumulator = "";
277
- subprocess.stdout?.on("data", (chunk) => {
278
- lineAccumulator += chunk.toString();
279
- this.processLineBuffer(lineAccumulator, pid, "strace");
280
- });
281
- subprocess.stderr?.on("data", (chunk) => {
282
- stderrBuffer += chunk.toString();
283
- const lines = stderrBuffer.split(/\r?\n/u);
284
- stderrBuffer = lines.pop() ?? "";
285
- for (const line of lines) if (line.length > 0) {
286
- const event = parseStraceLine(line, pid);
287
- if (event) this.capturedEvents.push(event);
288
- }
289
- });
290
- subprocess.on("error", (error) => {
291
- reject(/* @__PURE__ */ new Error(`strace process error: ${error.message}. Is strace installed?`));
292
- });
293
- subprocess.on("spawn", () => {
294
- resolve(subprocess);
295
- });
296
- });
297
- }
298
- /**
299
- * Spawn ETW tracing on Windows using logman.
300
- * Parses ETW trace output into SyscallEvent objects.
301
- */
302
- async captureWithETW(pid) {
303
- const { spawn } = await import("node:child_process");
304
- return new Promise((resolve, reject) => {
305
- const logman = spawn("logman", [
306
- "create",
307
- "trace",
308
- `JSHookETW_${pid}`,
309
- "-p",
310
- "NT Kernel Logger",
311
- "0x10000",
312
- "-o",
313
- `jshook_etw_${pid}.etl`,
314
- "-ets"
315
- ], {
316
- stdio: [
317
- "ignore",
318
- "pipe",
319
- "pipe"
320
- ],
321
- windowsHide: true
322
- });
323
- let outputBuffer = "";
324
- logman.stdout?.on("data", (chunk) => {
325
- outputBuffer += chunk.toString();
326
- const lines = outputBuffer.split(/\r?\n/u);
327
- outputBuffer = lines.pop() ?? "";
328
- for (const line of lines) {
329
- const event = parseETWLine(line, pid);
330
- if (event) this.capturedEvents.push(event);
331
- }
332
- });
333
- logman.stderr?.on("data", (chunk) => {
334
- const msg = chunk.toString().trim();
335
- if (msg.length > 0 && !msg.startsWith("The command completed successfully")) {}
336
- });
337
- logman.on("error", (error) => {
338
- reject(/* @__PURE__ */ new Error(`ETW trace error: ${error.message}. Run as Administrator.`));
339
- });
340
- logman.on("exit", (code) => {
341
- if (code !== 0 && code !== void 0) reject(/* @__PURE__ */ new Error(`ETW trace session ended (code ${code}). Check permissions.`));
342
- });
343
- logman.on("spawn", () => {
344
- resolve(logman);
345
- });
346
- });
347
- }
348
- /**
349
- * Spawn dtrace for syscall tracing on macOS.
350
- * Parses dtrace output into SyscallEvent objects.
351
- */
352
- async captureWithDTrace(pid) {
353
- const { spawn } = await import("node:child_process");
354
- return new Promise((resolve, reject) => {
355
- const dtrace = spawn("dtrace", ["-n", `
356
- syscall:::entry
357
- /pid == ${pid}/
358
- {
359
- printf("%d %d %s:entry %s", pid, probeproc, probefunc, copyinstr(arg0));
360
- }
361
- `], { stdio: [
362
- "ignore",
363
- "pipe",
364
- "pipe"
365
- ] });
366
- let outputBuffer = "";
367
- dtrace.stdout?.on("data", (chunk) => {
368
- outputBuffer += chunk.toString();
369
- const lines = outputBuffer.split(/\r?\n/u);
370
- outputBuffer = lines.pop() ?? "";
371
- for (const line of lines) {
372
- const event = parseDTraceLine(line, pid);
373
- if (event) this.capturedEvents.push(event);
374
- }
375
- });
376
- dtrace.stderr?.on("data", () => {});
377
- dtrace.on("error", (error) => {
378
- reject(/* @__PURE__ */ new Error(`dtrace error: ${error.message}. Run with sudo.`));
379
- });
380
- dtrace.on("spawn", () => {
381
- resolve(dtrace);
382
- });
383
- });
384
- }
385
- generateSyntheticEvents() {
386
- if (!this.activeState) return;
387
- const seeds = SYNTHETIC_EVENT_SEEDS[this.activeState.backend];
388
- if (!seeds) return;
389
- const elapsed = Date.now() - this.activeState.startedAt;
390
- const targetEventCount = Math.max(1, Math.min(seeds.length * 3, Math.floor(elapsed / 150) + 1));
391
- const pid = this.activeState.pid ?? process.pid;
392
- while (this.activeState.generatedEvents < targetEventCount) {
393
- const seed = seeds[this.activeState.generatedEvents % seeds.length];
394
- if (!seed) break;
395
- const timestamp = this.activeState.startedAt + this.activeState.generatedEvents * 75;
396
- this.capturedEvents.push({
397
- timestamp,
398
- pid,
399
- syscall: seed.syscall,
400
- args: [...seed.args],
401
- returnValue: seed.returnValue,
402
- duration: seed.duration
403
- });
404
- this.activeState.generatedEvents += 1;
405
- }
406
- }
407
- processLineBuffer(_buffer, _pid, _parser) {}
408
- };
409
- //#endregion
410
- //#region src/modules/syscall-hook/SyscallToJSMapper.ts
411
- const CORRELATION_RULES = [
412
- {
413
- syscallNames: [
414
- "NtCreateFile",
415
- "openat",
416
- "open_nocancel"
417
- ],
418
- jsFunction: "fs.open",
419
- baseConfidence: .8,
420
- explanation: "File open syscalls commonly originate from Node.js file-system entry points."
421
- },
422
- {
423
- syscallNames: [
424
- "NtReadFile",
425
- "read",
426
- "read_nocancel"
427
- ],
428
- jsFunction: "fs.readFile",
429
- baseConfidence: .78,
430
- explanation: "Read-oriented syscalls usually map back to file or stream reads in JavaScript."
431
- },
432
- {
433
- syscallNames: [
434
- "NtWriteFile",
435
- "write",
436
- "write_nocancel"
437
- ],
438
- jsFunction: "fs.writeFile",
439
- baseConfidence: .78,
440
- explanation: "Write-oriented syscalls are strongly associated with Node.js file writes."
441
- },
442
- {
443
- syscallNames: ["NtDeviceIoControlFile", "ioctl"],
444
- jsFunction: "child_process.spawn",
445
- baseConfidence: .55,
446
- explanation: "Device and control syscalls are often triggered by child processes or native helpers."
447
- },
448
- {
449
- syscallNames: [
450
- "connect",
451
- "sendto",
452
- "recvfrom"
453
- ],
454
- jsFunction: "fetch",
455
- baseConfidence: .7,
456
- explanation: "Socket syscalls generally indicate outbound network activity from fetch-like APIs."
457
- }
458
- ];
459
- function findRuleBySyscallName(syscallName) {
460
- return CORRELATION_RULES.find((rule) => rule.syscallNames.includes(syscallName));
461
- }
462
- function clampConfidence(confidence) {
463
- if (confidence < 0) return 0;
464
- if (confidence > 1) return 1;
465
- return confidence;
466
- }
467
- function hasArgContaining(args, fragments) {
468
- return args.some((arg) => fragments.some((fragment) => arg.toLowerCase().includes(fragment)));
469
- }
470
- var SyscallToJSMapper = class {
471
- map(syscall) {
472
- const jsFunction = this.findJSFunction(syscall.syscall);
473
- if (!jsFunction) return null;
474
- const rule = findRuleBySyscallName(syscall.syscall);
475
- if (!rule) return null;
476
- let confidence = rule.baseConfidence;
477
- if (jsFunction.startsWith("fs.") && hasArgContaining(syscall.args, [
478
- ".js",
479
- ".json",
480
- ".node"
481
- ])) confidence += .08;
482
- if (jsFunction === "fetch" && hasArgContaining(syscall.args, [
483
- "80",
484
- "443",
485
- "http",
486
- "https"
487
- ])) confidence += .1;
488
- return {
489
- syscall: {
490
- timestamp: syscall.timestamp,
491
- pid: syscall.pid,
492
- syscall: syscall.syscall,
493
- args: [...syscall.args],
494
- returnValue: syscall.returnValue,
495
- duration: syscall.duration
496
- },
497
- jsFunction,
498
- confidence: clampConfidence(confidence),
499
- reasoning: this.getCorrelationReason(syscall, jsFunction)
500
- };
501
- }
502
- findJSFunction(syscallName) {
503
- const rule = findRuleBySyscallName(syscallName);
504
- if (!rule) return null;
505
- return rule.jsFunction;
506
- }
507
- getCorrelationReason(syscall, jsFunc) {
508
- const rule = findRuleBySyscallName(syscall.syscall);
509
- const detailParts = [];
510
- if (rule) detailParts.push(rule.explanation);
511
- if (jsFunc.startsWith("fs.") && hasArgContaining(syscall.args, [
512
- ".js",
513
- ".json",
514
- ".node"
515
- ])) detailParts.push("The syscall arguments reference module-like file extensions, which strengthens the fs correlation.");
516
- if (jsFunc === "fetch" && hasArgContaining(syscall.args, [
517
- "80",
518
- "443",
519
- "http",
520
- "https"
521
- ])) detailParts.push("The syscall arguments look like network endpoints, which aligns with fetch or low-level HTTP clients.");
522
- if (detailParts.length === 0) detailParts.push(`Mapped ${syscall.syscall} to ${jsFunc} using the default syscall-to-JS heuristic table.`);
523
- return detailParts.join(" ");
524
- }
525
- };
526
- //#endregion
527
- //#region src/server/domains/syscall-hook/handlers.impl.ts
528
- function isRecord(value) {
529
- return typeof value === "object" && value !== null;
530
- }
531
- function readNumber(value) {
532
- if (typeof value === "number" && Number.isFinite(value)) return value;
533
- }
534
- function readString(value) {
535
- if (typeof value === "string") return value;
536
- }
537
- function readStringArray(value) {
538
- if (!Array.isArray(value)) return;
539
- const strings = [];
540
- for (const item of value) {
541
- if (typeof item !== "string") return;
542
- strings.push(item);
543
- }
544
- return strings;
545
- }
546
- function readBackend(value) {
547
- if (value === "etw" || value === "strace" || value === "dtrace") return value;
548
- }
549
- function readFilter(value) {
550
- if (!isRecord(value)) return;
551
- const filter = {};
552
- const names = readStringArray(value["name"]);
553
- const pid = readNumber(value["pid"]);
554
- if (names) filter.name = names;
555
- if (pid !== void 0) filter.pid = pid;
556
- return filter;
557
- }
558
- function isSyscallEvent(value) {
559
- if (!isRecord(value)) return false;
560
- const timestamp = readNumber(value["timestamp"]);
561
- const pid = readNumber(value["pid"]);
562
- const syscall = readString(value["syscall"]);
563
- const args = readStringArray(value["args"]);
564
- const returnValue = value["returnValue"];
565
- const duration = value["duration"];
566
- const returnValueValid = returnValue === void 0 || readNumber(returnValue) !== void 0;
567
- const durationValid = duration === void 0 || readNumber(duration) !== void 0;
568
- return timestamp !== void 0 && pid !== void 0 && syscall !== void 0 && args !== void 0 && returnValueValid && durationValid;
569
- }
570
- function cloneSyscallEvent(event) {
571
- return {
572
- timestamp: event.timestamp,
573
- pid: event.pid,
574
- syscall: event.syscall,
575
- args: [...event.args],
576
- returnValue: event.returnValue,
577
- duration: event.duration
578
- };
579
- }
580
- function toErrorMessage(error) {
581
- if (error instanceof Error) return error.message;
582
- return "Unknown syscall-hook error";
583
- }
584
- var SyscallHookHandlers = class {
585
- constructor(monitor, mapper, eventBus) {
586
- this.monitor = monitor;
587
- this.mapper = mapper;
588
- this.eventBus = eventBus;
589
- }
590
- async handleSyscallStartMonitor(args) {
591
- const backend = readBackend(args["backend"]);
592
- if (!backend) return {
593
- ok: false,
594
- error: "backend must be one of: etw, strace, dtrace"
595
- };
596
- const pid = readNumber(args["pid"]);
597
- if (args["pid"] !== void 0 && pid === void 0) return {
598
- ok: false,
599
- error: "pid must be a finite number when provided"
600
- };
601
- const monitor = this.ensureMonitor();
602
- try {
603
- await monitor.start({
604
- backend,
605
- pid
606
- });
607
- this.eventBus?.emit("syscall:trace_started", {
608
- backend,
609
- pid,
610
- timestamp: (/* @__PURE__ */ new Date()).toISOString()
611
- });
612
- return {
613
- ok: true,
614
- started: true,
615
- backend,
616
- pid,
617
- stats: monitor.getStats()
618
- };
619
- } catch (error) {
620
- return {
621
- ok: false,
622
- error: toErrorMessage(error),
623
- requestedBackend: backend,
624
- supportedBackends: monitor.getSupportedBackends()
625
- };
626
- }
627
- }
628
- async handleSyscallStopMonitor() {
629
- const monitor = this.ensureMonitor();
630
- try {
631
- await monitor.stop();
632
- return {
633
- ok: true,
634
- stopped: true,
635
- stats: monitor.getStats()
636
- };
637
- } catch (error) {
638
- return {
639
- ok: false,
640
- error: toErrorMessage(error)
641
- };
642
- }
643
- }
644
- async handleSyscallCaptureEvents(args) {
645
- const monitor = this.ensureMonitor();
646
- const filter = readFilter(args["filter"]);
647
- const events = await monitor.captureEvents(filter);
648
- return {
649
- ok: true,
650
- events,
651
- count: events.length,
652
- stats: monitor.getStats()
653
- };
654
- }
655
- async handleSyscallCorrelateJs(args) {
656
- const rawEvents = args["syscallEvents"];
657
- if (!Array.isArray(rawEvents) || !rawEvents.every((item) => isSyscallEvent(item))) return {
658
- ok: false,
659
- error: "syscallEvents must be an array of valid SyscallEvent objects"
660
- };
661
- const mapper = this.ensureMapper();
662
- const correlations = [];
663
- const unmatched = [];
664
- for (const event of rawEvents) {
665
- const clonedEvent = cloneSyscallEvent(event);
666
- const correlated = mapper.map(clonedEvent);
667
- if (correlated) correlations.push(correlated);
668
- else unmatched.push(clonedEvent);
669
- }
670
- return {
671
- ok: true,
672
- correlations,
673
- matched: correlations.length,
674
- unmatched
675
- };
676
- }
677
- async handleSyscallFilter(args) {
678
- const names = readStringArray(args["names"]);
679
- if (args["names"] !== void 0 && names === void 0) return {
680
- ok: false,
681
- error: "names must be an array of strings when provided"
682
- };
683
- const events = await this.ensureMonitor().captureEvents(names && names.length > 0 ? { name: names } : void 0);
684
- return {
685
- ok: true,
686
- names,
687
- events,
688
- count: events.length
689
- };
690
- }
691
- async handleSyscallGetStats() {
692
- const monitor = this.ensureMonitor();
693
- return {
694
- ok: true,
695
- ...monitor.getStats(),
696
- running: monitor.isRunning(),
697
- supportedBackends: monitor.getSupportedBackends()
698
- };
699
- }
700
- ensureMonitor() {
701
- if (!this.monitor) this.monitor = new SyscallMonitor();
702
- return this.monitor;
703
- }
704
- ensureMapper() {
705
- if (!this.mapper) this.mapper = new SyscallToJSMapper();
706
- return this.mapper;
707
- }
708
- };
709
- //#endregion
710
- export { SyscallHookHandlers };