@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,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
- });
@@ -1,134 +0,0 @@
1
- import type { BasicLogger } from "@clinebot/shared";
2
- import { describe, expect, it, vi } from "vitest";
3
- import type { ITelemetryAdapter } from "./ITelemetryAdapter";
4
- import { TelemetryService } from "./TelemetryService";
5
-
6
- describe("TelemetryService", () => {
7
- it("merges metadata and forwards calls to adapters", async () => {
8
- const { adapter, emit, recordCounter } = createAdapter();
9
- const service = new TelemetryService({
10
- adapters: [adapter],
11
- metadata: {
12
- extension_version: "1.2.3",
13
- cline_type: "cli",
14
- },
15
- distinctId: "distinct-1",
16
- commonProperties: {
17
- organization_id: "org-1",
18
- },
19
- });
20
-
21
- service.capture({
22
- event: "session.started",
23
- properties: { sessionId: "session-1" },
24
- });
25
- service.recordCounter("cline.session.starts.total", 1, {
26
- sessionId: "session-1",
27
- });
28
- await service.flush();
29
- await service.dispose();
30
-
31
- expect(emit).toHaveBeenCalledWith(
32
- "session.started",
33
- expect.objectContaining({
34
- sessionId: "session-1",
35
- organization_id: "org-1",
36
- extension_version: "1.2.3",
37
- cline_type: "cli",
38
- distinct_id: "distinct-1",
39
- }),
40
- );
41
- expect(recordCounter).toHaveBeenCalledWith(
42
- "cline.session.starts.total",
43
- 1,
44
- expect.objectContaining({
45
- sessionId: "session-1",
46
- distinct_id: "distinct-1",
47
- }),
48
- undefined,
49
- false,
50
- );
51
- });
52
-
53
- it("mirrors telemetry events into the logger when provided", () => {
54
- const logger: BasicLogger = {
55
- debug: vi.fn(),
56
- log: vi.fn(),
57
- error: vi.fn(),
58
- };
59
- const service = new TelemetryService({
60
- logger,
61
- metadata: {
62
- extension_version: "1.2.3",
63
- cline_type: "cli",
64
- },
65
- distinctId: "distinct-1",
66
- });
67
-
68
- service.capture({
69
- event: "session.started",
70
- properties: { sessionId: "session-1" },
71
- });
72
- service.captureRequired("user.opt_out", { reason: "manual" });
73
- service.recordCounter("cline.session.starts.total", 1, {
74
- sessionId: "session-1",
75
- });
76
-
77
- expect(logger.log).toHaveBeenCalledWith(
78
- "telemetry.event",
79
- expect.objectContaining({
80
- telemetrySink: "TelemetryLoggerSink",
81
- event: "session.started",
82
- properties: expect.objectContaining({
83
- sessionId: "session-1",
84
- extension_version: "1.2.3",
85
- distinct_id: "distinct-1",
86
- }),
87
- }),
88
- );
89
- expect(logger.log).toHaveBeenCalledWith(
90
- "telemetry.required_event",
91
- expect.objectContaining({
92
- telemetrySink: "TelemetryLoggerSink",
93
- severity: "warn",
94
- event: "user.opt_out",
95
- properties: expect.objectContaining({
96
- reason: "manual",
97
- extension_version: "1.2.3",
98
- }),
99
- }),
100
- );
101
- expect(logger.debug).toHaveBeenCalledWith(
102
- "telemetry.metric",
103
- expect.objectContaining({
104
- telemetrySink: "TelemetryLoggerSink",
105
- instrument: "counter",
106
- name: "cline.session.starts.total",
107
- }),
108
- );
109
- });
110
- });
111
-
112
- function createAdapter(): {
113
- adapter: ITelemetryAdapter;
114
- emit: ReturnType<typeof vi.fn>;
115
- recordCounter: ReturnType<typeof vi.fn>;
116
- } {
117
- const emit = vi.fn();
118
- const recordCounter = vi.fn();
119
- return {
120
- adapter: {
121
- name: "test",
122
- emit,
123
- emitRequired: vi.fn(),
124
- recordCounter,
125
- recordHistogram: vi.fn(),
126
- recordGauge: vi.fn(),
127
- isEnabled: vi.fn(() => true),
128
- flush: vi.fn().mockResolvedValue(undefined),
129
- dispose: vi.fn().mockResolvedValue(undefined),
130
- },
131
- emit,
132
- recordCounter,
133
- };
134
- }
@@ -1,57 +0,0 @@
1
- import { mkdtempSync, rmSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
5
-
6
- const machineIdSyncMock = vi.hoisted(() => vi.fn());
7
-
8
- vi.mock("node-machine-id", () => ({
9
- machineIdSync: machineIdSyncMock,
10
- }));
11
-
12
- describe("resolveCoreDistinctId", () => {
13
- beforeEach(() => {
14
- vi.resetModules();
15
- });
16
-
17
- afterEach(() => {
18
- machineIdSyncMock.mockReset();
19
- vi.unstubAllEnvs();
20
- vi.restoreAllMocks();
21
- });
22
-
23
- it("returns the explicit distinct ID override when provided", async () => {
24
- const { resolveCoreDistinctId } = await import("./distinct-id");
25
-
26
- expect(resolveCoreDistinctId(" user-provided-id ")).toBe(
27
- "user-provided-id",
28
- );
29
- expect(machineIdSyncMock).not.toHaveBeenCalled();
30
- });
31
-
32
- it("uses node-machine-id when no explicit override is provided", async () => {
33
- machineIdSyncMock.mockReturnValue("machine-id-123");
34
- const { resolveCoreDistinctId } = await import("./distinct-id");
35
-
36
- expect(resolveCoreDistinctId()).toBe("machine-id-123");
37
- });
38
-
39
- it("persists and reuses a generated fallback when machine ID lookup fails", async () => {
40
- const tempDir = mkdtempSync(join(tmpdir(), "cline-distinct-id-"));
41
- try {
42
- vi.stubEnv("CLINE_DATA_DIR", tempDir);
43
- machineIdSyncMock.mockImplementation(() => {
44
- throw new Error("machine id unavailable");
45
- });
46
-
47
- const { resolveCoreDistinctId } = await import("./distinct-id");
48
- const first = resolveCoreDistinctId();
49
- const second = resolveCoreDistinctId();
50
-
51
- expect(first).toMatch(/^cl-/);
52
- expect(second).toBe(first);
53
- } finally {
54
- rmSync(tempDir, { recursive: true, force: true });
55
- }
56
- });
57
- });