@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,343 @@
1
+ import * as winston from 'winston';
2
+ import * as path from 'node:path';
3
+ import * as fs from 'node:fs';
4
+ import envPaths from 'env-paths';
5
+ import DailyRotateFile from 'winston-daily-rotate-file';
6
+ const LOG_LEVELS = {
7
+ error: 0,
8
+ warn: 1,
9
+ info: 2,
10
+ security: 3,
11
+ debug: 4,
12
+ };
13
+ const parseBooleanEnv = (value) => {
14
+ if (typeof value !== 'string') {
15
+ return false;
16
+ }
17
+ const normalized = value.trim().toLowerCase();
18
+ return normalized === '1' || normalized === 'true' || normalized === 'yes';
19
+ };
20
+ /**
21
+ * Winston-based logging service for development, debugging, and security auditing.
22
+ *
23
+ * Features:
24
+ * - Custom log levels (error, warn, security, info, debug)
25
+ * - JSON-formatted file output with daily rotation
26
+ * - XDG-compliant log directories
27
+ * - Correlation ID tracking for request flows
28
+ * - Graceful degradation on write failures
29
+ * - Optional console output for development
30
+ */
31
+ export class LoggingService {
32
+ logger;
33
+ correlationId;
34
+ debugLogging;
35
+ suppressConsoleOutput;
36
+ openrouterLogger;
37
+ constructor(config = {}) {
38
+ const { logDir, logLevel = 'info', disableLogging, console: enableConsole = false, debugLogging = false, suppressConsoleOutput = true, } = config;
39
+ const resolvedDisableLogging = disableLogging ??
40
+ (parseBooleanEnv(process.env.DISABLE_LOGGING) ||
41
+ Boolean(process.env.AVA));
42
+ this.debugLogging = debugLogging;
43
+ this.suppressConsoleOutput = suppressConsoleOutput;
44
+ // Determine log directory
45
+ const finalLogDir = logDir || path.join(envPaths('term2').log, 'logs');
46
+ // Create log directory if needed and logging is enabled
47
+ if (!resolvedDisableLogging) {
48
+ try {
49
+ if (!fs.existsSync(finalLogDir)) {
50
+ fs.mkdirSync(finalLogDir, { recursive: true });
51
+ }
52
+ }
53
+ catch (error) {
54
+ // Graceful degradation: log creation errors to stderr only
55
+ this.emitConsoleError(`[LoggingService] Failed to create log directory: ${error.message}`);
56
+ }
57
+ }
58
+ // Configure Winston logger
59
+ const transports = [];
60
+ if (!resolvedDisableLogging) {
61
+ try {
62
+ // File transport with daily rotation
63
+ const fileTransport = new DailyRotateFile({
64
+ dirname: finalLogDir,
65
+ filename: 'term2-%DATE%.log',
66
+ datePattern: 'YYYY-MM-DD',
67
+ maxSize: '10m',
68
+ maxFiles: '14d',
69
+ format: winston.format.json(),
70
+ level: logLevel,
71
+ });
72
+ // Handle transport errors gracefully
73
+ fileTransport.on('error', (error) => {
74
+ this.emitConsoleError(`[LoggingService] File transport error: ${error.message}`);
75
+ });
76
+ transports.push(fileTransport);
77
+ }
78
+ catch (error) {
79
+ this.emitConsoleError(`[LoggingService] Failed to configure file transport: ${error.message}`);
80
+ }
81
+ }
82
+ // Optional console transport for development
83
+ if (enableConsole) {
84
+ transports.push(new winston.transports.Console({
85
+ format: winston.format.combine(winston.format.colorize(), winston.format.simple()),
86
+ level: logLevel,
87
+ }));
88
+ }
89
+ // Create logger with custom levels
90
+ this.logger = winston.createLogger({
91
+ levels: LOG_LEVELS,
92
+ format: winston.format.combine(winston.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), winston.format.json()),
93
+ defaultMeta: {},
94
+ transports: transports.length > 0
95
+ ? transports
96
+ : [new winston.transports.Console({ silent: true })], // Fallback silent console
97
+ });
98
+ // Add custom log levels to logger if they don't exist
99
+ Object.keys(LOG_LEVELS).forEach(level => {
100
+ if (typeof this.logger[level] !== 'function') {
101
+ this.logger[level] = (message, meta) => {
102
+ this.logger.log(level, message, meta);
103
+ };
104
+ }
105
+ });
106
+ // Create openrouter logger
107
+ if (!resolvedDisableLogging) {
108
+ try {
109
+ const openrouterTransport = new DailyRotateFile({
110
+ dirname: finalLogDir,
111
+ filename: 'term2-openrouter-%DATE%.log',
112
+ datePattern: 'YYYY-MM-DD',
113
+ maxSize: '10m',
114
+ maxFiles: '14d',
115
+ format: winston.format.json(),
116
+ level: logLevel,
117
+ });
118
+ openrouterTransport.on('error', (error) => {
119
+ this.emitConsoleError(`[LoggingService] OpenRouter file transport error: ${error.message}`);
120
+ });
121
+ this.openrouterLogger = winston.createLogger({
122
+ levels: LOG_LEVELS,
123
+ format: winston.format.combine(winston.format.timestamp({
124
+ format: 'YYYY-MM-DD HH:mm:ss',
125
+ }), winston.format.json()),
126
+ defaultMeta: {},
127
+ transports: [openrouterTransport],
128
+ });
129
+ // Add custom log levels
130
+ Object.keys(LOG_LEVELS).forEach(level => {
131
+ if (typeof this.openrouterLogger[level] !==
132
+ 'function') {
133
+ this.openrouterLogger[level] = (message, meta) => {
134
+ this.openrouterLogger.log(level, message, meta);
135
+ };
136
+ }
137
+ });
138
+ }
139
+ catch (error) {
140
+ if (this.debugLogging) {
141
+ this.emitConsoleError(`[LoggingService] Failed to configure openrouter transport: ${error.message}`);
142
+ }
143
+ // Fallback
144
+ this.openrouterLogger = winston.createLogger({
145
+ levels: LOG_LEVELS,
146
+ transports: [
147
+ new winston.transports.Console({ silent: true }),
148
+ ],
149
+ });
150
+ }
151
+ }
152
+ else {
153
+ this.openrouterLogger = winston.createLogger({
154
+ levels: LOG_LEVELS,
155
+ transports: [new winston.transports.Console({ silent: true })],
156
+ });
157
+ }
158
+ }
159
+ /**
160
+ * Return the current effective log level for the logger
161
+ */
162
+ getLogLevel() {
163
+ try {
164
+ return this.logger.level || 'info';
165
+ }
166
+ catch (error) {
167
+ return 'info';
168
+ }
169
+ }
170
+ setSuppressConsoleOutput(value) {
171
+ this.suppressConsoleOutput = value;
172
+ }
173
+ /**
174
+ * Set the current log level at runtime; updates logger and all transports
175
+ */
176
+ setLogLevel(level) {
177
+ if (!Object.prototype.hasOwnProperty.call(LOG_LEVELS, level)) {
178
+ // If invalid, ignore
179
+ this.emitConsoleError(`[LoggingService] Invalid log level: ${level}`);
180
+ return;
181
+ }
182
+ try {
183
+ this.logger.level = level;
184
+ // Update each transport's level as well
185
+ this.logger.transports.forEach((t) => {
186
+ try {
187
+ t.level = level;
188
+ }
189
+ catch (err) {
190
+ // ignore
191
+ }
192
+ });
193
+ // Update openrouter logger transports
194
+ this.openrouterLogger.transports.forEach((t) => {
195
+ try {
196
+ t.level = level;
197
+ }
198
+ catch (err) {
199
+ // ignore
200
+ }
201
+ });
202
+ }
203
+ catch (error) {
204
+ this.emitConsoleError(`[LoggingService] Failed to set log level: ${error.message}`);
205
+ }
206
+ }
207
+ /**
208
+ * Log error-level message
209
+ */
210
+ error(message, meta) {
211
+ this.#log('error', message, meta);
212
+ }
213
+ /**
214
+ * Log warn-level message
215
+ */
216
+ warn(message, meta) {
217
+ this.#log('warn', message, meta);
218
+ }
219
+ /**
220
+ * Log info-level message
221
+ */
222
+ info(message, meta) {
223
+ this.#log('info', message, meta);
224
+ }
225
+ /**
226
+ * Log security event (custom level)
227
+ */
228
+ security(message, meta) {
229
+ this.#log('security', message, meta);
230
+ }
231
+ /**
232
+ * Log debug-level message
233
+ */
234
+ debug(message, meta) {
235
+ this.#log('debug', message, meta);
236
+ }
237
+ logToOpenrouter(level, message, meta) {
238
+ try {
239
+ const metadata = {
240
+ ...meta,
241
+ ...(this.correlationId && { correlationId: this.correlationId }),
242
+ };
243
+ this.openrouterLogger.log(level, message, metadata);
244
+ }
245
+ catch (error) {
246
+ this.emitConsoleError(`[LoggingService] Error logging to openrouter: ${error.message}`);
247
+ }
248
+ }
249
+ /**
250
+ * Set correlation ID for tracking related operations
251
+ */
252
+ setCorrelationId(id) {
253
+ this.correlationId = id;
254
+ }
255
+ /**
256
+ * Clear correlation ID
257
+ */
258
+ clearCorrelationId() {
259
+ this.correlationId = undefined;
260
+ }
261
+ /**
262
+ * Get correlation ID
263
+ */
264
+ getCorrelationId() {
265
+ return this.correlationId;
266
+ }
267
+ log(level, message, meta) {
268
+ try {
269
+ const metadata = {
270
+ ...meta,
271
+ ...(this.correlationId && { correlationId: this.correlationId }),
272
+ };
273
+ if (this.logger &&
274
+ typeof this.logger[level] === 'function') {
275
+ this.logger[level](message, metadata);
276
+ }
277
+ else if (this.logger) {
278
+ this.logger.log(level, message, metadata);
279
+ }
280
+ }
281
+ catch (error) {
282
+ // Gracefully handle logging errors
283
+ this.emitConsoleError(`[LoggingService] Error logging message: ${error.message}`);
284
+ }
285
+ }
286
+ #log(level, message, meta) {
287
+ this.log(level, message, meta);
288
+ }
289
+ emitConsoleError(message) {
290
+ if (!this.debugLogging || this.suppressConsoleOutput) {
291
+ return;
292
+ }
293
+ console.error(message);
294
+ }
295
+ }
296
+ const isTestEnvironment = () => {
297
+ return (process.env.NODE_ENV === 'test' ||
298
+ process.env.VITEST !== undefined ||
299
+ process.env.AVA_PATH !== undefined ||
300
+ process.env.JEST_WORKER_ID !== undefined ||
301
+ process.env.TERM2_TEST_MODE === 'true' ||
302
+ Boolean(process.env.AVA));
303
+ };
304
+ /**
305
+ * @deprecated DO NOT USE - Singleton pattern is deprecated
306
+ *
307
+ * This singleton is deprecated and should not be used in application code.
308
+ * Instead, pass the LoggingService instance via dependency injection:
309
+ *
310
+ * - In services/tools: Accept via constructor deps parameter
311
+ * - In components: Accept as prop or use a context provider
312
+ *
313
+ * This export now throws an error when accessed to catch deprecated usage.
314
+ * It's only allowed in test files for backwards compatibility.
315
+ */
316
+ const _loggingServiceInstance = new LoggingService({
317
+ disableLogging: parseBooleanEnv(process.env.DISABLE_LOGGING) ||
318
+ Boolean(process.env.AVA),
319
+ debugLogging: parseBooleanEnv(process.env.DEBUG_LOGGING),
320
+ });
321
+ export const loggingService = new Proxy(_loggingServiceInstance, {
322
+ get(target, prop) {
323
+ // Allow access in test environment for backwards compatibility
324
+ if (isTestEnvironment()) {
325
+ const value = target[prop];
326
+ // Bind methods to the original target to preserve 'this' context
327
+ if (typeof value === 'function') {
328
+ return value.bind(target);
329
+ }
330
+ return value;
331
+ }
332
+ // Get the caller's stack trace to show where the deprecated usage is
333
+ const stack = new Error().stack || '';
334
+ const callerLine = stack.split('\n')[2] || 'unknown location';
335
+ throw new Error(`DEPRECATED: Direct use of loggingService singleton is not allowed.\n` +
336
+ `Called from: ${callerLine.trim()}\n\n` +
337
+ `Instead, pass LoggingService via dependency injection:\n` +
338
+ ` - In services/tools: Accept via 'deps' constructor parameter\n` +
339
+ ` - In components: Accept as prop or use a context provider\n\n` +
340
+ `The singleton pattern prevents proper testing and makes dependencies unclear.`);
341
+ },
342
+ });
343
+ //# sourceMappingURL=logging-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging-service.js","sourceRoot":"","sources":["../../source/services/logging-service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { ILoggingService, ISettingsService } from './service-interfaces.js';
2
+ export type ModelInfo = {
3
+ id: string;
4
+ name?: string;
5
+ provider: string;
6
+ };
7
+ type FetchFn = (url: string, options?: any) => Promise<any>;
8
+ export declare function fetchModels(deps: {
9
+ settingsService: ISettingsService;
10
+ loggingService: ILoggingService;
11
+ }, providerOverride?: string, fetchImpl?: FetchFn): Promise<ModelInfo[]>;
12
+ export declare function clearModelCache(): void;
13
+ export declare function filterModels(models: ModelInfo[], query: string): ModelInfo[];
14
+ export {};
15
+ //# sourceMappingURL=model-service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"model-service.d.ts","sourceRoot":"","sources":["../../source/services/model-service.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,eAAe,EAAE,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AAE/E,MAAM,MAAM,SAAS,GAAG;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,KAAK,OAAO,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;AAI5D,wBAAsB,WAAW,CAC7B,IAAI,EAAE;IACF,eAAe,EAAE,gBAAgB,CAAC;IAClC,cAAc,EAAE,eAAe,CAAC;CACnC,EACD,gBAAgB,CAAC,EAAE,MAAM,EACzB,SAAS,GAAE,OAAsB,GAClC,OAAO,CAAC,SAAS,EAAE,CAAC,CAkCtB;AAED,wBAAgB,eAAe,IAAI,IAAI,CAEtC;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,EAAE,CAY5E"}
@@ -0,0 +1,46 @@
1
+ import Fuse from 'fuse.js';
2
+ import { getProvider } from '../providers/index.js';
3
+ const cache = new Map();
4
+ export async function fetchModels(deps, providerOverride, fetchImpl = fetch) {
5
+ const { settingsService, loggingService } = deps;
6
+ const provider = providerOverride || settingsService.get('agent.provider');
7
+ const cacheKey = provider;
8
+ if (cache.has(cacheKey)) {
9
+ return cache.get(cacheKey);
10
+ }
11
+ try {
12
+ const providerDef = getProvider(provider);
13
+ if (!providerDef) {
14
+ throw new Error(`Provider '${provider}' is not registered`);
15
+ }
16
+ const rawModels = await providerDef.fetchModels({ settingsService, loggingService }, fetchImpl);
17
+ const models = rawModels.map(m => ({
18
+ ...m,
19
+ provider,
20
+ }));
21
+ cache.set(cacheKey, models);
22
+ return models;
23
+ }
24
+ catch (error) {
25
+ loggingService.warn('Failed to fetch models', {
26
+ provider,
27
+ error: error instanceof Error ? error.message : String(error),
28
+ });
29
+ throw error;
30
+ }
31
+ }
32
+ export function clearModelCache() {
33
+ cache.clear();
34
+ }
35
+ export function filterModels(models, query) {
36
+ if (!query.trim()) {
37
+ return models;
38
+ }
39
+ const fuse = new Fuse(models, {
40
+ keys: ['id', 'name'],
41
+ threshold: 0.4,
42
+ ignoreLocation: true,
43
+ });
44
+ return fuse.search(query.trim()).map(match => match.item);
45
+ }
46
+ //# sourceMappingURL=model-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"model-service.js","sourceRoot":"","sources":["../../source/services/model-service.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,SAAS,CAAC;AAC3B,OAAO,EAAC,WAAW,EAAC,MAAM,uBAAuB,CAAC;AAWlD,MAAM,KAAK,GAAG,IAAI,GAAG,EAAuB,CAAC;AAE7C,MAAM,CAAC,KAAK,UAAU,WAAW,CAC7B,IAGC,EACD,gBAAyB,EACzB,YAAqB,KAAY;IAEjC,MAAM,EAAC,eAAe,EAAE,cAAc,EAAC,GAAG,IAAI,CAAC;IAC/C,MAAM,QAAQ,GACV,gBAAgB,IAAI,eAAe,CAAC,GAAG,CAAS,gBAAgB,CAAC,CAAC;IACtE,MAAM,QAAQ,GAAG,QAAQ,CAAC;IAE1B,IAAI,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;QACtB,OAAO,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAgB,CAAC;IAC9C,CAAC;IAED,IAAI,CAAC;QACD,MAAM,WAAW,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,aAAa,QAAQ,qBAAqB,CAAC,CAAC;QAChE,CAAC;QAED,MAAM,SAAS,GAAG,MAAM,WAAW,CAAC,WAAW,CAC3C,EAAC,eAAe,EAAE,cAAc,EAAC,EACjC,SAAS,CACZ,CAAC;QACF,MAAM,MAAM,GAAgB,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC5C,GAAG,CAAC;YACJ,QAAQ;SACX,CAAC,CAAC,CAAC;QAEJ,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC5B,OAAO,MAAM,CAAC;IAClB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACb,cAAc,CAAC,IAAI,CAAC,wBAAwB,EAAE;YAC1C,QAAQ;YACR,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;SAChE,CAAC,CAAC;QACH,MAAM,KAAK,CAAC;IAChB,CAAC;AACL,CAAC;AAED,MAAM,UAAU,eAAe;IAC3B,KAAK,CAAC,KAAK,EAAE,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,MAAmB,EAAE,KAAa;IAC3D,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC;QAChB,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE;QAC1B,IAAI,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,GAAG;QACd,cAAc,EAAE,IAAI;KACvB,CAAC,CAAC;IAEH,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAC9D,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=model-service.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"model-service.test.d.ts","sourceRoot":"","sources":["../../source/services/model-service.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,128 @@
1
+ import test from 'ava';
2
+ import { fetchModels, clearModelCache, filterModels } from './model-service.js';
3
+ import { createMockSettingsService } from './settings-service.mock.js';
4
+ const originalApiKey = process.env.OPENAI_API_KEY;
5
+ test.beforeEach(() => {
6
+ clearModelCache();
7
+ });
8
+ test.afterEach(() => {
9
+ clearModelCache();
10
+ process.env.OPENAI_API_KEY = originalApiKey;
11
+ });
12
+ test.serial('fetchModels uses OpenRouter endpoint and caches results', async (t) => {
13
+ const calls = [];
14
+ let callCount = 0;
15
+ const fakeFetch = async (url, options) => {
16
+ callCount++;
17
+ calls.push({ url, options, callNumber: callCount });
18
+ return {
19
+ ok: true,
20
+ json: async () => ({
21
+ data: [
22
+ {
23
+ id: 'openrouter/model-a',
24
+ name: 'Model A',
25
+ supported_parameters: ['tools', 'temperature'],
26
+ },
27
+ {
28
+ id: 'openrouter/model-b',
29
+ name: 'Model B',
30
+ supported_parameters: ['temperature'],
31
+ },
32
+ {
33
+ id: 'openrouter/model-c',
34
+ name: 'Model C',
35
+ supported_parameters: ['tools', 'max_tokens'],
36
+ },
37
+ ],
38
+ }),
39
+ };
40
+ };
41
+ console.log('About to call fetchModels first time');
42
+ const first = await fetchModels({
43
+ settingsService: createMockSettingsService(),
44
+ loggingService: { warn: () => { } },
45
+ }, 'openrouter', fakeFetch);
46
+ console.log(`After first fetchModels, calls.length = ${calls.length}`);
47
+ console.log('About to call fetchModels second time');
48
+ const second = await fetchModels({
49
+ settingsService: createMockSettingsService(),
50
+ loggingService: { warn: () => { } },
51
+ }, 'openrouter', fakeFetch);
52
+ console.log(`After second fetchModels, calls.length = ${calls.length}`);
53
+ t.deepEqual(first.map(m => m.id), ['openrouter/model-a', 'openrouter/model-c']);
54
+ t.is(second.length, first.length, 'Cache should be reused');
55
+ // Only the first call should hit fetch because of caching
56
+ if (calls.length !== 1) {
57
+ console.log('Calls:', calls.map(c => ({ url: c.url, callNumber: c.callNumber })));
58
+ }
59
+ t.is(calls.length, 1);
60
+ t.true(calls[0].url.includes('/models'));
61
+ });
62
+ test.serial('fetchModels uses OpenAI models endpoint when provider is openai', async (t) => {
63
+ process.env.OPENAI_API_KEY = 'key-openai-test';
64
+ const calls = [];
65
+ const fakeFetch = async (url, options) => {
66
+ calls.push({ url, options });
67
+ return {
68
+ ok: true,
69
+ json: async () => ({ data: [{ id: 'gpt-4o' }, { id: 'gpt-4.1' }] }),
70
+ };
71
+ };
72
+ const models = await fetchModels({
73
+ settingsService: createMockSettingsService(),
74
+ loggingService: { warn: () => { } },
75
+ }, 'openai', fakeFetch);
76
+ t.deepEqual(models.map(m => m.id), ['gpt-4o', 'gpt-4.1']);
77
+ t.is(calls.length, 1);
78
+ t.is(calls[0].url, 'https://api.openai.com/v1/models');
79
+ // Should include Authorization header when API key present
80
+ t.truthy(calls[0].options?.headers?.Authorization);
81
+ });
82
+ test.serial('fetchModels uses /v1/models for custom OpenAI-compatible provider', async (t) => {
83
+ const providerId = `lmstudio-test-${Date.now()}-${Math.random()}`;
84
+ const settingsService = createMockSettingsService({
85
+ providers: [
86
+ {
87
+ name: providerId,
88
+ baseUrl: 'http://localhost:1234',
89
+ apiKey: 'local-key',
90
+ },
91
+ ],
92
+ });
93
+ const calls = [];
94
+ const fakeFetch = async (url, options) => {
95
+ calls.push({ url, options });
96
+ return {
97
+ ok: true,
98
+ json: async () => ({
99
+ data: [{ id: 'local-model-a' }, { id: 'local-model-b' }],
100
+ }),
101
+ };
102
+ };
103
+ const models = await fetchModels({
104
+ settingsService,
105
+ loggingService: { warn: () => { } },
106
+ }, providerId, fakeFetch);
107
+ t.deepEqual(models.map(m => m.id), ['local-model-a', 'local-model-b']);
108
+ t.is(calls.length, 1);
109
+ t.is(calls[0].url, 'http://localhost:1234/v1/models');
110
+ t.is(calls[0].options?.headers?.Authorization, 'Bearer local-key');
111
+ });
112
+ test('filterModels matches by id or name and limits results', t => {
113
+ const models = [
114
+ { id: 'gpt-4o', name: 'OpenAI 4o', provider: 'openai' },
115
+ { id: 'gpt-4.1', name: 'Reasoning', provider: 'openai' },
116
+ { id: 'meta/llama-3', name: 'Llama 3', provider: 'openrouter' },
117
+ {
118
+ id: 'mistral-large',
119
+ name: 'Mistral Large',
120
+ provider: 'openrouter',
121
+ },
122
+ ];
123
+ const top = filterModels(models, 'llama');
124
+ t.deepEqual(top.map(m => m.id), ['meta/llama-3']);
125
+ const fuzzy = filterModels(models, 'gpt');
126
+ t.is(fuzzy.length, 2);
127
+ });
128
+ //# sourceMappingURL=model-service.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"model-service.test.js","sourceRoot":"","sources":["../../source/services/model-service.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,33 @@
1
+ export interface ILoggingService {
2
+ info(message: string, meta?: any): void;
3
+ warn(message: string, meta?: any): void;
4
+ error(message: string, meta?: any): void;
5
+ debug(message: string, meta?: any): void;
6
+ security(message: string, meta?: any): void;
7
+ setCorrelationId(id: string | undefined): void;
8
+ getCorrelationId(): string | undefined;
9
+ clearCorrelationId(): void;
10
+ }
11
+ export interface ISettingsService {
12
+ get<T = any>(key: string): T;
13
+ set(key: string, value: any): void;
14
+ }
15
+ export interface ISSHService {
16
+ connect(): Promise<void>;
17
+ disconnect(): Promise<void>;
18
+ isConnected(): boolean;
19
+ executeCommand(cmd: string, opts?: {
20
+ cwd?: string;
21
+ }): Promise<{
22
+ stdout: string;
23
+ stderr: string;
24
+ exitCode: number | null;
25
+ timedOut: boolean;
26
+ }>;
27
+ readFile(path: string): Promise<string>;
28
+ writeFile(path: string, content: string): Promise<void>;
29
+ mkdir(path: string, opts?: {
30
+ recursive?: boolean;
31
+ }): Promise<void>;
32
+ }
33
+ //# sourceMappingURL=service-interfaces.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service-interfaces.d.ts","sourceRoot":"","sources":["../../source/services/service-interfaces.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IACxC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IACxC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IACzC,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IACzC,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CAAC;IAC5C,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IAC/C,gBAAgB,IAAI,MAAM,GAAG,SAAS,CAAC;IACvC,kBAAkB,IAAI,IAAI,CAAC;CAC9B;AAED,MAAM,WAAW,gBAAgB;IAC7B,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,MAAM,GAAG,CAAC,CAAC;IAC7B,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI,CAAC;CACtC;AAED,MAAM,WAAW,WAAW;IACxB,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,WAAW,IAAI,OAAO,CAAC;IACvB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC;QAC1D,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,QAAQ,EAAE,OAAO,CAAC;KACrB,CAAC,CAAC;IACH,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACxC,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxD,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACtE"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=service-interfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service-interfaces.js","sourceRoot":"","sources":["../../source/services/service-interfaces.ts"],"names":[],"mappings":""}