@trenchwork/erosolar 1.1.30 → 1.1.32

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 (819) hide show
  1. package/README.md +6 -6
  2. package/SECURITY.md +4 -4
  3. package/dist/bin/cliMode.d.ts +8 -0
  4. package/dist/bin/cliMode.d.ts.map +1 -0
  5. package/dist/bin/cliMode.js +20 -0
  6. package/dist/bin/cliMode.js.map +1 -0
  7. package/dist/bin/deepseek.d.ts +3 -0
  8. package/dist/bin/deepseek.d.ts.map +1 -0
  9. package/dist/bin/deepseek.js +345 -0
  10. package/dist/bin/deepseek.js.map +1 -0
  11. package/dist/bin/erosolar.d.ts +7 -0
  12. package/dist/bin/erosolar.d.ts.map +1 -0
  13. package/dist/bin/erosolar.js +7 -0
  14. package/dist/bin/erosolar.js.map +1 -0
  15. package/dist/bin/selfTest.d.ts +14 -0
  16. package/dist/bin/selfTest.d.ts.map +1 -0
  17. package/dist/bin/selfTest.js +298 -0
  18. package/dist/bin/selfTest.js.map +1 -0
  19. package/dist/capabilities/_binaryRequirements.d.ts +101 -0
  20. package/dist/capabilities/_binaryRequirements.d.ts.map +1 -0
  21. package/dist/capabilities/_binaryRequirements.js +288 -0
  22. package/dist/capabilities/_binaryRequirements.js.map +1 -0
  23. package/dist/capabilities/_opsContext.d.ts +129 -0
  24. package/dist/capabilities/_opsContext.d.ts.map +1 -0
  25. package/dist/capabilities/_opsContext.js +274 -0
  26. package/dist/capabilities/_opsContext.js.map +1 -0
  27. package/dist/capabilities/_processRunner.d.ts +49 -0
  28. package/dist/capabilities/_processRunner.d.ts.map +1 -0
  29. package/dist/capabilities/_processRunner.js +200 -0
  30. package/dist/capabilities/_processRunner.js.map +1 -0
  31. package/dist/capabilities/aflppCapability.d.ts +7 -0
  32. package/dist/capabilities/aflppCapability.d.ts.map +1 -0
  33. package/dist/capabilities/aflppCapability.js +301 -0
  34. package/dist/capabilities/aflppCapability.js.map +1 -0
  35. package/dist/capabilities/baseCapability.d.ts +72 -0
  36. package/dist/capabilities/baseCapability.d.ts.map +1 -0
  37. package/dist/capabilities/baseCapability.js +183 -0
  38. package/dist/capabilities/baseCapability.js.map +1 -0
  39. package/dist/capabilities/bashCapability.d.ts +13 -0
  40. package/dist/capabilities/bashCapability.d.ts.map +1 -0
  41. package/dist/capabilities/bashCapability.js +24 -0
  42. package/dist/capabilities/bashCapability.js.map +1 -0
  43. package/dist/capabilities/binaryAnalysisCapability.d.ts +7 -0
  44. package/dist/capabilities/binaryAnalysisCapability.d.ts.map +1 -0
  45. package/dist/capabilities/binaryAnalysisCapability.js +201 -0
  46. package/dist/capabilities/binaryAnalysisCapability.js.map +1 -0
  47. package/dist/capabilities/editCapability.d.ts +17 -0
  48. package/dist/capabilities/editCapability.d.ts.map +1 -0
  49. package/dist/capabilities/editCapability.js +27 -0
  50. package/dist/capabilities/editCapability.js.map +1 -0
  51. package/dist/capabilities/engagementCapability.d.ts +15 -0
  52. package/dist/capabilities/engagementCapability.d.ts.map +1 -0
  53. package/dist/capabilities/engagementCapability.js +40 -0
  54. package/dist/capabilities/engagementCapability.js.map +1 -0
  55. package/dist/capabilities/enhancedGitCapability.d.ts +7 -0
  56. package/dist/capabilities/enhancedGitCapability.d.ts.map +1 -0
  57. package/dist/capabilities/enhancedGitCapability.js +220 -0
  58. package/dist/capabilities/enhancedGitCapability.js.map +1 -0
  59. package/dist/capabilities/filesystemCapability.d.ts +13 -0
  60. package/dist/capabilities/filesystemCapability.d.ts.map +1 -0
  61. package/dist/capabilities/filesystemCapability.js +24 -0
  62. package/dist/capabilities/filesystemCapability.js.map +1 -0
  63. package/dist/capabilities/gdbCapability.d.ts +7 -0
  64. package/dist/capabilities/gdbCapability.d.ts.map +1 -0
  65. package/dist/capabilities/gdbCapability.js +125 -0
  66. package/dist/capabilities/gdbCapability.js.map +1 -0
  67. package/dist/capabilities/ghidraHeadlessCapability.d.ts +25 -0
  68. package/dist/capabilities/ghidraHeadlessCapability.d.ts.map +1 -0
  69. package/dist/capabilities/ghidraHeadlessCapability.js +593 -0
  70. package/dist/capabilities/ghidraHeadlessCapability.js.map +1 -0
  71. package/dist/capabilities/gitHistoryCapability.d.ts +6 -0
  72. package/dist/capabilities/gitHistoryCapability.d.ts.map +1 -0
  73. package/dist/capabilities/gitHistoryCapability.js +184 -0
  74. package/dist/capabilities/gitHistoryCapability.js.map +1 -0
  75. package/dist/capabilities/hitlCapability.d.ts +18 -0
  76. package/dist/capabilities/hitlCapability.d.ts.map +1 -0
  77. package/dist/capabilities/hitlCapability.js +29 -0
  78. package/dist/capabilities/hitlCapability.js.map +1 -0
  79. package/dist/capabilities/index.d.ts +26 -0
  80. package/dist/capabilities/index.d.ts.map +1 -0
  81. package/dist/capabilities/index.js +31 -0
  82. package/dist/capabilities/index.js.map +1 -0
  83. package/dist/capabilities/interactionCapability.d.ts +6 -0
  84. package/dist/capabilities/interactionCapability.d.ts.map +1 -0
  85. package/dist/capabilities/interactionCapability.js +17 -0
  86. package/dist/capabilities/interactionCapability.js.map +1 -0
  87. package/dist/capabilities/kaliCapability.d.ts +14 -0
  88. package/dist/capabilities/kaliCapability.d.ts.map +1 -0
  89. package/dist/capabilities/kaliCapability.js +478 -0
  90. package/dist/capabilities/kaliCapability.js.map +1 -0
  91. package/dist/capabilities/llmRedteamCapability.d.ts +38 -0
  92. package/dist/capabilities/llmRedteamCapability.d.ts.map +1 -0
  93. package/dist/capabilities/llmRedteamCapability.js +340 -0
  94. package/dist/capabilities/llmRedteamCapability.js.map +1 -0
  95. package/dist/capabilities/mcpCapability.d.ts +7 -0
  96. package/dist/capabilities/mcpCapability.d.ts.map +1 -0
  97. package/dist/capabilities/mcpCapability.js +82 -0
  98. package/dist/capabilities/mcpCapability.js.map +1 -0
  99. package/dist/capabilities/memoryCapability.d.ts +10 -0
  100. package/dist/capabilities/memoryCapability.d.ts.map +1 -0
  101. package/dist/capabilities/memoryCapability.js +22 -0
  102. package/dist/capabilities/memoryCapability.js.map +1 -0
  103. package/dist/capabilities/monitorCapability.d.ts +6 -0
  104. package/dist/capabilities/monitorCapability.d.ts.map +1 -0
  105. package/dist/capabilities/monitorCapability.js +19 -0
  106. package/dist/capabilities/monitorCapability.js.map +1 -0
  107. package/dist/capabilities/notebookCapability.d.ts +6 -0
  108. package/dist/capabilities/notebookCapability.d.ts.map +1 -0
  109. package/dist/capabilities/notebookCapability.js +17 -0
  110. package/dist/capabilities/notebookCapability.js.map +1 -0
  111. package/dist/capabilities/planModeCapability.d.ts +6 -0
  112. package/dist/capabilities/planModeCapability.d.ts.map +1 -0
  113. package/dist/capabilities/planModeCapability.js +16 -0
  114. package/dist/capabilities/planModeCapability.js.map +1 -0
  115. package/dist/capabilities/pwntoolsCapability.d.ts +7 -0
  116. package/dist/capabilities/pwntoolsCapability.d.ts.map +1 -0
  117. package/dist/capabilities/pwntoolsCapability.js +109 -0
  118. package/dist/capabilities/pwntoolsCapability.js.map +1 -0
  119. package/dist/capabilities/scheduleCapability.d.ts +6 -0
  120. package/dist/capabilities/scheduleCapability.d.ts.map +1 -0
  121. package/dist/capabilities/scheduleCapability.js +16 -0
  122. package/dist/capabilities/scheduleCapability.js.map +1 -0
  123. package/dist/capabilities/searchCapability.d.ts +19 -0
  124. package/dist/capabilities/searchCapability.d.ts.map +1 -0
  125. package/dist/capabilities/searchCapability.js +29 -0
  126. package/dist/capabilities/searchCapability.js.map +1 -0
  127. package/dist/capabilities/skillCapability.d.ts +6 -0
  128. package/dist/capabilities/skillCapability.d.ts.map +1 -0
  129. package/dist/capabilities/skillCapability.js +17 -0
  130. package/dist/capabilities/skillCapability.js.map +1 -0
  131. package/dist/capabilities/todoCapability.d.ts +11 -0
  132. package/dist/capabilities/todoCapability.d.ts.map +1 -0
  133. package/dist/capabilities/todoCapability.js +22 -0
  134. package/dist/capabilities/todoCapability.js.map +1 -0
  135. package/dist/capabilities/toolManifest.d.ts +3 -0
  136. package/dist/capabilities/toolManifest.d.ts.map +1 -0
  137. package/dist/capabilities/toolManifest.js +163 -0
  138. package/dist/capabilities/toolManifest.js.map +1 -0
  139. package/dist/capabilities/toolRegistry.d.ts +25 -0
  140. package/dist/capabilities/toolRegistry.d.ts.map +1 -0
  141. package/dist/capabilities/toolRegistry.js +150 -0
  142. package/dist/capabilities/toolRegistry.js.map +1 -0
  143. package/dist/capabilities/triggerCapability.d.ts +6 -0
  144. package/dist/capabilities/triggerCapability.d.ts.map +1 -0
  145. package/dist/capabilities/triggerCapability.js +16 -0
  146. package/dist/capabilities/triggerCapability.js.map +1 -0
  147. package/dist/capabilities/unifiedCodingCapability.d.ts +62 -0
  148. package/dist/capabilities/unifiedCodingCapability.d.ts.map +1 -0
  149. package/dist/capabilities/unifiedCodingCapability.js +788 -0
  150. package/dist/capabilities/unifiedCodingCapability.js.map +1 -0
  151. package/dist/capabilities/webCapability.d.ts +23 -0
  152. package/dist/capabilities/webCapability.d.ts.map +1 -0
  153. package/dist/capabilities/webCapability.js +33 -0
  154. package/dist/capabilities/webCapability.js.map +1 -0
  155. package/dist/capabilities/worktreeCapability.d.ts +6 -0
  156. package/dist/capabilities/worktreeCapability.d.ts.map +1 -0
  157. package/dist/capabilities/worktreeCapability.js +16 -0
  158. package/dist/capabilities/worktreeCapability.js.map +1 -0
  159. package/dist/cli/offsecInstall.d.ts +43 -0
  160. package/dist/cli/offsecInstall.d.ts.map +1 -0
  161. package/dist/cli/offsecInstall.js +258 -0
  162. package/dist/cli/offsecInstall.js.map +1 -0
  163. package/dist/config.d.ts +25 -0
  164. package/dist/config.d.ts.map +1 -0
  165. package/dist/config.js +155 -0
  166. package/dist/config.js.map +1 -0
  167. package/dist/contracts/v1/agent.d.ts +179 -0
  168. package/dist/contracts/v1/agent.d.ts.map +1 -0
  169. package/dist/contracts/v1/agent.js +8 -0
  170. package/dist/contracts/v1/agent.js.map +1 -0
  171. package/dist/contracts/v1/agentProfileManifest.d.ts +60 -0
  172. package/dist/contracts/v1/agentProfileManifest.d.ts.map +1 -0
  173. package/dist/contracts/v1/agentProfileManifest.js +9 -0
  174. package/dist/contracts/v1/agentProfileManifest.js.map +1 -0
  175. package/dist/contracts/v1/agentRules.d.ts +60 -0
  176. package/dist/contracts/v1/agentRules.d.ts.map +1 -0
  177. package/dist/contracts/v1/agentRules.js +10 -0
  178. package/dist/contracts/v1/agentRules.js.map +1 -0
  179. package/dist/contracts/v1/provider.d.ts +149 -0
  180. package/dist/contracts/v1/provider.d.ts.map +1 -0
  181. package/dist/contracts/v1/provider.js +7 -0
  182. package/dist/contracts/v1/provider.js.map +1 -0
  183. package/dist/contracts/v1/tool.d.ts +136 -0
  184. package/dist/contracts/v1/tool.d.ts.map +1 -0
  185. package/dist/contracts/v1/tool.js +7 -0
  186. package/dist/contracts/v1/tool.js.map +1 -0
  187. package/dist/contracts/v1/toolAccess.d.ts +43 -0
  188. package/dist/contracts/v1/toolAccess.d.ts.map +1 -0
  189. package/dist/contracts/v1/toolAccess.js +9 -0
  190. package/dist/contracts/v1/toolAccess.js.map +1 -0
  191. package/dist/core/agent.d.ts +320 -0
  192. package/dist/core/agent.d.ts.map +1 -0
  193. package/dist/core/agent.js +1627 -0
  194. package/dist/core/agent.js.map +1 -0
  195. package/dist/core/agentProfileManifest.d.ts +3 -0
  196. package/dist/core/agentProfileManifest.d.ts.map +1 -0
  197. package/dist/core/agentProfileManifest.js +188 -0
  198. package/dist/core/agentProfileManifest.js.map +1 -0
  199. package/dist/core/agentProfiles.d.ts +22 -0
  200. package/dist/core/agentProfiles.d.ts.map +1 -0
  201. package/dist/core/agentProfiles.js +35 -0
  202. package/dist/core/agentProfiles.js.map +1 -0
  203. package/dist/core/agentRegistry.d.ts +111 -0
  204. package/dist/core/agentRegistry.d.ts.map +1 -0
  205. package/dist/core/agentRegistry.js +229 -0
  206. package/dist/core/agentRegistry.js.map +1 -0
  207. package/dist/core/agentRulebook.d.ts +11 -0
  208. package/dist/core/agentRulebook.d.ts.map +1 -0
  209. package/dist/core/agentRulebook.js +136 -0
  210. package/dist/core/agentRulebook.js.map +1 -0
  211. package/dist/core/agentSchemaLoader.d.ts +131 -0
  212. package/dist/core/agentSchemaLoader.d.ts.map +1 -0
  213. package/dist/core/agentSchemaLoader.js +235 -0
  214. package/dist/core/agentSchemaLoader.js.map +1 -0
  215. package/dist/core/aiErrorFixer.d.ts +57 -0
  216. package/dist/core/aiErrorFixer.d.ts.map +1 -0
  217. package/dist/core/aiErrorFixer.js +214 -0
  218. package/dist/core/aiErrorFixer.js.map +1 -0
  219. package/dist/core/artifactStore.d.ts +35 -0
  220. package/dist/core/artifactStore.d.ts.map +1 -0
  221. package/dist/core/artifactStore.js +105 -0
  222. package/dist/core/artifactStore.js.map +1 -0
  223. package/dist/core/auth.d.ts +15 -0
  224. package/dist/core/auth.d.ts.map +1 -0
  225. package/dist/core/auth.js +345 -0
  226. package/dist/core/auth.js.map +1 -0
  227. package/dist/core/bashCommandGuidance.d.ts +16 -0
  228. package/dist/core/bashCommandGuidance.d.ts.map +1 -0
  229. package/dist/core/bashCommandGuidance.js +40 -0
  230. package/dist/core/bashCommandGuidance.js.map +1 -0
  231. package/dist/core/constants.d.ts +31 -0
  232. package/dist/core/constants.d.ts.map +1 -0
  233. package/dist/core/constants.js +62 -0
  234. package/dist/core/constants.js.map +1 -0
  235. package/dist/core/contextManager.d.ts +271 -0
  236. package/dist/core/contextManager.d.ts.map +1 -0
  237. package/dist/core/contextManager.js +1073 -0
  238. package/dist/core/contextManager.js.map +1 -0
  239. package/dist/core/contextWindow.d.ts +42 -0
  240. package/dist/core/contextWindow.d.ts.map +1 -0
  241. package/dist/core/contextWindow.js +123 -0
  242. package/dist/core/contextWindow.js.map +1 -0
  243. package/dist/core/customCommands.d.ts +19 -0
  244. package/dist/core/customCommands.d.ts.map +1 -0
  245. package/dist/core/customCommands.js +85 -0
  246. package/dist/core/customCommands.js.map +1 -0
  247. package/dist/core/errors/apiKeyErrors.d.ts +11 -0
  248. package/dist/core/errors/apiKeyErrors.d.ts.map +1 -0
  249. package/dist/core/errors/apiKeyErrors.js +159 -0
  250. package/dist/core/errors/apiKeyErrors.js.map +1 -0
  251. package/dist/core/errors/errorTypes.d.ts +111 -0
  252. package/dist/core/errors/errorTypes.d.ts.map +1 -0
  253. package/dist/core/errors/errorTypes.js +345 -0
  254. package/dist/core/errors/errorTypes.js.map +1 -0
  255. package/dist/core/errors/index.d.ts +50 -0
  256. package/dist/core/errors/index.d.ts.map +1 -0
  257. package/dist/core/errors/index.js +156 -0
  258. package/dist/core/errors/index.js.map +1 -0
  259. package/dist/core/errors/networkErrors.d.ts +14 -0
  260. package/dist/core/errors/networkErrors.d.ts.map +1 -0
  261. package/dist/core/errors/networkErrors.js +53 -0
  262. package/dist/core/errors/networkErrors.js.map +1 -0
  263. package/dist/core/errors/safetyValidator.d.ts +109 -0
  264. package/dist/core/errors/safetyValidator.d.ts.map +1 -0
  265. package/dist/core/errors/safetyValidator.js +271 -0
  266. package/dist/core/errors/safetyValidator.js.map +1 -0
  267. package/dist/core/errors.d.ts +4 -0
  268. package/dist/core/errors.d.ts.map +1 -0
  269. package/dist/core/errors.js +33 -0
  270. package/dist/core/errors.js.map +1 -0
  271. package/dist/core/finalResponseFormatter.d.ts +10 -0
  272. package/dist/core/finalResponseFormatter.d.ts.map +1 -0
  273. package/dist/core/finalResponseFormatter.js +14 -0
  274. package/dist/core/finalResponseFormatter.js.map +1 -0
  275. package/dist/core/guardrails.d.ts +146 -0
  276. package/dist/core/guardrails.d.ts.map +1 -0
  277. package/dist/core/guardrails.js +361 -0
  278. package/dist/core/guardrails.js.map +1 -0
  279. package/dist/core/hitl.d.ts +119 -0
  280. package/dist/core/hitl.d.ts.map +1 -0
  281. package/dist/core/hitl.js +387 -0
  282. package/dist/core/hitl.js.map +1 -0
  283. package/dist/core/hooks.d.ts +95 -0
  284. package/dist/core/hooks.d.ts.map +1 -0
  285. package/dist/core/hooks.js +239 -0
  286. package/dist/core/hooks.js.map +1 -0
  287. package/dist/core/index.d.ts +7 -0
  288. package/dist/core/index.d.ts.map +1 -0
  289. package/dist/core/index.js +7 -0
  290. package/dist/core/index.js.map +1 -0
  291. package/dist/core/inputProtection.d.ts +122 -0
  292. package/dist/core/inputProtection.d.ts.map +1 -0
  293. package/dist/core/inputProtection.js +422 -0
  294. package/dist/core/inputProtection.js.map +1 -0
  295. package/dist/core/modelDiscovery.d.ts +105 -0
  296. package/dist/core/modelDiscovery.d.ts.map +1 -0
  297. package/dist/core/modelDiscovery.js +768 -0
  298. package/dist/core/modelDiscovery.js.map +1 -0
  299. package/dist/core/multilinePasteHandler.d.ts +35 -0
  300. package/dist/core/multilinePasteHandler.d.ts.map +1 -0
  301. package/dist/core/multilinePasteHandler.js +81 -0
  302. package/dist/core/multilinePasteHandler.js.map +1 -0
  303. package/dist/core/preferences.d.ts +65 -0
  304. package/dist/core/preferences.d.ts.map +1 -0
  305. package/dist/core/preferences.js +305 -0
  306. package/dist/core/preferences.js.map +1 -0
  307. package/dist/core/projectTracker.d.ts +96 -0
  308. package/dist/core/projectTracker.d.ts.map +1 -0
  309. package/dist/core/projectTracker.js +275 -0
  310. package/dist/core/projectTracker.js.map +1 -0
  311. package/dist/core/providerKeys.d.ts +20 -0
  312. package/dist/core/providerKeys.d.ts.map +1 -0
  313. package/dist/core/providerKeys.js +40 -0
  314. package/dist/core/providerKeys.js.map +1 -0
  315. package/dist/core/refusalDetection.d.ts +2 -0
  316. package/dist/core/refusalDetection.d.ts.map +1 -0
  317. package/dist/core/refusalDetection.js +51 -0
  318. package/dist/core/refusalDetection.js.map +1 -0
  319. package/dist/core/resultVerification.d.ts +47 -0
  320. package/dist/core/resultVerification.d.ts.map +1 -0
  321. package/dist/core/resultVerification.js +126 -0
  322. package/dist/core/resultVerification.js.map +1 -0
  323. package/dist/core/reviewerGuard.d.ts +37 -0
  324. package/dist/core/reviewerGuard.d.ts.map +1 -0
  325. package/dist/core/reviewerGuard.js +188 -0
  326. package/dist/core/reviewerGuard.js.map +1 -0
  327. package/dist/core/schemaValidator.d.ts +49 -0
  328. package/dist/core/schemaValidator.d.ts.map +1 -0
  329. package/dist/core/schemaValidator.js +234 -0
  330. package/dist/core/schemaValidator.js.map +1 -0
  331. package/dist/core/secretStore.d.ts +48 -0
  332. package/dist/core/secretStore.d.ts.map +1 -0
  333. package/dist/core/secretStore.js +259 -0
  334. package/dist/core/secretStore.js.map +1 -0
  335. package/dist/core/sessionStorage.d.ts +10 -0
  336. package/dist/core/sessionStorage.d.ts.map +1 -0
  337. package/dist/core/sessionStorage.js +46 -0
  338. package/dist/core/sessionStorage.js.map +1 -0
  339. package/dist/core/sessionStore.d.ts +35 -0
  340. package/dist/core/sessionStore.d.ts.map +1 -0
  341. package/dist/core/sessionStore.js +191 -0
  342. package/dist/core/sessionStore.js.map +1 -0
  343. package/dist/core/sharedSecrets.d.ts +60 -0
  344. package/dist/core/sharedSecrets.d.ts.map +1 -0
  345. package/dist/core/sharedSecrets.js +111 -0
  346. package/dist/core/sharedSecrets.js.map +1 -0
  347. package/dist/core/shutdown.d.ts +34 -0
  348. package/dist/core/shutdown.d.ts.map +1 -0
  349. package/dist/core/shutdown.js +186 -0
  350. package/dist/core/shutdown.js.map +1 -0
  351. package/dist/core/sudoPasswordManager.d.ts +52 -0
  352. package/dist/core/sudoPasswordManager.d.ts.map +1 -0
  353. package/dist/core/sudoPasswordManager.js +115 -0
  354. package/dist/core/sudoPasswordManager.js.map +1 -0
  355. package/dist/core/taskCompletionDetector.d.ts +117 -0
  356. package/dist/core/taskCompletionDetector.d.ts.map +1 -0
  357. package/dist/core/taskCompletionDetector.js +532 -0
  358. package/dist/core/taskCompletionDetector.js.map +1 -0
  359. package/dist/core/testFailureMonitor.d.ts +67 -0
  360. package/dist/core/testFailureMonitor.d.ts.map +1 -0
  361. package/dist/core/testFailureMonitor.js +262 -0
  362. package/dist/core/testFailureMonitor.js.map +1 -0
  363. package/dist/core/toolPreconditions.d.ts +34 -0
  364. package/dist/core/toolPreconditions.d.ts.map +1 -0
  365. package/dist/core/toolPreconditions.js +242 -0
  366. package/dist/core/toolPreconditions.js.map +1 -0
  367. package/dist/core/toolRuntime.d.ts +192 -0
  368. package/dist/core/toolRuntime.d.ts.map +1 -0
  369. package/dist/core/toolRuntime.js +511 -0
  370. package/dist/core/toolRuntime.js.map +1 -0
  371. package/dist/core/types/utilityTypes.d.ts +183 -0
  372. package/dist/core/types/utilityTypes.d.ts.map +1 -0
  373. package/dist/core/types/utilityTypes.js +273 -0
  374. package/dist/core/types/utilityTypes.js.map +1 -0
  375. package/dist/core/types.d.ts +334 -0
  376. package/dist/core/types.d.ts.map +1 -0
  377. package/dist/core/types.js +76 -0
  378. package/dist/core/types.js.map +1 -0
  379. package/dist/core/updateChecker.d.ts +148 -0
  380. package/dist/core/updateChecker.d.ts.map +1 -0
  381. package/dist/core/updateChecker.js +599 -0
  382. package/dist/core/updateChecker.js.map +1 -0
  383. package/dist/core/usageTracker.d.ts +11 -0
  384. package/dist/core/usageTracker.d.ts.map +1 -0
  385. package/dist/core/usageTracker.js +128 -0
  386. package/dist/core/usageTracker.js.map +1 -0
  387. package/dist/core/userApproval.d.ts +95 -0
  388. package/dist/core/userApproval.d.ts.map +1 -0
  389. package/dist/core/userApproval.js +239 -0
  390. package/dist/core/userApproval.js.map +1 -0
  391. package/dist/headless/interactiveShell.d.ts +22 -0
  392. package/dist/headless/interactiveShell.d.ts.map +1 -0
  393. package/dist/headless/interactiveShell.js +2181 -0
  394. package/dist/headless/interactiveShell.js.map +1 -0
  395. package/dist/leanAgent.d.ts +73 -0
  396. package/dist/leanAgent.d.ts.map +1 -0
  397. package/dist/leanAgent.js +177 -0
  398. package/dist/leanAgent.js.map +1 -0
  399. package/dist/plugins/index.d.ts +49 -0
  400. package/dist/plugins/index.d.ts.map +1 -0
  401. package/dist/plugins/index.js +104 -0
  402. package/dist/plugins/index.js.map +1 -0
  403. package/dist/plugins/providers/anthropic/index.d.ts +9 -0
  404. package/dist/plugins/providers/anthropic/index.d.ts.map +1 -0
  405. package/dist/plugins/providers/anthropic/index.js +48 -0
  406. package/dist/plugins/providers/anthropic/index.js.map +1 -0
  407. package/dist/plugins/providers/deepseek/index.d.ts +11 -0
  408. package/dist/plugins/providers/deepseek/index.d.ts.map +1 -0
  409. package/dist/plugins/providers/deepseek/index.js +54 -0
  410. package/dist/plugins/providers/deepseek/index.js.map +1 -0
  411. package/dist/plugins/providers/index.d.ts +2 -0
  412. package/dist/plugins/providers/index.d.ts.map +1 -0
  413. package/dist/plugins/providers/index.js +17 -0
  414. package/dist/plugins/providers/index.js.map +1 -0
  415. package/dist/plugins/providers/openai/index.d.ts +10 -0
  416. package/dist/plugins/providers/openai/index.d.ts.map +1 -0
  417. package/dist/plugins/providers/openai/index.js +47 -0
  418. package/dist/plugins/providers/openai/index.js.map +1 -0
  419. package/dist/plugins/providers/xai/index.d.ts +10 -0
  420. package/dist/plugins/providers/xai/index.d.ts.map +1 -0
  421. package/dist/plugins/providers/xai/index.js +47 -0
  422. package/dist/plugins/providers/xai/index.js.map +1 -0
  423. package/dist/plugins/tools/agentSpawning/agentSpawningPlugin.d.ts +10 -0
  424. package/dist/plugins/tools/agentSpawning/agentSpawningPlugin.d.ts.map +1 -0
  425. package/dist/plugins/tools/agentSpawning/agentSpawningPlugin.js +110 -0
  426. package/dist/plugins/tools/agentSpawning/agentSpawningPlugin.js.map +1 -0
  427. package/dist/plugins/tools/bash/localBashPlugin.d.ts +3 -0
  428. package/dist/plugins/tools/bash/localBashPlugin.d.ts.map +1 -0
  429. package/dist/plugins/tools/bash/localBashPlugin.js +14 -0
  430. package/dist/plugins/tools/bash/localBashPlugin.js.map +1 -0
  431. package/dist/plugins/tools/edit/editPlugin.d.ts +9 -0
  432. package/dist/plugins/tools/edit/editPlugin.d.ts.map +1 -0
  433. package/dist/plugins/tools/edit/editPlugin.js +15 -0
  434. package/dist/plugins/tools/edit/editPlugin.js.map +1 -0
  435. package/dist/plugins/tools/enhancedGit/enhancedGitPlugin.d.ts +3 -0
  436. package/dist/plugins/tools/enhancedGit/enhancedGitPlugin.d.ts.map +1 -0
  437. package/dist/plugins/tools/enhancedGit/enhancedGitPlugin.js +9 -0
  438. package/dist/plugins/tools/enhancedGit/enhancedGitPlugin.js.map +1 -0
  439. package/dist/plugins/tools/filesystem/localFilesystemPlugin.d.ts +3 -0
  440. package/dist/plugins/tools/filesystem/localFilesystemPlugin.d.ts.map +1 -0
  441. package/dist/plugins/tools/filesystem/localFilesystemPlugin.js +14 -0
  442. package/dist/plugins/tools/filesystem/localFilesystemPlugin.js.map +1 -0
  443. package/dist/plugins/tools/gitHistory/gitHistoryPlugin.d.ts +3 -0
  444. package/dist/plugins/tools/gitHistory/gitHistoryPlugin.d.ts.map +1 -0
  445. package/dist/plugins/tools/gitHistory/gitHistoryPlugin.js +9 -0
  446. package/dist/plugins/tools/gitHistory/gitHistoryPlugin.js.map +1 -0
  447. package/dist/plugins/tools/index.d.ts +3 -0
  448. package/dist/plugins/tools/index.d.ts.map +1 -0
  449. package/dist/plugins/tools/index.js +3 -0
  450. package/dist/plugins/tools/index.js.map +1 -0
  451. package/dist/plugins/tools/integrity/integrityPlugin.d.ts +3 -0
  452. package/dist/plugins/tools/integrity/integrityPlugin.d.ts.map +1 -0
  453. package/dist/plugins/tools/integrity/integrityPlugin.js +31 -0
  454. package/dist/plugins/tools/integrity/integrityPlugin.js.map +1 -0
  455. package/dist/plugins/tools/kali/kaliPlugin.d.ts +3 -0
  456. package/dist/plugins/tools/kali/kaliPlugin.d.ts.map +1 -0
  457. package/dist/plugins/tools/kali/kaliPlugin.js +10 -0
  458. package/dist/plugins/tools/kali/kaliPlugin.js.map +1 -0
  459. package/dist/plugins/tools/mcp/mcpClient.d.ts +59 -0
  460. package/dist/plugins/tools/mcp/mcpClient.d.ts.map +1 -0
  461. package/dist/plugins/tools/mcp/mcpClient.js +118 -0
  462. package/dist/plugins/tools/mcp/mcpClient.js.map +1 -0
  463. package/dist/plugins/tools/mcp/mcpPlugin.d.ts +3 -0
  464. package/dist/plugins/tools/mcp/mcpPlugin.d.ts.map +1 -0
  465. package/dist/plugins/tools/mcp/mcpPlugin.js +10 -0
  466. package/dist/plugins/tools/mcp/mcpPlugin.js.map +1 -0
  467. package/dist/plugins/tools/nodeDefaults.d.ts +13 -0
  468. package/dist/plugins/tools/nodeDefaults.d.ts.map +1 -0
  469. package/dist/plugins/tools/nodeDefaults.js +37 -0
  470. package/dist/plugins/tools/nodeDefaults.js.map +1 -0
  471. package/dist/plugins/tools/orchestration/orchestrationPlugin.d.ts +3 -0
  472. package/dist/plugins/tools/orchestration/orchestrationPlugin.d.ts.map +1 -0
  473. package/dist/plugins/tools/orchestration/orchestrationPlugin.js +340 -0
  474. package/dist/plugins/tools/orchestration/orchestrationPlugin.js.map +1 -0
  475. package/dist/plugins/tools/registry.d.ts +22 -0
  476. package/dist/plugins/tools/registry.d.ts.map +1 -0
  477. package/dist/plugins/tools/registry.js +58 -0
  478. package/dist/plugins/tools/registry.js.map +1 -0
  479. package/dist/plugins/tools/search/localSearchPlugin.d.ts +3 -0
  480. package/dist/plugins/tools/search/localSearchPlugin.d.ts.map +1 -0
  481. package/dist/plugins/tools/search/localSearchPlugin.js +14 -0
  482. package/dist/plugins/tools/search/localSearchPlugin.js.map +1 -0
  483. package/dist/plugins/tools/skills/skillPlugin.d.ts +3 -0
  484. package/dist/plugins/tools/skills/skillPlugin.d.ts.map +1 -0
  485. package/dist/plugins/tools/skills/skillPlugin.js +27 -0
  486. package/dist/plugins/tools/skills/skillPlugin.js.map +1 -0
  487. package/dist/plugins/tools/todo/todoPlugin.d.ts +3 -0
  488. package/dist/plugins/tools/todo/todoPlugin.d.ts.map +1 -0
  489. package/dist/plugins/tools/todo/todoPlugin.js +10 -0
  490. package/dist/plugins/tools/todo/todoPlugin.js.map +1 -0
  491. package/dist/providers/baseProvider.d.ts +148 -0
  492. package/dist/providers/baseProvider.d.ts.map +1 -0
  493. package/dist/providers/baseProvider.js +284 -0
  494. package/dist/providers/baseProvider.js.map +1 -0
  495. package/dist/providers/openaiChatCompletionsProvider.d.ts +64 -0
  496. package/dist/providers/openaiChatCompletionsProvider.d.ts.map +1 -0
  497. package/dist/providers/openaiChatCompletionsProvider.js +1018 -0
  498. package/dist/providers/openaiChatCompletionsProvider.js.map +1 -0
  499. package/dist/providers/providerFactory.d.ts +22 -0
  500. package/dist/providers/providerFactory.d.ts.map +1 -0
  501. package/dist/providers/providerFactory.js +25 -0
  502. package/dist/providers/providerFactory.js.map +1 -0
  503. package/dist/providers/resilientProvider.d.ts +103 -0
  504. package/dist/providers/resilientProvider.d.ts.map +1 -0
  505. package/dist/providers/resilientProvider.js +468 -0
  506. package/dist/providers/resilientProvider.js.map +1 -0
  507. package/dist/runtime/agentController.d.ts +121 -0
  508. package/dist/runtime/agentController.d.ts.map +1 -0
  509. package/dist/runtime/agentController.js +739 -0
  510. package/dist/runtime/agentController.js.map +1 -0
  511. package/dist/runtime/agentHost.d.ts +61 -0
  512. package/dist/runtime/agentHost.d.ts.map +1 -0
  513. package/dist/runtime/agentHost.js +158 -0
  514. package/dist/runtime/agentHost.js.map +1 -0
  515. package/dist/runtime/agentSession.d.ts +49 -0
  516. package/dist/runtime/agentSession.d.ts.map +1 -0
  517. package/dist/runtime/agentSession.js +218 -0
  518. package/dist/runtime/agentSession.js.map +1 -0
  519. package/dist/runtime/agentSpawningWiring.d.ts +23 -0
  520. package/dist/runtime/agentSpawningWiring.d.ts.map +1 -0
  521. package/dist/runtime/agentSpawningWiring.js +119 -0
  522. package/dist/runtime/agentSpawningWiring.js.map +1 -0
  523. package/dist/runtime/agentWorkerPool.d.ts +167 -0
  524. package/dist/runtime/agentWorkerPool.d.ts.map +1 -0
  525. package/dist/runtime/agentWorkerPool.js +435 -0
  526. package/dist/runtime/agentWorkerPool.js.map +1 -0
  527. package/dist/runtime/node.d.ts +9 -0
  528. package/dist/runtime/node.d.ts.map +1 -0
  529. package/dist/runtime/node.js +112 -0
  530. package/dist/runtime/node.js.map +1 -0
  531. package/dist/runtime/phaseEmitter.d.ts +63 -0
  532. package/dist/runtime/phaseEmitter.d.ts.map +1 -0
  533. package/dist/runtime/phaseEmitter.js +207 -0
  534. package/dist/runtime/phaseEmitter.js.map +1 -0
  535. package/dist/runtime/profileGates.d.ts +19 -0
  536. package/dist/runtime/profileGates.d.ts.map +1 -0
  537. package/dist/runtime/profileGates.js +23 -0
  538. package/dist/runtime/profileGates.js.map +1 -0
  539. package/dist/runtime/universal.d.ts +18 -0
  540. package/dist/runtime/universal.d.ts.map +1 -0
  541. package/dist/runtime/universal.js +31 -0
  542. package/dist/runtime/universal.js.map +1 -0
  543. package/dist/shell/autoExecutor.d.ts +70 -0
  544. package/dist/shell/autoExecutor.d.ts.map +1 -0
  545. package/dist/shell/autoExecutor.js +320 -0
  546. package/dist/shell/autoExecutor.js.map +1 -0
  547. package/dist/shell/commandRegistry.d.ts +122 -0
  548. package/dist/shell/commandRegistry.d.ts.map +1 -0
  549. package/dist/shell/commandRegistry.js +355 -0
  550. package/dist/shell/commandRegistry.js.map +1 -0
  551. package/dist/shell/composableMessage.d.ts +178 -0
  552. package/dist/shell/composableMessage.d.ts.map +1 -0
  553. package/dist/shell/composableMessage.js +384 -0
  554. package/dist/shell/composableMessage.js.map +1 -0
  555. package/dist/shell/liveStatus.d.ts +27 -0
  556. package/dist/shell/liveStatus.d.ts.map +1 -0
  557. package/dist/shell/liveStatus.js +53 -0
  558. package/dist/shell/liveStatus.js.map +1 -0
  559. package/dist/shell/systemPrompt.d.ts +12 -0
  560. package/dist/shell/systemPrompt.d.ts.map +1 -0
  561. package/dist/shell/systemPrompt.js +16 -0
  562. package/dist/shell/systemPrompt.js.map +1 -0
  563. package/dist/shell/vimMode.d.ts +66 -0
  564. package/dist/shell/vimMode.d.ts.map +1 -0
  565. package/dist/shell/vimMode.js +435 -0
  566. package/dist/shell/vimMode.js.map +1 -0
  567. package/dist/tools/bashTools.d.ts +11 -0
  568. package/dist/tools/bashTools.d.ts.map +1 -0
  569. package/dist/tools/bashTools.js +779 -0
  570. package/dist/tools/bashTools.js.map +1 -0
  571. package/dist/tools/diffUtils.d.ts +43 -0
  572. package/dist/tools/diffUtils.d.ts.map +1 -0
  573. package/dist/tools/diffUtils.js +607 -0
  574. package/dist/tools/diffUtils.js.map +1 -0
  575. package/dist/tools/editTools.d.ts +29 -0
  576. package/dist/tools/editTools.d.ts.map +1 -0
  577. package/dist/tools/editTools.js +792 -0
  578. package/dist/tools/editTools.js.map +1 -0
  579. package/dist/tools/engagementTools.d.ts +45 -0
  580. package/dist/tools/engagementTools.d.ts.map +1 -0
  581. package/dist/tools/engagementTools.js +384 -0
  582. package/dist/tools/engagementTools.js.map +1 -0
  583. package/dist/tools/fileChangeTracker.d.ts +47 -0
  584. package/dist/tools/fileChangeTracker.d.ts.map +1 -0
  585. package/dist/tools/fileChangeTracker.js +154 -0
  586. package/dist/tools/fileChangeTracker.js.map +1 -0
  587. package/dist/tools/fileReadTracker.d.ts +69 -0
  588. package/dist/tools/fileReadTracker.d.ts.map +1 -0
  589. package/dist/tools/fileReadTracker.js +213 -0
  590. package/dist/tools/fileReadTracker.js.map +1 -0
  591. package/dist/tools/fileTools.d.ts +3 -0
  592. package/dist/tools/fileTools.d.ts.map +1 -0
  593. package/dist/tools/fileTools.js +389 -0
  594. package/dist/tools/fileTools.js.map +1 -0
  595. package/dist/tools/grepTools.d.ts +3 -0
  596. package/dist/tools/grepTools.d.ts.map +1 -0
  597. package/dist/tools/grepTools.js +128 -0
  598. package/dist/tools/grepTools.js.map +1 -0
  599. package/dist/tools/heliaControl.d.ts +51 -0
  600. package/dist/tools/heliaControl.d.ts.map +1 -0
  601. package/dist/tools/heliaControl.js +93 -0
  602. package/dist/tools/heliaControl.js.map +1 -0
  603. package/dist/tools/hitlTools.d.ts +7 -0
  604. package/dist/tools/hitlTools.d.ts.map +1 -0
  605. package/dist/tools/hitlTools.js +185 -0
  606. package/dist/tools/hitlTools.js.map +1 -0
  607. package/dist/tools/interactionTools.d.ts +16 -0
  608. package/dist/tools/interactionTools.d.ts.map +1 -0
  609. package/dist/tools/interactionTools.js +207 -0
  610. package/dist/tools/interactionTools.js.map +1 -0
  611. package/dist/tools/localExplore.d.ts +38 -0
  612. package/dist/tools/localExplore.d.ts.map +1 -0
  613. package/dist/tools/localExplore.js +30 -0
  614. package/dist/tools/localExplore.js.map +1 -0
  615. package/dist/tools/memoryTools.d.ts +20 -0
  616. package/dist/tools/memoryTools.d.ts.map +1 -0
  617. package/dist/tools/memoryTools.js +180 -0
  618. package/dist/tools/memoryTools.js.map +1 -0
  619. package/dist/tools/monitorTools.d.ts +16 -0
  620. package/dist/tools/monitorTools.d.ts.map +1 -0
  621. package/dist/tools/monitorTools.js +178 -0
  622. package/dist/tools/monitorTools.js.map +1 -0
  623. package/dist/tools/notebookTools.d.ts +20 -0
  624. package/dist/tools/notebookTools.d.ts.map +1 -0
  625. package/dist/tools/notebookTools.js +140 -0
  626. package/dist/tools/notebookTools.js.map +1 -0
  627. package/dist/tools/planModeTools.d.ts +32 -0
  628. package/dist/tools/planModeTools.d.ts.map +1 -0
  629. package/dist/tools/planModeTools.js +200 -0
  630. package/dist/tools/planModeTools.js.map +1 -0
  631. package/dist/tools/scheduleTools.d.ts +39 -0
  632. package/dist/tools/scheduleTools.d.ts.map +1 -0
  633. package/dist/tools/scheduleTools.js +182 -0
  634. package/dist/tools/scheduleTools.js.map +1 -0
  635. package/dist/tools/searchTools.d.ts +12 -0
  636. package/dist/tools/searchTools.d.ts.map +1 -0
  637. package/dist/tools/searchTools.js +413 -0
  638. package/dist/tools/searchTools.js.map +1 -0
  639. package/dist/tools/skillTools.d.ts +24 -0
  640. package/dist/tools/skillTools.d.ts.map +1 -0
  641. package/dist/tools/skillTools.js +140 -0
  642. package/dist/tools/skillTools.js.map +1 -0
  643. package/dist/tools/todoTools.d.ts +24 -0
  644. package/dist/tools/todoTools.d.ts.map +1 -0
  645. package/dist/tools/todoTools.js +115 -0
  646. package/dist/tools/todoTools.js.map +1 -0
  647. package/dist/tools/triggerTools.d.ts +28 -0
  648. package/dist/tools/triggerTools.d.ts.map +1 -0
  649. package/dist/tools/triggerTools.js +210 -0
  650. package/dist/tools/triggerTools.js.map +1 -0
  651. package/dist/tools/webTools.d.ts +26 -0
  652. package/dist/tools/webTools.d.ts.map +1 -0
  653. package/dist/tools/webTools.js +332 -0
  654. package/dist/tools/webTools.js.map +1 -0
  655. package/dist/tools/worktreeTools.d.ts +21 -0
  656. package/dist/tools/worktreeTools.d.ts.map +1 -0
  657. package/dist/tools/worktreeTools.js +158 -0
  658. package/dist/tools/worktreeTools.js.map +1 -0
  659. package/dist/ui/RenderGate.d.ts +83 -0
  660. package/dist/ui/RenderGate.d.ts.map +1 -0
  661. package/dist/ui/RenderGate.js +138 -0
  662. package/dist/ui/RenderGate.js.map +1 -0
  663. package/dist/ui/animatedStatus.d.ts +140 -0
  664. package/dist/ui/animatedStatus.d.ts.map +1 -0
  665. package/dist/ui/animatedStatus.js +480 -0
  666. package/dist/ui/animatedStatus.js.map +1 -0
  667. package/dist/ui/animation/AnimationScheduler.d.ts +197 -0
  668. package/dist/ui/animation/AnimationScheduler.d.ts.map +1 -0
  669. package/dist/ui/animation/AnimationScheduler.js +440 -0
  670. package/dist/ui/animation/AnimationScheduler.js.map +1 -0
  671. package/dist/ui/codeHighlighter.d.ts +6 -0
  672. package/dist/ui/codeHighlighter.d.ts.map +1 -0
  673. package/dist/ui/codeHighlighter.js +855 -0
  674. package/dist/ui/codeHighlighter.js.map +1 -0
  675. package/dist/ui/designSystem.d.ts +26 -0
  676. package/dist/ui/designSystem.d.ts.map +1 -0
  677. package/dist/ui/designSystem.js +114 -0
  678. package/dist/ui/designSystem.js.map +1 -0
  679. package/dist/ui/errorFormatter.d.ts +64 -0
  680. package/dist/ui/errorFormatter.d.ts.map +1 -0
  681. package/dist/ui/errorFormatter.js +316 -0
  682. package/dist/ui/errorFormatter.js.map +1 -0
  683. package/dist/ui/globalWriteLock.d.ts +63 -0
  684. package/dist/ui/globalWriteLock.d.ts.map +1 -0
  685. package/dist/ui/globalWriteLock.js +173 -0
  686. package/dist/ui/globalWriteLock.js.map +1 -0
  687. package/dist/ui/index.d.ts +31 -0
  688. package/dist/ui/index.d.ts.map +1 -0
  689. package/dist/ui/index.js +49 -0
  690. package/dist/ui/index.js.map +1 -0
  691. package/dist/ui/ink/App.d.ts +39 -0
  692. package/dist/ui/ink/App.d.ts.map +1 -0
  693. package/dist/ui/ink/App.js +19 -0
  694. package/dist/ui/ink/App.js.map +1 -0
  695. package/dist/ui/ink/ChatStatic.d.ts +29 -0
  696. package/dist/ui/ink/ChatStatic.d.ts.map +1 -0
  697. package/dist/ui/ink/ChatStatic.js +31 -0
  698. package/dist/ui/ink/ChatStatic.js.map +1 -0
  699. package/dist/ui/ink/InkPromptController.d.ts +286 -0
  700. package/dist/ui/ink/InkPromptController.d.ts.map +1 -0
  701. package/dist/ui/ink/InkPromptController.js +558 -0
  702. package/dist/ui/ink/InkPromptController.js.map +1 -0
  703. package/dist/ui/ink/Prompt.d.ts +36 -0
  704. package/dist/ui/ink/Prompt.d.ts.map +1 -0
  705. package/dist/ui/ink/Prompt.js +296 -0
  706. package/dist/ui/ink/Prompt.js.map +1 -0
  707. package/dist/ui/ink/StatusLine.d.ts +25 -0
  708. package/dist/ui/ink/StatusLine.d.ts.map +1 -0
  709. package/dist/ui/ink/StatusLine.js +12 -0
  710. package/dist/ui/ink/StatusLine.js.map +1 -0
  711. package/dist/ui/ink/adapter.d.ts +58 -0
  712. package/dist/ui/ink/adapter.d.ts.map +1 -0
  713. package/dist/ui/ink/adapter.js +113 -0
  714. package/dist/ui/ink/adapter.js.map +1 -0
  715. package/dist/ui/interrupts/InterruptManager.d.ts +157 -0
  716. package/dist/ui/interrupts/InterruptManager.d.ts.map +1 -0
  717. package/dist/ui/interrupts/InterruptManager.js +501 -0
  718. package/dist/ui/interrupts/InterruptManager.js.map +1 -0
  719. package/dist/ui/layout.d.ts +27 -0
  720. package/dist/ui/layout.d.ts.map +1 -0
  721. package/dist/ui/layout.js +184 -0
  722. package/dist/ui/layout.js.map +1 -0
  723. package/dist/ui/outputMode.d.ts +58 -0
  724. package/dist/ui/outputMode.d.ts.map +1 -0
  725. package/dist/ui/outputMode.js +179 -0
  726. package/dist/ui/outputMode.js.map +1 -0
  727. package/dist/ui/overlay/OverlayManager.d.ts +105 -0
  728. package/dist/ui/overlay/OverlayManager.d.ts.map +1 -0
  729. package/dist/ui/overlay/OverlayManager.js +304 -0
  730. package/dist/ui/overlay/OverlayManager.js.map +1 -0
  731. package/dist/ui/premiumComponents.d.ts +54 -0
  732. package/dist/ui/premiumComponents.d.ts.map +1 -0
  733. package/dist/ui/premiumComponents.js +241 -0
  734. package/dist/ui/premiumComponents.js.map +1 -0
  735. package/dist/ui/richText.d.ts +13 -0
  736. package/dist/ui/richText.d.ts.map +1 -0
  737. package/dist/ui/richText.js +444 -0
  738. package/dist/ui/richText.js.map +1 -0
  739. package/dist/ui/telemetry/ResponseTracker.d.ts +22 -0
  740. package/dist/ui/telemetry/ResponseTracker.d.ts.map +1 -0
  741. package/dist/ui/telemetry/ResponseTracker.js +60 -0
  742. package/dist/ui/telemetry/ResponseTracker.js.map +1 -0
  743. package/dist/ui/telemetry/UITelemetry.d.ts +181 -0
  744. package/dist/ui/telemetry/UITelemetry.d.ts.map +1 -0
  745. package/dist/ui/telemetry/UITelemetry.js +446 -0
  746. package/dist/ui/telemetry/UITelemetry.js.map +1 -0
  747. package/dist/ui/textHighlighter.d.ts +83 -0
  748. package/dist/ui/textHighlighter.d.ts.map +1 -0
  749. package/dist/ui/textHighlighter.js +267 -0
  750. package/dist/ui/textHighlighter.js.map +1 -0
  751. package/dist/ui/theme.d.ts +351 -0
  752. package/dist/ui/theme.d.ts.map +1 -0
  753. package/dist/ui/theme.js +436 -0
  754. package/dist/ui/theme.js.map +1 -0
  755. package/dist/ui/toolDisplay.d.ts +221 -0
  756. package/dist/ui/toolDisplay.d.ts.map +1 -0
  757. package/dist/ui/toolDisplay.js +1654 -0
  758. package/dist/ui/toolDisplay.js.map +1 -0
  759. package/dist/ui/uiConstants.d.ts +253 -0
  760. package/dist/ui/uiConstants.d.ts.map +1 -0
  761. package/dist/ui/uiConstants.js +437 -0
  762. package/dist/ui/uiConstants.js.map +1 -0
  763. package/dist/utils/analytics.d.ts +2 -0
  764. package/dist/utils/analytics.d.ts.map +1 -0
  765. package/dist/utils/analytics.js +51 -0
  766. package/dist/utils/analytics.js.map +1 -0
  767. package/dist/utils/askUserPrompt.d.ts +21 -0
  768. package/dist/utils/askUserPrompt.d.ts.map +1 -0
  769. package/dist/utils/askUserPrompt.js +87 -0
  770. package/dist/utils/askUserPrompt.js.map +1 -0
  771. package/dist/utils/asyncUtils.d.ts +95 -0
  772. package/dist/utils/asyncUtils.d.ts.map +1 -0
  773. package/dist/utils/asyncUtils.js +286 -0
  774. package/dist/utils/asyncUtils.js.map +1 -0
  775. package/dist/utils/debugLogger.d.ts +6 -0
  776. package/dist/utils/debugLogger.d.ts.map +1 -0
  777. package/dist/utils/debugLogger.js +39 -0
  778. package/dist/utils/debugLogger.js.map +1 -0
  779. package/dist/utils/errorUtils.d.ts +12 -0
  780. package/dist/utils/errorUtils.d.ts.map +1 -0
  781. package/dist/utils/errorUtils.js +83 -0
  782. package/dist/utils/errorUtils.js.map +1 -0
  783. package/dist/utils/frontmatter.d.ts +10 -0
  784. package/dist/utils/frontmatter.d.ts.map +1 -0
  785. package/dist/utils/frontmatter.js +78 -0
  786. package/dist/utils/frontmatter.js.map +1 -0
  787. package/dist/utils/lambdaClient.d.ts +35 -0
  788. package/dist/utils/lambdaClient.d.ts.map +1 -0
  789. package/dist/utils/lambdaClient.js +81 -0
  790. package/dist/utils/lambdaClient.js.map +1 -0
  791. package/dist/utils/packageInfo.d.ts +14 -0
  792. package/dist/utils/packageInfo.d.ts.map +1 -0
  793. package/dist/utils/packageInfo.js +45 -0
  794. package/dist/utils/packageInfo.js.map +1 -0
  795. package/dist/utils/planFormatter.d.ts +34 -0
  796. package/dist/utils/planFormatter.d.ts.map +1 -0
  797. package/dist/utils/planFormatter.js +141 -0
  798. package/dist/utils/planFormatter.js.map +1 -0
  799. package/dist/utils/projectRegistration.d.ts +61 -0
  800. package/dist/utils/projectRegistration.d.ts.map +1 -0
  801. package/dist/utils/projectRegistration.js +212 -0
  802. package/dist/utils/projectRegistration.js.map +1 -0
  803. package/dist/utils/securityUtils.d.ts +145 -0
  804. package/dist/utils/securityUtils.d.ts.map +1 -0
  805. package/dist/utils/securityUtils.js +507 -0
  806. package/dist/utils/securityUtils.js.map +1 -0
  807. package/dist/utils/statusReporter.d.ts +6 -0
  808. package/dist/utils/statusReporter.d.ts.map +1 -0
  809. package/dist/utils/statusReporter.js +26 -0
  810. package/dist/utils/statusReporter.js.map +1 -0
  811. package/dist/workspace.d.ts +8 -0
  812. package/dist/workspace.d.ts.map +1 -0
  813. package/dist/workspace.js +135 -0
  814. package/dist/workspace.js.map +1 -0
  815. package/dist/workspace.validator.d.ts +49 -0
  816. package/dist/workspace.validator.d.ts.map +1 -0
  817. package/dist/workspace.validator.js +215 -0
  818. package/dist/workspace.validator.js.map +1 -0
  819. package/package.json +1 -1
