@clinebot/core 0.0.34 → 0.0.36

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 (546) hide show
  1. package/README.md +13 -10
  2. package/dist/ClineCore.d.ts +96 -63
  3. package/dist/ClineCore.d.ts.map +1 -1
  4. package/dist/account/index.d.ts +1 -1
  5. package/dist/account/index.d.ts.map +1 -1
  6. package/dist/account/rpc.d.ts +6 -6
  7. package/dist/account/rpc.d.ts.map +1 -1
  8. package/dist/cron/index.d.ts +6 -0
  9. package/dist/cron/index.d.ts.map +1 -0
  10. package/dist/cron/resource-limiter.d.ts +9 -0
  11. package/dist/cron/resource-limiter.d.ts.map +1 -0
  12. package/dist/cron/schedule-command-service.d.ts +10 -0
  13. package/dist/cron/schedule-command-service.d.ts.map +1 -0
  14. package/dist/cron/schedule-service.d.ts +100 -0
  15. package/dist/cron/schedule-service.d.ts.map +1 -0
  16. package/dist/cron/scheduler.d.ts +66 -0
  17. package/dist/cron/scheduler.d.ts.map +1 -0
  18. package/dist/cron/sqlite-schedule-store.d.ts +52 -0
  19. package/dist/cron/sqlite-schedule-store.d.ts.map +1 -0
  20. package/dist/extensions/config/agent-config-loader.d.ts +6 -5
  21. package/dist/extensions/config/agent-config-loader.d.ts.map +1 -1
  22. package/dist/extensions/config/agent-config-parser.d.ts +1 -1
  23. package/dist/extensions/config/agent-config-parser.d.ts.map +1 -1
  24. package/dist/extensions/config/hooks-config-loader.d.ts +2 -2
  25. package/dist/extensions/config/hooks-config-loader.d.ts.map +1 -1
  26. package/dist/extensions/config/index.d.ts +3 -3
  27. package/dist/extensions/config/index.d.ts.map +1 -1
  28. package/dist/extensions/config/runtime-commands.d.ts +1 -0
  29. package/dist/extensions/config/runtime-commands.d.ts.map +1 -1
  30. package/dist/extensions/config/user-instruction-config-loader.d.ts +3 -2
  31. package/dist/extensions/config/user-instruction-config-loader.d.ts.map +1 -1
  32. package/dist/extensions/context/agentic-compaction.d.ts +2 -2
  33. package/dist/extensions/context/agentic-compaction.d.ts.map +1 -1
  34. package/dist/extensions/context/compaction-shared.d.ts +5 -4
  35. package/dist/extensions/context/compaction-shared.d.ts.map +1 -1
  36. package/dist/extensions/context/compaction.d.ts.map +1 -1
  37. package/dist/extensions/plugin/plugin-config-loader.d.ts +9 -2
  38. package/dist/extensions/plugin/plugin-config-loader.d.ts.map +1 -1
  39. package/dist/extensions/plugin/plugin-loader.d.ts +5 -3
  40. package/dist/extensions/plugin/plugin-loader.d.ts.map +1 -1
  41. package/dist/extensions/plugin/plugin-module-import.d.ts.map +1 -1
  42. package/dist/extensions/plugin/plugin-sandbox.d.ts +15 -2
  43. package/dist/extensions/plugin/plugin-sandbox.d.ts.map +1 -1
  44. package/dist/extensions/plugin/plugin-targeting.d.ts +7 -0
  45. package/dist/extensions/plugin/plugin-targeting.d.ts.map +1 -0
  46. package/dist/extensions/plugin-sandbox-bootstrap.js +253 -253
  47. package/dist/extensions/tools/constants.d.ts.map +1 -0
  48. package/dist/{tools → extensions/tools}/definitions.d.ts +1 -1
  49. package/dist/extensions/tools/definitions.d.ts.map +1 -0
  50. package/dist/extensions/tools/executors/apply-patch-parser.d.ts.map +1 -0
  51. package/dist/{tools → extensions/tools}/executors/apply-patch.d.ts +3 -1
  52. package/dist/extensions/tools/executors/apply-patch.d.ts.map +1 -0
  53. package/dist/extensions/tools/executors/bash.d.ts.map +1 -0
  54. package/dist/extensions/tools/executors/editor.d.ts.map +1 -0
  55. package/dist/extensions/tools/executors/file-read.d.ts.map +1 -0
  56. package/dist/extensions/tools/executors/index.d.ts.map +1 -0
  57. package/dist/{tools → extensions/tools}/executors/search.d.ts +1 -1
  58. package/dist/extensions/tools/executors/search.d.ts.map +1 -0
  59. package/dist/extensions/tools/executors/web-fetch.d.ts.map +1 -0
  60. package/dist/extensions/tools/helpers.d.ts.map +1 -0
  61. package/dist/{tools → extensions/tools}/index.d.ts +2 -0
  62. package/dist/extensions/tools/index.d.ts.map +1 -0
  63. package/dist/{tools → extensions/tools}/model-tool-routing.d.ts +1 -1
  64. package/dist/extensions/tools/model-tool-routing.d.ts.map +1 -0
  65. package/dist/{tools → extensions/tools}/presets.d.ts +26 -44
  66. package/dist/extensions/tools/presets.d.ts.map +1 -0
  67. package/dist/extensions/tools/runtime.d.ts +25 -0
  68. package/dist/extensions/tools/runtime.d.ts.map +1 -0
  69. package/dist/extensions/tools/schemas.d.ts.map +1 -0
  70. package/dist/extensions/tools/team/delegated-agent.d.ts.map +1 -0
  71. package/dist/extensions/tools/team/index.d.ts.map +1 -0
  72. package/dist/{team → extensions/tools/team}/multi-agent.d.ts +1 -3
  73. package/dist/extensions/tools/team/multi-agent.d.ts.map +1 -0
  74. package/dist/extensions/tools/team/projections.d.ts.map +1 -0
  75. package/dist/extensions/tools/team/runtime.d.ts.map +1 -0
  76. package/dist/{team → extensions/tools/team}/spawn-agent-tool.d.ts +0 -1
  77. package/dist/extensions/tools/team/spawn-agent-tool.d.ts.map +1 -0
  78. package/dist/extensions/tools/team/subagent-prompts.d.ts.map +1 -0
  79. package/dist/{team → extensions/tools/team}/team-tools.d.ts +1 -0
  80. package/dist/extensions/tools/team/team-tools.d.ts.map +1 -0
  81. package/dist/{tools → extensions/tools}/types.d.ts +4 -3
  82. package/dist/extensions/tools/types.d.ts.map +1 -0
  83. package/dist/{runtime → hooks}/checkpoint-hooks.d.ts +7 -0
  84. package/dist/hooks/checkpoint-hooks.d.ts.map +1 -0
  85. package/dist/{runtime → hooks}/hook-file-hooks.d.ts +4 -3
  86. package/dist/hooks/hook-file-hooks.d.ts.map +1 -0
  87. package/dist/hooks/index.d.ts +0 -1
  88. package/dist/hooks/index.d.ts.map +1 -1
  89. package/dist/hooks/subprocess.d.ts +10 -130
  90. package/dist/hooks/subprocess.d.ts.map +1 -1
  91. package/dist/hub/browser-websocket.d.ts +18 -0
  92. package/dist/hub/browser-websocket.d.ts.map +1 -0
  93. package/dist/hub/client.d.ts +45 -0
  94. package/dist/hub/client.d.ts.map +1 -0
  95. package/dist/hub/connect.d.ts +15 -0
  96. package/dist/hub/connect.d.ts.map +1 -0
  97. package/dist/hub/daemon-entry.d.ts +2 -0
  98. package/dist/hub/daemon-entry.d.ts.map +1 -0
  99. package/dist/hub/daemon-entry.js +1045 -0
  100. package/dist/hub/daemon.d.ts +5 -0
  101. package/dist/hub/daemon.d.ts.map +1 -0
  102. package/dist/hub/defaults.d.ts +13 -0
  103. package/dist/hub/defaults.d.ts.map +1 -0
  104. package/dist/hub/discovery.d.ts +29 -0
  105. package/dist/hub/discovery.d.ts.map +1 -0
  106. package/dist/hub/index.d.ts +15 -0
  107. package/dist/hub/index.d.ts.map +1 -0
  108. package/dist/hub/index.js +1044 -0
  109. package/dist/hub/native-transport.d.ts +17 -0
  110. package/dist/hub/native-transport.d.ts.map +1 -0
  111. package/dist/hub/runtime-handlers.d.ts +11 -0
  112. package/dist/hub/runtime-handlers.d.ts.map +1 -0
  113. package/dist/hub/server.d.ts +86 -0
  114. package/dist/hub/server.d.ts.map +1 -0
  115. package/dist/hub/session-client.d.ts +87 -0
  116. package/dist/hub/session-client.d.ts.map +1 -0
  117. package/dist/hub/start-shared-server.d.ts +19 -0
  118. package/dist/hub/start-shared-server.d.ts.map +1 -0
  119. package/dist/hub/transport.d.ts +8 -0
  120. package/dist/hub/transport.d.ts.map +1 -0
  121. package/dist/hub/ui-client.d.ts +44 -0
  122. package/dist/hub/ui-client.d.ts.map +1 -0
  123. package/dist/hub/workspace.d.ts +4 -0
  124. package/dist/hub/workspace.d.ts.map +1 -0
  125. package/dist/index.d.ts +52 -39
  126. package/dist/index.d.ts.map +1 -1
  127. package/dist/index.js +557 -533
  128. package/dist/llms/configured-provider-registry.d.ts +28 -0
  129. package/dist/llms/configured-provider-registry.d.ts.map +1 -0
  130. package/dist/llms/provider-defaults.d.ts +27 -0
  131. package/dist/llms/provider-defaults.d.ts.map +1 -0
  132. package/dist/llms/provider-settings.d.ts +202 -0
  133. package/dist/llms/provider-settings.d.ts.map +1 -0
  134. package/dist/llms/runtime-config.d.ts +4 -0
  135. package/dist/llms/runtime-config.d.ts.map +1 -0
  136. package/dist/llms/runtime-registry.d.ts +20 -0
  137. package/dist/llms/runtime-registry.d.ts.map +1 -0
  138. package/dist/llms/runtime-types.d.ts +85 -0
  139. package/dist/llms/runtime-types.d.ts.map +1 -0
  140. package/dist/runtime/history.d.ts +4 -0
  141. package/dist/runtime/history.d.ts.map +1 -0
  142. package/dist/runtime/host.d.ts +8 -0
  143. package/dist/runtime/host.d.ts.map +1 -0
  144. package/dist/runtime/rules.d.ts +1 -0
  145. package/dist/runtime/rules.d.ts.map +1 -1
  146. package/dist/runtime/runtime-builder.d.ts.map +1 -1
  147. package/dist/runtime/runtime-host.d.ts +103 -0
  148. package/dist/runtime/runtime-host.d.ts.map +1 -0
  149. package/dist/{session → runtime}/runtime-oauth-token-manager.d.ts +1 -1
  150. package/dist/{session → runtime}/runtime-oauth-token-manager.d.ts.map +1 -1
  151. package/dist/runtime/session-runtime.d.ts +3 -21
  152. package/dist/runtime/session-runtime.d.ts.map +1 -1
  153. package/dist/{session/session-agent-events.d.ts → services/agent-events.d.ts} +4 -4
  154. package/dist/services/agent-events.d.ts.map +1 -0
  155. package/dist/services/config.d.ts +3 -0
  156. package/dist/services/config.d.ts.map +1 -0
  157. package/dist/services/global-settings.d.ts +12 -0
  158. package/dist/services/global-settings.d.ts.map +1 -0
  159. package/dist/services/local-runtime-bootstrap.d.ts +47 -0
  160. package/dist/services/local-runtime-bootstrap.d.ts.map +1 -0
  161. package/dist/services/plugin-tools.d.ts +16 -0
  162. package/dist/services/plugin-tools.d.ts.map +1 -0
  163. package/dist/{providers → services/providers}/local-provider-registry.d.ts +4 -4
  164. package/dist/services/providers/local-provider-registry.d.ts.map +1 -0
  165. package/dist/{providers → services/providers}/local-provider-service.d.ts +13 -13
  166. package/dist/services/providers/local-provider-service.d.ts.map +1 -0
  167. package/dist/{session → services}/session-artifacts.d.ts +0 -4
  168. package/dist/services/session-artifacts.d.ts.map +1 -0
  169. package/dist/{session/utils/helpers.d.ts → services/session-data.d.ts} +19 -27
  170. package/dist/services/session-data.d.ts.map +1 -0
  171. package/dist/{session → services}/session-telemetry.d.ts +2 -2
  172. package/dist/services/session-telemetry.d.ts.map +1 -0
  173. package/dist/{storage → services/storage}/file-team-store.d.ts +2 -2
  174. package/dist/services/storage/file-team-store.d.ts.map +1 -0
  175. package/dist/{storage → services/storage}/provider-settings-legacy-migration.d.ts +1 -1
  176. package/dist/services/storage/provider-settings-legacy-migration.d.ts.map +1 -0
  177. package/dist/{storage → services/storage}/provider-settings-manager.d.ts +1 -1
  178. package/dist/services/storage/provider-settings-manager.d.ts.map +1 -0
  179. package/dist/{storage → services/storage}/sqlite-session-store.d.ts +3 -3
  180. package/dist/services/storage/sqlite-session-store.d.ts.map +1 -0
  181. package/dist/{storage → services/storage}/sqlite-team-store.d.ts +2 -2
  182. package/dist/services/storage/sqlite-team-store.d.ts.map +1 -0
  183. package/dist/{storage → services/storage}/team-store.d.ts +1 -1
  184. package/dist/services/storage/team-store.d.ts.map +1 -0
  185. package/dist/services/telemetry/ITelemetryAdapter.d.ts.map +1 -0
  186. package/dist/services/telemetry/OpenTelemetryAdapter.d.ts.map +1 -0
  187. package/dist/services/telemetry/OpenTelemetryProvider.d.ts.map +1 -0
  188. package/dist/services/telemetry/TelemetryLoggerSink.d.ts.map +1 -0
  189. package/dist/services/telemetry/TelemetryService.d.ts.map +1 -0
  190. package/dist/services/telemetry/core-events.d.ts.map +1 -0
  191. package/dist/services/telemetry/distinct-id.d.ts.map +1 -0
  192. package/dist/services/telemetry/index.d.ts.map +1 -0
  193. package/dist/services/telemetry/index.js +28 -0
  194. package/dist/{session/utils → services}/usage.d.ts +1 -1
  195. package/dist/services/usage.d.ts.map +1 -0
  196. package/dist/services/workspace/file-indexer.d.ts.map +1 -0
  197. package/dist/services/workspace/index.d.ts.map +1 -0
  198. package/dist/services/workspace/mention-enricher.d.ts.map +1 -0
  199. package/dist/services/workspace-manifest.d.ts +16 -0
  200. package/dist/services/workspace-manifest.d.ts.map +1 -0
  201. package/dist/session/file-session-service.d.ts +4 -1
  202. package/dist/session/file-session-service.d.ts.map +1 -1
  203. package/dist/session/persistence-service.d.ts +15 -25
  204. package/dist/session/persistence-service.d.ts.map +1 -1
  205. package/dist/session/session-manifest-store.d.ts +22 -0
  206. package/dist/session/session-manifest-store.d.ts.map +1 -0
  207. package/dist/session/session-row.d.ts +93 -0
  208. package/dist/session/session-row.d.ts.map +1 -0
  209. package/dist/session/session-service.d.ts +8 -109
  210. package/dist/session/session-service.d.ts.map +1 -1
  211. package/dist/session/session-team-coordination.d.ts +4 -4
  212. package/dist/session/session-team-coordination.d.ts.map +1 -1
  213. package/dist/session/subagent-session-manager.d.ts +36 -0
  214. package/dist/session/subagent-session-manager.d.ts.map +1 -0
  215. package/dist/session/team-persistence-store.d.ts +24 -0
  216. package/dist/session/team-persistence-store.d.ts.map +1 -0
  217. package/dist/transports/hub.d.ts +47 -0
  218. package/dist/transports/hub.d.ts.map +1 -0
  219. package/dist/{session/default-session-manager.d.ts → transports/local.d.ts} +30 -16
  220. package/dist/transports/local.d.ts.map +1 -0
  221. package/dist/transports/remote.d.ts +10 -0
  222. package/dist/transports/remote.d.ts.map +1 -0
  223. package/dist/transports/runtime-host-support.d.ts +22 -0
  224. package/dist/transports/runtime-host-support.d.ts.map +1 -0
  225. package/dist/{chat → types}/chat-schema.d.ts +10 -12
  226. package/dist/types/chat-schema.d.ts.map +1 -0
  227. package/dist/types/config.d.ts +10 -9
  228. package/dist/types/config.d.ts.map +1 -1
  229. package/dist/types/provider-settings.d.ts +4 -5
  230. package/dist/types/provider-settings.d.ts.map +1 -1
  231. package/dist/{session/utils/types.d.ts → types/session.d.ts} +16 -6
  232. package/dist/types/session.d.ts.map +1 -0
  233. package/dist/types/sessions.d.ts +19 -0
  234. package/dist/types/sessions.d.ts.map +1 -1
  235. package/dist/types/storage.d.ts +1 -3
  236. package/dist/types/storage.d.ts.map +1 -1
  237. package/dist/types.d.ts +14 -6
  238. package/dist/types.d.ts.map +1 -1
  239. package/package.json +22 -13
  240. package/src/ClineCore.ts +183 -85
  241. package/src/account/index.ts +3 -3
  242. package/src/account/rpc.ts +12 -12
  243. package/src/auth/cline.ts +1 -1
  244. package/src/auth/codex.ts +1 -1
  245. package/src/auth/oca.ts +1 -1
  246. package/src/cron/index.ts +5 -0
  247. package/src/cron/resource-limiter.ts +46 -0
  248. package/src/cron/schedule-command-service.ts +193 -0
  249. package/src/cron/schedule-service.ts +703 -0
  250. package/src/cron/scheduler.ts +637 -0
  251. package/src/cron/sqlite-schedule-store.ts +708 -0
  252. package/src/extensions/config/agent-config-loader.ts +18 -12
  253. package/src/extensions/config/agent-config-parser.ts +1 -1
  254. package/src/extensions/config/hooks-config-loader.ts +1 -2
  255. package/src/extensions/config/index.ts +0 -4
  256. package/src/extensions/config/runtime-commands.ts +6 -0
  257. package/src/extensions/config/user-instruction-config-loader.ts +1 -4
  258. package/src/extensions/context/agentic-compaction.ts +3 -3
  259. package/src/extensions/context/basic-compaction.ts +2 -2
  260. package/src/extensions/context/compaction-shared.ts +5 -4
  261. package/src/extensions/context/compaction.ts +3 -3
  262. package/src/extensions/plugin/plugin-config-loader.ts +17 -2
  263. package/src/extensions/plugin/plugin-loader.ts +48 -4
  264. package/src/extensions/plugin/plugin-module-import.ts +0 -2
  265. package/src/extensions/plugin/plugin-sandbox-bootstrap.ts +93 -39
  266. package/src/extensions/plugin/plugin-sandbox.ts +47 -27
  267. package/src/extensions/plugin/plugin-targeting.ts +32 -0
  268. package/src/{tools → extensions/tools}/definitions.ts +31 -50
  269. package/src/{tools → extensions/tools}/executors/apply-patch.ts +69 -80
  270. package/src/{tools → extensions/tools}/executors/file-read.ts +29 -4
  271. package/src/{tools → extensions/tools}/executors/search.ts +196 -4
  272. package/src/{tools → extensions/tools}/index.ts +10 -0
  273. package/src/{tools → extensions/tools}/model-tool-routing.ts +1 -1
  274. package/src/{tools → extensions/tools}/presets.ts +31 -47
  275. package/src/extensions/tools/runtime.ts +261 -0
  276. package/src/{tools → extensions/tools}/schemas.ts +4 -2
  277. package/src/{team → extensions/tools/team}/multi-agent.ts +80 -17
  278. package/src/{team → extensions/tools/team}/spawn-agent-tool.ts +1 -7
  279. package/src/{team → extensions/tools/team}/subagent-prompts.ts +2 -2
  280. package/src/{team → extensions/tools/team}/team-tools.ts +84 -53
  281. package/src/{tools → extensions/tools}/types.ts +5 -3
  282. package/src/{runtime → hooks}/checkpoint-hooks.ts +27 -0
  283. package/src/{runtime → hooks}/hook-file-hooks.ts +14 -13
  284. package/src/hooks/index.ts +0 -7
  285. package/src/hooks/subprocess-runner.ts +1 -1
  286. package/src/hooks/subprocess.ts +57 -257
  287. package/src/hub/browser-websocket.ts +137 -0
  288. package/src/hub/client.ts +574 -0
  289. package/src/hub/connect.ts +156 -0
  290. package/src/hub/daemon-entry.ts +87 -0
  291. package/src/hub/daemon.ts +181 -0
  292. package/src/hub/defaults.ts +43 -0
  293. package/src/hub/discovery.ts +247 -0
  294. package/src/hub/index.ts +14 -0
  295. package/src/hub/native-transport.ts +31 -0
  296. package/src/hub/runtime-handlers.ts +140 -0
  297. package/src/hub/server.ts +1888 -0
  298. package/src/hub/session-client.ts +460 -0
  299. package/src/hub/start-shared-server.ts +58 -0
  300. package/src/hub/transport.ts +14 -0
  301. package/src/hub/ui-client.ts +122 -0
  302. package/src/hub/workspace.ts +19 -0
  303. package/src/index.ts +264 -199
  304. package/src/llms/configured-provider-registry.ts +193 -0
  305. package/src/llms/provider-defaults.ts +637 -0
  306. package/src/llms/provider-settings.ts +263 -0
  307. package/src/llms/runtime-config.ts +43 -0
  308. package/src/llms/runtime-registry.ts +171 -0
  309. package/src/llms/runtime-types.ts +121 -0
  310. package/src/runtime/history.ts +237 -0
  311. package/src/runtime/host.ts +200 -0
  312. package/src/runtime/index.ts +1 -0
  313. package/src/runtime/rules.ts +12 -0
  314. package/src/runtime/runtime-builder.ts +37 -29
  315. package/src/runtime/runtime-host.ts +206 -0
  316. package/src/{session → runtime}/runtime-oauth-token-manager.ts +12 -16
  317. package/src/runtime/session-runtime.ts +2 -26
  318. package/src/{session/session-agent-events.ts → services/agent-events.ts} +7 -7
  319. package/src/services/config.ts +5 -0
  320. package/src/services/global-settings.ts +122 -0
  321. package/src/services/local-runtime-bootstrap.ts +318 -0
  322. package/src/services/plugin-tools.ts +85 -0
  323. package/src/{providers → services/providers}/local-provider-registry.ts +6 -6
  324. package/src/{providers → services/providers}/local-provider-service.ts +46 -41
  325. package/src/{session → services}/session-artifacts.ts +7 -19
  326. package/src/{session/utils/helpers.ts → services/session-data.ts} +90 -80
  327. package/src/{session → services}/session-telemetry.ts +7 -9
  328. package/src/services/storage/artifact-store.ts +1 -0
  329. package/src/{storage → services/storage}/file-team-store.ts +2 -2
  330. package/src/{storage → services/storage}/provider-settings-legacy-migration.ts +6 -4
  331. package/src/{storage → services/storage}/provider-settings-manager.ts +3 -3
  332. package/src/services/storage/session-store.ts +1 -0
  333. package/src/{storage → services/storage}/sqlite-session-store.ts +7 -12
  334. package/src/{storage → services/storage}/sqlite-team-store.ts +4 -4
  335. package/src/{storage → services/storage}/team-store.ts +1 -1
  336. package/src/{session/utils → services}/usage.ts +1 -1
  337. package/src/{input → services/workspace}/file-indexer.ts +26 -2
  338. package/src/{input → services/workspace}/mention-enricher.ts +1 -1
  339. package/src/{session → services}/workspace-manifest.ts +18 -0
  340. package/src/session/file-session-service.ts +10 -8
  341. package/src/session/index.ts +10 -23
  342. package/src/session/persistence-service.ts +144 -528
  343. package/src/session/session-manifest-store.ts +158 -0
  344. package/src/session/session-row.ts +199 -0
  345. package/src/session/session-service.ts +43 -389
  346. package/src/session/session-team-coordination.ts +14 -7
  347. package/src/session/subagent-session-manager.ts +397 -0
  348. package/src/session/team-persistence-store.ts +176 -0
  349. package/src/session/workspace-manager.ts +1 -1
  350. package/src/transports/hub.ts +656 -0
  351. package/src/{session/default-session-manager.ts → transports/local.ts} +263 -200
  352. package/src/transports/remote.ts +26 -0
  353. package/src/transports/runtime-host-support.ts +140 -0
  354. package/src/{chat → types}/chat-schema.ts +4 -5
  355. package/src/types/config.ts +10 -9
  356. package/src/types/provider-settings.ts +11 -7
  357. package/src/{session/utils/types.ts → types/session.ts} +16 -5
  358. package/src/types/sessions.ts +21 -0
  359. package/src/types/storage.ts +1 -6
  360. package/src/types.ts +52 -19
  361. package/dist/chat/chat-schema.d.ts.map +0 -1
  362. package/dist/hooks/persistent.d.ts +0 -64
  363. package/dist/hooks/persistent.d.ts.map +0 -1
  364. package/dist/input/file-indexer.d.ts.map +0 -1
  365. package/dist/input/index.d.ts.map +0 -1
  366. package/dist/input/mention-enricher.d.ts.map +0 -1
  367. package/dist/prompt/default-system.d.ts +0 -2
  368. package/dist/prompt/default-system.d.ts.map +0 -1
  369. package/dist/providers/local-provider-registry.d.ts.map +0 -1
  370. package/dist/providers/local-provider-service.d.ts.map +0 -1
  371. package/dist/runtime/checkpoint-hooks.d.ts.map +0 -1
  372. package/dist/runtime/hook-file-hooks.d.ts.map +0 -1
  373. package/dist/session/default-session-manager.d.ts.map +0 -1
  374. package/dist/session/rpc-runtime-ensure.d.ts +0 -53
  375. package/dist/session/rpc-runtime-ensure.d.ts.map +0 -1
  376. package/dist/session/rpc-session-service.d.ts +0 -13
  377. package/dist/session/rpc-session-service.d.ts.map +0 -1
  378. package/dist/session/rpc-spawn-lease.d.ts +0 -8
  379. package/dist/session/rpc-spawn-lease.d.ts.map +0 -1
  380. package/dist/session/session-agent-events.d.ts.map +0 -1
  381. package/dist/session/session-artifacts.d.ts.map +0 -1
  382. package/dist/session/session-config-builder.d.ts +0 -16
  383. package/dist/session/session-config-builder.d.ts.map +0 -1
  384. package/dist/session/session-host.d.ts +0 -15
  385. package/dist/session/session-host.d.ts.map +0 -1
  386. package/dist/session/session-manager.d.ts +0 -62
  387. package/dist/session/session-manager.d.ts.map +0 -1
  388. package/dist/session/session-telemetry.d.ts.map +0 -1
  389. package/dist/session/sqlite-rpc-session-backend.d.ts +0 -31
  390. package/dist/session/sqlite-rpc-session-backend.d.ts.map +0 -1
  391. package/dist/session/utils/helpers.d.ts.map +0 -1
  392. package/dist/session/utils/types.d.ts.map +0 -1
  393. package/dist/session/utils/usage.d.ts.map +0 -1
  394. package/dist/session/workspace-manifest.d.ts +0 -5
  395. package/dist/session/workspace-manifest.d.ts.map +0 -1
  396. package/dist/storage/file-team-store.d.ts.map +0 -1
  397. package/dist/storage/provider-settings-legacy-migration.d.ts.map +0 -1
  398. package/dist/storage/provider-settings-manager.d.ts.map +0 -1
  399. package/dist/storage/sqlite-session-store.d.ts.map +0 -1
  400. package/dist/storage/sqlite-team-store.d.ts.map +0 -1
  401. package/dist/storage/team-store.d.ts.map +0 -1
  402. package/dist/team/delegated-agent.d.ts.map +0 -1
  403. package/dist/team/index.d.ts.map +0 -1
  404. package/dist/team/multi-agent.d.ts.map +0 -1
  405. package/dist/team/projections.d.ts.map +0 -1
  406. package/dist/team/runtime.d.ts.map +0 -1
  407. package/dist/team/spawn-agent-tool.d.ts.map +0 -1
  408. package/dist/team/subagent-prompts.d.ts.map +0 -1
  409. package/dist/team/team-tools.d.ts.map +0 -1
  410. package/dist/telemetry/ITelemetryAdapter.d.ts.map +0 -1
  411. package/dist/telemetry/OpenTelemetryAdapter.d.ts.map +0 -1
  412. package/dist/telemetry/OpenTelemetryProvider.d.ts.map +0 -1
  413. package/dist/telemetry/TelemetryLoggerSink.d.ts.map +0 -1
  414. package/dist/telemetry/TelemetryService.d.ts.map +0 -1
  415. package/dist/telemetry/core-events.d.ts.map +0 -1
  416. package/dist/telemetry/distinct-id.d.ts.map +0 -1
  417. package/dist/telemetry/index.d.ts.map +0 -1
  418. package/dist/telemetry/index.js +0 -15
  419. package/dist/tools/constants.d.ts.map +0 -1
  420. package/dist/tools/definitions.d.ts.map +0 -1
  421. package/dist/tools/executors/apply-patch-parser.d.ts.map +0 -1
  422. package/dist/tools/executors/apply-patch.d.ts.map +0 -1
  423. package/dist/tools/executors/bash.d.ts.map +0 -1
  424. package/dist/tools/executors/editor.d.ts.map +0 -1
  425. package/dist/tools/executors/file-read.d.ts.map +0 -1
  426. package/dist/tools/executors/index.d.ts.map +0 -1
  427. package/dist/tools/executors/search.d.ts.map +0 -1
  428. package/dist/tools/executors/web-fetch.d.ts.map +0 -1
  429. package/dist/tools/helpers.d.ts.map +0 -1
  430. package/dist/tools/index.d.ts.map +0 -1
  431. package/dist/tools/model-tool-routing.d.ts.map +0 -1
  432. package/dist/tools/presets.d.ts.map +0 -1
  433. package/dist/tools/schemas.d.ts.map +0 -1
  434. package/dist/tools/types.d.ts.map +0 -1
  435. package/src/ClineCore.test.ts +0 -150
  436. package/src/account/cline-account-service.test.ts +0 -185
  437. package/src/account/featurebase-token.test.ts +0 -175
  438. package/src/account/rpc.test.ts +0 -63
  439. package/src/auth/bounded-ttl-cache.test.ts +0 -38
  440. package/src/auth/client.test.ts +0 -69
  441. package/src/auth/cline.test.ts +0 -267
  442. package/src/auth/codex.test.ts +0 -170
  443. package/src/auth/oca.test.ts +0 -340
  444. package/src/auth/server.test.ts +0 -287
  445. package/src/auth/utils.test.ts +0 -128
  446. package/src/extensions/config/agent-config-loader.test.ts +0 -236
  447. package/src/extensions/config/hooks-config-loader.test.ts +0 -20
  448. package/src/extensions/config/runtime-commands.test.ts +0 -115
  449. package/src/extensions/config/unified-config-file-watcher.test.ts +0 -196
  450. package/src/extensions/config/user-instruction-config-loader.test.ts +0 -246
  451. package/src/extensions/context/compaction.test.ts +0 -483
  452. package/src/extensions/mcp/config-loader.test.ts +0 -238
  453. package/src/extensions/mcp/manager.test.ts +0 -105
  454. package/src/extensions/plugin/plugin-config-loader.test.ts +0 -182
  455. package/src/extensions/plugin/plugin-loader.test.ts +0 -292
  456. package/src/extensions/plugin/plugin-sandbox.test.ts +0 -423
  457. package/src/hooks/persistent.ts +0 -661
  458. package/src/input/file-indexer.d.ts +0 -11
  459. package/src/input/file-indexer.test.ts +0 -127
  460. package/src/input/mention-enricher.test.ts +0 -85
  461. package/src/prompt/default-system.ts +0 -21
  462. package/src/providers/local-provider-service.test.ts +0 -1062
  463. package/src/runtime/checkpoint-hooks.test.ts +0 -168
  464. package/src/runtime/hook-file-hooks.test.ts +0 -311
  465. package/src/runtime/runtime-builder.team-persistence.test.ts +0 -242
  466. package/src/runtime/runtime-builder.test.ts +0 -616
  467. package/src/runtime/runtime-parity.test.ts +0 -143
  468. package/src/session/default-session-manager.e2e.test.ts +0 -384
  469. package/src/session/default-session-manager.test.ts +0 -2473
  470. package/src/session/persistence-service.test.ts +0 -241
  471. package/src/session/rpc-runtime-ensure.ts +0 -521
  472. package/src/session/rpc-session-service.ts +0 -107
  473. package/src/session/rpc-spawn-lease.test.ts +0 -49
  474. package/src/session/rpc-spawn-lease.ts +0 -122
  475. package/src/session/runtime-oauth-token-manager.test.ts +0 -137
  476. package/src/session/session-config-builder.ts +0 -172
  477. package/src/session/session-host.test.ts +0 -89
  478. package/src/session/session-host.ts +0 -213
  479. package/src/session/session-manager.ts +0 -74
  480. package/src/session/session-service.team-persistence.test.ts +0 -48
  481. package/src/session/sqlite-rpc-session-backend.ts +0 -303
  482. package/src/session/utils/helpers.test.ts +0 -160
  483. package/src/storage/artifact-store.ts +0 -1
  484. package/src/storage/provider-settings-legacy-migration.test.ts +0 -424
  485. package/src/storage/provider-settings-manager.test.ts +0 -191
  486. package/src/storage/session-store.ts +0 -1
  487. package/src/team/multi-agent.lifecycle.test.ts +0 -201
  488. package/src/team/spawn-agent-tool.test.ts +0 -387
  489. package/src/team/team-tools.test.ts +0 -906
  490. package/src/telemetry/OpenTelemetryAdapter.test.ts +0 -157
  491. package/src/telemetry/OpenTelemetryProvider.test.ts +0 -326
  492. package/src/telemetry/TelemetryLoggerSink.test.ts +0 -42
  493. package/src/telemetry/TelemetryService.test.ts +0 -134
  494. package/src/telemetry/distinct-id.test.ts +0 -57
  495. package/src/tools/definitions.test.ts +0 -780
  496. package/src/tools/executors/bash.test.ts +0 -87
  497. package/src/tools/executors/editor.test.ts +0 -35
  498. package/src/tools/executors/file-read.test.ts +0 -49
  499. package/src/tools/model-tool-routing.test.ts +0 -86
  500. package/src/tools/presets.test.ts +0 -70
  501. /package/dist/{tools → extensions/tools}/constants.d.ts +0 -0
  502. /package/dist/{tools → extensions/tools}/executors/apply-patch-parser.d.ts +0 -0
  503. /package/dist/{tools → extensions/tools}/executors/bash.d.ts +0 -0
  504. /package/dist/{tools → extensions/tools}/executors/editor.d.ts +0 -0
  505. /package/dist/{tools → extensions/tools}/executors/file-read.d.ts +0 -0
  506. /package/dist/{tools → extensions/tools}/executors/index.d.ts +0 -0
  507. /package/dist/{tools → extensions/tools}/executors/web-fetch.d.ts +0 -0
  508. /package/dist/{tools → extensions/tools}/helpers.d.ts +0 -0
  509. /package/dist/{tools → extensions/tools}/schemas.d.ts +0 -0
  510. /package/dist/{team → extensions/tools/team}/delegated-agent.d.ts +0 -0
  511. /package/dist/{team → extensions/tools/team}/index.d.ts +0 -0
  512. /package/dist/{team → extensions/tools/team}/projections.d.ts +0 -0
  513. /package/dist/{team → extensions/tools/team}/runtime.d.ts +0 -0
  514. /package/dist/{team → extensions/tools/team}/subagent-prompts.d.ts +0 -0
  515. /package/dist/{telemetry → services/telemetry}/ITelemetryAdapter.d.ts +0 -0
  516. /package/dist/{telemetry → services/telemetry}/OpenTelemetryAdapter.d.ts +0 -0
  517. /package/dist/{telemetry → services/telemetry}/OpenTelemetryProvider.d.ts +0 -0
  518. /package/dist/{telemetry → services/telemetry}/TelemetryLoggerSink.d.ts +0 -0
  519. /package/dist/{telemetry → services/telemetry}/TelemetryService.d.ts +0 -0
  520. /package/dist/{telemetry → services/telemetry}/core-events.d.ts +0 -0
  521. /package/dist/{telemetry → services/telemetry}/distinct-id.d.ts +0 -0
  522. /package/dist/{telemetry → services/telemetry}/index.d.ts +0 -0
  523. /package/dist/{input → services/workspace}/file-indexer.d.ts +0 -0
  524. /package/dist/{input → services/workspace}/index.d.ts +0 -0
  525. /package/dist/{input → services/workspace}/mention-enricher.d.ts +0 -0
  526. /package/src/{tools → extensions/tools}/constants.ts +0 -0
  527. /package/src/{tools → extensions/tools}/executors/apply-patch-parser.ts +0 -0
  528. /package/src/{tools → extensions/tools}/executors/bash.ts +0 -0
  529. /package/src/{tools → extensions/tools}/executors/editor.ts +0 -0
  530. /package/src/{tools → extensions/tools}/executors/index.ts +0 -0
  531. /package/src/{tools → extensions/tools}/executors/web-fetch.ts +0 -0
  532. /package/src/{tools → extensions/tools}/helpers.ts +0 -0
  533. /package/src/{team → extensions/tools/team}/delegated-agent.ts +0 -0
  534. /package/src/{team → extensions/tools/team}/index.ts +0 -0
  535. /package/src/{team → extensions/tools/team}/projections.ts +0 -0
  536. /package/src/{team → extensions/tools/team}/runtime.ts +0 -0
  537. /package/src/{storage → services/storage}/index.ts +0 -0
  538. /package/src/{telemetry → services/telemetry}/ITelemetryAdapter.ts +0 -0
  539. /package/src/{telemetry → services/telemetry}/OpenTelemetryAdapter.ts +0 -0
  540. /package/src/{telemetry → services/telemetry}/OpenTelemetryProvider.ts +0 -0
  541. /package/src/{telemetry → services/telemetry}/TelemetryLoggerSink.ts +0 -0
  542. /package/src/{telemetry → services/telemetry}/TelemetryService.ts +0 -0
  543. /package/src/{telemetry → services/telemetry}/core-events.ts +0 -0
  544. /package/src/{telemetry → services/telemetry}/distinct-id.ts +0 -0
  545. /package/src/{telemetry → services/telemetry}/index.ts +0 -0
  546. /package/src/{input → services/workspace}/index.ts +0 -0
