codna 0.1.0__py3-none-any.whl

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 (761) hide show
  1. codna/__init__.py +8 -0
  2. codna/_wheel_guard.py +28 -0
  3. codna/admission_control.py +275 -0
  4. codna/agent-core/CLINE_FORK.md +55 -0
  5. codna/agent-core/CLINE_SDK_AZ_INTEGRATION_PLAN.md +191 -0
  6. codna/agent-core/CLINE_SDK_INTERFACE.md +655 -0
  7. codna/agent-core/CLINE_SDK_RESEARCH.md +104 -0
  8. codna/agent-core/package.json +12 -0
  9. codna/agent-core/run-server.mjs +87 -0
  10. codna/agent-core/run-server.stub.mjs +149 -0
  11. codna/agent-core/vendor/cline/.gitignore +3 -0
  12. codna/agent-core/vendor/cline/LICENSE +201 -0
  13. codna/agent-core/vendor/cline/NOTICE +24 -0
  14. codna/agent-core/vendor/cline/UPSTREAM_COMMIT.txt +1 -0
  15. codna/agent-core/vendor/cline/algenta/README.md +27 -0
  16. codna/agent-core/vendor/cline/algenta/acp-editor.ts +176 -0
  17. codna/agent-core/vendor/cline/algenta/adapter.ts +452 -0
  18. codna/agent-core/vendor/cline/algenta/algenta-plugin.ts +30 -0
  19. codna/agent-core/vendor/cline/algenta/artifacts.test.ts +133 -0
  20. codna/agent-core/vendor/cline/algenta/execution.test.ts +63 -0
  21. codna/agent-core/vendor/cline/algenta/fallback.test.ts +73 -0
  22. codna/agent-core/vendor/cline/algenta/fallback.ts +83 -0
  23. codna/agent-core/vendor/cline/algenta/fix-runner.ts +27 -0
  24. codna/agent-core/vendor/cline/algenta/http.test.ts +48 -0
  25. codna/agent-core/vendor/cline/algenta/mojo-gate.test.ts +76 -0
  26. codna/agent-core/vendor/cline/algenta/mojo-gate.ts +151 -0
  27. codna/agent-core/vendor/cline/algenta/policy.test.ts +260 -0
  28. codna/agent-core/vendor/cline/algenta/postbuild.sh +31 -0
  29. codna/agent-core/vendor/cline/algenta/proof-artifacts.test.ts +55 -0
  30. codna/agent-core/vendor/cline/algenta/proof-provider.ts +301 -0
  31. codna/agent-core/vendor/cline/algenta/proofs.ts +311 -0
  32. codna/agent-core/vendor/cline/algenta/provider-key.test.ts +197 -0
  33. codna/agent-core/vendor/cline/algenta/run-server.ts +645 -0
  34. codna/agent-core/vendor/cline/algenta/scheduled-agents.ts +430 -0
  35. codna/agent-core/vendor/cline/algenta/server/artifacts.ts +532 -0
  36. codna/agent-core/vendor/cline/algenta/server/contracts.ts +254 -0
  37. codna/agent-core/vendor/cline/algenta/server/execution.ts +284 -0
  38. codna/agent-core/vendor/cline/algenta/server/http.ts +146 -0
  39. codna/agent-core/vendor/cline/algenta/server/policy.ts +391 -0
  40. codna/agent-core/vendor/cline/algenta/server/state.ts +21 -0
  41. codna/agent-core/vendor/cline/algenta/server/utils.ts +508 -0
  42. codna/agent-core/vendor/cline/algenta/task-policy.ts +82 -0
  43. codna/agent-core/vendor/cline/algenta/telys-localize.test.ts +416 -0
  44. codna/agent-core/vendor/cline/algenta/telys-localize.ts +608 -0
  45. codna/agent-core/vendor/cline/algenta/telys-worker.test.ts +99 -0
  46. codna/agent-core/vendor/cline/algenta/telys-worker.ts +245 -0
  47. codna/agent-core/vendor/cline/algenta/tools.test.ts +59 -0
  48. codna/agent-core/vendor/cline/algenta/tools.ts +196 -0
  49. codna/agent-core/vendor/cline/algenta/write-scope.test.ts +26 -0
  50. codna/agent-core/vendor/cline/algenta/write-scope.ts +60 -0
  51. codna/agent-core/vendor/cline/biome.json +19 -0
  52. codna/agent-core/vendor/cline/bun.lock +1179 -0
  53. codna/agent-core/vendor/cline/package.json +60 -0
  54. codna/agent-core/vendor/cline/sdk/.cline/rules/worktree_dependency_hygiene.md +15 -0
  55. codna/agent-core/vendor/cline/sdk/.cline/skills/plugin.md +892 -0
  56. codna/agent-core/vendor/cline/sdk/.gitignore +69 -0
  57. codna/agent-core/vendor/cline/sdk/AGENTS.md +109 -0
  58. codna/agent-core/vendor/cline/sdk/ARCHITECTURE.md +525 -0
  59. codna/agent-core/vendor/cline/sdk/CHANGELOG.md +32 -0
  60. codna/agent-core/vendor/cline/sdk/CONTRIBUTING.md +196 -0
  61. codna/agent-core/vendor/cline/sdk/README.md +273 -0
  62. codna/agent-core/vendor/cline/sdk/biome.json +140 -0
  63. codna/agent-core/vendor/cline/sdk/examples/README.md +196 -0
  64. codna/agent-core/vendor/cline/sdk/examples/cron/README.md +419 -0
  65. codna/agent-core/vendor/cline/sdk/examples/cron/changelog-generator.cron.md +37 -0
  66. codna/agent-core/vendor/cline/sdk/examples/cron/code-style-audit.cron.md +47 -0
  67. codna/agent-core/vendor/cline/sdk/examples/cron/daily-code-review.cron.md +28 -0
  68. codna/agent-core/vendor/cline/sdk/examples/cron/dead-code-finder.cron.md +58 -0
  69. codna/agent-core/vendor/cline/sdk/examples/cron/dependency-check.cron.md +35 -0
  70. codna/agent-core/vendor/cline/sdk/examples/cron/documentation-check.cron.md +66 -0
  71. codna/agent-core/vendor/cline/sdk/examples/cron/events/local-manual-test.event.md +28 -0
  72. codna/agent-core/vendor/cline/sdk/examples/cron/events/local-plugin-event.event.md +20 -0
  73. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-changelog-check.event.md +42 -0
  74. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-review.event.md +32 -0
  75. codna/agent-core/vendor/cline/sdk/examples/cron/events/pr-test-coverage.event.md +55 -0
  76. codna/agent-core/vendor/cline/sdk/examples/cron/performance-baseline.cron.md +45 -0
  77. codna/agent-core/vendor/cline/sdk/examples/cron/test-coverage-report.cron.md +41 -0
  78. codna/agent-core/vendor/cline/sdk/examples/cron/type-check-strict.cron.md +44 -0
  79. codna/agent-core/vendor/cline/sdk/examples/cron/weekly-metrics-summary.cron.md +67 -0
  80. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.py +62 -0
  81. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.sh +17 -0
  82. codna/agent-core/vendor/cline/sdk/examples/hooks/PostToolUse.ts +86 -0
  83. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.py +34 -0
  84. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.sh +16 -0
  85. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse.ts +66 -0
  86. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_BlockDestructive.sh +25 -0
  87. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_InjectContext.py +116 -0
  88. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_InjectFileContext.sh +57 -0
  89. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_ModifyInput.ts +125 -0
  90. codna/agent-core/vendor/cline/sdk/examples/hooks/PreToolUse_RequireReview.sh +19 -0
  91. codna/agent-core/vendor/cline/sdk/examples/hooks/README.md +435 -0
  92. codna/agent-core/vendor/cline/sdk/examples/hooks/SessionShutdown.sh +14 -0
  93. codna/agent-core/vendor/cline/sdk/examples/hooks/TaskComplete.sh +27 -0
  94. codna/agent-core/vendor/cline/sdk/examples/hooks/TaskStart.sh +14 -0
  95. codna/agent-core/vendor/cline/sdk/examples/hooks/custom-compaction-hook.example.ts +246 -0
  96. codna/agent-core/vendor/cline/sdk/examples/package.json +19 -0
  97. codna/agent-core/vendor/cline/sdk/examples/plugins/README.md +203 -0
  98. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/README.md +122 -0
  99. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/anvil.md +16 -0
  100. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/inquisitor.md +18 -0
  101. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/oracle.md +18 -0
  102. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/agents/phantom.md +17 -0
  103. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/index.ts +831 -0
  104. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/package.json +39 -0
  105. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/api-design.md +63 -0
  106. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/code-review.md +61 -0
  107. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/debugging.md +62 -0
  108. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/documentation.md +83 -0
  109. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/migration.md +77 -0
  110. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/refactoring.md +58 -0
  111. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/skills/test-generation.md +76 -0
  112. codna/agent-core/vendor/cline/sdk/examples/plugins/agents-squad/tsconfig.json +4 -0
  113. codna/agent-core/vendor/cline/sdk/examples/plugins/automation-events.ts +91 -0
  114. codna/agent-core/vendor/cline/sdk/examples/plugins/background-terminal.ts +444 -0
  115. codna/agent-core/vendor/cline/sdk/examples/plugins/custom-compaction.ts +225 -0
  116. codna/agent-core/vendor/cline/sdk/examples/plugins/env-blocker.ts +118 -0
  117. codna/agent-core/vendor/cline/sdk/examples/plugins/gitignore-read-files-guard.ts +270 -0
  118. codna/agent-core/vendor/cline/sdk/examples/plugins/mac-notify.ts +67 -0
  119. codna/agent-core/vendor/cline/sdk/examples/plugins/openrouter-provider.ts +144 -0
  120. codna/agent-core/vendor/cline/sdk/examples/plugins/typescript-lsp/README.md +106 -0
  121. codna/agent-core/vendor/cline/sdk/examples/plugins/typescript-lsp/index.ts +298 -0
  122. codna/agent-core/vendor/cline/sdk/examples/plugins/weather-metrics.ts +151 -0
  123. codna/agent-core/vendor/cline/sdk/examples/plugins/web-search.ts +324 -0
  124. codna/agent-core/vendor/cline/sdk/examples/tsconfig.json +58 -0
  125. codna/agent-core/vendor/cline/sdk/packages/README.md +44 -0
  126. codna/agent-core/vendor/cline/sdk/packages/agents/README.md +278 -0
  127. codna/agent-core/vendor/cline/sdk/packages/agents/bun.mts +29 -0
  128. codna/agent-core/vendor/cline/sdk/packages/agents/package.json +45 -0
  129. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.provider-form.test.ts +210 -0
  130. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.test.ts +1427 -0
  131. codna/agent-core/vendor/cline/sdk/packages/agents/src/agent-runtime.ts +1558 -0
  132. codna/agent-core/vendor/cline/sdk/packages/agents/src/index.ts +57 -0
  133. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.build.json +13 -0
  134. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.dev.json +13 -0
  135. codna/agent-core/vendor/cline/sdk/packages/agents/tsconfig.json +9 -0
  136. codna/agent-core/vendor/cline/sdk/packages/agents/vitest.config.ts +10 -0
  137. codna/agent-core/vendor/cline/sdk/packages/core/README.md +110 -0
  138. codna/agent-core/vendor/cline/sdk/packages/core/bun.mts +75 -0
  139. codna/agent-core/vendor/cline/sdk/packages/core/docs/messages-contract-v1.md +148 -0
  140. codna/agent-core/vendor/cline/sdk/packages/core/fixtures/messages/success.messages.json +72 -0
  141. codna/agent-core/vendor/cline/sdk/packages/core/package.json +80 -0
  142. codna/agent-core/vendor/cline/sdk/packages/core/scripts/telemetry-smoke-host.ts +204 -0
  143. codna/agent-core/vendor/cline/sdk/packages/core/scripts/telemetry-smoke.ts +431 -0
  144. codna/agent-core/vendor/cline/sdk/packages/core/src/ClineCore.test.ts +607 -0
  145. codna/agent-core/vendor/cline/sdk/packages/core/src/ClineCore.ts +566 -0
  146. codna/agent-core/vendor/cline/sdk/packages/core/src/account/cline-account-service.test.ts +217 -0
  147. codna/agent-core/vendor/cline/sdk/packages/core/src/account/cline-account-service.ts +338 -0
  148. codna/agent-core/vendor/cline/sdk/packages/core/src/account/featurebase-token.test.ts +175 -0
  149. codna/agent-core/vendor/cline/sdk/packages/core/src/account/index.ts +24 -0
  150. codna/agent-core/vendor/cline/sdk/packages/core/src/account/rpc.test.ts +63 -0
  151. codna/agent-core/vendor/cline/sdk/packages/core/src/account/rpc.ts +185 -0
  152. codna/agent-core/vendor/cline/sdk/packages/core/src/account/types.ts +108 -0
  153. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/bounded-ttl-cache.test.ts +38 -0
  154. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/bounded-ttl-cache.ts +53 -0
  155. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/client.test.ts +93 -0
  156. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/client.ts +50 -0
  157. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/cline.test.ts +233 -0
  158. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/cline.ts +722 -0
  159. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/codex.test.ts +170 -0
  160. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/codex.ts +491 -0
  161. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/oca.test.ts +340 -0
  162. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/oca.ts +588 -0
  163. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/server.test.ts +319 -0
  164. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/server.ts +265 -0
  165. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/types.ts +110 -0
  166. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/utils.test.ts +128 -0
  167. codna/agent-core/vendor/cline/sdk/packages/core/src/auth/utils.ts +247 -0
  168. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/automation.ts +250 -0
  169. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/runtime-services.ts +75 -0
  170. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/start-input.ts +91 -0
  171. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/telemetry.ts +39 -0
  172. codna/agent-core/vendor/cline/sdk/packages/core/src/cline-core/types.ts +274 -0
  173. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/cron-event-ingress.test.ts +255 -0
  174. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/cron-event-ingress.ts +357 -0
  175. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/events/index.ts +1 -0
  176. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/index.ts +7 -0
  177. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/reports/cron-report-writer.ts +153 -0
  178. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/reports/index.ts +1 -0
  179. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-materializer.test.ts +152 -0
  180. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-materializer.ts +100 -0
  181. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-runner.test.ts +342 -0
  182. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/cron-runner.ts +547 -0
  183. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/index.ts +3 -0
  184. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/runner/resource-limiter.ts +46 -0
  185. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/index.ts +1 -0
  186. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/scheduler.test.ts +16 -0
  187. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/schedule/scheduler.ts +373 -0
  188. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/cron-service.ts +163 -0
  189. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/index.ts +3 -0
  190. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-command-service.ts +198 -0
  191. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-service.test.ts +213 -0
  192. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/service/schedule-service.ts +416 -0
  193. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-reconciler.test.ts +138 -0
  194. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-reconciler.ts +241 -0
  195. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-spec-parser.test.ts +198 -0
  196. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-spec-parser.ts +489 -0
  197. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-watcher.test.ts +87 -0
  198. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/cron-watcher.ts +102 -0
  199. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/specs/index.ts +3 -0
  200. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/cron-schema.ts +127 -0
  201. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/index.ts +2 -0
  202. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/sqlite-cron-store.test.ts +354 -0
  203. codna/agent-core/vendor/cline/sdk/packages/core/src/cron/store/sqlite-cron-store.ts +1552 -0
  204. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/index.ts +46 -0
  205. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/runtime-commands.test.ts +185 -0
  206. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/runtime-commands.ts +92 -0
  207. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/skill-frontmatter-toggle.test.ts +109 -0
  208. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/skill-frontmatter-toggle.ts +83 -0
  209. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/unified-config-file-watcher.test.ts +193 -0
  210. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/unified-config-file-watcher.ts +496 -0
  211. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-config-loader.test.ts +424 -0
  212. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-config-loader.ts +628 -0
  213. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-plugin.ts +277 -0
  214. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/config/user-instruction-service.ts +128 -0
  215. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/agentic-compaction.ts +153 -0
  216. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/basic-compaction.ts +419 -0
  217. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction-shared.ts +511 -0
  218. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.live.test.ts +346 -0
  219. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.test.ts +1729 -0
  220. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/context/compaction.ts +430 -0
  221. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/index.ts +19 -0
  222. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/client.ts +579 -0
  223. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/config-loader.test.ts +402 -0
  224. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/config-loader.ts +446 -0
  225. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/index.ts +57 -0
  226. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/manager.test.ts +105 -0
  227. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/manager.ts +260 -0
  228. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/name-transform.ts +33 -0
  229. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/oauth.test.ts +79 -0
  230. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/oauth.ts +401 -0
  231. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/policies.ts +47 -0
  232. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/tools.ts +47 -0
  233. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/mcp/types.ts +135 -0
  234. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-config-loader.test.ts +480 -0
  235. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-config-loader.ts +313 -0
  236. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-load-report.ts +20 -0
  237. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-loader.test.ts +473 -0
  238. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-loader.ts +214 -0
  239. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-module-import.ts +682 -0
  240. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox-bootstrap.ts +781 -0
  241. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox.test.ts +810 -0
  242. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-sandbox.ts +640 -0
  243. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/plugin/plugin-targeting.ts +32 -0
  244. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/constants.ts +37 -0
  245. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/definitions.test.ts +1408 -0
  246. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/definitions.ts +863 -0
  247. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch-parser.ts +520 -0
  248. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch.test.ts +147 -0
  249. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/apply-patch.ts +348 -0
  250. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/bash.test.ts +108 -0
  251. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/bash.ts +211 -0
  252. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/editor.test.ts +113 -0
  253. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/editor.ts +220 -0
  254. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/file-read.test.ts +167 -0
  255. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/file-read.ts +140 -0
  256. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/index.ts +87 -0
  257. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/search.ts +471 -0
  258. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/executors/web-fetch.ts +259 -0
  259. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/helpers.ts +126 -0
  260. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/index.ts +183 -0
  261. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/model-tool-routing.test.ts +86 -0
  262. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/model-tool-routing.ts +134 -0
  263. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/presets.test.ts +72 -0
  264. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/presets.ts +190 -0
  265. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/runtime.test.ts +74 -0
  266. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/runtime.ts +261 -0
  267. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/schemas.ts +345 -0
  268. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/delegated-agent.ts +136 -0
  269. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/index.ts +5 -0
  270. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/multi-agent.lifecycle.test.ts +649 -0
  271. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/multi-agent.ts +1845 -0
  272. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/projections.ts +283 -0
  273. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/runtime.ts +54 -0
  274. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/spawn-agent-tool.test.ts +378 -0
  275. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/spawn-agent-tool.ts +203 -0
  276. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/subagent-prompts.ts +41 -0
  277. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/team-tools.test.ts +991 -0
  278. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/team/team-tools.ts +912 -0
  279. codna/agent-core/vendor/cline/sdk/packages/core/src/extensions/tools/types.ts +358 -0
  280. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/checkpoint-hooks.test.ts +276 -0
  281. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/checkpoint-hooks.ts +291 -0
  282. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-extension.ts +15 -0
  283. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-config.test.ts +17 -0
  284. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-config.ts +117 -0
  285. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-hooks.test.ts +593 -0
  286. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/hook-file-hooks.ts +1140 -0
  287. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/index.ts +34 -0
  288. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/subprocess-runner.ts +196 -0
  289. codna/agent-core/vendor/cline/sdk/packages/core/src/hooks/subprocess.ts +543 -0
  290. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/connect.test.ts +74 -0
  291. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/connect.ts +187 -0
  292. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/index.test.ts +994 -0
  293. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/index.ts +1087 -0
  294. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/session-client.test.ts +310 -0
  295. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/session-client.ts +734 -0
  296. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/client/ui-client.ts +128 -0
  297. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/entry.ts +129 -0
  298. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/index.test.ts +357 -0
  299. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/index.ts +345 -0
  300. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/runtime-handlers.ts +144 -0
  301. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/daemon/start-shared-server.ts +61 -0
  302. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/defaults.test.ts +122 -0
  303. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/defaults.ts +70 -0
  304. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/index.test.ts +91 -0
  305. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/index.ts +260 -0
  306. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/discovery/workspace.ts +19 -0
  307. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/index.ts +37 -0
  308. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/hub-runtime-host.test.ts +1485 -0
  309. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/hub-runtime-host.ts +1948 -0
  310. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/runtime-host/remote-runtime-host.ts +27 -0
  311. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/boundary.test.ts +1142 -0
  312. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/browser-websocket.test.ts +173 -0
  313. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/browser-websocket.ts +295 -0
  314. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/command-transport.ts +14 -0
  315. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/fetch-wiring.test.ts +102 -0
  316. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/approval-handlers.ts +133 -0
  317. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/capability-handlers.ts +278 -0
  318. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/client-handlers.ts +86 -0
  319. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/context.ts +211 -0
  320. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/run-handlers.test.ts +186 -0
  321. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/run-handlers.ts +337 -0
  322. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/session-event-projector.ts +355 -0
  323. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/handlers/session-handlers.ts +842 -0
  324. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-capability-tool-executors.test.ts +215 -0
  325. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-client-contributions.ts +687 -0
  326. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-notifications.ts +94 -0
  327. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-schedule-events.ts +20 -0
  328. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-logging.ts +69 -0
  329. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-options.ts +66 -0
  330. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-server-transport.ts +593 -0
  331. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-session-records.ts +99 -0
  332. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/hub-websocket-server.ts +562 -0
  333. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/index.test.ts +358 -0
  334. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/index.ts +4 -0
  335. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/native-transport.ts +31 -0
  336. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/notification.test.ts +21 -0
  337. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/server/ui-events.test.ts +232 -0
  338. codna/agent-core/vendor/cline/sdk/packages/core/src/hub/settings.test.ts +143 -0
  339. codna/agent-core/vendor/cline/sdk/packages/core/src/index.ts +789 -0
  340. codna/agent-core/vendor/cline/sdk/packages/core/src/remote-config/integration.ts +133 -0
  341. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/index.ts +2 -0
  342. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/normalize-runtime-capabilities.ts +33 -0
  343. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/capabilities/runtime-capabilities.ts +9 -0
  344. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-message-codec.test.ts +171 -0
  345. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-message-codec.ts +301 -0
  346. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-runtime-config-builder.test.ts +268 -0
  347. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/config/agent-runtime-config-builder.ts +181 -0
  348. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/history.test.ts +573 -0
  349. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/history.ts +516 -0
  350. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/host.test.ts +297 -0
  351. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/host.ts +248 -0
  352. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/agent-event-bridge.ts +231 -0
  353. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/session-record.ts +52 -0
  354. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/session-service-invoker.ts +40 -0
  355. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/spawn-tool.ts +162 -0
  356. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local/user-files.ts +18 -0
  357. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.e2e.test.ts +576 -0
  358. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.test.ts +5167 -0
  359. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/local-runtime-host.ts +1755 -0
  360. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host-support.test.ts +55 -0
  361. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host-support.ts +140 -0
  362. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/host/runtime-host.ts +323 -0
  363. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/index.ts +24 -0
  364. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.team-persistence.test.ts +290 -0
  365. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.test.ts +887 -0
  366. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-builder.ts +637 -0
  367. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-event-adapter.test.ts +901 -0
  368. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-event-adapter.ts +426 -0
  369. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-oauth-token-manager.test.ts +137 -0
  370. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-oauth-token-manager.ts +269 -0
  371. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/runtime-parity.test.ts +165 -0
  372. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime-orchestrator.test.ts +1900 -0
  373. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime-orchestrator.ts +1334 -0
  374. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/session-runtime.ts +73 -0
  375. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/orchestration/user-input-builder.ts +159 -0
  376. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/loop-detection.ts +162 -0
  377. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/mistake-tracker.ts +221 -0
  378. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/rules.test.ts +22 -0
  379. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/safety/rules.ts +49 -0
  380. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/subprocess-sandbox.test.ts +81 -0
  381. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/subprocess-sandbox.ts +333 -0
  382. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/tools/tool-approval.ts +102 -0
  383. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/turn-queue/pending-prompt-service.test.ts +168 -0
  384. codna/agent-core/vendor/cline/sdk/packages/core/src/runtime/turn-queue/pending-prompt-service.ts +381 -0
  385. codna/agent-core/vendor/cline/sdk/packages/core/src/services/agent-events.ts +321 -0
  386. codna/agent-core/vendor/cline/sdk/packages/core/src/services/config.ts +5 -0
  387. codna/agent-core/vendor/cline/sdk/packages/core/src/services/global-settings.test.ts +352 -0
  388. codna/agent-core/vendor/cline/sdk/packages/core/src/services/global-settings.ts +324 -0
  389. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/apihandler-agent-model-adapter.test.ts +229 -0
  390. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/apihandler-agent-model-adapter.ts +170 -0
  391. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/cline-recommended-models.ts +168 -0
  392. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/configured-provider-registry.ts +193 -0
  393. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/handler-factory.test.ts +288 -0
  394. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/handler-factory.ts +197 -0
  395. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-defaults.test.ts +260 -0
  396. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-defaults.ts +887 -0
  397. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-settings.test.ts +26 -0
  398. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/provider-settings.ts +322 -0
  399. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-config.ts +43 -0
  400. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-registry.ts +172 -0
  401. codna/agent-core/vendor/cline/sdk/packages/core/src/services/llms/runtime-types.ts +121 -0
  402. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.startup.test.ts +249 -0
  403. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.test.ts +543 -0
  404. codna/agent-core/vendor/cline/sdk/packages/core/src/services/local-runtime-bootstrap.ts +470 -0
  405. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-tools.ts +230 -0
  406. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-uninstall.test.ts +165 -0
  407. codna/agent-core/vendor/cline/sdk/packages/core/src/services/plugin-uninstall.ts +425 -0
  408. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-registry.ts +468 -0
  409. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-service.test.ts +1358 -0
  410. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/local-provider-service.ts +948 -0
  411. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/model-source.ts +105 -0
  412. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/provider-config-fields.test.ts +137 -0
  413. codna/agent-core/vendor/cline/sdk/packages/core/src/services/providers/provider-config-fields.ts +211 -0
  414. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-artifacts.ts +138 -0
  415. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-data.test.ts +307 -0
  416. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-data.ts +405 -0
  417. codna/agent-core/vendor/cline/sdk/packages/core/src/services/session-telemetry.ts +89 -0
  418. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/artifact-store.ts +1 -0
  419. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/file-team-store.ts +250 -0
  420. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/index.ts +11 -0
  421. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-legacy-migration.test.ts +656 -0
  422. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-legacy-migration.ts +798 -0
  423. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-manager.test.ts +354 -0
  424. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/provider-settings-manager.ts +194 -0
  425. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/session-store.ts +1 -0
  426. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/sqlite-session-store.ts +272 -0
  427. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/sqlite-team-store.ts +537 -0
  428. codna/agent-core/vendor/cline/sdk/packages/core/src/services/storage/team-store.ts +36 -0
  429. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/ITelemetryAdapter.ts +94 -0
  430. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryAdapter.test.ts +157 -0
  431. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryAdapter.ts +348 -0
  432. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryProvider.test.ts +401 -0
  433. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/OpenTelemetryProvider.ts +545 -0
  434. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryLoggerSink.test.ts +42 -0
  435. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryLoggerSink.ts +121 -0
  436. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryService.test.ts +134 -0
  437. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/TelemetryService.ts +139 -0
  438. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/core-events.test.ts +696 -0
  439. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/core-events.ts +680 -0
  440. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/distinct-id.test.ts +57 -0
  441. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/distinct-id.ts +69 -0
  442. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/index.ts +22 -0
  443. codna/agent-core/vendor/cline/sdk/packages/core/src/services/telemetry/tool-context.ts +15 -0
  444. codna/agent-core/vendor/cline/sdk/packages/core/src/services/usage.test.ts +75 -0
  445. codna/agent-core/vendor/cline/sdk/packages/core/src/services/usage.ts +87 -0
  446. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/file-indexer.test.ts +156 -0
  447. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/file-indexer.ts +362 -0
  448. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/index.ts +7 -0
  449. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/mention-enricher.test.ts +106 -0
  450. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/mention-enricher.ts +122 -0
  451. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-manager.ts +100 -0
  452. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-manifest.ts +129 -0
  453. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-telemetry.test.ts +166 -0
  454. codna/agent-core/vendor/cline/sdk/packages/core/src/services/workspace/workspace-telemetry.ts +70 -0
  455. codna/agent-core/vendor/cline/sdk/packages/core/src/session/checkpoint-restore.test.ts +154 -0
  456. codna/agent-core/vendor/cline/sdk/packages/core/src/session/checkpoint-restore.ts +189 -0
  457. codna/agent-core/vendor/cline/sdk/packages/core/src/session/index.ts +32 -0
  458. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-graph.ts +92 -0
  459. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-manifest.ts +29 -0
  460. codna/agent-core/vendor/cline/sdk/packages/core/src/session/models/session-row.ts +199 -0
  461. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/file-session-service.ts +284 -0
  462. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/message-builder.test.ts +375 -0
  463. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/message-builder.ts +976 -0
  464. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/persistence-service.test.ts +553 -0
  465. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/persistence-service.ts +582 -0
  466. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/session-service.team-persistence.test.ts +48 -0
  467. codna/agent-core/vendor/cline/sdk/packages/core/src/session/services/session-service.ts +326 -0
  468. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-snapshot.ts +208 -0
  469. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-versioning-service.test.ts +195 -0
  470. codna/agent-core/vendor/cline/sdk/packages/core/src/session/session-versioning-service.ts +245 -0
  471. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/conversation-store.ts +77 -0
  472. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/session-manifest-store.ts +160 -0
  473. codna/agent-core/vendor/cline/sdk/packages/core/src/session/stores/team-persistence-store.ts +176 -0
  474. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/index.ts +12 -0
  475. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/team-child-session-manager.ts +415 -0
  476. codna/agent-core/vendor/cline/sdk/packages/core/src/session/team/team-session-coordinator.ts +240 -0
  477. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/index.ts +15 -0
  478. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/settings-service.test.ts +303 -0
  479. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/settings-service.ts +317 -0
  480. codna/agent-core/vendor/cline/sdk/packages/core/src/settings/types.ts +67 -0
  481. codna/agent-core/vendor/cline/sdk/packages/core/src/types/chat-schema.ts +90 -0
  482. codna/agent-core/vendor/cline/sdk/packages/core/src/types/common.ts +54 -0
  483. codna/agent-core/vendor/cline/sdk/packages/core/src/types/config.ts +220 -0
  484. codna/agent-core/vendor/cline/sdk/packages/core/src/types/events.ts +88 -0
  485. codna/agent-core/vendor/cline/sdk/packages/core/src/types/index.ts +26 -0
  486. codna/agent-core/vendor/cline/sdk/packages/core/src/types/provider-settings.ts +56 -0
  487. codna/agent-core/vendor/cline/sdk/packages/core/src/types/session.ts +134 -0
  488. codna/agent-core/vendor/cline/sdk/packages/core/src/types/sessions.ts +45 -0
  489. codna/agent-core/vendor/cline/sdk/packages/core/src/types/storage.ts +56 -0
  490. codna/agent-core/vendor/cline/sdk/packages/core/src/types.ts +184 -0
  491. codna/agent-core/vendor/cline/sdk/packages/core/src/version.ts +3 -0
  492. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.build.json +18 -0
  493. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.dev.json +8 -0
  494. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.json +24 -0
  495. codna/agent-core/vendor/cline/sdk/packages/core/tsconfig.smoke.json +18 -0
  496. codna/agent-core/vendor/cline/sdk/packages/core/vitest.config.ts +9 -0
  497. codna/agent-core/vendor/cline/sdk/packages/core/vitest.e2e.config.ts +10 -0
  498. codna/agent-core/vendor/cline/sdk/packages/llms/AGENTS.md +39 -0
  499. codna/agent-core/vendor/cline/sdk/packages/llms/README.md +227 -0
  500. codna/agent-core/vendor/cline/sdk/packages/llms/bun.mts +49 -0
  501. codna/agent-core/vendor/cline/sdk/packages/llms/fixtures/usage.json +308 -0
  502. codna/agent-core/vendor/cline/sdk/packages/llms/package.json +73 -0
  503. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/fix-esm-imports.ts +109 -0
  504. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/generate-models.ts +136 -0
  505. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/models/generate-models-dev.ts +24 -0
  506. codna/agent-core/vendor/cline/sdk/packages/llms/scripts/tsconfig.json +14 -0
  507. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/README.md +165 -0
  508. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog-live.test.ts +275 -0
  509. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog-live.ts +186 -0
  510. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog.generated-access.ts +41 -0
  511. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/catalog.generated.ts +22756 -0
  512. codna/agent-core/vendor/cline/sdk/packages/llms/src/catalog/types.ts +97 -0
  513. codna/agent-core/vendor/cline/sdk/packages/llms/src/index.browser.ts +33 -0
  514. codna/agent-core/vendor/cline/sdk/packages/llms/src/index.ts +74 -0
  515. codna/agent-core/vendor/cline/sdk/packages/llms/src/models.ts +31 -0
  516. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ai-sdk.test.ts +371 -0
  517. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ai-sdk.ts +1012 -0
  518. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/async.ts +7 -0
  519. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/billing.test.ts +28 -0
  520. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/billing.ts +23 -0
  521. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins-runtime.ts +101 -0
  522. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins.test.ts +137 -0
  523. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/builtins.ts +1084 -0
  524. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/compat.test.ts +562 -0
  525. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/compat.ts +669 -0
  526. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/config.ts +429 -0
  527. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/factory-registry.ts +161 -0
  528. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/format.test.ts +43 -0
  529. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/format.ts +70 -0
  530. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/gateway.test.ts +3575 -0
  531. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/gateway.ts +310 -0
  532. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/handler.ts +91 -0
  533. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/http.ts +121 -0
  534. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ids.test.ts +143 -0
  535. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/ids.ts +95 -0
  536. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/messages.ts +17 -0
  537. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/middleware/split-tool-images.test.ts +504 -0
  538. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/middleware/split-tool-images.ts +293 -0
  539. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/model-facts.ts +270 -0
  540. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/model-registry.ts +122 -0
  541. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/openai-codex-models.ts +35 -0
  542. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/provider-keys.ts +153 -0
  543. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/registry.ts +279 -0
  544. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/anthropic-compatible.test.ts +503 -0
  545. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/anthropic-compatible.ts +602 -0
  546. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/generic-compatible.ts +151 -0
  547. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/glm-thinking.ts +106 -0
  548. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/minimax-thinking.ts +78 -0
  549. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-option-rules.ts +546 -0
  550. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options-types.ts +92 -0
  551. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options.test.ts +1872 -0
  552. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/provider-options.ts +119 -0
  553. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/reasoning-codecs.ts +40 -0
  554. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/routing/utils.ts +47 -0
  555. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/stream.ts +117 -0
  556. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/types.ts +77 -0
  557. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/anthropic.test.ts +90 -0
  558. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/anthropic.ts +39 -0
  559. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/bedrock.test.ts +201 -0
  560. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/bedrock.ts +171 -0
  561. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/community.test.ts +55 -0
  562. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/community.ts +207 -0
  563. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/google.ts +61 -0
  564. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/minimax-thinking.test.ts +69 -0
  565. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/minimax-thinking.ts +104 -0
  566. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/mistral.ts +31 -0
  567. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/openai-compatible.ts +49 -0
  568. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/openai.ts +24 -0
  569. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/types.ts +141 -0
  570. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/vertex.test.ts +125 -0
  571. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers/vendors/vertex.ts +56 -0
  572. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers.browser.ts +5 -0
  573. codna/agent-core/vendor/cline/sdk/packages/llms/src/providers.ts +106 -0
  574. codna/agent-core/vendor/cline/sdk/packages/llms/src/services/langfuse-telemetry.test.ts +90 -0
  575. codna/agent-core/vendor/cline/sdk/packages/llms/src/services/langfuse-telemetry.ts +187 -0
  576. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.example.json +254 -0
  577. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.openai-codex.example.json +19 -0
  578. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.openai-codex.reasoning.example.json +22 -0
  579. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.reasoning-disabled.example.json +423 -0
  580. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.reasoning.example.json +349 -0
  581. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/live-providers.tools.example.json +199 -0
  582. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-config.test.ts +98 -0
  583. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-config.ts +193 -0
  584. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-minimax-routing.test.ts +264 -0
  585. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-reasoning.test.ts +290 -0
  586. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-runner.ts +47 -0
  587. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live-tools.test.ts +265 -0
  588. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-live.test.ts +350 -0
  589. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/README.md +31 -0
  590. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/anthropic-claude-sonnet-4-6.json +12 -0
  591. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/cline-anthropic-sonnet.json +12 -0
  592. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/openai-codex-gpt-5-4.json +11 -0
  593. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr/openai-compatible-deepseek-v4-pro.json +12 -0
  594. codna/agent-core/vendor/cline/sdk/packages/llms/src/tests/provider-vcr.test.ts +450 -0
  595. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.build.json +19 -0
  596. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.dev.json +12 -0
  597. codna/agent-core/vendor/cline/sdk/packages/llms/tsconfig.json +11 -0
  598. codna/agent-core/vendor/cline/sdk/packages/llms/vitest.config.ts +24 -0
  599. codna/agent-core/vendor/cline/sdk/packages/sdk/bun.mts +18 -0
  600. codna/agent-core/vendor/cline/sdk/packages/sdk/package.json +37 -0
  601. codna/agent-core/vendor/cline/sdk/packages/sdk/src/index.ts +1 -0
  602. codna/agent-core/vendor/cline/sdk/packages/sdk/tsconfig.build.json +12 -0
  603. codna/agent-core/vendor/cline/sdk/packages/sdk/tsconfig.json +11 -0
  604. codna/agent-core/vendor/cline/sdk/packages/shared/README.md +47 -0
  605. codna/agent-core/vendor/cline/sdk/packages/shared/bun.mts +70 -0
  606. codna/agent-core/vendor/cline/sdk/packages/shared/package.json +63 -0
  607. codna/agent-core/vendor/cline/sdk/packages/shared/src/agent.ts +561 -0
  608. codna/agent-core/vendor/cline/sdk/packages/shared/src/agents/index.ts +1 -0
  609. codna/agent-core/vendor/cline/sdk/packages/shared/src/agents/types.ts +1055 -0
  610. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/index.ts +31 -0
  611. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/schemas.ts +99 -0
  612. codna/agent-core/vendor/cline/sdk/packages/shared/src/automation/types.ts +187 -0
  613. codna/agent-core/vendor/cline/sdk/packages/shared/src/connectors/events.ts +73 -0
  614. codna/agent-core/vendor/cline/sdk/packages/shared/src/connectors/options.ts +190 -0
  615. codna/agent-core/vendor/cline/sdk/packages/shared/src/cron/cron-spec-types.ts +104 -0
  616. codna/agent-core/vendor/cline/sdk/packages/shared/src/cron/index.ts +13 -0
  617. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/index.ts +14 -0
  618. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/sqlite-db.test.ts +155 -0
  619. codna/agent-core/vendor/cline/sdk/packages/shared/src/db/sqlite-db.ts +381 -0
  620. codna/agent-core/vendor/cline/sdk/packages/shared/src/dispose.ts +31 -0
  621. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/context.ts +92 -0
  622. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/contribution-registry.test.ts +156 -0
  623. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/contribution-registry.ts +524 -0
  624. codna/agent-core/vendor/cline/sdk/packages/shared/src/extensions/plugin.ts +1 -0
  625. codna/agent-core/vendor/cline/sdk/packages/shared/src/hooks/contracts.ts +9 -0
  626. codna/agent-core/vendor/cline/sdk/packages/shared/src/hooks/events.ts +327 -0
  627. codna/agent-core/vendor/cline/sdk/packages/shared/src/hub.ts +723 -0
  628. codna/agent-core/vendor/cline/sdk/packages/shared/src/index.browser.ts +355 -0
  629. codna/agent-core/vendor/cline/sdk/packages/shared/src/index.ts +405 -0
  630. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/ai-sdk-format.test.ts +898 -0
  631. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/ai-sdk-format.ts +389 -0
  632. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/gateway.ts +202 -0
  633. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/messages.ts +168 -0
  634. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/model-info.ts +94 -0
  635. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/reasoning-effort.ts +73 -0
  636. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/requests.ts +12 -0
  637. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/tokens.ts +12 -0
  638. codna/agent-core/vendor/cline/sdk/packages/shared/src/llms/tools.ts +96 -0
  639. codna/agent-core/vendor/cline/sdk/packages/shared/src/logging/logger.ts +45 -0
  640. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/error.ts +18 -0
  641. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/headers/utils.ts +28 -0
  642. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/json.test.ts +14 -0
  643. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/json.ts +86 -0
  644. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/shell.test.ts +46 -0
  645. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/shell.ts +32 -0
  646. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/string.ts +29 -0
  647. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/time.ts +39 -0
  648. codna/agent-core/vendor/cline/sdk/packages/shared/src/parse/zod.ts +23 -0
  649. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/cline.ts +117 -0
  650. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/format.test.ts +39 -0
  651. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/format.ts +99 -0
  652. codna/agent-core/vendor/cline/sdk/packages/shared/src/prompt/system.ts +64 -0
  653. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/artifact-store.ts +70 -0
  654. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/blob-storage.ts +416 -0
  655. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/bundle.ts +181 -0
  656. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/constants.ts +5 -0
  657. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/index.ts +9 -0
  658. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/materializer.ts +165 -0
  659. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/paths.ts +33 -0
  660. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/runtime.test.ts +102 -0
  661. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/runtime.ts +236 -0
  662. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/schema.test.ts +977 -0
  663. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/schema.ts +262 -0
  664. codna/agent-core/vendor/cline/sdk/packages/shared/src/remote-config/telemetry.ts +124 -0
  665. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/index.ts +5 -0
  666. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/runtime.ts +429 -0
  667. codna/agent-core/vendor/cline/sdk/packages/shared/src/rpc/team-progress.ts +71 -0
  668. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/build-env.test.ts +115 -0
  669. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/build-env.ts +183 -0
  670. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/cline-environment.test.ts +106 -0
  671. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/cline-environment.ts +88 -0
  672. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/hub-daemon-env.test.ts +20 -0
  673. codna/agent-core/vendor/cline/sdk/packages/shared/src/runtime/hub-daemon-env.ts +7 -0
  674. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry-config.ts +58 -0
  675. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry.test.ts +66 -0
  676. codna/agent-core/vendor/cline/sdk/packages/shared/src/services/telemetry.ts +295 -0
  677. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/hook-context.ts +45 -0
  678. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/index.ts +6 -0
  679. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/records.ts +41 -0
  680. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/runtime-config.ts +69 -0
  681. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/runtime-env.ts +8 -0
  682. codna/agent-core/vendor/cline/sdk/packages/shared/src/session/workspace.ts +45 -0
  683. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/index.ts +47 -0
  684. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/path-resolution.test.ts +63 -0
  685. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/path-resolution.ts +114 -0
  686. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.home-dir.test.ts +61 -0
  687. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.test.ts +180 -0
  688. codna/agent-core/vendor/cline/sdk/packages/shared/src/storage/paths.ts +588 -0
  689. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/index.ts +2 -0
  690. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/schema.ts +452 -0
  691. codna/agent-core/vendor/cline/sdk/packages/shared/src/team/types.ts +235 -0
  692. codna/agent-core/vendor/cline/sdk/packages/shared/src/tools/create.test.ts +201 -0
  693. codna/agent-core/vendor/cline/sdk/packages/shared/src/tools/create.ts +130 -0
  694. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/auth.ts +41 -0
  695. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/index.ts +2 -0
  696. codna/agent-core/vendor/cline/sdk/packages/shared/src/types/vcr.ts +14 -0
  697. codna/agent-core/vendor/cline/sdk/packages/shared/src/vcr.test.ts +229 -0
  698. codna/agent-core/vendor/cline/sdk/packages/shared/src/vcr.ts +900 -0
  699. codna/agent-core/vendor/cline/sdk/packages/shared/tsconfig.build.json +7 -0
  700. codna/agent-core/vendor/cline/sdk/packages/shared/tsconfig.json +9 -0
  701. codna/agent-core/vendor/cline/sdk/packages/shared/vitest.config.ts +9 -0
  702. codna/agent-core/vendor/cline/sdk/packages/tsconfig.base.json +22 -0
  703. codna/agent-core/vendor/cline/sdk/scripts/check-publish.ts +351 -0
  704. codna/agent-core/vendor/cline/sdk/scripts/ci-node-smoke.ts +155 -0
  705. codna/agent-core/vendor/cline/sdk/scripts/clean.ts +91 -0
  706. codna/agent-core/vendor/cline/sdk/scripts/release.ts +548 -0
  707. codna/agent-core/vendor/cline/sdk/scripts/run-vendored-tests.sh +44 -0
  708. codna/agent-core/vendor/cline/sdk/scripts/version.ts +120 -0
  709. codna/agent-core/vendor/cline/sdk/tsconfig.json +53 -0
  710. codna/agent_core_runtime.py +816 -0
  711. codna/cli.py +921 -0
  712. codna/cli_errors.py +50 -0
  713. codna/cline_agent.py +90 -0
  714. codna/codeunits.py +221 -0
  715. codna/codeunits_treesitter.py +148 -0
  716. codna/doctor.py +212 -0
  717. codna/doctor_output.py +61 -0
  718. codna/engine.py +149 -0
  719. codna/evasion.py +192 -0
  720. codna/evidence.py +163 -0
  721. codna/findings.py +272 -0
  722. codna/gate.py +132 -0
  723. codna/gitpush.py +57 -0
  724. codna/local_client.py +932 -0
  725. codna/local_mojo_daemon.py +568 -0
  726. codna/local_mojo_pool.py +861 -0
  727. codna/local_repository_shims.py +419 -0
  728. codna/local_runtime.py +650 -0
  729. codna/localfix.py +121 -0
  730. codna/manifest.py +164 -0
  731. codna/mcp_server.py +155 -0
  732. codna/memory.py +885 -0
  733. codna/netjail.py +68 -0
  734. codna/packaged_agent_runner.py +354 -0
  735. codna/packaged_git.py +378 -0
  736. codna/packaged_repository_advanced.py +618 -0
  737. codna/packaged_repository_backend.py +887 -0
  738. codna/patchgen.py +115 -0
  739. codna/policy.py +85 -0
  740. codna/refengine.py +132 -0
  741. codna/repo_backend.py +78 -0
  742. codna/repository_artifacts.py +291 -0
  743. codna/runtime/__init__.py +17 -0
  744. codna/runtime/config.py +394 -0
  745. codna/runtime/health.py +130 -0
  746. codna/runtime/local_stack.py +978 -0
  747. codna/runtime/ports.py +137 -0
  748. codna/runtime/processes.py +199 -0
  749. codna/runtime_config.py +94 -0
  750. codna/sandbox.py +111 -0
  751. codna/sarif.py +610 -0
  752. codna/secure.py +250 -0
  753. codna/supervisor.py +108 -0
  754. codna/worker.py +161 -0
  755. codna/worktree.py +73 -0
  756. codna/writer.py +169 -0
  757. codna-0.1.0.dist-info/METADATA +153 -0
  758. codna-0.1.0.dist-info/RECORD +761 -0
  759. codna-0.1.0.dist-info/WHEEL +5 -0
  760. codna-0.1.0.dist-info/entry_points.txt +2 -0
  761. codna-0.1.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1358 @@
