@qduc/term2 0.1.0

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 (621) hide show
  1. package/LICENSE +21 -0
  2. package/dist/agent.d.ts +19 -0
  3. package/dist/agent.d.ts.map +1 -0
  4. package/dist/agent.js +143 -0
  5. package/dist/agent.js.map +1 -0
  6. package/dist/app.d.ts +22 -0
  7. package/dist/app.d.ts.map +1 -0
  8. package/dist/app.js +403 -0
  9. package/dist/app.js.map +1 -0
  10. package/dist/app.model-command-feedback.test.d.ts +2 -0
  11. package/dist/app.model-command-feedback.test.d.ts.map +1 -0
  12. package/dist/app.model-command-feedback.test.js +19 -0
  13. package/dist/app.model-command-feedback.test.js.map +1 -0
  14. package/dist/app.parseInput.test.d.ts +2 -0
  15. package/dist/app.parseInput.test.d.ts.map +1 -0
  16. package/dist/app.parseInput.test.js +97 -0
  17. package/dist/app.parseInput.test.js.map +1 -0
  18. package/dist/cli.d.ts +3 -0
  19. package/dist/cli.d.ts.map +1 -0
  20. package/dist/cli.js +241 -0
  21. package/dist/cli.js.map +1 -0
  22. package/dist/components/ApprovalPrompt.d.ts +10 -0
  23. package/dist/components/ApprovalPrompt.d.ts.map +1 -0
  24. package/dist/components/ApprovalPrompt.js +163 -0
  25. package/dist/components/ApprovalPrompt.js.map +1 -0
  26. package/dist/components/Banner.d.ts +9 -0
  27. package/dist/components/Banner.d.ts.map +1 -0
  28. package/dist/components/Banner.js +86 -0
  29. package/dist/components/Banner.js.map +1 -0
  30. package/dist/components/BottomArea.d.ts +33 -0
  31. package/dist/components/BottomArea.d.ts.map +1 -0
  32. package/dist/components/BottomArea.js +31 -0
  33. package/dist/components/BottomArea.js.map +1 -0
  34. package/dist/components/BottomArea.test.d.ts +2 -0
  35. package/dist/components/BottomArea.test.d.ts.map +1 -0
  36. package/dist/components/BottomArea.test.js +73 -0
  37. package/dist/components/BottomArea.test.js.map +1 -0
  38. package/dist/components/ChatMessage.d.ts +7 -0
  39. package/dist/components/ChatMessage.d.ts.map +1 -0
  40. package/dist/components/ChatMessage.js +10 -0
  41. package/dist/components/ChatMessage.js.map +1 -0
  42. package/dist/components/CommandMessage.d.ts +15 -0
  43. package/dist/components/CommandMessage.d.ts.map +1 -0
  44. package/dist/components/CommandMessage.js +188 -0
  45. package/dist/components/CommandMessage.js.map +1 -0
  46. package/dist/components/CommandMessage.test.d.ts +2 -0
  47. package/dist/components/CommandMessage.test.d.ts.map +1 -0
  48. package/dist/components/CommandMessage.test.js +35 -0
  49. package/dist/components/CommandMessage.test.js.map +1 -0
  50. package/dist/components/ErrorBoundary.d.ts +27 -0
  51. package/dist/components/ErrorBoundary.d.ts.map +1 -0
  52. package/dist/components/ErrorBoundary.js +77 -0
  53. package/dist/components/ErrorBoundary.js.map +1 -0
  54. package/dist/components/ErrorBoundary.test.d.ts +2 -0
  55. package/dist/components/ErrorBoundary.test.d.ts.map +1 -0
  56. package/dist/components/ErrorBoundary.test.js +32 -0
  57. package/dist/components/ErrorBoundary.test.js.map +1 -0
  58. package/dist/components/Input/PopupManager.d.ts +42 -0
  59. package/dist/components/Input/PopupManager.d.ts.map +1 -0
  60. package/dist/components/Input/PopupManager.js +13 -0
  61. package/dist/components/Input/PopupManager.js.map +1 -0
  62. package/dist/components/InputBox.d.ts +18 -0
  63. package/dist/components/InputBox.d.ts.map +1 -0
  64. package/dist/components/InputBox.js +384 -0
  65. package/dist/components/InputBox.js.map +1 -0
  66. package/dist/components/InputBox.menu-logic.test.d.ts +2 -0
  67. package/dist/components/InputBox.menu-logic.test.d.ts.map +1 -0
  68. package/dist/components/InputBox.menu-logic.test.js +151 -0
  69. package/dist/components/InputBox.menu-logic.test.js.map +1 -0
  70. package/dist/components/InputBox.test.d.ts +2 -0
  71. package/dist/components/InputBox.test.d.ts.map +1 -0
  72. package/dist/components/InputBox.test.js +91 -0
  73. package/dist/components/InputBox.test.js.map +1 -0
  74. package/dist/components/LiveResponse.d.ts +13 -0
  75. package/dist/components/LiveResponse.d.ts.map +1 -0
  76. package/dist/components/LiveResponse.js +16 -0
  77. package/dist/components/LiveResponse.js.map +1 -0
  78. package/dist/components/MarkdownRenderer.d.ts +8 -0
  79. package/dist/components/MarkdownRenderer.d.ts.map +1 -0
  80. package/dist/components/MarkdownRenderer.js +225 -0
  81. package/dist/components/MarkdownRenderer.js.map +1 -0
  82. package/dist/components/MentorMode.test.d.ts +2 -0
  83. package/dist/components/MentorMode.test.d.ts.map +1 -0
  84. package/dist/components/MentorMode.test.js.map +1 -0
  85. package/dist/components/MessageList.d.ts +7 -0
  86. package/dist/components/MessageList.d.ts.map +1 -0
  87. package/dist/components/MessageList.js +29 -0
  88. package/dist/components/MessageList.js.map +1 -0
  89. package/dist/components/MessageList.test.d.ts +2 -0
  90. package/dist/components/MessageList.test.d.ts.map +1 -0
  91. package/dist/components/MessageList.test.js +15 -0
  92. package/dist/components/MessageList.test.js.map +1 -0
  93. package/dist/components/ModelSelectionMenu.d.ts +18 -0
  94. package/dist/components/ModelSelectionMenu.d.ts.map +1 -0
  95. package/dist/components/ModelSelectionMenu.js +91 -0
  96. package/dist/components/ModelSelectionMenu.js.map +1 -0
  97. package/dist/components/ModelSelectionMenu.test.d.ts +2 -0
  98. package/dist/components/ModelSelectionMenu.test.d.ts.map +1 -0
  99. package/dist/components/ModelSelectionMenu.test.js +83 -0
  100. package/dist/components/ModelSelectionMenu.test.js.map +1 -0
  101. package/dist/components/PathSelectionMenu.d.ts +12 -0
  102. package/dist/components/PathSelectionMenu.d.ts.map +1 -0
  103. package/dist/components/PathSelectionMenu.js +42 -0
  104. package/dist/components/PathSelectionMenu.js.map +1 -0
  105. package/dist/components/SettingsSelectionMenu.d.ts +9 -0
  106. package/dist/components/SettingsSelectionMenu.d.ts.map +1 -0
  107. package/dist/components/SettingsSelectionMenu.js +21 -0
  108. package/dist/components/SettingsSelectionMenu.js.map +1 -0
  109. package/dist/components/SlashCommandMenu.d.ts +15 -0
  110. package/dist/components/SlashCommandMenu.d.ts.map +1 -0
  111. package/dist/components/SlashCommandMenu.js +20 -0
  112. package/dist/components/SlashCommandMenu.js.map +1 -0
  113. package/dist/components/StatusBar.d.ts +11 -0
  114. package/dist/components/StatusBar.d.ts.map +1 -0
  115. package/dist/components/StatusBar.js +59 -0
  116. package/dist/components/StatusBar.js.map +1 -0
  117. package/dist/components/TextInput.d.ts +42 -0
  118. package/dist/components/TextInput.d.ts.map +1 -0
  119. package/dist/components/TextInput.js +397 -0
  120. package/dist/components/TextInput.js.map +1 -0
  121. package/dist/components/TextInput.test.d.ts +2 -0
  122. package/dist/components/TextInput.test.d.ts.map +1 -0
  123. package/dist/components/TextInput.test.js +75 -0
  124. package/dist/components/TextInput.test.js.map +1 -0
  125. package/dist/context/InputContext.d.ts +31 -0
  126. package/dist/context/InputContext.d.ts.map +1 -0
  127. package/dist/context/InputContext.js +36 -0
  128. package/dist/context/InputContext.js.map +1 -0
  129. package/dist/context/InputContext.stability.test.d.ts +2 -0
  130. package/dist/context/InputContext.stability.test.d.ts.map +1 -0
  131. package/dist/context/InputContext.stability.test.js +28 -0
  132. package/dist/context/InputContext.stability.test.js.map +1 -0
  133. package/dist/context/InputContext.test.d.ts +2 -0
  134. package/dist/context/InputContext.test.d.ts.map +1 -0
  135. package/dist/context/InputContext.test.js +168 -0
  136. package/dist/context/InputContext.test.js.map +1 -0
  137. package/dist/debug-schema.d.ts +2 -0
  138. package/dist/debug-schema.d.ts.map +1 -0
  139. package/dist/debug-schema.js +22 -0
  140. package/dist/debug-schema.js.map +1 -0
  141. package/dist/hooks/use-conversation.d.ts +78 -0
  142. package/dist/hooks/use-conversation.d.ts.map +1 -0
  143. package/dist/hooks/use-conversation.js +1017 -0
  144. package/dist/hooks/use-conversation.js.map +1 -0
  145. package/dist/hooks/use-input-history.d.ts +16 -0
  146. package/dist/hooks/use-input-history.d.ts.map +1 -0
  147. package/dist/hooks/use-input-history.js +71 -0
  148. package/dist/hooks/use-input-history.js.map +1 -0
  149. package/dist/hooks/use-model-selection.d.ts +27 -0
  150. package/dist/hooks/use-model-selection.d.ts.map +1 -0
  151. package/dist/hooks/use-model-selection.js +187 -0
  152. package/dist/hooks/use-model-selection.js.map +1 -0
  153. package/dist/hooks/use-model-selection.test.d.ts +2 -0
  154. package/dist/hooks/use-model-selection.test.d.ts.map +1 -0
  155. package/dist/hooks/use-model-selection.test.js +28 -0
  156. package/dist/hooks/use-model-selection.test.js.map +1 -0
  157. package/dist/hooks/use-path-completion.d.ts +22 -0
  158. package/dist/hooks/use-path-completion.d.ts.map +1 -0
  159. package/dist/hooks/use-path-completion.js +153 -0
  160. package/dist/hooks/use-path-completion.js.map +1 -0
  161. package/dist/hooks/use-path-completion.test.d.ts +2 -0
  162. package/dist/hooks/use-path-completion.test.d.ts.map +1 -0
  163. package/dist/hooks/use-path-completion.test.js +29 -0
  164. package/dist/hooks/use-path-completion.test.js.map +1 -0
  165. package/dist/hooks/use-setting.d.ts +7 -0
  166. package/dist/hooks/use-setting.d.ts.map +1 -0
  167. package/dist/hooks/use-setting.js +35 -0
  168. package/dist/hooks/use-setting.js.map +1 -0
  169. package/dist/hooks/use-settings-completion.d.ts +23 -0
  170. package/dist/hooks/use-settings-completion.d.ts.map +1 -0
  171. package/dist/hooks/use-settings-completion.js +164 -0
  172. package/dist/hooks/use-settings-completion.js.map +1 -0
  173. package/dist/hooks/use-settings-completion.test.d.ts +2 -0
  174. package/dist/hooks/use-settings-completion.test.d.ts.map +1 -0
  175. package/dist/hooks/use-settings-completion.test.js +334 -0
  176. package/dist/hooks/use-settings-completion.test.js.map +1 -0
  177. package/dist/hooks/use-slash-commands.d.ts +21 -0
  178. package/dist/hooks/use-slash-commands.d.ts.map +1 -0
  179. package/dist/hooks/use-slash-commands.js +87 -0
  180. package/dist/hooks/use-slash-commands.js.map +1 -0
  181. package/dist/hooks/use-slash-commands.test.d.ts +2 -0
  182. package/dist/hooks/use-slash-commands.test.d.ts.map +1 -0
  183. package/dist/hooks/use-slash-commands.test.js +246 -0
  184. package/dist/hooks/use-slash-commands.test.js.map +1 -0
  185. package/dist/lib/editor-impl.d.ts +23 -0
  186. package/dist/lib/editor-impl.d.ts.map +1 -0
  187. package/dist/lib/editor-impl.js +235 -0
  188. package/dist/lib/editor-impl.js.map +1 -0
  189. package/dist/lib/openai-agent-client.chat.test.d.ts +2 -0
  190. package/dist/lib/openai-agent-client.chat.test.d.ts.map +1 -0
  191. package/dist/lib/openai-agent-client.chat.test.js +68 -0
  192. package/dist/lib/openai-agent-client.chat.test.js.map +1 -0
  193. package/dist/lib/openai-agent-client.d.ts +48 -0
  194. package/dist/lib/openai-agent-client.d.ts.map +1 -0
  195. package/dist/lib/openai-agent-client.js +653 -0
  196. package/dist/lib/openai-agent-client.js.map +1 -0
  197. package/dist/lib/openai-agent-client.test.d.ts +2 -0
  198. package/dist/lib/openai-agent-client.test.d.ts.map +1 -0
  199. package/dist/lib/openai-agent-client.test.js +181 -0
  200. package/dist/lib/openai-agent-client.test.js.map +1 -0
  201. package/dist/lib/shell.d.ts +7 -0
  202. package/dist/lib/shell.d.ts.map +1 -0
  203. package/dist/lib/shell.js +56 -0
  204. package/dist/lib/shell.js.map +1 -0
  205. package/dist/lib/tool-invoke.d.ts +4 -0
  206. package/dist/lib/tool-invoke.d.ts.map +1 -0
  207. package/dist/lib/tool-invoke.js +26 -0
  208. package/dist/lib/tool-invoke.js.map +1 -0
  209. package/dist/lib/tool-invoke.test.d.ts +2 -0
  210. package/dist/lib/tool-invoke.test.d.ts.map +1 -0
  211. package/dist/lib/tool-invoke.test.js +19 -0
  212. package/dist/lib/tool-invoke.test.js.map +1 -0
  213. package/dist/no-singleton-imports.test.d.ts +2 -0
  214. package/dist/no-singleton-imports.test.d.ts.map +1 -0
  215. package/dist/no-singleton-imports.test.js +30 -0
  216. package/dist/no-singleton-imports.test.js.map +1 -0
  217. package/dist/prompts/anthropic.md +79 -0
  218. package/dist/prompts/codex.md +97 -0
  219. package/dist/prompts/default.md +77 -0
  220. package/dist/prompts/default.md.bak +77 -0
  221. package/dist/prompts/gpt-5.md +318 -0
  222. package/dist/prompts/lite.md +29 -0
  223. package/dist/prompts/simple-mentor.md +207 -0
  224. package/dist/prompts/simple.md +189 -0
  225. package/dist/providers/index.d.ts +5 -0
  226. package/dist/providers/index.d.ts.map +1 -0
  227. package/dist/providers/index.js +8 -0
  228. package/dist/providers/index.js.map +1 -0
  229. package/dist/providers/openai-compatible/api.d.ts +17 -0
  230. package/dist/providers/openai-compatible/api.d.ts.map +1 -0
  231. package/dist/providers/openai-compatible/api.js +58 -0
  232. package/dist/providers/openai-compatible/api.js.map +1 -0
  233. package/dist/providers/openai-compatible/model.d.ts +17 -0
  234. package/dist/providers/openai-compatible/model.d.ts.map +1 -0
  235. package/dist/providers/openai-compatible/model.js +435 -0
  236. package/dist/providers/openai-compatible/model.js.map +1 -0
  237. package/dist/providers/openai-compatible/provider.d.ts +22 -0
  238. package/dist/providers/openai-compatible/provider.d.ts.map +1 -0
  239. package/dist/providers/openai-compatible/provider.js +43 -0
  240. package/dist/providers/openai-compatible/provider.js.map +1 -0
  241. package/dist/providers/openai-compatible/utils.d.ts +3 -0
  242. package/dist/providers/openai-compatible/utils.d.ts.map +1 -0
  243. package/dist/providers/openai-compatible/utils.js +11 -0
  244. package/dist/providers/openai-compatible/utils.js.map +1 -0
  245. package/dist/providers/openai-compatible.provider.d.ts +8 -0
  246. package/dist/providers/openai-compatible.provider.d.ts.map +1 -0
  247. package/dist/providers/openai-compatible.provider.js +71 -0
  248. package/dist/providers/openai-compatible.provider.js.map +1 -0
  249. package/dist/providers/openai.provider.d.ts +2 -0
  250. package/dist/providers/openai.provider.d.ts.map +1 -0
  251. package/dist/providers/openai.provider.js +36 -0
  252. package/dist/providers/openai.provider.js.map +1 -0
  253. package/dist/providers/openrouter/api.d.ts +39 -0
  254. package/dist/providers/openrouter/api.d.ts.map +1 -0
  255. package/dist/providers/openrouter/api.js +172 -0
  256. package/dist/providers/openrouter/api.js.map +1 -0
  257. package/dist/providers/openrouter/converters.d.ts +8 -0
  258. package/dist/providers/openrouter/converters.d.ts.map +1 -0
  259. package/dist/providers/openrouter/converters.js +382 -0
  260. package/dist/providers/openrouter/converters.js.map +1 -0
  261. package/dist/providers/openrouter/converters.test.d.ts +2 -0
  262. package/dist/providers/openrouter/converters.test.d.ts.map +1 -0
  263. package/dist/providers/openrouter/converters.test.js +158 -0
  264. package/dist/providers/openrouter/converters.test.js.map +1 -0
  265. package/dist/providers/openrouter/index.d.ts +4 -0
  266. package/dist/providers/openrouter/index.d.ts.map +1 -0
  267. package/dist/providers/openrouter/index.js +4 -0
  268. package/dist/providers/openrouter/index.js.map +1 -0
  269. package/dist/providers/openrouter/model.d.ts +14 -0
  270. package/dist/providers/openrouter/model.d.ts.map +1 -0
  271. package/dist/providers/openrouter/model.js +485 -0
  272. package/dist/providers/openrouter/model.js.map +1 -0
  273. package/dist/providers/openrouter/provider.d.ts +15 -0
  274. package/dist/providers/openrouter/provider.d.ts.map +1 -0
  275. package/dist/providers/openrouter/provider.js +21 -0
  276. package/dist/providers/openrouter/provider.js.map +1 -0
  277. package/dist/providers/openrouter/utils.d.ts +10 -0
  278. package/dist/providers/openrouter/utils.d.ts.map +1 -0
  279. package/dist/providers/openrouter/utils.js +27 -0
  280. package/dist/providers/openrouter/utils.js.map +1 -0
  281. package/dist/providers/openrouter.api.retry.test.d.ts +2 -0
  282. package/dist/providers/openrouter.api.retry.test.d.ts.map +1 -0
  283. package/dist/providers/openrouter.api.retry.test.js +148 -0
  284. package/dist/providers/openrouter.api.retry.test.js.map +1 -0
  285. package/dist/providers/openrouter.d.ts +2 -0
  286. package/dist/providers/openrouter.d.ts.map +1 -0
  287. package/dist/providers/openrouter.history.test.d.ts +2 -0
  288. package/dist/providers/openrouter.history.test.d.ts.map +1 -0
  289. package/dist/providers/openrouter.history.test.js +533 -0
  290. package/dist/providers/openrouter.history.test.js.map +1 -0
  291. package/dist/providers/openrouter.js +4 -0
  292. package/dist/providers/openrouter.js.map +1 -0
  293. package/dist/providers/openrouter.provider.createRunner.test.d.ts +2 -0
  294. package/dist/providers/openrouter.provider.createRunner.test.d.ts.map +1 -0
  295. package/dist/providers/openrouter.provider.createRunner.test.js +23 -0
  296. package/dist/providers/openrouter.provider.createRunner.test.js.map +1 -0
  297. package/dist/providers/openrouter.provider.d.ts +2 -0
  298. package/dist/providers/openrouter.provider.d.ts.map +1 -0
  299. package/dist/providers/openrouter.provider.js +56 -0
  300. package/dist/providers/openrouter.provider.js.map +1 -0
  301. package/dist/providers/openrouter.test.d.ts +2 -0
  302. package/dist/providers/openrouter.test.d.ts.map +1 -0
  303. package/dist/providers/openrouter.test.js +1382 -0
  304. package/dist/providers/openrouter.test.js.map +1 -0
  305. package/dist/providers/registry.d.ts +65 -0
  306. package/dist/providers/registry.d.ts.map +1 -0
  307. package/dist/providers/registry.js +44 -0
  308. package/dist/providers/registry.js.map +1 -0
  309. package/dist/providers/registry.test.d.ts +2 -0
  310. package/dist/providers/registry.test.d.ts.map +1 -0
  311. package/dist/providers/registry.test.js +76 -0
  312. package/dist/providers/registry.test.js.map +1 -0
  313. package/dist/providers/web-search/index.d.ts +8 -0
  314. package/dist/providers/web-search/index.d.ts.map +1 -0
  315. package/dist/providers/web-search/index.js +9 -0
  316. package/dist/providers/web-search/index.js.map +1 -0
  317. package/dist/providers/web-search/registry.d.ts +35 -0
  318. package/dist/providers/web-search/registry.d.ts.map +1 -0
  319. package/dist/providers/web-search/registry.js +56 -0
  320. package/dist/providers/web-search/registry.js.map +1 -0
  321. package/dist/providers/web-search/registry.test.d.ts +2 -0
  322. package/dist/providers/web-search/registry.test.d.ts.map +1 -0
  323. package/dist/providers/web-search/registry.test.js +105 -0
  324. package/dist/providers/web-search/registry.test.js.map +1 -0
  325. package/dist/providers/web-search/tavily.provider.d.ts +15 -0
  326. package/dist/providers/web-search/tavily.provider.d.ts.map +1 -0
  327. package/dist/providers/web-search/tavily.provider.js +69 -0
  328. package/dist/providers/web-search/tavily.provider.js.map +1 -0
  329. package/dist/providers/web-search/tavily.provider.test.d.ts +2 -0
  330. package/dist/providers/web-search/tavily.provider.test.d.ts.map +1 -0
  331. package/dist/providers/web-search/tavily.provider.test.js +67 -0
  332. package/dist/providers/web-search/tavily.provider.test.js.map +1 -0
  333. package/dist/providers/web-search/types.d.ts +55 -0
  334. package/dist/providers/web-search/types.d.ts.map +1 -0
  335. package/dist/providers/web-search/types.js +6 -0
  336. package/dist/providers/web-search/types.js.map +1 -0
  337. package/dist/safety-checker.js +57 -0
  338. package/dist/services/conversation-events.d.ts +76 -0
  339. package/dist/services/conversation-events.d.ts.map +1 -0
  340. package/dist/services/conversation-events.js +2 -0
  341. package/dist/services/conversation-events.js.map +1 -0
  342. package/dist/services/conversation-service.d.ts +31 -0
  343. package/dist/services/conversation-service.d.ts.map +1 -0
  344. package/dist/services/conversation-service.js +46 -0
  345. package/dist/services/conversation-service.js.map +1 -0
  346. package/dist/services/conversation-service.test.js +190 -0
  347. package/dist/services/conversation-session.d.ts +99 -0
  348. package/dist/services/conversation-session.d.ts.map +1 -0
  349. package/dist/services/conversation-session.js +978 -0
  350. package/dist/services/conversation-session.js.map +1 -0
  351. package/dist/services/conversation-store.d.ts +24 -0
  352. package/dist/services/conversation-store.d.ts.map +1 -0
  353. package/dist/services/conversation-store.js +216 -0
  354. package/dist/services/conversation-store.js.map +1 -0
  355. package/dist/services/conversation-store.test.d.ts +2 -0
  356. package/dist/services/conversation-store.test.d.ts.map +1 -0
  357. package/dist/services/conversation-store.test.js +167 -0
  358. package/dist/services/conversation-store.test.js.map +1 -0
  359. package/dist/services/execution-context.d.ts +10 -0
  360. package/dist/services/execution-context.d.ts.map +1 -0
  361. package/dist/services/execution-context.js +22 -0
  362. package/dist/services/execution-context.js.map +1 -0
  363. package/dist/services/execution-context.test.d.ts +2 -0
  364. package/dist/services/execution-context.test.d.ts.map +1 -0
  365. package/dist/services/execution-context.test.js +49 -0
  366. package/dist/services/execution-context.test.js.map +1 -0
  367. package/dist/services/file-service.d.ts +12 -0
  368. package/dist/services/file-service.d.ts.map +1 -0
  369. package/dist/services/file-service.js +90 -0
  370. package/dist/services/file-service.js.map +1 -0
  371. package/dist/services/history-service.d.ts +39 -0
  372. package/dist/services/history-service.d.ts.map +1 -0
  373. package/dist/services/history-service.js +152 -0
  374. package/dist/services/history-service.js.map +1 -0
  375. package/dist/services/logging-service.d.ts +75 -0
  376. package/dist/services/logging-service.d.ts.map +1 -0
  377. package/dist/services/logging-service.js +343 -0
  378. package/dist/services/logging-service.js.map +1 -0
  379. package/dist/services/model-service.d.ts +15 -0
  380. package/dist/services/model-service.d.ts.map +1 -0
  381. package/dist/services/model-service.js +46 -0
  382. package/dist/services/model-service.js.map +1 -0
  383. package/dist/services/model-service.test.d.ts +2 -0
  384. package/dist/services/model-service.test.d.ts.map +1 -0
  385. package/dist/services/model-service.test.js +128 -0
  386. package/dist/services/model-service.test.js.map +1 -0
  387. package/dist/services/service-interfaces.d.ts +33 -0
  388. package/dist/services/service-interfaces.d.ts.map +1 -0
  389. package/dist/services/service-interfaces.js +2 -0
  390. package/dist/services/service-interfaces.js.map +1 -0
  391. package/dist/services/settings-service.d.ts +316 -0
  392. package/dist/services/settings-service.d.ts.map +1 -0
  393. package/dist/services/settings-service.js +1128 -0
  394. package/dist/services/settings-service.js.map +1 -0
  395. package/dist/services/settings-service.mock.d.ts +20 -0
  396. package/dist/services/settings-service.mock.d.ts.map +1 -0
  397. package/dist/services/settings-service.mock.js +55 -0
  398. package/dist/services/settings-service.mock.js.map +1 -0
  399. package/dist/services/singleton-deprecation.test.d.ts +2 -0
  400. package/dist/services/singleton-deprecation.test.d.ts.map +1 -0
  401. package/dist/services/singleton-deprecation.test.js +59 -0
  402. package/dist/services/singleton-deprecation.test.js.map +1 -0
  403. package/dist/services/ssh-service.d.ts +32 -0
  404. package/dist/services/ssh-service.d.ts.map +1 -0
  405. package/dist/services/ssh-service.js +119 -0
  406. package/dist/services/ssh-service.js.map +1 -0
  407. package/dist/services/ssh-service.test.d.ts +2 -0
  408. package/dist/services/ssh-service.test.d.ts.map +1 -0
  409. package/dist/services/ssh-service.test.js +269 -0
  410. package/dist/services/ssh-service.test.js.map +1 -0
  411. package/dist/test-search-tool.d.ts +2 -0
  412. package/dist/test-search-tool.d.ts.map +1 -0
  413. package/dist/test-search-tool.js +36 -0
  414. package/dist/test-search-tool.js.map +1 -0
  415. package/dist/tools/apply-patch.d.ts +28 -0
  416. package/dist/tools/apply-patch.d.ts.map +1 -0
  417. package/dist/tools/apply-patch.js +399 -0
  418. package/dist/tools/apply-patch.js.map +1 -0
  419. package/dist/tools/apply-patch.test.d.ts +2 -0
  420. package/dist/tools/apply-patch.test.d.ts.map +1 -0
  421. package/dist/tools/apply-patch.test.js +155 -0
  422. package/dist/tools/apply-patch.test.js.map +1 -0
  423. package/dist/tools/ask-mentor.d.ts +11 -0
  424. package/dist/tools/ask-mentor.d.ts.map +1 -0
  425. package/dist/tools/ask-mentor.js +52 -0
  426. package/dist/tools/ask-mentor.js.map +1 -0
  427. package/dist/tools/ask-mentor.test.d.ts +2 -0
  428. package/dist/tools/ask-mentor.test.d.ts.map +1 -0
  429. package/dist/tools/ask-mentor.test.js +47 -0
  430. package/dist/tools/ask-mentor.test.js.map +1 -0
  431. package/dist/tools/bash.d.ts +10 -0
  432. package/dist/tools/bash.d.ts.map +1 -0
  433. package/dist/tools/bash.js +55 -0
  434. package/dist/tools/bash.js.map +1 -0
  435. package/dist/tools/find-files.d.ts +15 -0
  436. package/dist/tools/find-files.d.ts.map +1 -0
  437. package/dist/tools/find-files.js +179 -0
  438. package/dist/tools/find-files.js.map +1 -0
  439. package/dist/tools/find-files.test.d.ts +2 -0
  440. package/dist/tools/find-files.test.d.ts.map +1 -0
  441. package/dist/tools/find-files.test.js +131 -0
  442. package/dist/tools/find-files.test.js.map +1 -0
  443. package/dist/tools/format-helpers.d.ts +34 -0
  444. package/dist/tools/format-helpers.d.ts.map +1 -0
  445. package/dist/tools/format-helpers.js +131 -0
  446. package/dist/tools/format-helpers.js.map +1 -0
  447. package/dist/tools/grep.d.ts +16 -0
  448. package/dist/tools/grep.d.ts.map +1 -0
  449. package/dist/tools/grep.js +211 -0
  450. package/dist/tools/grep.js.map +1 -0
  451. package/dist/tools/read-file.d.ts +15 -0
  452. package/dist/tools/read-file.d.ts.map +1 -0
  453. package/dist/tools/read-file.js +114 -0
  454. package/dist/tools/read-file.js.map +1 -0
  455. package/dist/tools/read-file.test.d.ts +2 -0
  456. package/dist/tools/read-file.test.d.ts.map +1 -0
  457. package/dist/tools/read-file.test.js +122 -0
  458. package/dist/tools/read-file.test.js.map +1 -0
  459. package/dist/tools/search-replace.d.ts +19 -0
  460. package/dist/tools/search-replace.d.ts.map +1 -0
  461. package/dist/tools/search-replace.js +411 -0
  462. package/dist/tools/search-replace.js.map +1 -0
  463. package/dist/tools/search-replace.test.d.ts +2 -0
  464. package/dist/tools/search-replace.test.d.ts.map +1 -0
  465. package/dist/tools/search-replace.test.js +302 -0
  466. package/dist/tools/search-replace.test.js.map +1 -0
  467. package/dist/tools/search.d.ts +15 -0
  468. package/dist/tools/search.d.ts.map +1 -0
  469. package/dist/tools/search.js +143 -0
  470. package/dist/tools/search.js.map +1 -0
  471. package/dist/tools/shell.d.ts +19 -0
  472. package/dist/tools/shell.d.ts.map +1 -0
  473. package/dist/tools/shell.js +278 -0
  474. package/dist/tools/shell.js.map +1 -0
  475. package/dist/tools/tool-execution-context.d.ts +7 -0
  476. package/dist/tools/tool-execution-context.d.ts.map +1 -0
  477. package/dist/tools/tool-execution-context.js +7 -0
  478. package/dist/tools/tool-execution-context.js.map +1 -0
  479. package/dist/tools/types.d.ts +30 -0
  480. package/dist/tools/types.d.ts.map +1 -0
  481. package/dist/tools/types.js +2 -0
  482. package/dist/tools/types.js.map +1 -0
  483. package/dist/tools/utils.d.ts +12 -0
  484. package/dist/tools/utils.d.ts.map +1 -0
  485. package/dist/tools/utils.js +19 -0
  486. package/dist/tools/utils.js.map +1 -0
  487. package/dist/tools/web-search.d.ts +29 -0
  488. package/dist/tools/web-search.d.ts.map +1 -0
  489. package/dist/tools/web-search.js +106 -0
  490. package/dist/tools/web-search.js.map +1 -0
  491. package/dist/tools/web-search.test.d.ts +2 -0
  492. package/dist/tools/web-search.test.d.ts.map +1 -0
  493. package/dist/tools/web-search.test.js +176 -0
  494. package/dist/tools/web-search.test.js.map +1 -0
  495. package/dist/utils/command-logger.d.ts +11 -0
  496. package/dist/utils/command-logger.d.ts.map +1 -0
  497. package/dist/utils/command-logger.js +34 -0
  498. package/dist/utils/command-logger.js.map +1 -0
  499. package/dist/utils/command-safety/constants.d.ts +21 -0
  500. package/dist/utils/command-safety/constants.d.ts.map +1 -0
  501. package/dist/utils/command-safety/constants.js +245 -0
  502. package/dist/utils/command-safety/constants.js.map +1 -0
  503. package/dist/utils/command-safety/find-helpers.d.ts +15 -0
  504. package/dist/utils/command-safety/find-helpers.d.ts.map +1 -0
  505. package/dist/utils/command-safety/find-helpers.js +218 -0
  506. package/dist/utils/command-safety/find-helpers.js.map +1 -0
  507. package/dist/utils/command-safety/handlers/find-handler.d.ts +6 -0
  508. package/dist/utils/command-safety/handlers/find-handler.d.ts.map +1 -0
  509. package/dist/utils/command-safety/handlers/find-handler.js +113 -0
  510. package/dist/utils/command-safety/handlers/find-handler.js.map +1 -0
  511. package/dist/utils/command-safety/handlers/git-handler.d.ts +6 -0
  512. package/dist/utils/command-safety/handlers/git-handler.d.ts.map +1 -0
  513. package/dist/utils/command-safety/handlers/git-handler.js +68 -0
  514. package/dist/utils/command-safety/handlers/git-handler.js.map +1 -0
  515. package/dist/utils/command-safety/handlers/index.d.ts +13 -0
  516. package/dist/utils/command-safety/handlers/index.d.ts.map +1 -0
  517. package/dist/utils/command-safety/handlers/index.js +20 -0
  518. package/dist/utils/command-safety/handlers/index.js.map +1 -0
  519. package/dist/utils/command-safety/handlers/sed-handler.d.ts +6 -0
  520. package/dist/utils/command-safety/handlers/sed-handler.d.ts.map +1 -0
  521. package/dist/utils/command-safety/handlers/sed-handler.js +94 -0
  522. package/dist/utils/command-safety/handlers/sed-handler.js.map +1 -0
  523. package/dist/utils/command-safety/handlers/types.d.ts +36 -0
  524. package/dist/utils/command-safety/handlers/types.d.ts.map +1 -0
  525. package/dist/utils/command-safety/handlers/types.js +2 -0
  526. package/dist/utils/command-safety/handlers/types.js.map +1 -0
  527. package/dist/utils/command-safety/index.d.ts +14 -0
  528. package/dist/utils/command-safety/index.d.ts.map +1 -0
  529. package/dist/utils/command-safety/index.js +183 -0
  530. package/dist/utils/command-safety/index.js.map +1 -0
  531. package/dist/utils/command-safety/path-analysis.d.ts +4 -0
  532. package/dist/utils/command-safety/path-analysis.d.ts.map +1 -0
  533. package/dist/utils/command-safety/path-analysis.js +153 -0
  534. package/dist/utils/command-safety/path-analysis.js.map +1 -0
  535. package/dist/utils/command-safety/utils.d.ts +2 -0
  536. package/dist/utils/command-safety/utils.d.ts.map +1 -0
  537. package/dist/utils/command-safety/utils.js +22 -0
  538. package/dist/utils/command-safety/utils.js.map +1 -0
  539. package/dist/utils/command-safety.d.ts +21 -0
  540. package/dist/utils/command-safety.d.ts.map +1 -0
  541. package/dist/utils/command-safety.find.test.d.ts +2 -0
  542. package/dist/utils/command-safety.find.test.d.ts.map +1 -0
  543. package/dist/utils/command-safety.find.test.js +342 -0
  544. package/dist/utils/command-safety.find.test.js.map +1 -0
  545. package/dist/utils/command-safety.js +702 -0
  546. package/dist/utils/command-safety.js.map +1 -0
  547. package/dist/utils/command-safety.path.test.d.ts +2 -0
  548. package/dist/utils/command-safety.path.test.d.ts.map +1 -0
  549. package/dist/utils/command-safety.path.test.js +360 -0
  550. package/dist/utils/command-safety.path.test.js.map +1 -0
  551. package/dist/utils/diff.d.ts +2 -0
  552. package/dist/utils/diff.d.ts.map +1 -0
  553. package/dist/utils/diff.js +44 -0
  554. package/dist/utils/diff.js.map +1 -0
  555. package/dist/utils/diff.test.d.ts +2 -0
  556. package/dist/utils/diff.test.d.ts.map +1 -0
  557. package/dist/utils/diff.test.js +85 -0
  558. package/dist/utils/diff.test.js.map +1 -0
  559. package/dist/utils/error-helpers.d.ts +6 -0
  560. package/dist/utils/error-helpers.d.ts.map +1 -0
  561. package/dist/utils/error-helpers.js +46 -0
  562. package/dist/utils/error-helpers.js.map +1 -0
  563. package/dist/utils/error-helpers.test.d.ts +2 -0
  564. package/dist/utils/error-helpers.test.d.ts.map +1 -0
  565. package/dist/utils/error-helpers.test.js +152 -0
  566. package/dist/utils/error-helpers.test.js.map +1 -0
  567. package/dist/utils/execute-shell.d.ts +15 -0
  568. package/dist/utils/execute-shell.d.ts.map +1 -0
  569. package/dist/utils/execute-shell.js +34 -0
  570. package/dist/utils/execute-shell.js.map +1 -0
  571. package/dist/utils/execute-shell.test.d.ts +2 -0
  572. package/dist/utils/execute-shell.test.d.ts.map +1 -0
  573. package/dist/utils/execute-shell.test.js +20 -0
  574. package/dist/utils/execute-shell.test.js.map +1 -0
  575. package/dist/utils/extract-command-messages.d.ts +5 -0
  576. package/dist/utils/extract-command-messages.d.ts.map +1 -0
  577. package/dist/utils/extract-command-messages.js +140 -0
  578. package/dist/utils/extract-command-messages.js.map +1 -0
  579. package/dist/utils/extract-command-messages.repro.test.d.ts +2 -0
  580. package/dist/utils/extract-command-messages.repro.test.d.ts.map +1 -0
  581. package/dist/utils/extract-command-messages.repro.test.js +31 -0
  582. package/dist/utils/extract-command-messages.repro.test.js.map +1 -0
  583. package/dist/utils/extract-command-messages.test.js +57 -0
  584. package/dist/utils/message-buffer.d.ts +2 -0
  585. package/dist/utils/message-buffer.d.ts.map +1 -0
  586. package/dist/utils/message-buffer.js +15 -0
  587. package/dist/utils/message-buffer.js.map +1 -0
  588. package/dist/utils/message-buffer.test.d.ts +2 -0
  589. package/dist/utils/message-buffer.test.d.ts.map +1 -0
  590. package/dist/utils/message-buffer.test.js +17 -0
  591. package/dist/utils/message-buffer.test.js.map +1 -0
  592. package/dist/utils/output-trim.d.ts +31 -0
  593. package/dist/utils/output-trim.d.ts.map +1 -0
  594. package/dist/utils/output-trim.js +71 -0
  595. package/dist/utils/output-trim.js.map +1 -0
  596. package/dist/utils/provider-credentials.d.ts +10 -0
  597. package/dist/utils/provider-credentials.d.ts.map +1 -0
  598. package/dist/utils/provider-credentials.js +22 -0
  599. package/dist/utils/provider-credentials.js.map +1 -0
  600. package/dist/utils/settings-command.d.ts +13 -0
  601. package/dist/utils/settings-command.d.ts.map +1 -0
  602. package/dist/utils/settings-command.js +173 -0
  603. package/dist/utils/settings-command.js.map +1 -0
  604. package/dist/utils/ssh-config-parser.d.ts +21 -0
  605. package/dist/utils/ssh-config-parser.d.ts.map +1 -0
  606. package/dist/utils/ssh-config-parser.js +89 -0
  607. package/dist/utils/ssh-config-parser.js.map +1 -0
  608. package/dist/utils/ssh-config-parser.test.d.ts +2 -0
  609. package/dist/utils/ssh-config-parser.test.d.ts.map +1 -0
  610. package/dist/utils/ssh-config-parser.test.js +153 -0
  611. package/dist/utils/ssh-config-parser.test.js.map +1 -0
  612. package/dist/utils/streaming-updater.d.ts +7 -0
  613. package/dist/utils/streaming-updater.d.ts.map +1 -0
  614. package/dist/utils/streaming-updater.js +41 -0
  615. package/dist/utils/streaming-updater.js.map +1 -0
  616. package/dist/utils/throttle.d.ts +7 -0
  617. package/dist/utils/throttle.d.ts.map +1 -0
  618. package/dist/utils/throttle.js +49 -0
  619. package/dist/utils/throttle.js.map +1 -0
  620. package/package.json +108 -0
  621. package/readme.md +428 -0