@@ -1,780 +0,0 @@
1
- import { describe, expect, it, vi } from "vitest";
2
- import {
3
- createDefaultTools,
4
- createReadFilesTool,
5
- createSkillsTool,
6
- createWindowsShellTool,
7
- } from "./definitions";
8
- import { INPUT_ARG_CHAR_LIMIT } from "./schemas";
9
- import type { SkillsExecutorWithMetadata } from "./types";
10
-
11
- function createMockSkillsExecutor(
12
- fn: (...args: unknown[]) => Promise<string> = async () => "ok",
13
- configuredSkills?: SkillsExecutorWithMetadata["configuredSkills"],
14
- ): SkillsExecutorWithMetadata {
15
- const executor = fn as SkillsExecutorWithMetadata;
16
- executor.configuredSkills = configuredSkills;
17
- return executor;
18
- }
19
-
20
- describe("default skills tool", () => {
21
- it("is included only when enabled with a skills executor", () => {
22
- const toolsWithoutExecutor = createDefaultTools({
23
- executors: {},
24
- enableSkills: true,
25
- });
26
- expect(toolsWithoutExecutor.map((tool) => tool.name)).not.toContain(
27
- "skills",
28
- );
29
-
30
- const toolsWithExecutor = createDefaultTools({
31
- executors: {
32
- skills: createMockSkillsExecutor(),
33
- },
34
- enableSkills: true,
35
- });
36
- expect(toolsWithExecutor.map((tool) => tool.name)).toContain("skills");
37
- });
38
-
39
- it("includes configured skill names in description", () => {
40
- const executor = createMockSkillsExecutor(
41
- async () => "ok",
42
- [
43
- { id: "commit", name: "commit", disabled: false },
44
- {
45
- id: "review-pr",
46
- name: "review-pr",
47
- description: "Review a PR",
48
- disabled: false,
49
- },
50
- { id: "disabled-skill", name: "disabled-skill", disabled: true },
51
- ],
52
- );
53
- const tool = createSkillsTool(executor);
54
- expect(tool.description).toContain("Available skills: commit, review-pr.");
55
- expect(tool.description).not.toContain("disabled-skill");
56
- });
57
-
58
- it("omits skill list from description when no skills are configured", () => {
59
- const executor = createMockSkillsExecutor(async () => "ok");
60
- const tool = createSkillsTool(executor);
61
- expect(tool.description).not.toContain("Available skills");
62
- });
63
-
64
- it("validates and executes skill invocation input", async () => {
65
- const execute = vi.fn(async () => "loaded");
66
- const tools = createDefaultTools({
67
- executors: {
68
- skills: createMockSkillsExecutor(execute),
69
- },
70
- enableReadFiles: false,
71
- enableSearch: false,
72
- enableBash: false,
73
- enableWebFetch: false,
74
- enableEditor: false,
75
- enableSkills: true,
76
- });
77
- const skillsTool = tools.find((tool) => tool.name === "skills");
78
- expect(skillsTool).toBeDefined();
79
- if (!skillsTool) {
80
- throw new Error("Expected skills tool to be defined.");
81
- }
82
-
83
- const result = await skillsTool.execute(
84
- { skill: "commit", args: "-m 'fix'" },
85
- {
86
- agentId: "agent-1",
87
- conversationId: "conv-1",
88
- iteration: 1,
89
- },
90
- );
91
-
92
- expect(result).toBe("loaded");
93
- expect(execute).toHaveBeenCalledWith(
94
- "commit",
95
- "-m 'fix'",
96
- expect.objectContaining({
97
- agentId: "agent-1",
98
- conversationId: "conv-1",
99
- iteration: 1,
100
- }),
101
- );
102
- });
103
- });
104
-
105
- describe("default ask_question tool", () => {
106
- it("is enabled by default when executor is provided", () => {
107
- const tools = createDefaultTools({
108
- executors: {
109
- askQuestion: async () => "ok",
110
- },
111
- });
112
- expect(tools.map((tool) => tool.name)).toContain("ask_question");
113
- });
114
-
115
- it("is excluded when explicitly disabled", () => {
116
- const tools = createDefaultTools({
117
- executors: {
118
- askQuestion: async () => "ok",
119
- },
120
- enableAskQuestion: false,
121
- });
122
- expect(tools.map((tool) => tool.name)).not.toContain("ask_question");
123
- });
124
-
125
- it("is included only when enabled with an askQuestion executor", () => {
126
- const toolsWithoutExecutor = createDefaultTools({
127
- executors: {},
128
- enableAskQuestion: true,
129
- });
130
- expect(toolsWithoutExecutor.map((tool) => tool.name)).not.toContain(
131
- "ask_question",
132
- );
133
-
134
- const toolsWithExecutor = createDefaultTools({
135
- executors: {
136
- askQuestion: async () => "ok",
137
- },
138
- enableAskQuestion: true,
139
- });
140
- expect(toolsWithExecutor.map((tool) => tool.name)).toContain(
141
- "ask_question",
142
- );
143
- });
144
-
145
- it("validates and executes ask_question input", async () => {
146
- const execute = vi.fn(async () => "asked");
147
- const tools = createDefaultTools({
148
- executors: {
149
- askQuestion: execute,
150
- },
151
- enableReadFiles: false,
152
- enableSearch: false,
153
- enableBash: false,
154
- enableWebFetch: false,
155
- enableEditor: false,
156
- enableSkills: false,
157
- enableAskQuestion: true,
158
- });
159
- const askTool = tools.find((tool) => tool.name === "ask_question");
160
- expect(askTool).toBeDefined();
161
- if (!askTool) {
162
- throw new Error("Expected ask_question tool to be defined.");
163
- }
164
-
165
- const result = await askTool.execute(
166
- {
167
- question: "Which approach should I take?",
168
- options: ["Option 1", "Option 2"],
169
- },
170
- {
171
- agentId: "agent-1",
172
- conversationId: "conv-1",
173
- iteration: 1,
174
- },
175
- );
176
-
177
- expect(result).toBe("asked");
178
- expect(execute).toHaveBeenCalledWith(
179
- "Which approach should I take?",
180
- ["Option 1", "Option 2"],
181
- expect.objectContaining({
182
- agentId: "agent-1",
183
- conversationId: "conv-1",
184
- iteration: 1,
185
- }),
186
- );
187
- });
188
- });
189
-
190
- describe("default submit_and_exit tool", () => {
191
- it("is excluded by default even when executor is provided", () => {
192
- const tools = createDefaultTools({
193
- executors: {
194
- submit: async () => "ok",
195
- },
196
- });
197
- expect(tools.map((tool) => tool.name)).not.toContain("submit_and_exit");
198
- });
199
-
200
- it("is included only when enabled with a submit executor", () => {
201
- const toolsWithoutExecutor = createDefaultTools({
202
- executors: {},
203
- enableSubmitAndExit: true,
204
- });
205
- expect(toolsWithoutExecutor.map((tool) => tool.name)).not.toContain(
206
- "submit_and_exit",
207
- );
208
-
209
- const toolsWithExecutor = createDefaultTools({
210
- executors: {
211
- submit: async () => "ok",
212
- },
213
- enableSubmitAndExit: true,
214
- });
215
- expect(toolsWithExecutor.map((tool) => tool.name)).toContain(
216
- "submit_and_exit",
217
- );
218
- });
219
-
220
- it("validates and executes submit_and_exit input", async () => {
221
- const execute = vi.fn(async () => "submitted");
222
- const tools = createDefaultTools({
223
- executors: {
224
- submit: execute,
225
- },
226
- enableReadFiles: false,
227
- enableSearch: false,
228
- enableBash: false,
229
- enableWebFetch: false,
230
- enableEditor: false,
231
- enableSkills: false,
232
- enableAskQuestion: false,
233
- enableSubmitAndExit: true,
234
- });
235
- const submitTool = tools.find((tool) => tool.name === "submit_and_exit");
236
- expect(submitTool).toBeDefined();
237
- if (!submitTool) {
238
- throw new Error("Expected submit_and_exit tool to be defined.");
239
- }
240
-
241
- const result = await submitTool.execute(
242
- {
243
- summary: "Done and verified with the requested checks.",
244
- verified: true,
245
- },
246
- {
247
- agentId: "agent-1",
248
- conversationId: "conv-1",
249
- iteration: 1,
250
- },
251
- );
252
-
253
- expect(result).toBe("submitted");
254
- expect(execute).toHaveBeenCalledWith(
255
- "Done and verified with the requested checks.",
256
- true,
257
- expect.objectContaining({
258
- agentId: "agent-1",
259
- conversationId: "conv-1",
260
- iteration: 1,
261
- }),
262
- );
263
- });
264
- });
265
-
266
- describe("default apply_patch tool", () => {
267
- it("is included only when enabled with an applyPatch executor", () => {
268
- const toolsWithoutExecutor = createDefaultTools({
269
- executors: {},
270
- enableApplyPatch: true,
271
- });
272
- expect(toolsWithoutExecutor.map((tool) => tool.name)).not.toContain(
273
- "apply_patch",
274
- );
275
-
276
- const toolsWithExecutor = createDefaultTools({
277
- executors: {
278
- applyPatch: async () => "ok",
279
- },
280
- enableApplyPatch: true,
281
- });
282
- expect(toolsWithExecutor.map((tool) => tool.name)).toContain("apply_patch");
283
- });
284
-
285
- it("validates and executes apply_patch input", async () => {
286
- const execute = vi.fn(async () => "patched");
287
- const tools = createDefaultTools({
288
- executors: {
289
- applyPatch: execute,
290
- },
291
- enableReadFiles: false,
292
- enableSearch: false,
293
- enableBash: false,
294
- enableWebFetch: false,
295
- enableEditor: false,
296
- enableSkills: false,
297
- enableAskQuestion: false,
298
- enableApplyPatch: true,
299
- });
300
-
301
- const applyPatchTool = tools.find((tool) => tool.name === "apply_patch");
302
- expect(applyPatchTool).toBeDefined();
303
- if (!applyPatchTool) {
304
- throw new Error("Expected apply_patch tool to be defined.");
305
- }
306
-
307
- const result = await applyPatchTool.execute(
308
- { input: "*** Begin Patch\n*** End Patch" },
309
- {
310
- agentId: "agent-1",
311
- conversationId: "conv-1",
312
- iteration: 1,
313
- },
314
- );
315
-
316
- expect(result).toEqual({
317
- query: "apply_patch",
318
- result: "patched",
319
- success: true,
320
- });
321
- expect(execute).toHaveBeenCalledWith(
322
- { input: "*** Begin Patch\n*** End Patch" },
323
- process.cwd(),
324
- expect.objectContaining({
325
- agentId: "agent-1",
326
- conversationId: "conv-1",
327
- iteration: 1,
328
- }),
329
- );
330
- });
331
- });
332
-
333
- describe("default run_commands tool", () => {
334
- it("accepts object input with commands as a single string", async () => {
335
- const execute = vi.fn(async (command: string | { command: string }) =>
336
- typeof command === "string" ? `ran:${command}` : `ran:${command.command}`,
337
- );
338
- const tool = createWindowsShellTool(execute);
339
-
340
- const result = await tool.execute({ commands: "ls" } as never, {
341
- agentId: "agent-1",
342
- conversationId: "conv-1",
343
- iteration: 1,
344
- });
345
-
346
- expect(result).toEqual([
347
- {
348
- query: "ls",
349
- result: "ran:ls",
350
- success: true,
351
- },
352
- ]);
353
- expect(execute).toHaveBeenCalledTimes(1);
354
- expect(execute).toHaveBeenCalledWith(
355
- "ls",
356
- process.cwd(),
357
- expect.objectContaining({
358
- agentId: "agent-1",
359
- conversationId: "conv-1",
360
- iteration: 1,
361
- }),
362
- );
363
- });
364
-
365
- it("accepts structured commands and preserves argv", async () => {
366
- const execute = vi.fn(
367
- async (command: string | { command: string; args?: string[] }) =>
368
- typeof command === "string"
369
- ? `ran:${command}`
370
- : `ran:${command.command}:${(command.args ?? []).join(",")}`,
371
- );
372
- const tool = createWindowsShellTool(execute);
373
-
374
- const result = await tool.execute(
375
- {
376
- commands: {
377
- command: "node",
378
- args: ["-e", "console.log('ok')"],
379
- },
380
- } as never,
381
- {
382
- agentId: "agent-1",
383
- conversationId: "conv-1",
384
- iteration: 1,
385
- },
386
- );
387
-
388
- expect(result).toEqual([
389
- {
390
- query: "node -e console.log('ok')",
391
- result: "ran:node:-e,console.log('ok')",
392
- success: true,
393
- },
394
- ]);
395
- expect(execute).toHaveBeenCalledWith(
396
- {
397
- command: "node",
398
- args: ["-e", "console.log('ok')"],
399
- },
400
- process.cwd(),
401
- expect.objectContaining({
402
- agentId: "agent-1",
403
- conversationId: "conv-1",
404
- iteration: 1,
405
- }),
406
- );
407
- });
408
- });
409
-
410
- describe("default read_files tool", () => {
411
- it("normalizes ranged file requests and passes them to the executor", async () => {
412
- const execute = vi.fn(async () => "selected lines");
413
- const tool = createReadFilesTool(execute);
414
-
415
- const result = await tool.execute(
416
- {
417
- files: [
418
- {
419
- path: "/tmp/example.ts",
420
- start_line: 3,
421
- end_line: 5,
422
- },
423
- ],
424
- },
425
- {
426
- agentId: "agent-1",
427
- conversationId: "conv-1",
428
- iteration: 1,
429
- },
430
- );
431
-
432
- expect(result).toEqual([
433
- {
434
- query: "/tmp/example.ts:3-5",
435
- result: "selected lines",
436
- success: true,
437
- },
438
- ]);
439
- expect(execute).toHaveBeenCalledWith(
440
- {
441
- path: "/tmp/example.ts",
442
- start_line: 3,
443
- end_line: 5,
444
- },
445
- expect.objectContaining({
446
- agentId: "agent-1",
447
- conversationId: "conv-1",
448
- iteration: 1,
449
- }),
450
- );
451
- });
452
-
453
- it("keeps legacy string inputs reading full file content", async () => {
454
- const execute = vi.fn(async () => "full file");
455
- const tool = createReadFilesTool(execute);
456
-
457
- await tool.execute("/tmp/example.ts" as never, {
458
- agentId: "agent-1",
459
- conversationId: "conv-1",
460
- iteration: 1,
461
- });
462
-
463
- expect(execute).toHaveBeenCalledWith(
464
- { path: "/tmp/example.ts" },
465
- expect.objectContaining({
466
- agentId: "agent-1",
467
- conversationId: "conv-1",
468
- iteration: 1,
469
- }),
470
- );
471
- });
472
-
473
- it("treats null line bounds as full-file boundaries", async () => {
474
- const execute = vi.fn(async () => "full file");
475
- const tool = createReadFilesTool(execute);
476
-
477
- const result = await tool.execute(
478
- {
479
- files: [
480
- {
481
- path: "/tmp/example.ts",
482
- start_line: null,
483
- end_line: null,
484
- },
485
- ],
486
- },
487
- {
488
- agentId: "agent-1",
489
- conversationId: "conv-1",
490
- iteration: 1,
491
- },
492
- );
493
-
494
- expect(result).toEqual([
495
- {
496
- query: "/tmp/example.ts",
497
- result: "full file",
498
- success: true,
499
- },
500
- ]);
501
- expect(execute).toHaveBeenCalledWith(
502
- {
503
- path: "/tmp/example.ts",
504
- start_line: null,
505
- end_line: null,
506
- },
507
- expect.objectContaining({
508
- agentId: "agent-1",
509
- conversationId: "conv-1",
510
- iteration: 1,
511
- }),
512
- );
513
- });
514
- });
515
-
516
- describe("zod schema conversion", () => {
517
- it("preserves read_files required properties in generated JSON schema", () => {
518
- const tool = createReadFilesTool(async () => "ok");
519
- const inputSchema = tool.inputSchema as Record<string, unknown>;
520
- const properties = inputSchema.properties as Record<string, unknown>;
521
- expect(inputSchema.type).toBe("object");
522
- expect(properties.files).toMatchObject({
523
- type: "array",
524
- items: {
525
- type: "object",
526
- properties: {
527
- path: {
528
- type: "string",
529
- description:
530
- "The absolute file path of a text file to read content from",
531
- },
532
- start_line: {
533
- anyOf: [{ type: "integer" }, { type: "null" }],
534
- description:
535
- "Optional one-based starting line number to read from; use null or omit for the start of the file",
536
- },
537
- end_line: {
538
- anyOf: [{ type: "integer" }, { type: "null" }],
539
- description:
540
- "Optional one-based ending line number to read through; use null or omit for the end of the file",
541
- },
542
- },
543
- required: ["path"],
544
- },
545
- description:
546
- "Array of file read requests. Omit start_line/end_line or set them to null to return the full file content boundaries; provide integers to return only that inclusive one-based line range. Prefer this tool over running terminal command to get file content for better performance and reliability.",
547
- });
548
- expect(inputSchema.required).toEqual(["files"]);
549
- });
550
-
551
- it("exposes skills args as optional nullable in tool schemas", () => {
552
- const tools = createDefaultTools({
553
- executors: {
554
- skills: createMockSkillsExecutor(),
555
- },
556
- enableReadFiles: false,
557
- enableSearch: false,
558
- enableBash: false,
559
- enableWebFetch: false,
560
- enableEditor: false,
561
- enableApplyPatch: false,
562
- enableAskQuestion: false,
563
- enableSkills: true,
564
- });
565
- const skills = tools.find((tool) => tool.name === "skills");
566
- expect(skills).toBeDefined();
567
- if (!skills) {
568
- throw new Error("Expected skills tool.");
569
- }
570
- const schema = skills.inputSchema as {
571
- required?: string[];
572
- properties?: Record<string, unknown>;
573
- };
574
- expect(schema.required).toEqual(["skill"]);
575
- expect(schema.properties).toHaveProperty("args");
576
- });
577
- });
578
-
579
- describe("default editor tool", () => {
580
- it("accepts replacement edits without insert fields", async () => {
581
- const execute = vi.fn(async () => "patched");
582
- const tools = createDefaultTools({
583
- executors: {
584
- editor: execute,
585
- },
586
- enableReadFiles: false,
587
- enableSearch: false,
588
- enableBash: false,
589
- enableWebFetch: false,
590
- enableSkills: false,
591
- enableAskQuestion: false,
592
- enableApplyPatch: false,
593
- enableEditor: true,
594
- });
595
- const editorTool = tools.find((tool) => tool.name === "editor");
596
- expect(editorTool).toBeDefined();
597
- if (!editorTool) {
598
- throw new Error("Expected editor tool to be defined.");
599
- }
600
-
601
- const result = await editorTool.execute(
602
- {
603
- path: "/tmp/example.ts",
604
- old_text: "before",
605
- new_text: "after",
606
- },
607
- {
608
- agentId: "agent-1",
609
- conversationId: "conv-1",
610
- iteration: 1,
611
- },
612
- );
613
-
614
- expect(result).toEqual({
615
- query: "edit:/tmp/example.ts",
616
- result: "patched",
617
- success: true,
618
- });
619
- expect(execute).toHaveBeenCalledWith(
620
- expect.objectContaining({
621
- path: "/tmp/example.ts",
622
- old_text: "before",
623
- new_text: "after",
624
- }),
625
- process.cwd(),
626
- expect.objectContaining({
627
- agentId: "agent-1",
628
- conversationId: "conv-1",
629
- iteration: 1,
630
- }),
631
- );
632
- });
633
-
634
- it("allows edit without old_text so missing files can be created", async () => {
635
- const execute = vi.fn(async () => "patched");
636
- const tools = createDefaultTools({
637
- executors: {
638
- editor: execute,
639
- },
640
- enableReadFiles: false,
641
- enableSearch: false,
642
- enableBash: false,
643
- enableWebFetch: false,
644
- enableSkills: false,
645
- enableAskQuestion: false,
646
- enableApplyPatch: false,
647
- enableEditor: true,
648
- });
649
- const editorTool = tools.find((tool) => tool.name === "editor");
650
- expect(editorTool).toBeDefined();
651
- if (!editorTool) {
652
- throw new Error("Expected editor tool to be defined.");
653
- }
654
-
655
- const result = await editorTool.execute(
656
- {
657
- path: "/tmp/example.ts",
658
- new_text: "created",
659
- },
660
- {
661
- agentId: "agent-1",
662
- conversationId: "conv-1",
663
- iteration: 1,
664
- },
665
- );
666
-
667
- expect(result).toEqual({
668
- query: "edit:/tmp/example.ts",
669
- result: "patched",
670
- success: true,
671
- });
672
- expect(execute).toHaveBeenCalledWith(
673
- expect.objectContaining({
674
- path: "/tmp/example.ts",
675
- new_text: "created",
676
- }),
677
- process.cwd(),
678
- expect.anything(),
679
- );
680
- });
681
-
682
- it("treats insert_line as an insert operation", async () => {
683
- const execute = vi.fn(async () => "patched");
684
- const tools = createDefaultTools({
685
- executors: {
686
- editor: execute,
687
- },
688
- enableReadFiles: false,
689
- enableSearch: false,
690
- enableBash: false,
691
- enableWebFetch: false,
692
- enableSkills: false,
693
- enableAskQuestion: false,
694
- enableApplyPatch: false,
695
- enableEditor: true,
696
- });
697
- const editorTool = tools.find((tool) => tool.name === "editor");
698
- expect(editorTool).toBeDefined();
699
- if (!editorTool) {
700
- throw new Error("Expected editor tool to be defined.");
701
- }
702
-
703
- const result = await editorTool.execute(
704
- {
705
- path: "/tmp/example.ts",
706
- new_text: "after",
707
- insert_line: 3,
708
- },
709
- {
710
- agentId: "agent-1",
711
- conversationId: "conv-1",
712
- iteration: 1,
713
- },
714
- );
715
-
716
- expect(result).toEqual({
717
- query: "insert:/tmp/example.ts",
718
- result: "patched",
719
- success: true,
720
- });
721
- expect(execute).toHaveBeenCalledWith(
722
- expect.objectContaining({
723
- path: "/tmp/example.ts",
724
- new_text: "after",
725
- insert_line: 3,
726
- }),
727
- process.cwd(),
728
- expect.anything(),
729
- );
730
- });
731
-
732
- it("returns a recoverable tool error when text exceeds the soft character limit", async () => {
733
- const execute = vi.fn(async () => "patched");
734
- const tools = createDefaultTools({
735
- executors: {
736
- editor: execute,
737
- },
738
- enableReadFiles: false,
739
- enableSearch: false,
740
- enableBash: false,
741
- enableWebFetch: false,
742
- enableSkills: false,
743
- enableAskQuestion: false,
744
- enableApplyPatch: false,
745
- enableEditor: true,
746
- });
747
- const editorTool = tools.find((tool) => tool.name === "editor");
748
- expect(editorTool).toBeDefined();
749
- if (!editorTool) {
750
- throw new Error("Expected editor tool to be defined.");
751
- }
752
-
753
- const oversizedText = "x".repeat(INPUT_ARG_CHAR_LIMIT + 1);
754
- const result = await editorTool.execute(
755
- {
756
- path: "/tmp/example.ts",
757
- new_text: oversizedText,
758
- },
759
- {
760
- agentId: "agent-1",
761
- conversationId: "conv-1",
762
- iteration: 1,
763
- },
764
- );
765
-
766
- expect(result).toEqual({
767
- query: "edit:/tmp/example.ts",
768
- result: "",
769
- error: expect.stringContaining("new_text was"),
770
- success: false,
771
- });
772
- if (typeof result !== "object" || result == null || !("error" in result)) {
773
- throw new Error("Expected editor tool result to include an error.");
774
- }
775
- expect(result.error).toContain(
776
- `recommended limit of ${INPUT_ARG_CHAR_LIMIT}`,
777
- );
778
- expect(execute).not.toHaveBeenCalled();
779
- });
780
- });