@clinebot/core 0.0.35 → 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 (335) hide show
  1. package/README.md +1 -2
  2. package/dist/ClineCore.d.ts +53 -39
  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 +4 -3
  21. package/dist/extensions/config/agent-config-loader.d.ts.map +1 -1
  22. package/dist/extensions/config/runtime-commands.d.ts +1 -0
  23. package/dist/extensions/config/runtime-commands.d.ts.map +1 -1
  24. package/dist/extensions/config/user-instruction-config-loader.d.ts +1 -0
  25. package/dist/extensions/config/user-instruction-config-loader.d.ts.map +1 -1
  26. package/dist/extensions/context/agentic-compaction.d.ts +2 -2
  27. package/dist/extensions/context/agentic-compaction.d.ts.map +1 -1
  28. package/dist/extensions/context/compaction-shared.d.ts +5 -4
  29. package/dist/extensions/context/compaction-shared.d.ts.map +1 -1
  30. package/dist/extensions/context/compaction.d.ts.map +1 -1
  31. package/dist/extensions/plugin/plugin-config-loader.d.ts +9 -2
  32. package/dist/extensions/plugin/plugin-config-loader.d.ts.map +1 -1
  33. package/dist/extensions/plugin/plugin-loader.d.ts +5 -3
  34. package/dist/extensions/plugin/plugin-loader.d.ts.map +1 -1
  35. package/dist/extensions/plugin/plugin-module-import.d.ts.map +1 -1
  36. package/dist/extensions/plugin/plugin-sandbox.d.ts +15 -2
  37. package/dist/extensions/plugin/plugin-sandbox.d.ts.map +1 -1
  38. package/dist/extensions/plugin/plugin-targeting.d.ts +7 -0
  39. package/dist/extensions/plugin/plugin-targeting.d.ts.map +1 -0
  40. package/dist/extensions/plugin-sandbox-bootstrap.js +211 -211
  41. package/dist/extensions/tools/definitions.d.ts +1 -1
  42. package/dist/extensions/tools/definitions.d.ts.map +1 -1
  43. package/dist/extensions/tools/executors/apply-patch.d.ts +3 -1
  44. package/dist/extensions/tools/executors/apply-patch.d.ts.map +1 -1
  45. package/dist/extensions/tools/executors/search.d.ts +1 -1
  46. package/dist/extensions/tools/executors/search.d.ts.map +1 -1
  47. package/dist/extensions/tools/index.d.ts +2 -0
  48. package/dist/extensions/tools/index.d.ts.map +1 -1
  49. package/dist/extensions/tools/presets.d.ts +26 -43
  50. package/dist/extensions/tools/presets.d.ts.map +1 -1
  51. package/dist/extensions/tools/runtime.d.ts +25 -0
  52. package/dist/extensions/tools/runtime.d.ts.map +1 -0
  53. package/dist/extensions/tools/schemas.d.ts.map +1 -1
  54. package/dist/extensions/tools/team/team-tools.d.ts +1 -0
  55. package/dist/extensions/tools/team/team-tools.d.ts.map +1 -1
  56. package/dist/hooks/hook-file-hooks.d.ts +4 -1
  57. package/dist/hooks/hook-file-hooks.d.ts.map +1 -1
  58. package/dist/hooks/index.d.ts +0 -1
  59. package/dist/hooks/index.d.ts.map +1 -1
  60. package/dist/hooks/subprocess.d.ts +8 -1
  61. package/dist/hooks/subprocess.d.ts.map +1 -1
  62. package/dist/hub/browser-websocket.d.ts +18 -0
  63. package/dist/hub/browser-websocket.d.ts.map +1 -0
  64. package/dist/hub/client.d.ts +45 -0
  65. package/dist/hub/client.d.ts.map +1 -0
  66. package/dist/hub/connect.d.ts +15 -0
  67. package/dist/hub/connect.d.ts.map +1 -0
  68. package/dist/hub/daemon-entry.d.ts +2 -0
  69. package/dist/hub/daemon-entry.d.ts.map +1 -0
  70. package/dist/hub/daemon-entry.js +1045 -0
  71. package/dist/hub/daemon.d.ts +5 -0
  72. package/dist/hub/daemon.d.ts.map +1 -0
  73. package/dist/hub/defaults.d.ts +13 -0
  74. package/dist/hub/defaults.d.ts.map +1 -0
  75. package/dist/hub/discovery.d.ts +29 -0
  76. package/dist/hub/discovery.d.ts.map +1 -0
  77. package/dist/hub/index.d.ts +15 -0
  78. package/dist/hub/index.d.ts.map +1 -0
  79. package/dist/hub/index.js +1044 -0
  80. package/dist/hub/native-transport.d.ts +17 -0
  81. package/dist/hub/native-transport.d.ts.map +1 -0
  82. package/dist/hub/runtime-handlers.d.ts +11 -0
  83. package/dist/hub/runtime-handlers.d.ts.map +1 -0
  84. package/dist/hub/server.d.ts +86 -0
  85. package/dist/hub/server.d.ts.map +1 -0
  86. package/dist/hub/session-client.d.ts +87 -0
  87. package/dist/hub/session-client.d.ts.map +1 -0
  88. package/dist/hub/start-shared-server.d.ts +19 -0
  89. package/dist/hub/start-shared-server.d.ts.map +1 -0
  90. package/dist/hub/transport.d.ts +8 -0
  91. package/dist/hub/transport.d.ts.map +1 -0
  92. package/dist/hub/ui-client.d.ts +44 -0
  93. package/dist/hub/ui-client.d.ts.map +1 -0
  94. package/dist/hub/workspace.d.ts +4 -0
  95. package/dist/hub/workspace.d.ts.map +1 -0
  96. package/dist/index.d.ts +26 -15
  97. package/dist/index.d.ts.map +1 -1
  98. package/dist/index.js +498 -476
  99. package/dist/llms/configured-provider-registry.d.ts +28 -0
  100. package/dist/llms/configured-provider-registry.d.ts.map +1 -0
  101. package/dist/llms/provider-defaults.d.ts +27 -0
  102. package/dist/llms/provider-defaults.d.ts.map +1 -0
  103. package/dist/llms/provider-settings.d.ts +202 -0
  104. package/dist/llms/provider-settings.d.ts.map +1 -0
  105. package/dist/llms/runtime-config.d.ts +4 -0
  106. package/dist/llms/runtime-config.d.ts.map +1 -0
  107. package/dist/llms/runtime-registry.d.ts +20 -0
  108. package/dist/llms/runtime-registry.d.ts.map +1 -0
  109. package/dist/llms/runtime-types.d.ts +85 -0
  110. package/dist/llms/runtime-types.d.ts.map +1 -0
  111. package/dist/runtime/host.d.ts +1 -2
  112. package/dist/runtime/host.d.ts.map +1 -1
  113. package/dist/runtime/rules.d.ts +1 -0
  114. package/dist/runtime/rules.d.ts.map +1 -1
  115. package/dist/runtime/runtime-builder.d.ts.map +1 -1
  116. package/dist/runtime/runtime-host.d.ts +22 -24
  117. package/dist/runtime/runtime-host.d.ts.map +1 -1
  118. package/dist/runtime/runtime-oauth-token-manager.d.ts.map +1 -1
  119. package/dist/runtime/session-runtime.d.ts +1 -19
  120. package/dist/runtime/session-runtime.d.ts.map +1 -1
  121. package/dist/services/global-settings.d.ts +12 -0
  122. package/dist/services/global-settings.d.ts.map +1 -0
  123. package/dist/services/local-runtime-bootstrap.d.ts +9 -3
  124. package/dist/services/local-runtime-bootstrap.d.ts.map +1 -1
  125. package/dist/services/plugin-tools.d.ts +16 -0
  126. package/dist/services/plugin-tools.d.ts.map +1 -0
  127. package/dist/services/providers/local-provider-registry.d.ts +4 -4
  128. package/dist/services/providers/local-provider-registry.d.ts.map +1 -1
  129. package/dist/services/providers/local-provider-service.d.ts +13 -13
  130. package/dist/services/providers/local-provider-service.d.ts.map +1 -1
  131. package/dist/services/session-data.d.ts +1 -1
  132. package/dist/services/session-data.d.ts.map +1 -1
  133. package/dist/services/storage/provider-settings-legacy-migration.d.ts +1 -1
  134. package/dist/services/storage/provider-settings-legacy-migration.d.ts.map +1 -1
  135. package/dist/services/telemetry/index.js +28 -15
  136. package/dist/services/workspace-manifest.d.ts +11 -0
  137. package/dist/services/workspace-manifest.d.ts.map +1 -1
  138. package/dist/session/persistence-service.d.ts +11 -23
  139. package/dist/session/persistence-service.d.ts.map +1 -1
  140. package/dist/session/session-manifest-store.d.ts +22 -0
  141. package/dist/session/session-manifest-store.d.ts.map +1 -0
  142. package/dist/session/session-row.d.ts +93 -0
  143. package/dist/session/session-row.d.ts.map +1 -0
  144. package/dist/session/session-service.d.ts +2 -102
  145. package/dist/session/session-service.d.ts.map +1 -1
  146. package/dist/session/subagent-session-manager.d.ts +36 -0
  147. package/dist/session/subagent-session-manager.d.ts.map +1 -0
  148. package/dist/session/team-persistence-store.d.ts +24 -0
  149. package/dist/session/team-persistence-store.d.ts.map +1 -0
  150. package/dist/transports/hub.d.ts +47 -0
  151. package/dist/transports/hub.d.ts.map +1 -0
  152. package/dist/transports/local.d.ts +10 -6
  153. package/dist/transports/local.d.ts.map +1 -1
  154. package/dist/transports/remote.d.ts +10 -0
  155. package/dist/transports/remote.d.ts.map +1 -0
  156. package/dist/transports/runtime-host-support.d.ts +3 -2
  157. package/dist/transports/runtime-host-support.d.ts.map +1 -1
  158. package/dist/types/chat-schema.d.ts +10 -12
  159. package/dist/types/chat-schema.d.ts.map +1 -1
  160. package/dist/types/config.d.ts +8 -7
  161. package/dist/types/config.d.ts.map +1 -1
  162. package/dist/types/provider-settings.d.ts +4 -5
  163. package/dist/types/provider-settings.d.ts.map +1 -1
  164. package/dist/types/session.d.ts +2 -1
  165. package/dist/types/session.d.ts.map +1 -1
  166. package/dist/types.d.ts +8 -1
  167. package/dist/types.d.ts.map +1 -1
  168. package/package.json +20 -6
  169. package/src/ClineCore.ts +68 -40
  170. package/src/account/index.ts +3 -3
  171. package/src/account/rpc.ts +12 -12
  172. package/src/cron/index.ts +5 -0
  173. package/src/cron/resource-limiter.ts +46 -0
  174. package/src/cron/schedule-command-service.ts +193 -0
  175. package/src/cron/schedule-service.ts +703 -0
  176. package/src/cron/scheduler.ts +637 -0
  177. package/src/cron/sqlite-schedule-store.ts +708 -0
  178. package/src/extensions/config/agent-config-loader.ts +17 -7
  179. package/src/extensions/config/runtime-commands.ts +6 -0
  180. package/src/extensions/config/user-instruction-config-loader.ts +1 -0
  181. package/src/extensions/context/agentic-compaction.ts +3 -3
  182. package/src/extensions/context/basic-compaction.ts +2 -2
  183. package/src/extensions/context/compaction-shared.ts +5 -4
  184. package/src/extensions/context/compaction.ts +3 -3
  185. package/src/extensions/plugin/plugin-config-loader.ts +17 -2
  186. package/src/extensions/plugin/plugin-loader.ts +48 -4
  187. package/src/extensions/plugin/plugin-module-import.ts +0 -2
  188. package/src/extensions/plugin/plugin-sandbox-bootstrap.ts +93 -39
  189. package/src/extensions/plugin/plugin-sandbox.ts +47 -27
  190. package/src/extensions/plugin/plugin-targeting.ts +32 -0
  191. package/src/extensions/tools/definitions.ts +30 -49
  192. package/src/extensions/tools/executors/apply-patch.ts +69 -80
  193. package/src/extensions/tools/executors/search.ts +195 -3
  194. package/src/extensions/tools/index.ts +10 -0
  195. package/src/extensions/tools/presets.ts +31 -46
  196. package/src/extensions/tools/runtime.ts +261 -0
  197. package/src/extensions/tools/schemas.ts +4 -2
  198. package/src/extensions/tools/team/team-tools.ts +21 -0
  199. package/src/hooks/hook-file-hooks.ts +8 -2
  200. package/src/hooks/index.ts +0 -7
  201. package/src/hooks/subprocess-runner.ts +1 -1
  202. package/src/hooks/subprocess.ts +9 -0
  203. package/src/hub/browser-websocket.ts +137 -0
  204. package/src/hub/client.ts +574 -0
  205. package/src/hub/connect.ts +156 -0
  206. package/src/hub/daemon-entry.ts +87 -0
  207. package/src/hub/daemon.ts +181 -0
  208. package/src/hub/defaults.ts +43 -0
  209. package/src/hub/discovery.ts +247 -0
  210. package/src/hub/index.ts +14 -0
  211. package/src/hub/native-transport.ts +31 -0
  212. package/src/hub/runtime-handlers.ts +140 -0
  213. package/src/hub/server.ts +1888 -0
  214. package/src/hub/session-client.ts +460 -0
  215. package/src/hub/start-shared-server.ts +58 -0
  216. package/src/hub/transport.ts +14 -0
  217. package/src/hub/ui-client.ts +122 -0
  218. package/src/hub/workspace.ts +19 -0
  219. package/src/index.ts +124 -68
  220. package/src/llms/configured-provider-registry.ts +193 -0
  221. package/src/llms/provider-defaults.ts +637 -0
  222. package/src/llms/provider-settings.ts +263 -0
  223. package/src/llms/runtime-config.ts +43 -0
  224. package/src/llms/runtime-registry.ts +171 -0
  225. package/src/llms/runtime-types.ts +121 -0
  226. package/src/runtime/host.ts +107 -269
  227. package/src/runtime/index.ts +1 -0
  228. package/src/runtime/rules.ts +12 -0
  229. package/src/runtime/runtime-builder.ts +24 -8
  230. package/src/runtime/runtime-host.ts +89 -61
  231. package/src/runtime/runtime-oauth-token-manager.ts +11 -15
  232. package/src/runtime/session-runtime.ts +0 -24
  233. package/src/services/global-settings.ts +122 -0
  234. package/src/services/local-runtime-bootstrap.ts +51 -13
  235. package/src/services/plugin-tools.ts +85 -0
  236. package/src/services/providers/local-provider-registry.ts +6 -6
  237. package/src/services/providers/local-provider-service.ts +42 -37
  238. package/src/services/session-data.ts +15 -9
  239. package/src/services/storage/provider-settings-legacy-migration.ts +6 -4
  240. package/src/services/storage/provider-settings-manager.ts +1 -1
  241. package/src/services/workspace-manifest.ts +18 -0
  242. package/src/session/file-session-service.ts +1 -1
  243. package/src/session/index.ts +6 -27
  244. package/src/session/persistence-service.ts +119 -504
  245. package/src/session/session-manifest-store.ts +158 -0
  246. package/src/session/session-row.ts +199 -0
  247. package/src/session/session-service.ts +17 -376
  248. package/src/session/session-team-coordination.ts +1 -1
  249. package/src/session/subagent-session-manager.ts +397 -0
  250. package/src/session/team-persistence-store.ts +176 -0
  251. package/src/transports/hub.ts +656 -0
  252. package/src/transports/local.ts +135 -40
  253. package/src/transports/remote.ts +26 -0
  254. package/src/transports/runtime-host-support.ts +63 -9
  255. package/src/types/chat-schema.ts +4 -5
  256. package/src/types/config.ts +8 -7
  257. package/src/types/provider-settings.ts +11 -7
  258. package/src/types/session.ts +2 -4
  259. package/src/types.ts +27 -1
  260. package/dist/hooks/persistent.d.ts +0 -64
  261. package/dist/hooks/persistent.d.ts.map +0 -1
  262. package/dist/runtime/rpc-runtime-ensure.d.ts +0 -65
  263. package/dist/runtime/rpc-runtime-ensure.d.ts.map +0 -1
  264. package/dist/runtime/rpc-spawn-lease.d.ts +0 -8
  265. package/dist/runtime/rpc-spawn-lease.d.ts.map +0 -1
  266. package/dist/session/rpc-session-service.d.ts +0 -16
  267. package/dist/session/rpc-session-service.d.ts.map +0 -1
  268. package/dist/session/sqlite-rpc-session-backend.d.ts +0 -31
  269. package/dist/session/sqlite-rpc-session-backend.d.ts.map +0 -1
  270. package/dist/transports/rpc.d.ts +0 -51
  271. package/dist/transports/rpc.d.ts.map +0 -1
  272. package/src/ClineCore.test.ts +0 -226
  273. package/src/account/cline-account-service.test.ts +0 -185
  274. package/src/account/featurebase-token.test.ts +0 -175
  275. package/src/account/rpc.test.ts +0 -63
  276. package/src/auth/bounded-ttl-cache.test.ts +0 -38
  277. package/src/auth/client.test.ts +0 -69
  278. package/src/auth/cline.test.ts +0 -267
  279. package/src/auth/codex.test.ts +0 -170
  280. package/src/auth/oca.test.ts +0 -340
  281. package/src/auth/server.test.ts +0 -287
  282. package/src/auth/utils.test.ts +0 -128
  283. package/src/extensions/config/agent-config-loader.test.ts +0 -236
  284. package/src/extensions/config/hooks-config-loader.test.ts +0 -20
  285. package/src/extensions/config/runtime-commands.test.ts +0 -115
  286. package/src/extensions/config/unified-config-file-watcher.test.ts +0 -196
  287. package/src/extensions/config/user-instruction-config-loader.test.ts +0 -246
  288. package/src/extensions/context/compaction.test.ts +0 -483
  289. package/src/extensions/mcp/config-loader.test.ts +0 -238
  290. package/src/extensions/mcp/manager.test.ts +0 -105
  291. package/src/extensions/plugin/plugin-config-loader.test.ts +0 -184
  292. package/src/extensions/plugin/plugin-loader.test.ts +0 -292
  293. package/src/extensions/plugin/plugin-sandbox.test.ts +0 -423
  294. package/src/extensions/tools/definitions.test.ts +0 -780
  295. package/src/extensions/tools/executors/bash.test.ts +0 -87
  296. package/src/extensions/tools/executors/editor.test.ts +0 -35
  297. package/src/extensions/tools/executors/file-read.test.ts +0 -125
  298. package/src/extensions/tools/model-tool-routing.test.ts +0 -86
  299. package/src/extensions/tools/presets.test.ts +0 -70
  300. package/src/extensions/tools/team/multi-agent.lifecycle.test.ts +0 -455
  301. package/src/extensions/tools/team/spawn-agent-tool.test.ts +0 -381
  302. package/src/extensions/tools/team/team-tools.test.ts +0 -918
  303. package/src/hooks/checkpoint-hooks.test.ts +0 -168
  304. package/src/hooks/hook-file-hooks.test.ts +0 -311
  305. package/src/hooks/persistent.ts +0 -661
  306. package/src/runtime/history.test.ts +0 -114
  307. package/src/runtime/host.test.ts +0 -230
  308. package/src/runtime/rpc-runtime-ensure.test.ts +0 -123
  309. package/src/runtime/rpc-runtime-ensure.ts +0 -659
  310. package/src/runtime/rpc-spawn-lease.test.ts +0 -81
  311. package/src/runtime/rpc-spawn-lease.ts +0 -156
  312. package/src/runtime/runtime-builder.team-persistence.test.ts +0 -245
  313. package/src/runtime/runtime-builder.test.ts +0 -615
  314. package/src/runtime/runtime-oauth-token-manager.test.ts +0 -137
  315. package/src/runtime/runtime-parity.test.ts +0 -143
  316. package/src/services/providers/local-provider-service.test.ts +0 -1062
  317. package/src/services/session-data.test.ts +0 -160
  318. package/src/services/storage/provider-settings-legacy-migration.test.ts +0 -424
  319. package/src/services/storage/provider-settings-manager.test.ts +0 -191
  320. package/src/services/telemetry/OpenTelemetryAdapter.test.ts +0 -157
  321. package/src/services/telemetry/OpenTelemetryProvider.test.ts +0 -326
  322. package/src/services/telemetry/TelemetryLoggerSink.test.ts +0 -42
  323. package/src/services/telemetry/TelemetryService.test.ts +0 -134
  324. package/src/services/telemetry/distinct-id.test.ts +0 -57
  325. package/src/services/workspace/file-indexer.d.ts +0 -11
  326. package/src/services/workspace/file-indexer.test.ts +0 -156
  327. package/src/services/workspace/mention-enricher.test.ts +0 -106
  328. package/src/session/persistence-service.test.ts +0 -300
  329. package/src/session/rpc-session-service.ts +0 -114
  330. package/src/session/session-service.team-persistence.test.ts +0 -48
  331. package/src/session/sqlite-rpc-session-backend.ts +0 -301
  332. package/src/transports/local.e2e.test.ts +0 -380
  333. package/src/transports/local.test.ts +0 -2559
  334. package/src/transports/rpc.test.ts +0 -82
  335. package/src/transports/rpc.ts +0 -665