@@ -0,0 +1,274 @@
1
+ /**
2
+ * Operations-Center wiring for offsec capabilities.
3
+ *
4
+ * Every offsec tool wrapper (recon / web / llmRedteam / network / mobile)
5
+ * shares this single helper. It abstracts:
6
+ *
7
+ * • Engagement-scope enforcement (defence-in-depth — the Lambda
8
+ * re-checks server-side, but a CLI-side gate trips faster + emits
9
+ * a clearer error before any process spawns).
10
+ * • Long-running job lifecycle (start → append-log → progress →
11
+ * complete) routed through the existing cliJob* Lambda surface,
12
+ * which the portal's #jobsList rail listens to via Firestore.
13
+ * • HITL approval prompts (cliQuestionCreate / cliQuestionPoll) for
14
+ * destructive ops, so the operator can veto from the portal.
15
+ * • Findings emission with a unified schema — every tool's output
16
+ * normalised so the portal's #findingsList rail renders without
17
+ * per-tool special-casing.
18
+ *
19
+ * Tools that own a long-running scan should:
20
+ *
21
+ * const job = await opsCtx.startJob({ tool: 'garak', kind: 'llmRedteam',
22
+ * targetId, cmd: ['garak', ...] });
23
+ * for await (const line of job.lines()) {
24
+ * await job.appendLog(line);
25
+ * const finding = parse(line);
26
+ * if (finding) await opsCtx.emitFinding(finding);
27
+ * }
28
+ * await job.complete('done', { probesRun: N, findingsEmitted: M });
29
+ *
30
+ * The `lines()` iterator is backed by the existing Monitor capability
31
+ * (background spawn + streaming reader). Multiple jobs run concurrently
32
+ * without blocking the agent loop.
33
+ */
34
+ import { spawn } from 'node:child_process';
35
+ import { callLambda } from '../utils/lambdaClient.js';
36
+ import { logDebug } from '../utils/debugLogger.js';
37
+ import { ensureBinary } from './_processRunner.js';
38
+ // ── Implementation ────────────────────────────────────────────────
39
+ const FINDING_SEVERITIES = new Set(['info', 'low', 'medium', 'high', 'critical']);
40
+ const FINDING_SOURCES = new Set(['recon', 'web', 'llmRedteam', 'network', 'mobile', 'manual']);
41
+ function validateFindingDraft(d) {
42
+ if (!FINDING_SOURCES.has(d.source))
43
+ throw new Error(`invalid finding.source: ${d.source}`);
44
+ if (!FINDING_SEVERITIES.has(d.severity))
45
+ throw new Error(`invalid finding.severity: ${d.severity}`);
46
+ if (typeof d.tool !== 'string' || !d.tool)
47
+ throw new Error('finding.tool required');
48
+ if (typeof d.title !== 'string' || !d.title)
49
+ throw new Error('finding.title required');
50
+ if (typeof d.replication !== 'string')
51
+ throw new Error('finding.replication required');
52
+ }
53
+ /**
54
+ * Engagement scope cache. Reused across many startJob/assertInScope calls
55
+ * within a single agent turn so we don't hammer Firestore for the same
56
+ * scope doc. Cleared whenever the engagementId changes.
57
+ */
58
+ class ScopeCache {
59
+ cached = null;
60
+ async load(engagementId) {
61
+ if (this.cached && this.cached.engagementId === engagementId)
62
+ return this.cached.scope;
63
+ const r = await callLambda('cliEngagementGetScope', { engagementId });
64
+ if (!r.ok)
65
+ throw new Error(`scope fetch failed: ${r.error}`);
66
+ const scope = r.result?.scope || { hosts: [], cidrs: [], allowedTools: [] };
67
+ this.cached = { engagementId, scope };
68
+ return scope;
69
+ }
70
+ invalidate() { this.cached = null; }
71
+ }
72
+ function hostMatchesPattern(host, pattern) {
73
+ // Exact match.
74
+ if (host === pattern)
75
+ return true;
76
+ // Wildcard pattern like *.example.com.
77
+ if (pattern.startsWith('*.')) {
78
+ const suffix = pattern.slice(1); // ".example.com"
79
+ return host.endsWith(suffix) && host.length > suffix.length;
80
+ }
81
+ return false;
82
+ }
83
+ function isInScope(target, scope) {
84
+ const candidate = (target.host || (target.url && hostFromUrl(target.url)) ||
85
+ (target.endpoint && hostFromUrl(target.endpoint)) || '').toLowerCase();
86
+ if (!candidate)
87
+ return false;
88
+ if ((scope.deniedHosts || []).some((p) => hostMatchesPattern(candidate, p.toLowerCase())))
89
+ return false;
90
+ const hostHits = (scope.hosts || []).some((p) => hostMatchesPattern(candidate, p.toLowerCase()));
91
+ if (hostHits)
92
+ return true;
93
+ // CIDR check is best-effort — if the operator wrote one, we ask the
94
+ // Lambda to evaluate it (it has the IP-math lib loaded). Local check
95
+ // here would duplicate logic.
96
+ return false;
97
+ }
98
+ function hostFromUrl(value) {
99
+ try {
100
+ return new URL(value).hostname;
101
+ }
102
+ catch {
103
+ return null;
104
+ }
105
+ }
106
+ class NodeOpsContext {
107
+ engagementId;
108
+ uid;
109
+ scopeCache = new ScopeCache();
110
+ constructor(opts = {}) {
111
+ this.engagementId = opts.engagementId ?? null;
112
+ this.uid = opts.uid ?? null;
113
+ }
114
+ async assertInScope(target) {
115
+ if (!this.engagementId) {
116
+ // No engagement selected = no scope. Refuse — the operator must
117
+ // pick an engagement before any offsec tool fires. This also
118
+ // means the Lambda's defence-in-depth check has a non-null
119
+ // engagementId to evaluate against.
120
+ throw new Error('no engagement selected — pick one in the portal before running offsec tools');
121
+ }
122
+ const scope = await this.scopeCache.load(this.engagementId);
123
+ if (!isInScope(target, scope)) {
124
+ const t = target.host || target.url || target.endpoint || '<unknown>';
125
+ throw new Error(`target ${t} is OUT OF SCOPE for engagement ${this.engagementId}. ` +
126
+ `Edit the engagement scope in the portal before retrying.`);
127
+ }
128
+ }
129
+ async startJob(spec) {
130
+ // Cross-platform preflight (see _processRunner.ts comment): throws
131
+ // BinaryMissingError with the install hint for this operator's OS
132
+ // BEFORE we register a Job doc, so a missing binary doesn't leave
133
+ // a phantom "running" row in the portal that never completes.
134
+ await ensureBinary(spec.cmd[0]);
135
+ if (this.engagementId && (spec.engagementId == null))
136
+ spec.engagementId = this.engagementId;
137
+ const r = await callLambda('cliJobStart', {
138
+ tool: spec.tool, kind: spec.kind,
139
+ engagementId: spec.engagementId ?? null, targetId: spec.targetId ?? null,
140
+ status: 'running',
141
+ cmd: spec.cmd.slice(0, 64), // truncate long argv
142
+ });
143
+ if (!r.ok || !r.result?.id)
144
+ throw new Error(`cliJobStart failed: ${r.error}`);
145
+ const jobId = r.result.id;
146
+ const child = spawn(spec.cmd[0], spec.cmd.slice(1), {
147
+ cwd: spec.cwd, env: { ...process.env, ...(spec.env || {}) },
148
+ stdio: ['ignore', 'pipe', 'pipe'],
149
+ });
150
+ const timeoutMs = spec.timeoutMs ?? 30 * 60 * 1000;
151
+ const killTimer = setTimeout(() => {
152
+ try {
153
+ child.kill('SIGTERM');
154
+ }
155
+ catch (_) { }
156
+ setTimeout(() => { try {
157
+ child.kill('SIGKILL');
158
+ }
159
+ catch (_) { } }, 1500);
160
+ }, timeoutMs);
161
+ const handle = {
162
+ id: jobId,
163
+ lines: () => readlines(child),
164
+ appendLog: (line) => callLambda('cliJobAppendLog', { jobId, line: String(line).slice(0, 8 * 1024) })
165
+ .then((res) => { if (!res.ok)
166
+ logDebug('[Ops] appendLog failed', res.error); }),
167
+ setProgress: (pct, lastLine) => callLambda('cliJobUpdate', {
168
+ id: jobId, pct: Math.max(0, Math.min(100, Math.round(pct))),
169
+ lastLine: lastLine ? String(lastLine).slice(0, 1024) : null,
170
+ }).then((res) => { if (!res.ok)
171
+ logDebug('[Ops] setProgress failed', res.error); }),
172
+ complete: async (status, summary = {}) => {
173
+ clearTimeout(killTimer);
174
+ await callLambda('cliJobComplete', { id: jobId, status, summary });
175
+ },
176
+ cancel: () => {
177
+ clearTimeout(killTimer);
178
+ try {
179
+ child.kill('SIGTERM');
180
+ }
181
+ catch (_) { }
182
+ },
183
+ };
184
+ return handle;
185
+ }
186
+ async requestApproval(req) {
187
+ if (!Array.isArray(req.options) || req.options.length < 2) {
188
+ throw new Error('requestApproval needs ≥2 options');
189
+ }
190
+ const create = await callLambda('cliQuestionCreate', {
191
+ question: `[${req.severity.toUpperCase()}] ${req.question}`,
192
+ header: req.severity,
193
+ multiSelect: false,
194
+ options: req.options.map((o) => ({ label: o.label, description: o.description || '' })),
195
+ });
196
+ if (!create.ok || !create.result?.id)
197
+ throw new Error(`HITL create failed: ${create.error}`);
198
+ const id = create.result.id;
199
+ const timeoutSec = req.timeoutSec ?? 300;
200
+ const deadline = Date.now() + timeoutSec * 1000;
201
+ while (Date.now() < deadline) {
202
+ await new Promise((r) => setTimeout(r, 2000));
203
+ const poll = await callLambda('cliQuestionPoll', { id });
204
+ if (poll.ok && poll.result?.answered) {
205
+ const sel = poll.result.selected?.[0];
206
+ if (typeof sel === 'string')
207
+ return sel;
208
+ }
209
+ }
210
+ if (req.defaultOnTimeout === 'proceed')
211
+ return req.options[0].label;
212
+ throw new Error(`HITL timed out after ${timeoutSec}s — operator did not answer in the portal`);
213
+ }
214
+ async emitFinding(draft) {
215
+ if (this.engagementId && draft.engagementId == null)
216
+ draft.engagementId = this.engagementId;
217
+ validateFindingDraft(draft);
218
+ const r = await callLambda('cliFindingEmit', draft);
219
+ if (!r.ok || !r.result?.id)
220
+ throw new Error(`emitFinding failed: ${r.error}`);
221
+ return r.result.id;
222
+ }
223
+ }
224
+ /**
225
+ * Async iterator over a child's stdout + stderr, yielding one line at a
226
+ * time. Both streams are merged so the order in `lines()` matches the
227
+ * order the process actually printed them.
228
+ */
229
+ async function* readlines(child) {
230
+ const queue = [];
231
+ let resolveNext = null;
232
+ let done = false;
233
+ function pushChunk(buf) {
234
+ const text = buf.toString('utf8');
235
+ for (const line of text.split(/\r?\n/))
236
+ if (line.length)
237
+ queue.push(line);
238
+ if (resolveNext) {
239
+ const r = resolveNext;
240
+ resolveNext = null;
241
+ r();
242
+ }
243
+ }
244
+ child.stdout.on('data', pushChunk);
245
+ child.stderr.on('data', pushChunk);
246
+ child.on('close', () => { done = true; if (resolveNext) {
247
+ const r = resolveNext;
248
+ resolveNext = null;
249
+ r();
250
+ } });
251
+ child.on('error', () => { done = true; if (resolveNext) {
252
+ const r = resolveNext;
253
+ resolveNext = null;
254
+ r();
255
+ } });
256
+ while (true) {
257
+ if (queue.length) {
258
+ yield queue.shift();
259
+ continue;
260
+ }
261
+ if (done)
262
+ return;
263
+ await new Promise((r) => { resolveNext = r; });
264
+ }
265
+ }
266
+ /**
267
+ * Build an OpsContext for a CLI agent session. The engagementId can be
268
+ * threaded in from the active engagement (set via the portal or
269
+ * EngagementCapability tool calls).
270
+ */
271
+ export function createOpsContext(opts = {}) {
272
+ return new NodeOpsContext(opts);
273
+ }
274
+ //# sourceMappingURL=_opsContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_opsContext.js","sourceRoot":"","sources":["../../src/capabilities/_opsContext.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,49 @@
1
+ export interface BinaryMissingErrorInfo {
2
+ bin: string;
3
+ message: string;
4
+ installCommand: string | null;
5
+ installChannel: string | null;
6
+ platformNote: string | null;
7
+ capability: string | null;
8
+ /** True when the bin has no plausibly-native install path on this platform. */
9
+ unsupportedOnPlatform: boolean;
10
+ }
11
+ export declare class BinaryMissingError extends Error {
12
+ readonly code = "binary-missing";
13
+ readonly info: BinaryMissingErrorInfo;
14
+ constructor(info: BinaryMissingErrorInfo);
15
+ }
16
+ /**
17
+ * Throws `BinaryMissingError` if the binary isn't on PATH. Every
18
+ * offsec capability tool handler should call this first.
19
+ *
20
+ * Tool handlers should NOT catch the error themselves — let it
21
+ * propagate so the agent loop's tool-error formatter wraps it
22
+ * uniformly.
23
+ */
24
+ export declare function ensureBinary(bin: string): Promise<void>;
25
+ /**
26
+ * Non-throwing variant — returns true/false. Use when the caller
27
+ * wants to render a "(unavailable)" badge in the tool inventory
28
+ * rather than fail the call.
29
+ */
30
+ export declare function isBinaryAvailable(bin: string): Promise<boolean>;
31
+ /** Reset the availability cache. Tests + the post-`offsec install` flow use this. */
32
+ export declare function clearBinaryAvailabilityCache(): void;
33
+ export interface RunResult {
34
+ stdout: string;
35
+ stderr: string;
36
+ exitCode: number | null;
37
+ signal: NodeJS.Signals | null;
38
+ truncated: boolean;
39
+ }
40
+ export interface RunOptions {
41
+ timeoutMs?: number;
42
+ cwd?: string;
43
+ stdin?: string;
44
+ env?: Record<string, string>;
45
+ maxOutputBytes?: number;
46
+ }
47
+ export declare function runBinary(command: string, args: string[], options?: RunOptions): Promise<RunResult>;
48
+ export declare function formatResult(command: string, args: string[], result: RunResult): string;
49
+ //# sourceMappingURL=_processRunner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_processRunner.d.ts","sourceRoot":"","sources":["../../src/capabilities/_processRunner.ts"],"names":[],"mappings":"AAkCA,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;IAChB,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,+EAA+E;IAC/E,qBAAqB,EAAE,OAAO,CAAC;CAChC;AAED,qBAAa,kBAAmB,SAAQ,KAAK;IAC3C,QAAQ,CAAC,IAAI,oBAAoB;IACjC,QAAQ,CAAC,IAAI,EAAE,sBAAsB,CAAC;gBAC1B,IAAI,EAAE,sBAAsB;CAKzC;AAmBD;;;;;;;GAOG;AACH,wBAAsB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAQ7D;AAED;;;;GAIG;AACH,wBAAsB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAMrE;AAED,qFAAqF;AACrF,wBAAgB,4BAA4B,IAAI,IAAI,CAEnD;AAuDD,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC;IAC9B,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,UAAU;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAKD,wBAAsB,SAAS,CAC7B,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,MAAM,EAAE,EACd,OAAO,GAAE,UAAe,GACvB,OAAO,CAAC,SAAS,CAAC,CAkEpB;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,SAAS,GAAG,MAAM,CAQvF"}
@@ -0,0 +1,200 @@
1
+ import { spawn } from 'node:child_process';
2
+ import { promisify } from 'node:util';
3
+ import { execFile } from 'node:child_process';
4
+ import { findRequirement, pickInstallCommand, isNativelyAvailable, platformNote, } from './_binaryRequirements.js';
5
+ const execFileP = promisify(execFile);
6
+ export class BinaryMissingError extends Error {
7
+ code = 'binary-missing';
8
+ info;
9
+ constructor(info) {
10
+ super(info.message);
11
+ this.info = info;
12
+ this.name = 'BinaryMissingError';
13
+ }
14
+ }
15
+ const BINARY_AVAILABILITY_CACHE = new Map();
16
+ async function checkPathBinary(bin) {
17
+ // `which` (POSIX) / `where` (Windows) — both exit 0 when the
18
+ // executable is found on PATH. We use the OS lookup rather than
19
+ // probing `bin --version` because some offsec tools (afl-fuzz,
20
+ // ghidra) take seconds to print --version, which would gate the
21
+ // agent loop on cold-start runtime cost.
22
+ const cmd = process.platform === 'win32' ? 'where' : 'which';
23
+ try {
24
+ await execFileP(cmd, [bin], { timeout: 3000 });
25
+ return true;
26
+ }
27
+ catch {
28
+ return false;
29
+ }
30
+ }
31
+ /**
32
+ * Throws `BinaryMissingError` if the binary isn't on PATH. Every
33
+ * offsec capability tool handler should call this first.
34
+ *
35
+ * Tool handlers should NOT catch the error themselves — let it
36
+ * propagate so the agent loop's tool-error formatter wraps it
37
+ * uniformly.
38
+ */
39
+ export async function ensureBinary(bin) {
40
+ const cached = BINARY_AVAILABILITY_CACHE.get(bin);
41
+ if (cached === true)
42
+ return;
43
+ if (cached === false)
44
+ throw makeMissingError(bin);
45
+ const present = await checkPathBinary(bin);
46
+ BINARY_AVAILABILITY_CACHE.set(bin, present);
47
+ if (!present)
48
+ throw makeMissingError(bin);
49
+ }
50
+ /**
51
+ * Non-throwing variant — returns true/false. Use when the caller
52
+ * wants to render a "(unavailable)" badge in the tool inventory
53
+ * rather than fail the call.
54
+ */
55
+ export async function isBinaryAvailable(bin) {
56
+ const cached = BINARY_AVAILABILITY_CACHE.get(bin);
57
+ if (cached !== undefined)
58
+ return cached;
59
+ const present = await checkPathBinary(bin);
60
+ BINARY_AVAILABILITY_CACHE.set(bin, present);
61
+ return present;
62
+ }
63
+ /** Reset the availability cache. Tests + the post-`offsec install` flow use this. */
64
+ export function clearBinaryAvailabilityCache() {
65
+ BINARY_AVAILABILITY_CACHE.clear();
66
+ }
67
+ function makeMissingError(bin) {
68
+ const req = findRequirement(bin);
69
+ if (!req) {
70
+ // Bin we don't track — agent capability is calling something
71
+ // outside the manifest. Surface that explicitly so the operator
72
+ // can add it to _binaryRequirements.ts.
73
+ return new BinaryMissingError({
74
+ bin,
75
+ message: `Binary "${bin}" not found on PATH and not in the offsec requirements manifest. Add it to src/capabilities/_binaryRequirements.ts.`,
76
+ installCommand: null,
77
+ installChannel: null,
78
+ platformNote: null,
79
+ capability: null,
80
+ unsupportedOnPlatform: false,
81
+ });
82
+ }
83
+ const native = isNativelyAvailable(req);
84
+ const note = platformNote(req);
85
+ const pick = pickInstallCommand(req);
86
+ // Build the message body. Three branches matching the table above.
87
+ let message;
88
+ if (native && pick) {
89
+ message =
90
+ `Binary "${bin}" required by capability "${req.capability}" but not on PATH.\n\n` +
91
+ `${req.description}\n\n` +
92
+ `Install (${pick.channel}):\n` +
93
+ ` ${pick.cmd}\n\n` +
94
+ `Or run: erosolar offsec install --capability ${req.capability}`;
95
+ }
96
+ else if (note) {
97
+ message =
98
+ `Binary "${bin}" required by capability "${req.capability}" is not natively packaged for ${process.platform}.\n\n` +
99
+ `${req.description}\n\n` +
100
+ `${note}`;
101
+ }
102
+ else if (pick) {
103
+ message =
104
+ `Binary "${bin}" required by capability "${req.capability}" but not on PATH.\n` +
105
+ `Install (${pick.channel}): ${pick.cmd}`;
106
+ }
107
+ else {
108
+ message =
109
+ `Binary "${bin}" required by capability "${req.capability}" but no install path is registered for ${process.platform}. ` +
110
+ `Use WSL2 (Windows) or a Docker container.`;
111
+ }
112
+ return new BinaryMissingError({
113
+ bin,
114
+ message,
115
+ installCommand: pick?.cmd ?? null,
116
+ installChannel: pick?.channel ?? null,
117
+ platformNote: note,
118
+ capability: req.capability,
119
+ unsupportedOnPlatform: !native,
120
+ });
121
+ }
122
+ const DEFAULT_TIMEOUT_MS = 5 * 60 * 1000;
123
+ const DEFAULT_MAX_OUTPUT = 1 * 1024 * 1024;
124
+ export async function runBinary(command, args, options = {}) {
125
+ // Cross-platform preflight: refuse with a clean BinaryMissingError
126
+ // (carrying the install hint for the operator's OS, or the
127
+ // 'use WSL2' note when no native channel exists) instead of letting
128
+ // ENOENT bubble. Bins not in the manifest fall through with a
129
+ // descriptive error pointing at _binaryRequirements.ts.
130
+ await ensureBinary(command);
131
+ return new Promise((resolve, reject) => {
132
+ const maxBytes = options.maxOutputBytes ?? DEFAULT_MAX_OUTPUT;
133
+ const spawnOpts = {
134
+ cwd: options.cwd,
135
+ stdio: [options.stdin !== undefined ? 'pipe' : 'ignore', 'pipe', 'pipe'],
136
+ };
137
+ if (options.env) {
138
+ spawnOpts.env = { ...process.env, ...options.env };
139
+ }
140
+ const child = spawn(command, args, spawnOpts);
141
+ let stdoutBytes = 0;
142
+ let stderrBytes = 0;
143
+ let truncated = false;
144
+ const stdoutChunks = [];
145
+ const stderrChunks = [];
146
+ const append = (chunks, buf, isStdout) => {
147
+ const used = isStdout ? stdoutBytes : stderrBytes;
148
+ const room = maxBytes - used;
149
+ if (room <= 0) {
150
+ truncated = true;
151
+ return;
152
+ }
153
+ const slice = buf.length > room ? buf.subarray(0, room) : buf;
154
+ chunks.push(slice.toString());
155
+ if (isStdout)
156
+ stdoutBytes += slice.length;
157
+ else
158
+ stderrBytes += slice.length;
159
+ if (buf.length > room)
160
+ truncated = true;
161
+ };
162
+ child.stdout?.on('data', (d) => append(stdoutChunks, d, true));
163
+ child.stderr?.on('data', (d) => append(stderrChunks, d, false));
164
+ if (options.stdin !== undefined && child.stdin) {
165
+ child.stdin.write(options.stdin);
166
+ child.stdin.end();
167
+ }
168
+ const timeout = setTimeout(() => {
169
+ child.kill('SIGTERM');
170
+ setTimeout(() => child.kill('SIGKILL'), 1000);
171
+ }, options.timeoutMs ?? DEFAULT_TIMEOUT_MS);
172
+ child.on('error', (err) => {
173
+ clearTimeout(timeout);
174
+ reject(err);
175
+ });
176
+ child.on('close', (code, signal) => {
177
+ clearTimeout(timeout);
178
+ resolve({
179
+ stdout: stdoutChunks.join(''),
180
+ stderr: stderrChunks.join(''),
181
+ exitCode: code,
182
+ signal,
183
+ truncated,
184
+ });
185
+ });
186
+ });
187
+ }
188
+ export function formatResult(command, args, result) {
189
+ const lines = [];
190
+ lines.push(`$ ${command} ${args.join(' ')}`);
191
+ lines.push(`exit ${result.exitCode ?? 'null'}${result.signal ? ` (signal ${result.signal})` : ''}`);
192
+ if (result.truncated)
193
+ lines.push('[output truncated]');
194
+ if (result.stdout)
195
+ lines.push('--- stdout ---', result.stdout.trimEnd());
196
+ if (result.stderr)
197
+ lines.push('--- stderr ---', result.stderr.trimEnd());
198
+ return lines.join('\n');
199
+ }
200
+ //# sourceMappingURL=_processRunner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_processRunner.js","sourceRoot":"","sources":["../../src/capabilities/_processRunner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import type { CapabilityContext, CapabilityContribution, CapabilityModule } from '../runtime/agentHost.js';
2
+ export declare class AflppCapabilityModule implements CapabilityModule {
3
+ readonly id = "capability.aflpp";
4
+ readonly description = "AFL++ fuzzer wrappers \u2014 afl_compile_harness, afl_fuzz_start (detached), afl_fuzz_status (auto-registers crash files in the artifact store), afl_fuzz_stop, afl_showmap, afl_cmin, afl_tmin. Long campaigns run as detached background processes addressed by jobId.";
5
+ create(_context: CapabilityContext): Promise<CapabilityContribution>;
6
+ }
7
+ //# sourceMappingURL=aflppCapability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"aflppCapability.d.ts","sourceRoot":"","sources":["../../src/capabilities/aflppCapability.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AA2R3G,qBAAa,qBAAsB,YAAW,gBAAgB;IAC5D,QAAQ,CAAC,EAAE,sBAAsB;IACjC,QAAQ,CAAC,WAAW,8QAAyQ;IAEvR,MAAM,CAAC,QAAQ,EAAE,iBAAiB,GAAG,OAAO,CAAC,sBAAsB,CAAC;CAU3E"}