1
+ import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
2
+ import os from "node:os";
3
+ import path from "node:path";
4
+ import * as LlmsModels from "@cline/llms";
5
+ import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
6
+ import { ProviderSettingsManager } from "../storage/provider-settings-manager";
7
+ import {
8
+ parseModelsFile,
9
+ readModelsFile,
10
+ registerCustomProvider,
11
+ resolveModelsRegistryPath,
12
+ } from "./local-provider-registry";
13
+ import {
14
+ addLocalProvider,
15
+ deleteLocalProvider,
16
+ getLocalProviderModels,
17
+ listLocalProviders,
18
+ normalizeOAuthProvider,
19
+ refreshProviderModelsFromSource,
20
+ resolveLocalClineAuthToken,
21
+ saveLocalProviderSettings,
22
+ updateLocalProvider,
23
+ } from "./local-provider-service";
24
+
25
+ // ---------------------------------------------------------------------------
26
+ // Helpers
27
+ // ---------------------------------------------------------------------------
28
+
29
+ function makeTempManager(): {
30
+ manager: ProviderSettingsManager;
31
+ cleanup: () => void;
32
+ } {
33
+ const dir = mkdtempSync(
34
+ path.join(os.tmpdir(), "local-provider-service-test-"),
35
+ );
36
+ const manager = new ProviderSettingsManager({
37
+ filePath: path.join(dir, "providers.json"),
38
+ });
39
+ return {
40
+ manager,
41
+ cleanup: () => rmSync(dir, { recursive: true, force: true }),
42
+ };
43
+ }
44
+
45
+ // ---------------------------------------------------------------------------
46
+ // Shared state reset
47
+ // ---------------------------------------------------------------------------
48
+
49
+ afterEach(() => {
50
+ LlmsModels.resetRegistry();
51
+ vi.restoreAllMocks();
52
+ vi.unstubAllGlobals();
53
+ });
54
+
55
+ describe("models registry parsing", () => {
56
+ it("accepts model entries that use the record key as the model id", async () => {
57
+ const parsed = parseModelsFile({
58
+ version: 1,
59
+ providers: {
60
+ "schema-provider": {
61
+ provider: {
62
+ name: "Schema Provider",
63
+ baseUrl: "https://schema.example.invalid/v1",
64
+ defaultModelId: "alpha",
65
+ protocol: "openai-responses",
66
+ },
67
+ models: {
68
+ alpha: {
69
+ name: "Alpha",
70
+ capabilities: ["reasoning"],
71
+ },
72
+ },
73
+ },
74
+ },
75
+ });
76
+
77
+ const entry = parsed.providers["schema-provider"];
78
+ expect(entry?.models?.alpha?.id).toBeUndefined();
79
+ if (!entry) {
80
+ throw new Error("expected parsed provider entry");
81
+ }
82
+
83
+ registerCustomProvider("schema-provider", entry);
84
+
85
+ await expect(
86
+ LlmsModels.getProvider("schema-provider"),
87
+ ).resolves.toMatchObject({
88
+ id: "schema-provider",
89
+ protocol: "openai-responses",
90
+ client: "openai",
91
+ });
92
+ await expect(
93
+ LlmsModels.getModelsForProvider("schema-provider"),
94
+ ).resolves.toHaveProperty("alpha");
95
+ });
96
+
97
+ it("skips malformed provider entries while preserving valid providers", () => {
98
+ expect(
99
+ parseModelsFile({
100
+ version: 1,
101
+ providers: {
102
+ valid: {
103
+ provider: {
104
+ name: "Valid",
105
+ baseUrl: "https://valid.example.invalid/v1",
106
+ },
107
+ models: {
108
+ alpha: {
109
+ name: "Alpha",
110
+ },
111
+ },
112
+ },
113
+ broken: {
114
+ provider: {
115
+ name: "Broken",
116
+ baseUrl: 42,
117
+ },
118
+ },
119
+ },
120
+ }),
121
+ ).toEqual({
122
+ version: 1,
123
+ providers: {
124
+ valid: {
125
+ provider: {
126
+ name: "Valid",
127
+ baseUrl: "https://valid.example.invalid/v1",
128
+ },
129
+ models: {
130
+ alpha: {
131
+ name: "Alpha",
132
+ },
133
+ },
134
+ },
135
+ },
136
+ });
137
+ });
138
+
139
+ it("falls back to an empty registry when the file shape is malformed", () => {
140
+ expect(
141
+ parseModelsFile({
142
+ version: 1,
143
+ providers: [],
144
+ }),
145
+ ).toEqual({ version: 1, providers: {} });
146
+ });
147
+ });
148
+
149
+ // ===========================================================================
150
+ // extractModelIdsFromPayload is tested indirectly via addLocalProvider
151
+ // ===========================================================================
152
+
153
+ describe("addLocalProvider – model ID parsing via modelsSourceUrl", () => {
154
+ let manager: ProviderSettingsManager;
155
+ let cleanup: () => void;
156
+
157
+ beforeEach(() => {
158
+ ({ manager, cleanup } = makeTempManager());
159
+ });
160
+
161
+ afterEach(() => cleanup());
162
+
163
+ it("parses a flat array payload from modelsSourceUrl", async () => {
164
+ const mockFetch = vi.fn().mockResolvedValue({
165
+ ok: true,
166
+ json: async () => ["alpha", "beta", "gamma"],
167
+ });
168
+ vi.stubGlobal("fetch", mockFetch);
169
+
170
+ const result = await addLocalProvider(manager, {
171
+ providerId: "flat-array-provider",
172
+ name: "Flat Array",
173
+ baseUrl: "https://example.invalid/v1",
174
+ models: [],
175
+ modelsSourceUrl: "https://example.invalid/models",
176
+ });
177
+
178
+ expect(result.modelsCount).toBe(3);
179
+ const { models } = await getLocalProviderModels("flat-array-provider");
180
+ expect(models.map((m) => m.id).sort()).toEqual(["alpha", "beta", "gamma"]);
181
+ });
182
+
183
+ it("parses a { data: [...] } payload from modelsSourceUrl", async () => {
184
+ vi.stubGlobal(
185
+ "fetch",
186
+ vi.fn().mockResolvedValue({
187
+ ok: true,
188
+ json: async () => ({ data: [{ id: "model-x" }, { id: "model-y" }] }),
189
+ }),
190
+ );
191
+
192
+ await addLocalProvider(manager, {
193
+ providerId: "data-array-provider",
194
+ name: "Data Array",
195
+ baseUrl: "https://example.invalid/v1",
196
+ models: [],
197
+ modelsSourceUrl: "https://example.invalid/models",
198
+ });
199
+
200
+ const { models } = await getLocalProviderModels("data-array-provider");
201
+ expect(models.map((m) => m.id).sort()).toEqual(["model-x", "model-y"]);
202
+ });
203
+
204
+ it("parses Ollama-style { models: [{ name }] } payloads", async () => {
205
+ vi.stubGlobal(
206
+ "fetch",
207
+ vi.fn().mockResolvedValue({
208
+ ok: true,
209
+ json: async () => ({
210
+ models: [{ name: "llama3.1" }, { model: "qwen3:8b" }],
211
+ }),
212
+ }),
213
+ );
214
+
215
+ await addLocalProvider(manager, {
216
+ providerId: "ollama-shaped-provider",
217
+ name: "Ollama Shaped",
218
+ baseUrl: "https://example.invalid/v1",
219
+ models: [],
220
+ modelsSourceUrl: "https://example.invalid/api/tags",
221
+ });
222
+
223
+ const { models } = await getLocalProviderModels("ollama-shaped-provider");
224
+ expect(models.map((m) => m.id).sort()).toEqual(["llama3.1", "qwen3:8b"]);
225
+ });
226
+
227
+ it("parses a { models: { id1: {}, id2: {} } } object-keyed payload", async () => {
228
+ vi.stubGlobal(
229
+ "fetch",
230
+ vi.fn().mockResolvedValue({
231
+ ok: true,
232
+ json: async () => ({ models: { "key-a": {}, "key-b": {} } }),
233
+ }),
234
+ );
235
+
236
+ await addLocalProvider(manager, {
237
+ providerId: "obj-keys-provider",
238
+ name: "Object Keys",
239
+ baseUrl: "https://example.invalid/v1",
240
+ models: [],
241
+ modelsSourceUrl: "https://example.invalid/models",
242
+ });
243
+
244
+ const { models } = await getLocalProviderModels("obj-keys-provider");
245
+ expect(models.map((m) => m.id).sort()).toEqual(["key-a", "key-b"]);
246
+ });
247
+
248
+ it("parses a { providers: { <id>: { models: [...] } } } nested payload", async () => {
249
+ vi.stubGlobal(
250
+ "fetch",
251
+ vi.fn().mockResolvedValue({
252
+ ok: true,
253
+ json: async () => ({
254
+ providers: {
255
+ "nested-provider": { models: ["nested-a", "nested-b"] },
256
+ },
257
+ }),
258
+ }),
259
+ );
260
+
261
+ await addLocalProvider(manager, {
262
+ providerId: "nested-provider",
263
+ name: "Nested Provider",
264
+ baseUrl: "https://example.invalid/v1",
265
+ models: [],
266
+ modelsSourceUrl: "https://example.invalid/models",
267
+ });
268
+
269
+ const { models } = await getLocalProviderModels("nested-provider");
270
+ expect(models.map((m) => m.id).sort()).toEqual(["nested-a", "nested-b"]);
271
+ });
272
+
273
+ it("merges manually specified models with fetched models and deduplicates", async () => {
274
+ vi.stubGlobal(
275
+ "fetch",
276
+ vi.fn().mockResolvedValue({
277
+ ok: true,
278
+ json: async () => ["fetched-1", "fetched-2", "manual-1"],
279
+ }),
280
+ );
281
+
282
+ const result = await addLocalProvider(manager, {
283
+ providerId: "merged-provider",
284
+ name: "Merged",
285
+ baseUrl: "https://example.invalid/v1",
286
+ models: ["manual-1", "manual-2"],
287
+ modelsSourceUrl: "https://example.invalid/models",
288
+ });
289
+
290
+ // manual-1, manual-2, fetched-1, fetched-2, manual-1 → Set → 4
291
+ expect(result.modelsCount).toBe(4);
292
+ const { models } = await getLocalProviderModels("merged-provider");
293
+ const ids = models.map((m) => m.id).sort();
294
+ expect(ids).toEqual(["fetched-1", "fetched-2", "manual-1", "manual-2"]);
295
+ });
296
+
297
+ it("throws when fetch returns non-OK status", async () => {
298
+ vi.stubGlobal(
299
+ "fetch",
300
+ vi.fn().mockResolvedValue({
301
+ ok: false,
302
+ status: 404,
303
+ }),
304
+ );
305
+
306
+ await expect(
307
+ addLocalProvider(manager, {
308
+ providerId: "fail-fetch-provider",
309
+ name: "Fail",
310
+ baseUrl: "https://example.invalid/v1",
311
+ models: [],
312
+ modelsSourceUrl: "https://example.invalid/models",
313
+ }),
314
+ ).rejects.toThrow("HTTP 404");
315
+ });
316
+
317
+ it("ignores empty string entries in array payloads", async () => {
318
+ vi.stubGlobal(
319
+ "fetch",
320
+ vi.fn().mockResolvedValue({
321
+ ok: true,
322
+ json: async () => ["good-model", "", " "],
323
+ }),
324
+ );
325
+
326
+ await addLocalProvider(manager, {
327
+ providerId: "empty-strings-provider",
328
+ name: "Empty Strings",
329
+ baseUrl: "https://example.invalid/v1",
330
+ models: [],
331
+ modelsSourceUrl: "https://example.invalid/models",
332
+ });
333
+
334
+ const { models } = await getLocalProviderModels("empty-strings-provider");
335
+ expect(models.map((m) => m.id)).toEqual(["good-model"]);
336
+ });
337
+
338
+ it("ignores non-array, non-object payload shapes and falls back to manual models", async () => {
339
+ vi.stubGlobal(
340
+ "fetch",
341
+ vi.fn().mockResolvedValue({
342
+ ok: true,
343
+ json: async () => "just a string",
344
+ }),
345
+ );
346
+
347
+ await addLocalProvider(manager, {
348
+ providerId: "fallback-provider",
349
+ name: "Fallback",
350
+ baseUrl: "https://example.invalid/v1",
351
+ models: ["fallback-model"],
352
+ modelsSourceUrl: "https://example.invalid/models",
353
+ });
354
+
355
+ const { models } = await getLocalProviderModels("fallback-provider");
356
+ expect(models.map((m) => m.id)).toEqual(["fallback-model"]);
357
+ });
358
+ });
359
+
360
+ // ===========================================================================
361
+ // addLocalProvider – validation guards
362
+ // ===========================================================================
363
+
364
+ describe("addLocalProvider – validation", () => {
365
+ let manager: ProviderSettingsManager;
366
+ let cleanup: () => void;
367
+
368
+ beforeEach(() => {
369
+ ({ manager, cleanup } = makeTempManager());
370
+ });
371
+
372
+ afterEach(() => cleanup());
373
+
374
+ it("throws when providerId is empty", async () => {
375
+ await expect(
376
+ addLocalProvider(manager, {
377
+ providerId: " ",
378
+ name: "X",
379
+ baseUrl: "https://example.invalid",
380
+ models: ["m"],
381
+ }),
382
+ ).rejects.toThrow("providerId is required");
383
+ });
384
+
385
+ it("throws when name is empty", async () => {
386
+ await expect(
387
+ addLocalProvider(manager, {
388
+ providerId: "my-provider",
389
+ name: " ",
390
+ baseUrl: "https://example.invalid",
391
+ models: ["m"],
392
+ }),
393
+ ).rejects.toThrow("name is required");
394
+ });
395
+
396
+ it("throws when baseUrl is empty and apiKey is provided", async () => {
397
+ await expect(
398
+ addLocalProvider(manager, {
399
+ providerId: "my-provider2",
400
+ name: "My Provider",
401
+ baseUrl: " ",
402
+ apiKey: "present-key",
403
+ models: ["m"],
404
+ }),
405
+ ).rejects.toThrow("baseUrl is required");
406
+ });
407
+
408
+ it("throws when no models are provided and no modelsSourceUrl", async () => {
409
+ await expect(
410
+ addLocalProvider(manager, {
411
+ providerId: "no-models-provider",
412
+ name: "No Models",
413
+ baseUrl: "https://example.invalid",
414
+ models: [],
415
+ }),
416
+ ).rejects.toThrow("at least one model is required");
417
+ });
418
+
419
+ it("throws when provider already exists", async () => {
420
+ // Register a provider first
421
+ await addLocalProvider(manager, {
422
+ providerId: "duplicate-provider",
423
+ name: "First",
424
+ baseUrl: "https://example.invalid/v1",
425
+ models: ["m1"],
426
+ });
427
+
428
+ await expect(
429
+ addLocalProvider(manager, {
430
+ providerId: "duplicate-provider",
431
+ name: "Second",
432
+ baseUrl: "https://example.invalid/v1",
433
+ models: ["m2"],
434
+ }),
435
+ ).rejects.toThrow('"duplicate-provider" already exists');
436
+ });
437
+ });
438
+
439
+ // ===========================================================================
440
+ // addLocalProvider – delete compatibility path
441
+ // ===========================================================================
442
+
443
+ describe("addLocalProvider – delete compatibility", () => {
444
+ let manager: ProviderSettingsManager;
445
+ let cleanup: () => void;
446
+
447
+ beforeEach(async () => {
448
+ ({ manager, cleanup } = makeTempManager());
449
+ await addLocalProvider(manager, {
450
+ providerId: "legacy-delete-provider",
451
+ name: "Legacy Delete Provider",
452
+ baseUrl: "https://example.invalid/v1",
453
+ models: ["legacy-model"],
454
+ });
455
+ manager.saveProviderSettings(
456
+ {
457
+ provider: "legacy-delete-provider",
458
+ baseUrl: "https://example.invalid/v1",
459
+ model: "legacy-model",
460
+ },
461
+ { setLastUsed: true },
462
+ );
463
+ });
464
+
465
+ afterEach(() => cleanup());
466
+
467
+ it("treats empty baseUrl and apiKey as a delete request for existing provider", async () => {
468
+ const result = await addLocalProvider(manager, {
469
+ providerId: "legacy-delete-provider",
470
+ name: "Ignored",
471
+ baseUrl: " ",
472
+ apiKey: " ",
473
+ models: [],
474
+ });
475
+
476
+ expect(result.providerId).toBe("legacy-delete-provider");
477
+ expect(result.modelsCount).toBe(0);
478
+ expect(LlmsModels.hasProvider("legacy-delete-provider")).toBe(false);
479
+ expect(
480
+ manager.getProviderSettings("legacy-delete-provider"),
481
+ ).toBeUndefined();
482
+ expect(manager.getLastUsedProviderSettings()).toBeUndefined();
483
+ });
484
+
485
+ it("is a no-op delete when provider is already missing", async () => {
486
+ await deleteLocalProvider(manager, {
487
+ providerId: "legacy-delete-provider",
488
+ });
489
+
490
+ await expect(
491
+ addLocalProvider(manager, {
492
+ providerId: "legacy-delete-provider",
493
+ name: "Ignored",
494
+ baseUrl: " ",
495
+ models: [],
496
+ }),
497
+ ).resolves.toMatchObject({
498
+ providerId: "legacy-delete-provider",
499
+ modelsCount: 0,
500
+ });
501
+ });
502
+ });
503
+
504
+ // ===========================================================================
505
+ // addLocalProvider – defaultModelId selection
506
+ // ===========================================================================
507
+
508
+ describe("addLocalProvider – defaultModelId selection", () => {
509
+ let manager: ProviderSettingsManager;
510
+ let cleanup: () => void;
511
+
512
+ beforeEach(() => {
513
+ ({ manager, cleanup } = makeTempManager());
514
+ });
515
+
516
+ afterEach(() => cleanup());
517
+
518
+ it("uses explicit defaultModelId when it is in the model list", async () => {
519
+ await addLocalProvider(manager, {
520
+ providerId: "default-model-provider",
521
+ name: "Test",
522
+ baseUrl: "https://example.invalid/v1",
523
+ models: ["model-a", "model-b", "model-c"],
524
+ defaultModelId: "model-b",
525
+ });
526
+
527
+ const settings = manager.getProviderSettings("default-model-provider");
528
+ expect(settings?.model).toBe("model-b");
529
+ });
530
+
531
+ it("falls back to the first model when defaultModelId is not in the list", async () => {
532
+ await addLocalProvider(manager, {
533
+ providerId: "fallback-default-provider",
534
+ name: "Test",
535
+ baseUrl: "https://example.invalid/v1",
536
+ models: ["model-a", "model-b"],
537
+ defaultModelId: "not-in-list",
538
+ });
539
+
540
+ const settings = manager.getProviderSettings("fallback-default-provider");
541
+ expect(settings?.model).toBe("model-a");
542
+ });
543
+ });
544
+
545
+ // ===========================================================================
546
+ // addLocalProvider – capabilities → vision / reasoning flags
547
+ // ===========================================================================
548
+
549
+ describe("addLocalProvider – capabilities", () => {
550
+ let manager: ProviderSettingsManager;
551
+ let cleanup: () => void;
552
+
553
+ beforeEach(() => {
554
+ ({ manager, cleanup } = makeTempManager());
555
+ });
556
+
557
+ afterEach(() => cleanup());
558
+
559
+ it("sets supportsVision and supportsAttachments when capability is 'vision'", async () => {
560
+ await addLocalProvider(manager, {
561
+ providerId: "vision-provider",
562
+ name: "Vision",
563
+ baseUrl: "https://example.invalid/v1",
564
+ models: ["vis-model"],
565
+ capabilities: ["vision"],
566
+ });
567
+
568
+ const { models } = await getLocalProviderModels("vision-provider");
569
+ expect(models).toHaveLength(1);
570
+ expect(models[0].supportsVision).toBe(true);
571
+ expect(models[0].supportsAttachments).toBe(true);
572
+ });
573
+
574
+ it("sets supportsReasoning when capability is 'reasoning'", async () => {
575
+ await addLocalProvider(manager, {
576
+ providerId: "reasoning-provider",
577
+ name: "Reasoning",
578
+ baseUrl: "https://example.invalid/v1",
579
+ models: ["r-model"],
580
+ capabilities: ["reasoning"],
581
+ });
582
+
583
+ const { models } = await getLocalProviderModels("reasoning-provider");
584
+ expect(models[0].supportsReasoning).toBe(true);
585
+ expect(models[0].supportsVision).toBeFalsy();
586
+ });
587
+
588
+ it("does not set vision/reasoning flags when capabilities are absent", async () => {
589
+ await addLocalProvider(manager, {
590
+ providerId: "plain-provider",
591
+ name: "Plain",
592
+ baseUrl: "https://example.invalid/v1",
593
+ models: ["plain-model"],
594
+ });
595
+
596
+ const { models } = await getLocalProviderModels("plain-provider");
597
+ expect(models[0].supportsVision).toBeFalsy();
598
+ expect(models[0].supportsReasoning).toBeFalsy();
599
+ });
600
+
601
+ it("merges LiteLLM private models into the provider model listing when auth is configured", async () => {
602
+ manager.saveProviderSettings(
603
+ {
604
+ provider: "litellm",
605
+ apiKey: "test-key-catalog",
606
+ baseUrl: "http://localhost:4010",
607
+ model: "gpt-4o",
608
+ },
609
+ { setLastUsed: false },
610
+ );
611
+ vi.stubGlobal(
612
+ "fetch",
613
+ vi.fn().mockResolvedValue({
614
+ ok: true,
615
+ json: async () => ({
616
+ data: [
617
+ {
618
+ model_name: "private-proxy-model",
619
+ litellm_params: { model: "openai/gpt-4o-mini" },
620
+ model_info: {
621
+ supports_vision: true,
622
+ supports_reasoning: true,
623
+ },
624
+ },
625
+ ],
626
+ }),
627
+ }),
628
+ );
629
+
630
+ const { models } = await getLocalProviderModels(
631
+ "litellm",
632
+ manager.getProviderConfig("litellm"),
633
+ );
634
+
635
+ expect(models.map((model) => model.id)).toContain("private-proxy-model");
636
+ expect(models.map((model) => model.id)).toContain("openai/gpt-4o-mini");
637
+ expect(
638
+ models.find((model) => model.id === "private-proxy-model"),
639
+ ).toMatchObject({
640
+ supportsVision: true,
641
+ supportsReasoning: true,
642
+ });
643
+ });
644
+ });
645
+
646
+ // ===========================================================================
647
+ // models.json – built-in provider model overlays
648
+ // ===========================================================================
649
+
650
+ describe("models.json model overlays", () => {
651
+ it("loads model-only entries for built-in providers", async () => {
652
+ const dir = mkdtempSync(
653
+ path.join(os.tmpdir(), "local-provider-overlay-test-"),
654
+ );
655
+ try {
656
+ const settingsDir = path.join(dir, "settings");
657
+ mkdirSync(settingsDir, { recursive: true });
658
+ writeFileSync(
659
+ path.join(settingsDir, "models.json"),
660
+ `${JSON.stringify(
661
+ {
662
+ version: 1,
663
+ providers: {
664
+ cline: {
665
+ models: {
666
+ "openai/gpt-5.5": {
667
+ id: "openai/gpt-5.5",
668
+ name: "OpenAI GPT-5.5",
669
+ },
670
+ },
671
+ },
672
+ },
673
+ },
674
+ null,
675
+ 2,
676
+ )}\n`,
677
+ );
678
+
679
+ const manager = new ProviderSettingsManager({
680
+ filePath: path.join(settingsDir, "providers.json"),
681
+ });
682
+
683
+ const provider = await LlmsModels.getProvider("cline");
684
+ expect(provider).toMatchObject({
685
+ id: "cline",
686
+ baseUrl: "https://api.cline.bot/api/v1",
687
+ defaultModelId: "anthropic/claude-sonnet-4.6",
688
+ });
689
+
690
+ const { models } = await getLocalProviderModels("cline");
691
+ expect(
692
+ models.find((model) => model.id === "openai/gpt-5.5"),
693
+ ).toMatchObject({
694
+ id: "openai/gpt-5.5",
695
+ name: "OpenAI GPT-5.5",
696
+ });
697
+ expect(manager.getFilePath()).toBe(
698
+ path.join(settingsDir, "providers.json"),
699
+ );
700
+ } finally {
701
+ rmSync(dir, { recursive: true, force: true });
702
+ }
703
+ });
704
+ });
705
+
706
+ // ===========================================================================
707
+ // saveLocalProviderSettings
708
+ // ===========================================================================
709
+
710
+ describe("saveLocalProviderSettings", () => {
711
+ let manager: ProviderSettingsManager;
712
+ let cleanup: () => void;
713
+
714
+ beforeEach(async () => {
715
+ ({ manager, cleanup } = makeTempManager());
716
+ // Seed a provider so there is something to operate on
717
+ await addLocalProvider(manager, {
718
+ providerId: "test-provider",
719
+ name: "Test",
720
+ baseUrl: "https://example.invalid/v1",
721
+ models: ["m1"],
722
+ });
723
+ });
724
+
725
+ afterEach(() => cleanup());
726
+
727
+ it("disabling a provider removes it from settings", () => {
728
+ const result = saveLocalProviderSettings(manager, {
729
+ providerId: "test-provider",
730
+ enabled: false,
731
+ });
732
+
733
+ expect(result.enabled).toBe(false);
734
+ expect(manager.getProviderSettings("test-provider")).toBeUndefined();
735
+ });
736
+
737
+ it("updates apiKey", () => {
738
+ saveLocalProviderSettings(manager, {
739
+ providerId: "test-provider",
740
+ enabled: true,
741
+ apiKey: "new-key",
742
+ });
743
+
744
+ expect(manager.getProviderSettings("test-provider")?.apiKey).toBe(
745
+ "new-key",
746
+ );
747
+ });
748
+
749
+ it("clears apiKey when empty string is provided", () => {
750
+ // First set a key
751
+ saveLocalProviderSettings(manager, {
752
+ providerId: "test-provider",
753
+ enabled: true,
754
+ apiKey: "some-key",
755
+ });
756
+ // Then clear it
757
+ saveLocalProviderSettings(manager, {
758
+ providerId: "test-provider",
759
+ enabled: true,
760
+ apiKey: "",
761
+ });
762
+
763
+ const settings = manager.getProviderSettings("test-provider");
764
+ expect(settings).not.toHaveProperty("apiKey");
765
+ });
766
+
767
+ it("merges auth object rather than replacing it", () => {
768
+ saveLocalProviderSettings(manager, {
769
+ providerId: "test-provider",
770
+ enabled: true,
771
+ auth: { accessToken: "tok1" },
772
+ });
773
+ saveLocalProviderSettings(manager, {
774
+ providerId: "test-provider",
775
+ enabled: true,
776
+ auth: { refreshToken: "ref1" },
777
+ });
778
+
779
+ const settings = manager.getProviderSettings("test-provider") as Record<
780
+ string,
781
+ unknown
782
+ >;
783
+ const auth = settings?.auth as Record<string, unknown>;
784
+ expect(auth?.accessToken).toBe("tok1");
785
+ expect(auth?.refreshToken).toBe("ref1");
786
+ });
787
+
788
+ it("merges and clears nested provider config fields", () => {
789
+ saveLocalProviderSettings(manager, {
790
+ providerId: "test-provider",
791
+ enabled: true,
792
+ gcp: { projectId: "project-a", region: "us-central1" },
793
+ });
794
+ saveLocalProviderSettings(manager, {
795
+ providerId: "test-provider",
796
+ enabled: true,
797
+ gcp: { projectId: "" },
798
+ });
799
+
800
+ const settings = manager.getProviderSettings("test-provider");
801
+ expect(settings?.gcp?.projectId).toBeUndefined();
802
+ expect(settings?.gcp?.region).toBe("us-central1");
803
+ });
804
+
805
+ it("passes through scalar fields like maxTokens and timeout", () => {
806
+ saveLocalProviderSettings(manager, {
807
+ providerId: "test-provider",
808
+ enabled: true,
809
+ maxTokens: 4096,
810
+ timeout: 30_000,
811
+ });
812
+
813
+ const settings = manager.getProviderSettings("test-provider") as Record<
814
+ string,
815
+ unknown
816
+ >;
817
+ expect(settings?.maxTokens).toBe(4096);
818
+ expect(settings?.timeout).toBe(30_000);
819
+ });
820
+
821
+ it("disabling a last-used provider also clears lastUsedProvider", async () => {
822
+ // Set test-provider as last used
823
+ manager.saveProviderSettings(
824
+ { provider: "test-provider", model: "m1" },
825
+ { setLastUsed: true },
826
+ );
827
+ expect(manager.getLastUsedProviderSettings()?.provider).toBe(
828
+ "test-provider",
829
+ );
830
+
831
+ saveLocalProviderSettings(manager, {
832
+ providerId: "test-provider",
833
+ enabled: false,
834
+ });
835
+
836
+ expect(manager.getLastUsedProviderSettings()).toBeUndefined();
837
+ });
838
+ });
839
+
840
+ // ===========================================================================
841
+ // updateLocalProvider
842
+ // ===========================================================================
843
+
844
+ describe("updateLocalProvider", () => {
845
+ let manager: ProviderSettingsManager;
846
+ let cleanup: () => void;
847
+
848
+ beforeEach(async () => {
849
+ ({ manager, cleanup } = makeTempManager());
850
+ await addLocalProvider(manager, {
851
+ providerId: "editable-provider",
852
+ name: "Editable Provider",
853
+ baseUrl: "https://example.invalid/v1",
854
+ apiKey: "seed-key",
855
+ models: ["model-a", "model-b"],
856
+ defaultModelId: "model-a",
857
+ });
858
+ });
859
+
860
+ afterEach(() => cleanup());
861
+
862
+ it("updates provider metadata and model registry", async () => {
863
+ await updateLocalProvider(manager, {
864
+ providerId: "editable-provider",
865
+ name: "Renamed Provider",
866
+ baseUrl: "https://api.example.invalid/v2",
867
+ models: ["model-c", "model-d"],
868
+ defaultModelId: "model-d",
869
+ capabilities: ["vision", "reasoning"],
870
+ });
871
+
872
+ const provider = await LlmsModels.getProvider("editable-provider");
873
+ expect(provider?.name).toBe("Renamed Provider");
874
+ expect(provider?.baseUrl).toBe("https://api.example.invalid/v2");
875
+ expect(provider?.defaultModelId).toBe("model-d");
876
+
877
+ const { models } = await getLocalProviderModels("editable-provider");
878
+ expect(models.map((model) => model.id).sort()).toEqual([
879
+ "model-c",
880
+ "model-d",
881
+ ]);
882
+ expect(models.find((model) => model.id === "model-c")?.supportsVision).toBe(
883
+ true,
884
+ );
885
+ expect(
886
+ models.find((model) => model.id === "model-c")?.supportsReasoning,
887
+ ).toBe(true);
888
+ });
889
+
890
+ it("updates provider settings and can clear optional fields", async () => {
891
+ await updateLocalProvider(manager, {
892
+ providerId: "editable-provider",
893
+ baseUrl: "https://api.example.invalid/v3",
894
+ apiKey: "",
895
+ headers: null,
896
+ timeoutMs: null,
897
+ });
898
+
899
+ const settings = manager.getProviderSettings("editable-provider");
900
+ expect(settings?.baseUrl).toBe("https://api.example.invalid/v3");
901
+ expect(settings).not.toHaveProperty("apiKey");
902
+ expect(settings).not.toHaveProperty("headers");
903
+ expect(settings).not.toHaveProperty("timeout");
904
+ });
905
+
906
+ it("clears capabilities with null and does not treat [] as a clear sentinel", async () => {
907
+ await updateLocalProvider(manager, {
908
+ providerId: "editable-provider",
909
+ capabilities: ["vision"],
910
+ });
911
+ const modelsPath = resolveModelsRegistryPath(manager);
912
+ let modelsState = await readModelsFile(modelsPath);
913
+ expect(
914
+ modelsState.providers["editable-provider"]?.provider?.capabilities,
915
+ ).toEqual(["vision"]);
916
+
917
+ await updateLocalProvider(manager, {
918
+ providerId: "editable-provider",
919
+ capabilities: [],
920
+ });
921
+ modelsState = await readModelsFile(modelsPath);
922
+ expect(
923
+ modelsState.providers["editable-provider"]?.provider?.capabilities,
924
+ ).toEqual([]);
925
+
926
+ await updateLocalProvider(manager, {
927
+ providerId: "editable-provider",
928
+ capabilities: null,
929
+ });
930
+ modelsState = await readModelsFile(modelsPath);
931
+ expect(
932
+ modelsState.providers["editable-provider"]?.provider?.capabilities,
933
+ ).toBeUndefined();
934
+ });
935
+
936
+ it("allows modelsSourceUrl: null to clear URL while preserving existing models", async () => {
937
+ const fetchMock = vi.fn().mockResolvedValue({
938
+ ok: true,
939
+ json: async () => ["remote-a", "remote-b"],
940
+ });
941
+ vi.stubGlobal("fetch", fetchMock);
942
+
943
+ await updateLocalProvider(manager, {
944
+ providerId: "editable-provider",
945
+ models: ["model-a", "model-b"],
946
+ modelsSourceUrl: "https://example.invalid/models",
947
+ });
948
+
949
+ await updateLocalProvider(manager, {
950
+ providerId: "editable-provider",
951
+ modelsSourceUrl: null,
952
+ });
953
+
954
+ const modelsState = await readModelsFile(
955
+ resolveModelsRegistryPath(manager),
956
+ );
957
+ expect(
958
+ modelsState.providers["editable-provider"]?.provider?.modelsSourceUrl,
959
+ ).toBeUndefined();
960
+
961
+ const { models } = await getLocalProviderModels("editable-provider");
962
+ expect(models.map((model) => model.id).sort()).toEqual([
963
+ "model-a",
964
+ "model-b",
965
+ "remote-a",
966
+ "remote-b",
967
+ ]);
968
+ expect(fetchMock).toHaveBeenCalledTimes(1);
969
+ });
970
+
971
+ it("updates a provider that exists in settings but not models registry", async () => {
972
+ manager.saveProviderSettings(
973
+ {
974
+ provider: "settings-only-provider",
975
+ baseUrl: "https://settings.example.invalid/v1",
976
+ model: "saved-model",
977
+ },
978
+ { setLastUsed: false },
979
+ );
980
+
981
+ const result = await updateLocalProvider(manager, {
982
+ providerId: "settings-only-provider",
983
+ models: ["new-model-a", "new-model-b"],
984
+ defaultModelId: "new-model-b",
985
+ });
986
+
987
+ expect(result.modelsCount).toBe(2);
988
+ const provider = await LlmsModels.getProvider("settings-only-provider");
989
+ expect(provider?.name).toBe("Settings Only Provider");
990
+ expect(provider?.baseUrl).toBe("https://settings.example.invalid/v1");
991
+ expect(provider?.defaultModelId).toBe("new-model-b");
992
+
993
+ const settings = manager.getProviderSettings("settings-only-provider");
994
+ expect(settings?.baseUrl).toBe("https://settings.example.invalid/v1");
995
+ expect(settings?.model).toBe("new-model-b");
996
+
997
+ const { models } = await getLocalProviderModels("settings-only-provider");
998
+ expect(models.map((model) => model.id).sort()).toEqual([
999
+ "new-model-a",
1000
+ "new-model-b",
1001
+ ]);
1002
+ });
1003
+
1004
+ it("throws when updating a provider that does not exist in custom registry", async () => {
1005
+ await expect(
1006
+ updateLocalProvider(manager, {
1007
+ providerId: "missing-provider",
1008
+ name: "Nope",
1009
+ }),
1010
+ ).rejects.toThrow('"missing-provider" does not exist');
1011
+ });
1012
+ });
1013
+
1014
+ // ===========================================================================
1015
+ // deleteLocalProvider
1016
+ // ===========================================================================
1017
+
1018
+ describe("deleteLocalProvider", () => {
1019
+ let manager: ProviderSettingsManager;
1020
+ let cleanup: () => void;
1021
+
1022
+ beforeEach(async () => {
1023
+ ({ manager, cleanup } = makeTempManager());
1024
+ await addLocalProvider(manager, {
1025
+ providerId: "delete-me-provider",
1026
+ name: "Delete Me",
1027
+ baseUrl: "https://example.invalid/v1",
1028
+ models: ["delete-model"],
1029
+ });
1030
+ manager.saveProviderSettings(
1031
+ {
1032
+ provider: "delete-me-provider",
1033
+ baseUrl: "https://example.invalid/v1",
1034
+ model: "delete-model",
1035
+ },
1036
+ { setLastUsed: true },
1037
+ );
1038
+ });
1039
+
1040
+ afterEach(() => cleanup());
1041
+
1042
+ it("removes provider from registry and local settings", async () => {
1043
+ await deleteLocalProvider(manager, {
1044
+ providerId: "delete-me-provider",
1045
+ });
1046
+
1047
+ expect(LlmsModels.hasProvider("delete-me-provider")).toBe(false);
1048
+ expect(manager.getProviderSettings("delete-me-provider")).toBeUndefined();
1049
+ expect(manager.getLastUsedProviderSettings()).toBeUndefined();
1050
+ });
1051
+
1052
+ it("throws when deleting an unknown provider", async () => {
1053
+ await expect(
1054
+ deleteLocalProvider(manager, { providerId: "missing-provider" }),
1055
+ ).rejects.toThrow('"missing-provider" does not exist');
1056
+ });
1057
+ });
1058
+
1059
+ // ===========================================================================
1060
+ // listLocalProviders
1061
+ // ===========================================================================
1062
+
1063
+ describe("listLocalProviders", () => {
1064
+ let manager: ProviderSettingsManager;
1065
+ let cleanup: () => void;
1066
+
1067
+ beforeEach(() => {
1068
+ ({ manager, cleanup } = makeTempManager());
1069
+ });
1070
+
1071
+ afterEach(() => cleanup());
1072
+
1073
+ it("includes all registered providers", async () => {
1074
+ await addLocalProvider(manager, {
1075
+ providerId: "list-provider-a",
1076
+ name: "Provider A",
1077
+ baseUrl: "https://example.invalid/a",
1078
+ models: ["ma1"],
1079
+ });
1080
+ await addLocalProvider(manager, {
1081
+ providerId: "list-provider-b",
1082
+ name: "Provider B",
1083
+ baseUrl: "https://example.invalid/b",
1084
+ models: ["mb1"],
1085
+ });
1086
+
1087
+ const { providers } = await listLocalProviders(manager);
1088
+ const ids = providers.map((p) => p.id);
1089
+ expect(ids).toContain("list-provider-a");
1090
+ expect(ids).toContain("list-provider-b");
1091
+ });
1092
+
1093
+ it("marks enabled providers correctly", async () => {
1094
+ await addLocalProvider(manager, {
1095
+ providerId: "enabled-check-provider",
1096
+ name: "Enabled Check",
1097
+ baseUrl: "https://example.invalid/v1",
1098
+ models: ["m1"],
1099
+ });
1100
+
1101
+ const { providers } = await listLocalProviders(manager);
1102
+ const p = providers.find((x) => x.id === "enabled-check-provider");
1103
+ expect(p?.enabled).toBe(true);
1104
+ });
1105
+
1106
+ it("exposes model count", async () => {
1107
+ await addLocalProvider(manager, {
1108
+ providerId: "count-provider",
1109
+ name: "Count",
1110
+ baseUrl: "https://example.invalid/v1",
1111
+ models: ["x", "y", "z"],
1112
+ });
1113
+
1114
+ const { providers } = await listLocalProviders(manager);
1115
+ const p = providers.find((x) => x.id === "count-provider");
1116
+ expect(p?.models).toBe(3);
1117
+ });
1118
+
1119
+ it("generates a stable color and letter for each provider", async () => {
1120
+ await addLocalProvider(manager, {
1121
+ providerId: "color-letter-provider",
1122
+ name: "Color Letter",
1123
+ baseUrl: "https://example.invalid/v1",
1124
+ models: ["m1"],
1125
+ });
1126
+
1127
+ const { providers } = await listLocalProviders(manager);
1128
+ const p = providers.find((x) => x.id === "color-letter-provider");
1129
+ expect(p?.color).toMatch(/^#[0-9a-f]{6}$/i);
1130
+ expect(p?.letter).toBeTruthy();
1131
+ });
1132
+
1133
+ it("includes built-in model lists in the provider catalog path", async () => {
1134
+ manager.saveProviderSettings(
1135
+ {
1136
+ provider: "openai-native",
1137
+ apiKey: "test-key",
1138
+ baseUrl: "https://api.openai.com/v1",
1139
+ model: "gpt-5.3-codex",
1140
+ },
1141
+ { setLastUsed: false },
1142
+ );
1143
+
1144
+ const { providers } = await listLocalProviders(manager);
1145
+ const openai = providers.find(
1146
+ (provider) => provider.id === "openai-native",
1147
+ );
1148
+
1149
+ expect(openai?.modelList?.length).toBeGreaterThan(0);
1150
+ expect(
1151
+ openai?.modelList?.some((model) => model.id === "gpt-5.3-codex"),
1152
+ ).toBe(true);
1153
+ });
1154
+
1155
+ it("exposes provider-specific config fields for Vertex", async () => {
1156
+ manager.saveProviderSettings(
1157
+ {
1158
+ provider: "vertex",
1159
+ gcp: { projectId: "gcp-project", region: "us-west1" },
1160
+ model: "claude-sonnet-4-6@default",
1161
+ },
1162
+ { setLastUsed: false },
1163
+ );
1164
+
1165
+ const { providers } = await listLocalProviders(manager);
1166
+ const vertex = providers.find((provider) => provider.id === "vertex");
1167
+
1168
+ expect(vertex?.configFields?.map((field) => field.path)).toEqual([
1169
+ "gcp.projectId",
1170
+ "gcp.region",
1171
+ "apiKey",
1172
+ ]);
1173
+ expect(vertex?.configValues?.["gcp.projectId"]).toBe("gcp-project");
1174
+ expect(vertex?.configValues?.["gcp.region"]).toBe("us-west1");
1175
+ expect(
1176
+ vertex?.configFields?.some((field) => field.path === "baseUrl"),
1177
+ ).toBe(false);
1178
+ });
1179
+
1180
+ it("uses the same built-in model list for cline as openrouter", async () => {
1181
+ manager.saveProviderSettings(
1182
+ {
1183
+ provider: "cline",
1184
+ apiKey: "test-key",
1185
+ baseUrl: "https://api.cline.bot/api/v1",
1186
+ model: "anthropic/claude-sonnet-4.6",
1187
+ },
1188
+ { setLastUsed: false },
1189
+ );
1190
+
1191
+ const { providers } = await listLocalProviders(manager);
1192
+ const cline = providers.find((provider) => provider.id === "cline");
1193
+ const openrouter = providers.find(
1194
+ (provider) => provider.id === "openrouter",
1195
+ );
1196
+
1197
+ expect(cline?.modelList?.length).toBeGreaterThan(0);
1198
+ expect(cline?.modelList).toEqual(openrouter?.modelList);
1199
+ });
1200
+
1201
+ it("does not eagerly fetch LiteLLM private models while listing providers", async () => {
1202
+ manager.saveProviderSettings(
1203
+ {
1204
+ provider: "litellm",
1205
+ apiKey: "test-key",
1206
+ baseUrl: "http://localhost:4000",
1207
+ model: "gpt-4o",
1208
+ },
1209
+ { setLastUsed: false },
1210
+ );
1211
+ const fetchMock = vi.fn().mockResolvedValue({
1212
+ ok: true,
1213
+ json: async () => ({
1214
+ data: [
1215
+ {
1216
+ model_name: "team-private-model",
1217
+ litellm_params: { model: "team/private-model" },
1218
+ model_info: {},
1219
+ },
1220
+ ],
1221
+ }),
1222
+ });
1223
+ vi.stubGlobal("fetch", fetchMock);
1224
+
1225
+ const { providers } = await listLocalProviders(manager);
1226
+ const litellm = providers.find((provider) => provider.id === "litellm");
1227
+
1228
+ expect(fetchMock).not.toHaveBeenCalled();
1229
+ expect(litellm?.modelList?.length).toBeGreaterThan(0);
1230
+ expect(
1231
+ litellm?.modelList?.some((model) => model.id === "team/private-model"),
1232
+ ).toBe(false);
1233
+ });
1234
+ });
1235
+
1236
+ // ===========================================================================
1237
+ // normalizeOAuthProvider
1238
+ // ===========================================================================
1239
+
1240
+ describe("normalizeOAuthProvider", () => {
1241
+ it("normalizes 'cline' to 'cline'", () => {
1242
+ expect(normalizeOAuthProvider("cline")).toBe("cline");
1243
+ expect(normalizeOAuthProvider(" CLINE ")).toBe("cline");
1244
+ });
1245
+
1246
+ it("normalizes 'oca' to 'oca'", () => {
1247
+ expect(normalizeOAuthProvider("oca")).toBe("oca");
1248
+ expect(normalizeOAuthProvider("OCA")).toBe("oca");
1249
+ });
1250
+
1251
+ it("normalizes 'codex' and 'openai-codex' to 'openai-codex'", () => {
1252
+ expect(normalizeOAuthProvider("codex")).toBe("openai-codex");
1253
+ expect(normalizeOAuthProvider("openai-codex")).toBe("openai-codex");
1254
+ expect(normalizeOAuthProvider("OPENAI-CODEX")).toBe("openai-codex");
1255
+ });
1256
+
1257
+ it("throws for unsupported providers", () => {
1258
+ expect(() => normalizeOAuthProvider("anthropic")).toThrow(
1259
+ "does not support OAuth login",
1260
+ );
1261
+ expect(() => normalizeOAuthProvider("")).toThrow();
1262
+ });
1263
+ });
1264
+
1265
+ // ===========================================================================
1266
+ // resolveLocalClineAuthToken
1267
+ // ===========================================================================
1268
+
1269
+ describe("resolveLocalClineAuthToken", () => {
1270
+ it("returns undefined when settings is undefined", () => {
1271
+ expect(resolveLocalClineAuthToken(undefined)).toBeUndefined();
1272
+ });
1273
+
1274
+ it("returns accessToken when present", () => {
1275
+ expect(
1276
+ resolveLocalClineAuthToken({
1277
+ provider: "cline" as never,
1278
+ auth: { accessToken: "tok123" },
1279
+ }),
1280
+ ).toBe("tok123");
1281
+ });
1282
+
1283
+ it("falls back to apiKey when accessToken is absent", () => {
1284
+ expect(
1285
+ resolveLocalClineAuthToken({
1286
+ provider: "cline" as never,
1287
+ apiKey: "api-key-456",
1288
+ }),
1289
+ ).toBe("api-key-456");
1290
+ });
1291
+
1292
+ it("prefers accessToken over apiKey", () => {
1293
+ expect(
1294
+ resolveLocalClineAuthToken({
1295
+ provider: "cline" as never,
1296
+ apiKey: "api-key",
1297
+ auth: { accessToken: "access-token" },
1298
+ }),
1299
+ ).toBe("access-token");
1300
+ });
1301
+
1302
+ it("returns undefined when both accessToken and apiKey are empty strings", () => {
1303
+ expect(
1304
+ resolveLocalClineAuthToken({
1305
+ provider: "cline" as never,
1306
+ apiKey: " ",
1307
+ auth: { accessToken: " " },
1308
+ }),
1309
+ ).toBeUndefined();
1310
+ });
1311
+
1312
+ it("returns undefined when both fields are absent", () => {
1313
+ expect(
1314
+ resolveLocalClineAuthToken({ provider: "cline" as never }),
1315
+ ).toBeUndefined();
1316
+ });
1317
+ });
1318
+
1319
+ describe("refreshProviderModelsFromSource", () => {
1320
+ let manager: ProviderSettingsManager;
1321
+ let cleanup: () => void;
1322
+
1323
+ beforeEach(() => {
1324
+ ({ manager, cleanup } = makeTempManager());
1325
+ });
1326
+
1327
+ afterEach(() => cleanup());
1328
+
1329
+ it("refreshes built-in Ollama models through modelsSourceUrl using the saved base URL", async () => {
1330
+ const fetchMock = vi.fn().mockResolvedValue({
1331
+ ok: true,
1332
+ json: async () => ({ models: [{ name: "remote-llama" }] }),
1333
+ });
1334
+ vi.stubGlobal("fetch", fetchMock);
1335
+ saveLocalProviderSettings(manager, {
1336
+ providerId: "ollama",
1337
+ baseUrl: "http://tailscale-host:11434/v1",
1338
+ });
1339
+
1340
+ const result = await refreshProviderModelsFromSource(manager, "ollama");
1341
+
1342
+ expect(result).toMatchObject({ providerId: "ollama", refreshed: true });
1343
+ expect(fetchMock).toHaveBeenCalledWith(
1344
+ "http://tailscale-host:11434/api/tags",
1345
+ {
1346
+ method: "GET",
1347
+ },
1348
+ );
1349
+ const modelsState = await readModelsFile(
1350
+ resolveModelsRegistryPath(manager),
1351
+ );
1352
+ expect(modelsState.providers.ollama?.provider?.modelsSourceUrl).toBe(
1353
+ "http://tailscale-host:11434/api/tags",
1354
+ );
1355
+ const { models } = await getLocalProviderModels("ollama");
1356
+ expect(models.map((model) => model.id)).toContain("remote-llama");
1357
+ });
1358
+ });