@@ -1,191 +0,0 @@
1
- import { mkdtempSync, rmSync, writeFileSync } from "node:fs";
2
- import os from "node:os";
3
- import path from "node:path";
4
- import * as LlmsModels from "@clinebot/llms";
5
- import { afterEach, describe, expect, it } from "vitest";
6
- import { ProviderSettingsManager } from "./provider-settings-manager";
7
-
8
- describe("ProviderSettingsManager", () => {
9
- const tempDirs: string[] = [];
10
-
11
- afterEach(() => {
12
- LlmsModels.resetRegistry();
13
- for (const dir of tempDirs.splice(0)) {
14
- rmSync(dir, { recursive: true, force: true });
15
- }
16
- });
17
-
18
- it("persists and restores provider settings", () => {
19
- const tempDir = mkdtempSync(
20
- path.join(os.tmpdir(), "core-provider-settings-"),
21
- );
22
- tempDirs.push(tempDir);
23
- const filePath = path.join(tempDir, "provider-settings.json");
24
- const manager = new ProviderSettingsManager({ filePath });
25
-
26
- manager.saveProviderSettings(
27
- {
28
- provider: "anthropic",
29
- model: "claude-sonnet-4-6",
30
- apiKey: "test-key",
31
- },
32
- { setLastUsed: true },
33
- );
34
-
35
- const reloaded = new ProviderSettingsManager({ filePath });
36
- expect(reloaded.getLastUsedProviderSettings()).toEqual({
37
- provider: "anthropic",
38
- model: "claude-sonnet-4-6",
39
- apiKey: "test-key",
40
- });
41
- expect(reloaded.getProviderConfig("anthropic")?.providerId).toBe(
42
- "anthropic",
43
- );
44
- expect(reloaded.getProviderConfig("anthropic")?.modelId).toBe(
45
- "claude-sonnet-4-6",
46
- );
47
- expect(reloaded.read().providers.anthropic?.tokenSource).toBe("manual");
48
- });
49
-
50
- it("migrates legacy provider settings during manager construction", () => {
51
- const tempDir = mkdtempSync(
52
- path.join(os.tmpdir(), "core-provider-settings-"),
53
- );
54
- tempDirs.push(tempDir);
55
- const filePath = path.join(tempDir, "settings", "providers.json");
56
-
57
- writeFileSync(
58
- path.join(tempDir, "globalState.json"),
59
- JSON.stringify(
60
- {
61
- mode: "act",
62
- actModeApiProvider: "anthropic",
63
- actModeApiModelId: "claude-sonnet-4-6",
64
- },
65
- null,
66
- 2,
67
- ),
68
- );
69
- writeFileSync(
70
- path.join(tempDir, "secrets.json"),
71
- JSON.stringify({ apiKey: "legacy-key" }, null, 2),
72
- );
73
-
74
- const manager = new ProviderSettingsManager({ filePath, dataDir: tempDir });
75
-
76
- expect(manager.getLastUsedProviderSettings()).toEqual({
77
- provider: "anthropic",
78
- model: "claude-sonnet-4-6",
79
- apiKey: "legacy-key",
80
- });
81
- expect(manager.read().providers.anthropic?.tokenSource).toBe("migration");
82
- });
83
-
84
- it("registers migrated custom providers during manager construction", async () => {
85
- const tempDir = mkdtempSync(
86
- path.join(os.tmpdir(), "core-provider-settings-"),
87
- );
88
- tempDirs.push(tempDir);
89
- const filePath = path.join(tempDir, "settings", "providers.json");
90
-
91
- writeFileSync(
92
- path.join(tempDir, "globalState.json"),
93
- JSON.stringify(
94
- {
95
- mode: "act",
96
- actModeApiProvider: "openai",
97
- actModeOpenAiModelId: "gpt-oss-120b",
98
- openAiBaseUrl: "https://gateway.example.invalid/v1",
99
- },
100
- null,
101
- 2,
102
- ),
103
- );
104
- writeFileSync(
105
- path.join(tempDir, "secrets.json"),
106
- JSON.stringify({ openAiApiKey: "legacy-key" }, null, 2),
107
- );
108
-
109
- const manager = new ProviderSettingsManager({ filePath, dataDir: tempDir });
110
- const providers = await LlmsModels.getAllProviders();
111
- const openAiProvider = providers.find(
112
- (provider) => provider.id === "openai",
113
- );
114
-
115
- expect(manager.getProviderSettings("openai")).toEqual({
116
- provider: "openai",
117
- model: "gpt-oss-120b",
118
- apiKey: "legacy-key",
119
- baseUrl: "https://gateway.example.invalid/v1",
120
- });
121
- expect(openAiProvider).toMatchObject({
122
- id: "openai",
123
- baseUrl: "https://gateway.example.invalid/v1",
124
- defaultModelId: "gpt-oss-120b",
125
- });
126
- });
127
-
128
- it("tracks provider-specific settings while preserving last-used provider", () => {
129
- const tempDir = mkdtempSync(
130
- path.join(os.tmpdir(), "core-provider-settings-"),
131
- );
132
- tempDirs.push(tempDir);
133
- const filePath = path.join(tempDir, "provider-settings.json");
134
- const manager = new ProviderSettingsManager({ filePath });
135
-
136
- manager.saveProviderSettings({
137
- provider: "anthropic",
138
- model: "claude-sonnet-4-6",
139
- });
140
- manager.saveProviderSettings(
141
- {
142
- provider: "openai-native",
143
- model: "gpt-5",
144
- },
145
- { setLastUsed: false },
146
- );
147
-
148
- expect(manager.getProviderSettings("anthropic")?.model).toBe(
149
- "claude-sonnet-4-6",
150
- );
151
- expect(manager.getProviderSettings("openai-native")?.model).toBe("gpt-5");
152
- expect(manager.getLastUsedProviderSettings()?.provider).toBe("anthropic");
153
- expect(manager.read().providers["openai-native"]?.tokenSource).toBe(
154
- "manual",
155
- );
156
- });
157
-
158
- it("allows overriding token source metadata", () => {
159
- const tempDir = mkdtempSync(
160
- path.join(os.tmpdir(), "core-provider-settings-"),
161
- );
162
- tempDirs.push(tempDir);
163
- const filePath = path.join(tempDir, "provider-settings.json");
164
- const manager = new ProviderSettingsManager({ filePath });
165
-
166
- manager.saveProviderSettings(
167
- {
168
- provider: "openai-codex",
169
- apiKey: "oauth-token",
170
- },
171
- { tokenSource: "oauth" },
172
- );
173
-
174
- expect(manager.read().providers["openai-codex"]?.tokenSource).toBe("oauth");
175
- });
176
-
177
- it("ignores invalid persisted JSON and falls back to empty state", () => {
178
- const tempDir = mkdtempSync(
179
- path.join(os.tmpdir(), "core-provider-settings-"),
180
- );
181
- tempDirs.push(tempDir);
182
- const filePath = path.join(tempDir, "provider-settings.json");
183
- writeFileSync(filePath, "{ not-json", "utf8");
184
-
185
- const manager = new ProviderSettingsManager({ filePath });
186
- expect(manager.read()).toEqual({
187
- version: 1,
188
- providers: {},
189
- });
190
- });
191
- });
@@ -1,157 +0,0 @@
1
- import type { LoggerProvider } from "@opentelemetry/sdk-logs";
2
- import type { MeterProvider } from "@opentelemetry/sdk-metrics";
3
- import { describe, expect, it, vi } from "vitest";
4
- import { OpenTelemetryAdapter } from "./OpenTelemetryAdapter";
5
-
6
- describe("OpenTelemetryAdapter", () => {
7
- it("emits events in the telemetry service log format", () => {
8
- const emit = vi.fn();
9
- const adapter = new OpenTelemetryAdapter({
10
- metadata: makeMetadata(),
11
- distinctId: "user-123",
12
- commonProperties: {
13
- organization_id: "org-1",
14
- },
15
- loggerProvider: {
16
- getLogger: () => ({ emit }),
17
- } as unknown as LoggerProvider,
18
- });
19
-
20
- adapter.emit("task.created", {
21
- ulid: "01HXYZ",
22
- nested: {
23
- mode: "act",
24
- },
25
- items: ["a", "b"],
26
- nullable: null,
27
- });
28
-
29
- expect(emit).toHaveBeenCalledWith({
30
- severityText: "INFO",
31
- body: "task.created",
32
- attributes: expect.objectContaining({
33
- ulid: "01HXYZ",
34
- "nested.mode": "act",
35
- items: JSON.stringify(["a", "b"]),
36
- nullable: "null",
37
- distinct_id: "user-123",
38
- organization_id: "org-1",
39
- extension_version: "1.2.3",
40
- cline_type: "cli",
41
- platform: "terminal",
42
- }),
43
- });
44
- });
45
-
46
- it("marks required events with the expected flag", () => {
47
- const emit = vi.fn();
48
- const adapter = new OpenTelemetryAdapter({
49
- metadata: makeMetadata(),
50
- loggerProvider: {
51
- getLogger: () => ({ emit }),
52
- } as unknown as LoggerProvider,
53
- enabled: false,
54
- });
55
-
56
- adapter.emitRequired("user.opt_out");
57
-
58
- expect(emit).toHaveBeenCalledWith({
59
- severityText: "INFO",
60
- body: "user.opt_out",
61
- attributes: expect.objectContaining({
62
- _required: true,
63
- }),
64
- });
65
- });
66
-
67
- it("records metrics with merged telemetry attributes and retires gauge series", () => {
68
- const counterAdd = vi.fn();
69
- const histogramRecord = vi.fn();
70
- let gaugeCallback:
71
- | ((result: {
72
- observe: (
73
- value: number,
74
- attributes?: Record<string, string | number | boolean>,
75
- ) => void;
76
- }) => void)
77
- | undefined;
78
-
79
- const forceFlush = vi.fn().mockResolvedValue(undefined);
80
- const shutdown = vi.fn().mockResolvedValue(undefined);
81
-
82
- const adapter = new OpenTelemetryAdapter({
83
- metadata: makeMetadata(),
84
- distinctId: "user-123",
85
- meterProvider: {
86
- getMeter: () =>
87
- ({
88
- createCounter: () => ({ add: counterAdd }),
89
- createHistogram: () => ({ record: histogramRecord }),
90
- createObservableGauge: () => ({
91
- addCallback: (callback: typeof gaugeCallback) => {
92
- gaugeCallback = callback;
93
- },
94
- }),
95
- }) as never,
96
- forceFlush,
97
- shutdown,
98
- } as unknown as MeterProvider,
99
- });
100
-
101
- adapter.recordCounter("cline.turns.total", 2, { ulid: "01HXYZ" });
102
- adapter.recordHistogram("cline.api.duration.seconds", 1.5, {
103
- ulid: "01HXYZ",
104
- });
105
- adapter.recordGauge("cline.workspace.active_roots", 3, { workspace: "a" });
106
-
107
- expect(counterAdd).toHaveBeenCalledWith(
108
- 2,
109
- expect.objectContaining({
110
- ulid: "01HXYZ",
111
- distinct_id: "user-123",
112
- extension_version: "1.2.3",
113
- }),
114
- );
115
- expect(histogramRecord).toHaveBeenCalledWith(
116
- 1.5,
117
- expect.objectContaining({
118
- ulid: "01HXYZ",
119
- distinct_id: "user-123",
120
- }),
121
- );
122
-
123
- const observe = vi.fn();
124
- gaugeCallback?.({ observe });
125
- expect(observe).toHaveBeenCalledWith(
126
- 3,
127
- expect.objectContaining({
128
- workspace: "a",
129
- distinct_id: "user-123",
130
- }),
131
- );
132
-
133
- adapter.recordGauge("cline.workspace.active_roots", null, {
134
- workspace: "a",
135
- });
136
- const observeAfterRetire = vi.fn();
137
- gaugeCallback?.({ observe: observeAfterRetire });
138
- expect(observeAfterRetire).not.toHaveBeenCalled();
139
-
140
- return Promise.all([adapter.flush(), adapter.dispose()]).then(() => {
141
- expect(forceFlush).toHaveBeenCalledTimes(1);
142
- expect(shutdown).toHaveBeenCalledTimes(1);
143
- });
144
- });
145
- });
146
-
147
- function makeMetadata() {
148
- return {
149
- extension_version: "1.2.3",
150
- cline_type: "cli",
151
- platform: "terminal",
152
- platform_version: "1.0.0",
153
- os_type: "darwin",
154
- os_version: "24.0.0",
155
- is_dev: "true",
156
- };
157
- }
@@ -1,326 +0,0 @@
1
- import type { BasicLogger } from "@clinebot/shared";
2
- import { afterEach, describe, expect, it, vi } from "vitest";
3
- import {
4
- createConfiguredTelemetryService,
5
- createOpenTelemetryTelemetryService,
6
- OpenTelemetryProvider,
7
- } from "./OpenTelemetryProvider";
8
- import { TelemetryService } from "./TelemetryService";
9
-
10
- describe("createOpenTelemetryTelemetryService", () => {
11
- afterEach(() => {
12
- vi.restoreAllMocks();
13
- });
14
-
15
- it("logs a provider creation event during bootstrap", async () => {
16
- const captureRequired = vi
17
- .spyOn(TelemetryService.prototype, "captureRequired")
18
- .mockImplementation(() => {});
19
-
20
- const { provider } = createOpenTelemetryTelemetryService({
21
- metadata: {
22
- extension_version: "1.2.3",
23
- cline_type: "cli",
24
- platform: "terminal",
25
- platform_version: process.version,
26
- os_type: process.platform,
27
- os_version: "unknown",
28
- },
29
- enabled: true,
30
- logsExporter: "console",
31
- metricsExporter: "otlp",
32
- otlpProtocol: "http/json",
33
- otlpEndpoint: "http://localhost:4318",
34
- serviceName: "cline-cli",
35
- serviceVersion: "1.2.3",
36
- });
37
-
38
- expect(captureRequired).toHaveBeenCalledWith(
39
- "telemetry.provider_created",
40
- expect.objectContaining({
41
- provider: "opentelemetry",
42
- enabled: true,
43
- logsExporter: "console",
44
- metricsExporter: "otlp",
45
- otlpProtocol: "http/json",
46
- hasOtlpEndpoint: true,
47
- serviceName: "cline-cli",
48
- serviceVersion: "1.2.3",
49
- }),
50
- );
51
-
52
- await provider.dispose();
53
- });
54
-
55
- it("registers a tracer provider when tracesExporter is set", async () => {
56
- const { provider } = createOpenTelemetryTelemetryService({
57
- metadata: {
58
- extension_version: "1.2.3",
59
- cline_type: "cli",
60
- platform: "terminal",
61
- platform_version: process.version,
62
- os_type: process.platform,
63
- os_version: "unknown",
64
- },
65
- enabled: true,
66
- tracesExporter: "console",
67
- logsExporter: "console",
68
- metricsExporter: "console",
69
- serviceName: "cline-test",
70
- });
71
-
72
- expect(provider.tracerProvider).not.toBeNull();
73
- const span = provider.getTracer("test").startSpan("verify.tracing");
74
- span.end();
75
- await provider.dispose();
76
- });
77
-
78
- it("does not create an OTEL provider when disabled", () => {
79
- const providerSpy = vi.spyOn(
80
- OpenTelemetryProvider.prototype,
81
- "createTelemetryService",
82
- );
83
-
84
- const { telemetry, provider } = createConfiguredTelemetryService({
85
- metadata: {
86
- extension_version: "1.2.3",
87
- cline_type: "cli",
88
- platform: "terminal",
89
- platform_version: process.version,
90
- os_type: process.platform,
91
- os_version: "unknown",
92
- },
93
- enabled: false,
94
- });
95
-
96
- expect(provider).toBeUndefined();
97
- expect(providerSpy).not.toHaveBeenCalled();
98
- expect(telemetry).toBeInstanceOf(TelemetryService);
99
- });
100
-
101
- it("preserves metadata when disabled", () => {
102
- const metadata = {
103
- extension_version: "1.0.0",
104
- cline_type: "kanban",
105
- platform: "kanban",
106
- platform_version: "v22.0.0",
107
- os_type: "darwin",
108
- os_version: "15.0",
109
- };
110
- const { telemetry } = createConfiguredTelemetryService({
111
- metadata,
112
- enabled: false,
113
- });
114
- const spy = vi.fn();
115
- (telemetry as any).adapters.push({
116
- name: "test",
117
- emit: spy,
118
- emitRequired: spy,
119
- isEnabled: () => true,
120
- recordCounter: vi.fn(),
121
- recordHistogram: vi.fn(),
122
- recordGauge: vi.fn(),
123
- flush: async () => {},
124
- dispose: async () => {},
125
- });
126
- telemetry.captureRequired("test.event", {});
127
- expect(spy).toHaveBeenCalledWith(
128
- "test.event",
129
- expect.objectContaining({
130
- cline_type: "kanban",
131
- platform: "kanban",
132
- }),
133
- );
134
- });
135
-
136
- it("preserves metadata in the enabled (OTEL) path", async () => {
137
- const metadata = {
138
- extension_version: "1.0.0",
139
- cline_type: "kanban",
140
- platform: "kanban",
141
- platform_version: "v22.0.0",
142
- os_type: "darwin",
143
- os_version: "15.0",
144
- };
145
- const { telemetry, provider } = createOpenTelemetryTelemetryService({
146
- metadata,
147
- enabled: true,
148
- logsExporter: "console",
149
- });
150
- const spy = vi.fn();
151
- (telemetry as any).adapters.push({
152
- name: "test",
153
- emit: spy,
154
- emitRequired: spy,
155
- isEnabled: () => true,
156
- recordCounter: vi.fn(),
157
- recordHistogram: vi.fn(),
158
- recordGauge: vi.fn(),
159
- flush: async () => {},
160
- dispose: async () => {},
161
- });
162
- telemetry.captureRequired("test.event", {});
163
- expect(spy).toHaveBeenCalledWith(
164
- "test.event",
165
- expect.objectContaining({
166
- cline_type: "kanban",
167
- platform: "kanban",
168
- }),
169
- );
170
- await provider.dispose();
171
- });
172
-
173
- it("delivers metadata to the OTEL logger without duplication", async () => {
174
- const otelEmit = vi.fn();
175
- const provider = new OpenTelemetryProvider({
176
- enabled: true,
177
- });
178
- // Replace the loggerProvider with a mock so we can inspect emit calls
179
- (provider as any).loggerProvider = {
180
- getLogger: () => ({ emit: otelEmit }),
181
- forceFlush: async () => {},
182
- shutdown: async () => {},
183
- };
184
-
185
- const metadata = {
186
- extension_version: "1.0.0",
187
- cline_type: "kanban",
188
- platform: "kanban",
189
- platform_version: "v22.0.0",
190
- os_type: "darwin",
191
- os_version: "15.0",
192
- };
193
-
194
- const telemetry = provider.createTelemetryService({ metadata });
195
-
196
- telemetry.captureRequired("test.otel_event", { custom_prop: "value" });
197
-
198
- expect(otelEmit).toHaveBeenCalledTimes(1);
199
- const emittedAttributes = otelEmit.mock.calls[0][0].attributes;
200
-
201
- // Metadata fields must be present
202
- expect(emittedAttributes).toMatchObject({
203
- cline_type: "kanban",
204
- platform: "kanban",
205
- extension_version: "1.0.0",
206
- custom_prop: "value",
207
- });
208
-
209
- // Verify no key appears more than once (flattened object can't have
210
- // duplicate keys, but this guards against nested duplication patterns
211
- // like metadata appearing under a sub-prefix)
212
- const keys = Object.keys(emittedAttributes);
213
- const metadataKeys = Object.keys(metadata);
214
- for (const mk of metadataKeys) {
215
- const occurrences = keys.filter((k) => k === mk || k.endsWith(`.${mk}`));
216
- expect(
217
- occurrences,
218
- `metadata key "${mk}" should appear exactly once, found: ${occurrences.join(", ")}`,
219
- ).toHaveLength(1);
220
- }
221
-
222
- await provider.dispose();
223
- });
224
-
225
- it("propagates updateMetadata to OTEL logger output", async () => {
226
- const otelEmit = vi.fn();
227
- const provider = new OpenTelemetryProvider({
228
- enabled: true,
229
- });
230
- (provider as any).loggerProvider = {
231
- getLogger: () => ({ emit: otelEmit }),
232
- forceFlush: async () => {},
233
- shutdown: async () => {},
234
- };
235
-
236
- const metadata = {
237
- extension_version: "1.0.0",
238
- cline_type: "kanban",
239
- platform: "kanban",
240
- platform_version: "v22.0.0",
241
- os_type: "darwin",
242
- os_version: "15.0",
243
- };
244
-
245
- const telemetry = provider.createTelemetryService({ metadata });
246
-
247
- // Update metadata after construction
248
- telemetry.updateMetadata({ cline_type: "kanban-updated" });
249
-
250
- telemetry.captureRequired("test.updated_event", {});
251
-
252
- // The OTEL logger should see the updated value
253
- const emittedAttributes =
254
- otelEmit.mock.calls[otelEmit.mock.calls.length - 1][0].attributes;
255
- expect(emittedAttributes.cline_type).toBe("kanban-updated");
256
-
257
- await provider.dispose();
258
- });
259
-
260
- it("preserves logger when disabled", () => {
261
- const logger: BasicLogger = {
262
- debug: vi.fn(),
263
- log: vi.fn(),
264
- error: vi.fn(),
265
- };
266
- const { telemetry } = createConfiguredTelemetryService({
267
- metadata: {
268
- extension_version: "1.0.0",
269
- cline_type: "kanban",
270
- platform: "kanban",
271
- platform_version: "v22.0.0",
272
- os_type: "darwin",
273
- os_version: "15.0",
274
- },
275
- enabled: false,
276
- logger,
277
- });
278
-
279
- telemetry.capture({
280
- event: "session.started",
281
- properties: { sessionId: "session-1" },
282
- });
283
-
284
- expect(logger.log).toHaveBeenCalledWith(
285
- "telemetry.event",
286
- expect.objectContaining({
287
- event: "session.started",
288
- }),
289
- );
290
- });
291
-
292
- it("attaches the logger adapter when creating configured telemetry", () => {
293
- const logger: BasicLogger = {
294
- debug: vi.fn(),
295
- log: vi.fn(),
296
- error: vi.fn(),
297
- };
298
- const { telemetry, provider } = createConfiguredTelemetryService({
299
- metadata: {
300
- extension_version: "1.2.3",
301
- cline_type: "cli",
302
- platform: "terminal",
303
- platform_version: process.version,
304
- os_type: process.platform,
305
- os_version: "unknown",
306
- },
307
- enabled: true,
308
- logsExporter: "console",
309
- logger,
310
- });
311
-
312
- telemetry.capture({
313
- event: "session.started",
314
- properties: { sessionId: "session-1" },
315
- });
316
-
317
- expect(logger.log).toHaveBeenCalledWith(
318
- "telemetry.event",
319
- expect.objectContaining({
320
- event: "session.started",
321
- }),
322
- );
323
-
324
- return provider?.dispose();
325
- });
326
- });
@@ -1,42 +0,0 @@
1
- import { describe, expect, it, vi } from "vitest";
2
- import { TelemetryLoggerSink } from "./TelemetryLoggerSink";
3
-
4
- describe("TelemetryLoggerSink", () => {
5
- it("logs events and metrics through the provided logger", async () => {
6
- const logger = {
7
- debug: vi.fn(),
8
- log: vi.fn(),
9
- };
10
- const sink = new TelemetryLoggerSink({ logger });
11
-
12
- sink.emit("session.started", { sessionId: "s1" });
13
- sink.emitRequired("user.opt_out", { reason: "manual" });
14
- sink.recordCounter("cline.session.starts.total", 1, {
15
- sessionId: "s1",
16
- });
17
-
18
- expect(logger.log).toHaveBeenCalledWith("telemetry.event", {
19
- telemetrySink: "TelemetryLoggerSink",
20
- event: "session.started",
21
- properties: { sessionId: "s1" },
22
- });
23
- expect(logger.log).toHaveBeenCalledWith("telemetry.required_event", {
24
- telemetrySink: "TelemetryLoggerSink",
25
- severity: "warn",
26
- event: "user.opt_out",
27
- properties: { reason: "manual" },
28
- });
29
- expect(logger.debug).toHaveBeenCalledWith("telemetry.metric", {
30
- telemetrySink: "TelemetryLoggerSink",
31
- instrument: "counter",
32
- name: "cline.session.starts.total",
33
- value: 1,
34
- attributes: { sessionId: "s1" },
35
- description: undefined,
36
- required: false,
37
- });
38
-
39
- await sink.flush();
40
- await sink.dispose();
41
- });
42
- });