@@ -0,0 +1,218 @@
1
+ import { extractWordText } from './utils.js';
2
+ /**
3
+ * Check if a find command has dangerous execution flags (-exec, -execdir, -ok, -okdir, -delete)
4
+ */
5
+ export function hasFindDangerousExecution(args) {
6
+ for (let i = 0; i < args.length; i++) {
7
+ const argText = extractWordText(args[i]);
8
+ if (!argText)
9
+ continue;
10
+ // Check for -delete flag
11
+ if (argText === '-delete') {
12
+ return { dangerous: true, reason: 'find -delete (destructive)' };
13
+ }
14
+ // Check for execution flags
15
+ const execFlags = ['-exec', '-execdir', '-ok', '-okdir'];
16
+ if (!execFlags.includes(argText))
17
+ continue;
18
+ // Found an exec flag - analyze the command it executes
19
+ // Find the terminator (; or +)
20
+ let terminatorIndex = -1;
21
+ for (let j = i + 1; j < args.length; j++) {
22
+ const term = extractWordText(args[j]);
23
+ if (term === ';' ||
24
+ term === '+' ||
25
+ term === '\\;' ||
26
+ term === '\\+') {
27
+ terminatorIndex = j;
28
+ break;
29
+ }
30
+ }
31
+ if (terminatorIndex === -1) {
32
+ // Malformed -exec (no terminator)
33
+ return {
34
+ dangerous: true,
35
+ reason: `find ${argText} without terminator`,
36
+ };
37
+ }
38
+ // Extract the command between exec flag and terminator
39
+ const execArgs = args.slice(i + 1, terminatorIndex);
40
+ // Check for redirects (which indicate shell operations)
41
+ const hasRedirect = execArgs.some((a) => a?.type === 'Redirect');
42
+ if (hasRedirect) {
43
+ return {
44
+ dangerous: true,
45
+ reason: `find ${argText} with shell redirection`,
46
+ };
47
+ }
48
+ const execCommand = execArgs
49
+ .map(a => extractWordText(a))
50
+ .filter(Boolean);
51
+ if (execCommand.length === 0) {
52
+ return {
53
+ dangerous: true,
54
+ reason: `find ${argText} with empty command`,
55
+ };
56
+ }
57
+ const cmdName = execCommand[0];
58
+ if (!cmdName) {
59
+ return {
60
+ dangerous: true,
61
+ reason: `find ${argText} with undefined command`,
62
+ };
63
+ }
64
+ // Check if {} is the command itself (executing found files)
65
+ if (cmdName === '{}') {
66
+ return {
67
+ dangerous: true,
68
+ reason: `find ${argText} {} (executes found files directly)`,
69
+ };
70
+ }
71
+ // Check for destructive commands
72
+ const destructiveCmds = [
73
+ 'rm',
74
+ 'shred',
75
+ 'chmod',
76
+ 'chown',
77
+ 'mv',
78
+ 'dd',
79
+ 'mkfs',
80
+ 'truncate',
81
+ 'tee',
82
+ 'cp',
83
+ 'ln',
84
+ 'install',
85
+ 'rsync',
86
+ ];
87
+ if (destructiveCmds.includes(cmdName)) {
88
+ return {
89
+ dangerous: true,
90
+ reason: `find ${argText} ${cmdName} (destructive)`,
91
+ };
92
+ }
93
+ // Check for dangerous interpreters and meta-executors
94
+ // These can all invoke arbitrary commands or scripts
95
+ const dangerousInterpreters = [
96
+ // Shells
97
+ 'sh',
98
+ 'bash',
99
+ 'zsh',
100
+ 'ksh',
101
+ 'dash',
102
+ 'fish',
103
+ 'tcsh',
104
+ 'csh',
105
+ // Script interpreters
106
+ 'perl',
107
+ 'python',
108
+ 'python2',
109
+ 'python3',
110
+ 'ruby',
111
+ 'node',
112
+ 'nodejs',
113
+ 'php',
114
+ 'lua',
115
+ // Meta-executors that can run commands
116
+ 'env',
117
+ 'xargs',
118
+ 'parallel',
119
+ 'nohup',
120
+ 'nice',
121
+ 'ionice',
122
+ 'timeout',
123
+ 'stdbuf',
124
+ 'script',
125
+ 'expect',
126
+ // Text processors that can execute
127
+ 'awk',
128
+ 'gawk',
129
+ 'mawk',
130
+ 'nawk',
131
+ 'sed',
132
+ 'ed',
133
+ // Editors that can run shell commands
134
+ 'vim',
135
+ 'nvim',
136
+ 'emacs',
137
+ ];
138
+ // Handle both bare names and full paths like /usr/bin/python
139
+ const isDangerousInterpreter = dangerousInterpreters.some(interp => cmdName === interp || cmdName.endsWith(`/${interp}`));
140
+ if (isDangerousInterpreter) {
141
+ return {
142
+ dangerous: true,
143
+ reason: `find ${argText} ${cmdName} (can execute commands)`,
144
+ };
145
+ }
146
+ // Check for shell metacharacters in command
147
+ const fullExecCmd = execCommand.join(' ');
148
+ if (/[|&;$`<>]/.test(fullExecCmd)) {
149
+ return {
150
+ dangerous: true,
151
+ reason: `find ${argText} with shell metacharacters`,
152
+ };
153
+ }
154
+ }
155
+ return { dangerous: false };
156
+ }
157
+ /**
158
+ * Check for suspicious find flags that warrant YELLOW classification
159
+ */
160
+ export function hasFindSuspiciousFlags(args) {
161
+ for (const arg of args) {
162
+ const argText = extractWordText(arg);
163
+ if (!argText)
164
+ continue;
165
+ // File output flags
166
+ if (['-fprint', '-fprint0', '-fprintf', '-fls'].some(flag => argText.startsWith(flag))) {
167
+ return {
168
+ suspicious: true,
169
+ reason: `find ${argText} (file output)`,
170
+ };
171
+ }
172
+ // Symlink following
173
+ if (['-L', '-follow', '-H'].includes(argText)) {
174
+ return {
175
+ suspicious: true,
176
+ reason: `find ${argText} (symlink following)`,
177
+ };
178
+ }
179
+ // SUID/SGID permission searches
180
+ if (argText === '-perm') {
181
+ // Check the next argument for dangerous permission patterns
182
+ const nextIdx = args.indexOf(arg) + 1;
183
+ if (nextIdx < args.length) {
184
+ const permValue = extractWordText(args[nextIdx]);
185
+ if (permValue) {
186
+ // Numeric SUID/SGID patterns (e.g., -4000, /6000)
187
+ const hasNumericSuid = /[-\/]?[2467]000/.test(permValue);
188
+ // Symbolic SUID/SGID patterns (e.g., -u+s, /g+s, +s)
189
+ const hasSymbolicSuid = /[ug]?\+s/.test(permValue);
190
+ if (hasNumericSuid || hasSymbolicSuid) {
191
+ return {
192
+ suspicious: true,
193
+ reason: `find -perm ${permValue} (SUID/SGID search)`,
194
+ };
195
+ }
196
+ }
197
+ }
198
+ }
199
+ // Inode-based searches (can bypass path restrictions)
200
+ if (argText === '-inum') {
201
+ return {
202
+ suspicious: true,
203
+ reason: 'find -inum (inode-based access bypasses path checks)',
204
+ };
205
+ }
206
+ // Read-only exec (still suspicious, requires approval)
207
+ if (['-exec', '-execdir', '-ok', '-okdir'].includes(argText)) {
208
+ // If we reach here, hasFindDangerousExecution already passed (not RED)
209
+ // but any -exec usage should still be YELLOW
210
+ return {
211
+ suspicious: true,
212
+ reason: `find ${argText} (command execution)`,
213
+ };
214
+ }
215
+ }
216
+ return { suspicious: false };
217
+ }
218
+ //# sourceMappingURL=find-helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find-helpers.js","sourceRoot":"","sources":["../../../source/utils/command-safety/find-helpers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { CommandHandler } from './types.js';
2
+ /**
3
+ * Handler for find command safety analysis
4
+ */
5
+ export declare const findHandler: CommandHandler;
6
+ //# sourceMappingURL=find-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/find-handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,WAAW,EAAE,cA+HzB,CAAC"}
@@ -0,0 +1,113 @@
1
+ import { SafetyStatus } from '../constants.js';
2
+ /**
3
+ * Handler for find command safety analysis
4
+ */
5
+ export const findHandler = {
6
+ handle(node, helpers) {
7
+ const { extractWordText, analyzePathRisk, hasFindDangerousExecution, hasFindSuspiciousFlags, } = helpers;
8
+ const reasons = [];
9
+ let status = SafetyStatus.GREEN;
10
+ if (!node.suffix) {
11
+ return { status, reasons };
12
+ }
13
+ // Check for dangerous find operations first (RED)
14
+ const dangerResult = hasFindDangerousExecution(node.suffix);
15
+ if (dangerResult.dangerous) {
16
+ return {
17
+ status: SafetyStatus.RED,
18
+ reasons: [dangerResult.reason || 'find with dangerous flags'],
19
+ };
20
+ }
21
+ // Check for suspicious find flags (YELLOW)
22
+ const suspiciousResult = hasFindSuspiciousFlags(node.suffix);
23
+ if (suspiciousResult.suspicious) {
24
+ status = SafetyStatus.YELLOW;
25
+ reasons.push(suspiciousResult.reason || 'find with suspicious flags');
26
+ }
27
+ // Check path arguments for find
28
+ // Track if previous arg was a pattern flag like -name, -regex
29
+ let previousArgWasPatternFlag = false;
30
+ for (const arg of node.suffix) {
31
+ if (arg?.type === 'Redirect')
32
+ continue;
33
+ const argText = extractWordText(arg);
34
+ if (!argText)
35
+ continue;
36
+ // Track pattern flags
37
+ if ([
38
+ '-name',
39
+ '-iname',
40
+ '-path',
41
+ '-ipath',
42
+ '-regex',
43
+ '-iregex',
44
+ ].includes(argText)) {
45
+ previousArgWasPatternFlag = true;
46
+ continue;
47
+ }
48
+ // Skip flags
49
+ if (argText.startsWith('-')) {
50
+ previousArgWasPatternFlag = false;
51
+ continue;
52
+ }
53
+ // Skip pattern arguments (the values after -name, -regex, etc.)
54
+ if (previousArgWasPatternFlag) {
55
+ previousArgWasPatternFlag = false;
56
+ continue;
57
+ }
58
+ // Skip glob patterns (contain wildcards)
59
+ if (/[*?[\]]/.test(argText))
60
+ continue;
61
+ // Skip safe relative paths (. and ./)
62
+ if (argText === '.' || argText === './')
63
+ continue;
64
+ // Skip patterns with backslashes (regex patterns)
65
+ if (argText.includes('\\'))
66
+ continue;
67
+ // Root traversal detection (DoS + information disclosure)
68
+ if (argText === '/' || argText === '//') {
69
+ status = SafetyStatus.YELLOW;
70
+ reasons.push('find / (root traversal - resource intensive)');
71
+ continue;
72
+ }
73
+ // For find, analyzing paths is more lenient:
74
+ // - System paths like /etc are YELLOW (not RED)
75
+ // - Home directories and dotfiles are still RED
76
+ const pathStatus = analyzePathRisk(argText);
77
+ if (pathStatus === SafetyStatus.RED) {
78
+ // Keep RED for home directories, dotfiles, and traversal
79
+ // Downgrade system paths to YELLOW
80
+ const homeRelatedPatterns = [
81
+ /^~/, // Tilde
82
+ /^\$/, // Variables like $HOME, $USER
83
+ /^\/home\//, // Linux home
84
+ /^\/Users\//, // macOS home
85
+ /^\/root/, // Root's home
86
+ /\/\.ssh/, // SSH keys
87
+ /\/\.env/, // Environment files
88
+ /\/\.git/, // Git config
89
+ /\/\.aws/, // AWS credentials
90
+ /\/\.kube/, // Kubernetes config
91
+ /\/\.gnupg/, // GPG keys
92
+ /\.\./, // Directory traversal
93
+ ];
94
+ const isHomeRelated = homeRelatedPatterns.some(pattern => pattern.test(argText));
95
+ if (isHomeRelated) {
96
+ status = SafetyStatus.RED;
97
+ reasons.push(`find dangerous path: ${argText}`);
98
+ }
99
+ else {
100
+ // System paths like /etc get downgraded to YELLOW
101
+ status = SafetyStatus.YELLOW;
102
+ reasons.push(`find system path: ${argText}`);
103
+ }
104
+ }
105
+ else if (pathStatus === SafetyStatus.YELLOW) {
106
+ status = pathStatus;
107
+ reasons.push(`find path argument ${argText}`);
108
+ }
109
+ }
110
+ return { status, reasons };
111
+ },
112
+ };
113
+ //# sourceMappingURL=find-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"find-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/find-handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { CommandHandler } from './types.js';
2
+ /**
3
+ * Handler for git command safety analysis
4
+ */
5
+ export declare const gitHandler: CommandHandler;
6
+ //# sourceMappingURL=git-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/git-handler.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,cAsExB,CAAC"}
@@ -0,0 +1,68 @@
1
+ import { SafetyStatus, SAFE_GIT_COMMANDS, DANGEROUS_GIT_COMMANDS, } from '../constants.js';
2
+ /**
3
+ * Handler for git command safety analysis
4
+ */
5
+ export const gitHandler = {
6
+ handle(node, helpers) {
7
+ const { extractWordText } = helpers;
8
+ const reasons = [];
9
+ let status = SafetyStatus.GREEN;
10
+ // Extract the git subcommand (first non-flag argument)
11
+ let gitSubcommand;
12
+ if (node.suffix) {
13
+ for (const arg of node.suffix) {
14
+ const argText = extractWordText(arg);
15
+ if (argText && !argText.startsWith('-')) {
16
+ gitSubcommand = argText;
17
+ break;
18
+ }
19
+ }
20
+ }
21
+ if (!gitSubcommand) {
22
+ // No subcommand found (e.g., just "git" or "git --version")
23
+ return {
24
+ status: SafetyStatus.YELLOW,
25
+ reasons: ['git without subcommand'],
26
+ };
27
+ }
28
+ // Check if it's a known dangerous command
29
+ if (DANGEROUS_GIT_COMMANDS.has(gitSubcommand)) {
30
+ return {
31
+ status: SafetyStatus.YELLOW,
32
+ reasons: [`git ${gitSubcommand} (write operation)`],
33
+ };
34
+ }
35
+ // Check if it's a known safe command
36
+ if (SAFE_GIT_COMMANDS.has(gitSubcommand)) {
37
+ // Check for dangerous flags that might make it unsafe
38
+ const hasDangerousFlags = node.suffix.some((arg) => {
39
+ const argText = extractWordText(arg);
40
+ if (!argText)
41
+ return false;
42
+ // Flags that might modify repository state
43
+ return (argText.startsWith('--force') ||
44
+ argText.startsWith('-f') ||
45
+ argText.startsWith('--hard') ||
46
+ argText.startsWith('--delete') ||
47
+ argText.startsWith('-d') ||
48
+ argText.startsWith('-D'));
49
+ });
50
+ if (hasDangerousFlags) {
51
+ return {
52
+ status: SafetyStatus.YELLOW,
53
+ reasons: [
54
+ `git ${gitSubcommand} with potentially dangerous flags`,
55
+ ],
56
+ };
57
+ }
58
+ // Otherwise stays GREEN - safe read-only git command
59
+ return { status, reasons };
60
+ }
61
+ // Unknown git subcommand
62
+ return {
63
+ status: SafetyStatus.YELLOW,
64
+ reasons: [`git ${gitSubcommand} (unknown subcommand)`],
65
+ };
66
+ },
67
+ };
68
+ //# sourceMappingURL=git-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/git-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,iBAAiB,EACjB,sBAAsB,GACzB,MAAM,iBAAiB,CAAC;AAOzB;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAmB;IACtC,MAAM,CAAC,IAAS,EAAE,OAA8B;QAC5C,MAAM,EAAC,eAAe,EAAC,GAAG,OAAO,CAAC;QAClC,MAAM,OAAO,GAAa,EAAE,CAAC;QAC7B,IAAI,MAAM,GAAiB,YAAY,CAAC,KAAK,CAAC;QAE9C,uDAAuD;QACvD,IAAI,aAAiC,CAAC;QACtC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC5B,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;oBACtC,aAAa,GAAG,OAAO,CAAC;oBACxB,MAAM;gBACV,CAAC;YACL,CAAC;QACL,CAAC;QAED,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,4DAA4D;YAC5D,OAAO;gBACH,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE,CAAC,wBAAwB,CAAC;aACtC,CAAC;QACN,CAAC;QAED,0CAA0C;QAC1C,IAAI,sBAAsB,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;YAC5C,OAAO;gBACH,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE,CAAC,OAAO,aAAa,oBAAoB,CAAC;aACtD,CAAC;QACN,CAAC;QAED,qCAAqC;QACrC,IAAI,iBAAiB,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;YACvC,sDAAsD;YACtD,MAAM,iBAAiB,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACpD,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,CAAC,OAAO;oBAAE,OAAO,KAAK,CAAC;gBAE3B,2CAA2C;gBAC3C,OAAO,CACH,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC;oBAC7B,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;oBACxB,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC;oBAC5B,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC;oBAC9B,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC;oBACxB,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAC3B,CAAC;YACN,CAAC,CAAC,CAAC;YAEH,IAAI,iBAAiB,EAAE,CAAC;gBACpB,OAAO;oBACH,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,OAAO,EAAE;wBACL,OAAO,aAAa,mCAAmC;qBAC1D;iBACJ,CAAC;YACN,CAAC;YACD,qDAAqD;YACrD,OAAO,EAAC,MAAM,EAAE,OAAO,EAAC,CAAC;QAC7B,CAAC;QAED,yBAAyB;QACzB,OAAO;YACH,MAAM,EAAE,YAAY,CAAC,MAAM;YAC3B,OAAO,EAAE,CAAC,OAAO,aAAa,uBAAuB,CAAC;SACzD,CAAC;IACN,CAAC;CACJ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { CommandHandler } from './types.js';
2
+ /**
3
+ * Registry of command-specific handlers
4
+ */
5
+ export declare const commandHandlers: Map<string, CommandHandler>;
6
+ /**
7
+ * Get a handler for a specific command
8
+ * @param commandName The command name
9
+ * @returns The handler if one exists, undefined otherwise
10
+ */
11
+ export declare function getCommandHandler(commandName: string): CommandHandler | undefined;
12
+ export type { CommandHandler, CommandHandlerHelpers, CommandHandlerResult, } from './types.js';
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,cAAc,EAAC,MAAM,YAAY,CAAC;AAK/C;;GAEG;AACH,eAAO,MAAM,eAAe,6BAI1B,CAAC;AAEH;;;;GAIG;AACH,wBAAgB,iBAAiB,CAC7B,WAAW,EAAE,MAAM,GACpB,cAAc,GAAG,SAAS,CAE5B;AAGD,YAAY,EACR,cAAc,EACd,qBAAqB,EACrB,oBAAoB,GACvB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,20 @@
1
+ import { gitHandler } from './git-handler.js';
2
+ import { findHandler } from './find-handler.js';
3
+ import { sedHandler } from './sed-handler.js';
4
+ /**
5
+ * Registry of command-specific handlers
6
+ */
7
+ export const commandHandlers = new Map([
8
+ ['git', gitHandler],
9
+ ['find', findHandler],
10
+ ['sed', sedHandler],
11
+ ]);
12
+ /**
13
+ * Get a handler for a specific command
14
+ * @param commandName The command name
15
+ * @returns The handler if one exists, undefined otherwise
16
+ */
17
+ export function getCommandHandler(commandName) {
18
+ return commandHandlers.get(commandName);
19
+ }
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAC,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAE5C;;GAEG;AACH,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,GAAG,CAAyB;IAC3D,CAAC,KAAK,EAAE,UAAU,CAAC;IACnB,CAAC,MAAM,EAAE,WAAW,CAAC;IACrB,CAAC,KAAK,EAAE,UAAU,CAAC;CACtB,CAAC,CAAC;AAEH;;;;GAIG;AACH,MAAM,UAAU,iBAAiB,CAC7B,WAAmB;IAEnB,OAAO,eAAe,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;AAC5C,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { CommandHandler } from './types.js';
2
+ /**
3
+ * Handler for sed command safety analysis
4
+ */
5
+ export declare const sedHandler: CommandHandler;
6
+ //# sourceMappingURL=sed-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sed-handler.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/sed-handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACR,cAAc,EAGjB,MAAM,YAAY,CAAC;AAEpB;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,cAqGxB,CAAC"}
@@ -0,0 +1,94 @@
1
+ import { SafetyStatus } from '../constants.js';
2
+ /**
3
+ * Handler for sed command safety analysis
4
+ */
5
+ export const sedHandler = {
6
+ handle(node, helpers) {
7
+ const { extractWordText, analyzePathRisk } = helpers;
8
+ const reasons = [];
9
+ let status = SafetyStatus.GREEN;
10
+ if (!node.suffix) {
11
+ return { status, reasons };
12
+ }
13
+ let hasOutputRedirect = false;
14
+ let hasInPlaceEdit = false;
15
+ // First pass: detect dangerous sed patterns
16
+ for (const arg of node.suffix) {
17
+ if (arg?.type === 'Redirect') {
18
+ // Check if it's an output redirect (>, >>)
19
+ const op = arg.op?.text || arg.op;
20
+ if (op === '>' || op === '>>') {
21
+ hasOutputRedirect = true;
22
+ }
23
+ }
24
+ const argText = extractWordText(arg);
25
+ if (argText && argText.startsWith('-')) {
26
+ if (argText.startsWith('-i')) {
27
+ hasInPlaceEdit = true;
28
+ }
29
+ }
30
+ }
31
+ // Second pass: classify arguments
32
+ for (const arg of node.suffix) {
33
+ // Redirects: analyze path risk. For `sed`, only mark output redirects as YELLOW
34
+ if (arg?.type === 'Redirect') {
35
+ const fileText = extractWordText(arg.file ?? arg);
36
+ const op = arg.op?.text || arg.op;
37
+ if (op === '>' || op === '>>') {
38
+ status = SafetyStatus.YELLOW;
39
+ reasons.push(`sed with output redirection to ${fileText ?? '<unknown>'}`);
40
+ }
41
+ const pathStatus = analyzePathRisk(fileText);
42
+ if (pathStatus !== SafetyStatus.GREEN) {
43
+ status = pathStatus;
44
+ reasons.push(`redirect to ${fileText ?? '<unknown>'}`);
45
+ }
46
+ continue;
47
+ }
48
+ const argText = extractWordText(arg);
49
+ // Flags are normally ignored, but for `sed` the -i flag is dangerous
50
+ // because it performs in-place edits. Detect -i and variants (e.g. -i, -i.bak, -i'')
51
+ if (argText && argText.startsWith('-')) {
52
+ if (argText.startsWith('-i')) {
53
+ return {
54
+ status: SafetyStatus.RED,
55
+ reasons: [`sed in-place edit detected: ${argText}`],
56
+ };
57
+ }
58
+ continue; // other flags ignored
59
+ }
60
+ const pathStatus = analyzePathRisk(argText);
61
+ // For `sed`, file arguments are only risky if combined with dangerous operations
62
+ if (argText) {
63
+ // If there's an in-place edit or output redirect, path risk matters
64
+ // Otherwise, reading files with sed is safe (GREEN)
65
+ if (hasInPlaceEdit || hasOutputRedirect) {
66
+ if (pathStatus === SafetyStatus.RED) {
67
+ status = pathStatus;
68
+ reasons.push(`sed file argument ${argText}`);
69
+ }
70
+ else {
71
+ status = SafetyStatus.YELLOW;
72
+ reasons.push(`sed file argument ${argText}`);
73
+ }
74
+ }
75
+ else {
76
+ // Read-only sed: only escalate if path itself is risky
77
+ if (pathStatus !== SafetyStatus.GREEN) {
78
+ status = pathStatus;
79
+ reasons.push(`sed file argument ${argText}`);
80
+ }
81
+ // Otherwise GREEN - read-only sed is safe
82
+ }
83
+ continue;
84
+ }
85
+ // Unknown/opaque args fall back to YELLOW
86
+ if (!argText) {
87
+ status = SafetyStatus.YELLOW;
88
+ reasons.push('opaque or unparseable argument');
89
+ }
90
+ }
91
+ return { status, reasons };
92
+ },
93
+ };
94
+ //# sourceMappingURL=sed-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sed-handler.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/sed-handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import { SafetyStatus } from '../constants.js';
2
+ /**
3
+ * Result from a command handler
4
+ */
5
+ export interface CommandHandlerResult {
6
+ status: SafetyStatus;
7
+ reasons: string[];
8
+ }
9
+ /**
10
+ * Helper functions passed to command handlers
11
+ */
12
+ export interface CommandHandlerHelpers {
13
+ extractWordText: (arg: any) => string | undefined;
14
+ analyzePathRisk: (path: string | undefined) => SafetyStatus;
15
+ hasFindDangerousExecution: (suffix: any[]) => {
16
+ dangerous: boolean;
17
+ reason?: string;
18
+ };
19
+ hasFindSuspiciousFlags: (suffix: any[]) => {
20
+ suspicious: boolean;
21
+ reason?: string;
22
+ };
23
+ }
24
+ /**
25
+ * Interface for command-specific safety handlers
26
+ */
27
+ export interface CommandHandler {
28
+ /**
29
+ * Handle command-specific safety analysis
30
+ * @param node The AST node representing the command
31
+ * @param helpers Helper functions for analysis
32
+ * @returns Safety status and reasons
33
+ */
34
+ handle(node: any, helpers: CommandHandlerHelpers): CommandHandlerResult;
35
+ }
36
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAE7C;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACjC,MAAM,EAAE,YAAY,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IAClC,eAAe,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,MAAM,GAAG,SAAS,CAAC;IAClD,eAAe,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,KAAK,YAAY,CAAC;IAC5D,yBAAyB,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK;QAC1C,SAAS,EAAE,OAAO,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,sBAAsB,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,KAAK;QACvC,UAAU,EAAE,OAAO,CAAC;QACpB,MAAM,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;CACL;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC3B;;;;;OAKG;IACH,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,qBAAqB,GAAG,oBAAoB,CAAC;CAC3E"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../source/utils/command-safety/handlers/types.ts"],"names":[],"mappings":""}