@kb-labs/adapters 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (276) hide show
  1. package/.cursorrules +32 -0
  2. package/.github/workflows/ci.yml +13 -0
  3. package/.github/workflows/deploy.yml +28 -0
  4. package/.github/workflows/docker-build.yml +25 -0
  5. package/.github/workflows/drift-check.yml +10 -0
  6. package/.github/workflows/profiles-validate.yml +16 -0
  7. package/.github/workflows/release.yml +8 -0
  8. package/.kb/devkit/agents/devkit-maintainer/context.globs +15 -0
  9. package/.kb/devkit/agents/devkit-maintainer/permissions.yml +17 -0
  10. package/.kb/devkit/agents/devkit-maintainer/prompt.md +28 -0
  11. package/.kb/devkit/agents/devkit-maintainer/runbook.md +31 -0
  12. package/.kb/devkit/agents/docs-crafter/prompt.md +24 -0
  13. package/.kb/devkit/agents/docs-crafter/runbook.md +18 -0
  14. package/.kb/devkit/agents/release-manager/context.globs +7 -0
  15. package/.kb/devkit/agents/release-manager/prompt.md +27 -0
  16. package/.kb/devkit/agents/release-manager/runbook.md +17 -0
  17. package/.kb/devkit/agents/test-generator/context.globs +7 -0
  18. package/.kb/devkit/agents/test-generator/prompt.md +27 -0
  19. package/.kb/devkit/agents/test-generator/runbook.md +18 -0
  20. package/CONTRIBUTING.md +90 -0
  21. package/IMPLEMENTATION_COMPLETE.md +416 -0
  22. package/LICENSE +186 -0
  23. package/README-TEMPLATE.md +179 -0
  24. package/README.md +306 -0
  25. package/docs/DOCUMENTATION.md +74 -0
  26. package/docs/adr/0000-template.md +49 -0
  27. package/docs/adr/0001-architecture-and-repository-layout.md +33 -0
  28. package/docs/adr/0002-plugins-and-extensibility.md +46 -0
  29. package/docs/adr/0003-package-and-module-boundaries.md +37 -0
  30. package/docs/adr/0004-versioning-and-release-policy.md +38 -0
  31. package/docs/adr/0005-use-devkit-for-shared-tooling.md +48 -0
  32. package/docs/adr/0006-adopt-devkit-sync.md +47 -0
  33. package/docs/adr/0007-drift-kit-check.md +72 -0
  34. package/docs/adr/0008-devkit-sync-wrapper-strategy.md +67 -0
  35. package/docs/naming-convention.md +272 -0
  36. package/eslint.config.js +27 -0
  37. package/kb-labs.config.json +5 -0
  38. package/package.json +84 -0
  39. package/package.json.bin +25 -0
  40. package/package.json.lib +30 -0
  41. package/packages/adapters-analytics-duckdb/package.json +54 -0
  42. package/packages/adapters-analytics-duckdb/scripts/migrate-from-jsonl.mjs +253 -0
  43. package/packages/adapters-analytics-duckdb/src/index.ts +380 -0
  44. package/packages/adapters-analytics-duckdb/src/manifest.ts +36 -0
  45. package/packages/adapters-analytics-duckdb/src/schema.ts +161 -0
  46. package/packages/adapters-analytics-duckdb/tsconfig.build.json +15 -0
  47. package/packages/adapters-analytics-duckdb/tsconfig.json +9 -0
  48. package/packages/adapters-analytics-duckdb/tsup.config.ts +9 -0
  49. package/packages/adapters-analytics-file/README.md +32 -0
  50. package/packages/adapters-analytics-file/eslint.config.js +27 -0
  51. package/packages/adapters-analytics-file/package.json +50 -0
  52. package/packages/adapters-analytics-file/src/__tests__/daily-stats.spec.ts +287 -0
  53. package/packages/adapters-analytics-file/src/__tests__/scoped-analytics.test.ts +233 -0
  54. package/packages/adapters-analytics-file/src/index.test.ts +214 -0
  55. package/packages/adapters-analytics-file/src/index.ts +830 -0
  56. package/packages/adapters-analytics-file/src/manifest.ts +45 -0
  57. package/packages/adapters-analytics-file/tsconfig.build.json +15 -0
  58. package/packages/adapters-analytics-file/tsconfig.json +9 -0
  59. package/packages/adapters-analytics-file/tsup.config.ts +9 -0
  60. package/packages/adapters-analytics-sqlite/package.json +55 -0
  61. package/packages/adapters-analytics-sqlite/scripts/migrate-from-jsonl.mjs +194 -0
  62. package/packages/adapters-analytics-sqlite/src/index.ts +460 -0
  63. package/packages/adapters-analytics-sqlite/src/manifest.ts +41 -0
  64. package/packages/adapters-analytics-sqlite/tsconfig.build.json +15 -0
  65. package/packages/adapters-analytics-sqlite/tsconfig.json +9 -0
  66. package/packages/adapters-analytics-sqlite/tsup.config.ts +9 -0
  67. package/packages/adapters-environment-docker/README.md +28 -0
  68. package/packages/adapters-environment-docker/eslint.config.js +5 -0
  69. package/packages/adapters-environment-docker/package.json +49 -0
  70. package/packages/adapters-environment-docker/src/index.test.ts +138 -0
  71. package/packages/adapters-environment-docker/src/index.ts +439 -0
  72. package/packages/adapters-environment-docker/src/manifest.ts +65 -0
  73. package/packages/adapters-environment-docker/tsconfig.build.json +15 -0
  74. package/packages/adapters-environment-docker/tsconfig.json +16 -0
  75. package/packages/adapters-environment-docker/tsup.config.ts +9 -0
  76. package/packages/adapters-eventbus-cache/README.md +242 -0
  77. package/packages/adapters-eventbus-cache/eslint.config.js +27 -0
  78. package/packages/adapters-eventbus-cache/package.json +46 -0
  79. package/packages/adapters-eventbus-cache/src/index.test.ts +235 -0
  80. package/packages/adapters-eventbus-cache/src/index.ts +215 -0
  81. package/packages/adapters-eventbus-cache/src/manifest.ts +50 -0
  82. package/packages/adapters-eventbus-cache/src/types.ts +58 -0
  83. package/packages/adapters-eventbus-cache/tsconfig.build.json +15 -0
  84. package/packages/adapters-eventbus-cache/tsconfig.json +9 -0
  85. package/packages/adapters-eventbus-cache/tsup.config.ts +9 -0
  86. package/packages/adapters-fs/README.md +171 -0
  87. package/packages/adapters-fs/allowed.txt +1 -0
  88. package/packages/adapters-fs/conflict.txt +1 -0
  89. package/packages/adapters-fs/dest.txt +1 -0
  90. package/packages/adapters-fs/eslint.config.js +27 -0
  91. package/packages/adapters-fs/exists.txt +1 -0
  92. package/packages/adapters-fs/not-allowed.txt +1 -0
  93. package/packages/adapters-fs/other.txt +1 -0
  94. package/packages/adapters-fs/package.json +55 -0
  95. package/packages/adapters-fs/public/file1.txt +1 -0
  96. package/packages/adapters-fs/public/file2.txt +1 -0
  97. package/packages/adapters-fs/secret.txt +1 -0
  98. package/packages/adapters-fs/secrets/key.txt +1 -0
  99. package/packages/adapters-fs/src/index.test.ts +243 -0
  100. package/packages/adapters-fs/src/index.ts +258 -0
  101. package/packages/adapters-fs/src/manifest.ts +35 -0
  102. package/packages/adapters-fs/src/secure-storage.test.ts +380 -0
  103. package/packages/adapters-fs/src/secure-storage.ts +268 -0
  104. package/packages/adapters-fs/test.json +1 -0
  105. package/packages/adapters-fs/test.txt +1 -0
  106. package/packages/adapters-fs/test.xyz +1 -0
  107. package/packages/adapters-fs/test1.txt +1 -0
  108. package/packages/adapters-fs/test2.txt +1 -0
  109. package/packages/adapters-fs/tsconfig.build.json +15 -0
  110. package/packages/adapters-fs/tsconfig.json +9 -0
  111. package/packages/adapters-fs/tsup.config.ts +8 -0
  112. package/packages/adapters-fs/vitest.config.ts +19 -0
  113. package/packages/adapters-log-ringbuffer/README.md +228 -0
  114. package/packages/adapters-log-ringbuffer/eslint.config.js +27 -0
  115. package/packages/adapters-log-ringbuffer/package.json +47 -0
  116. package/packages/adapters-log-ringbuffer/src/__tests__/ring-buffer.test.ts +450 -0
  117. package/packages/adapters-log-ringbuffer/src/index.ts +212 -0
  118. package/packages/adapters-log-ringbuffer/src/manifest.ts +30 -0
  119. package/packages/adapters-log-ringbuffer/tsconfig.build.json +15 -0
  120. package/packages/adapters-log-ringbuffer/tsconfig.json +9 -0
  121. package/packages/adapters-log-ringbuffer/tsup.config.ts +9 -0
  122. package/packages/adapters-log-ringbuffer/vitest.config.ts +14 -0
  123. package/packages/adapters-log-sqlite/README.md +396 -0
  124. package/packages/adapters-log-sqlite/eslint.config.js +27 -0
  125. package/packages/adapters-log-sqlite/package.json +49 -0
  126. package/packages/adapters-log-sqlite/src/__tests__/log-persistence.test.ts +718 -0
  127. package/packages/adapters-log-sqlite/src/index.ts +1068 -0
  128. package/packages/adapters-log-sqlite/src/manifest.ts +36 -0
  129. package/packages/adapters-log-sqlite/src/schema.sql +46 -0
  130. package/packages/adapters-log-sqlite/tsconfig.build.json +15 -0
  131. package/packages/adapters-log-sqlite/tsconfig.json +9 -0
  132. package/packages/adapters-log-sqlite/tsup.config.ts +9 -0
  133. package/packages/adapters-log-sqlite/vitest.config.ts +15 -0
  134. package/packages/adapters-mongodb/README.md +147 -0
  135. package/packages/adapters-mongodb/eslint.config.js +27 -0
  136. package/packages/adapters-mongodb/package.json +53 -0
  137. package/packages/adapters-mongodb/src/index.ts +428 -0
  138. package/packages/adapters-mongodb/src/manifest.ts +45 -0
  139. package/packages/adapters-mongodb/src/secure-document.ts +231 -0
  140. package/packages/adapters-mongodb/tsconfig.build.json +15 -0
  141. package/packages/adapters-mongodb/tsconfig.json +9 -0
  142. package/packages/adapters-mongodb/tsup.config.ts +8 -0
  143. package/packages/adapters-openai/README.md +151 -0
  144. package/packages/adapters-openai/embeddings.ts +37 -0
  145. package/packages/adapters-openai/eslint.config.js +26 -0
  146. package/packages/adapters-openai/index.ts +22 -0
  147. package/packages/adapters-openai/package.json +57 -0
  148. package/packages/adapters-openai/src/embeddings-manifest.ts +45 -0
  149. package/packages/adapters-openai/src/embeddings.ts +104 -0
  150. package/packages/adapters-openai/src/index.ts +13 -0
  151. package/packages/adapters-openai/src/llm.ts +304 -0
  152. package/packages/adapters-openai/src/manifest.ts +47 -0
  153. package/packages/adapters-openai/tsconfig.build.json +15 -0
  154. package/packages/adapters-openai/tsconfig.json +9 -0
  155. package/packages/adapters-openai/tsup.config.ts +8 -0
  156. package/packages/adapters-pino/README.md +152 -0
  157. package/packages/adapters-pino/eslint.config.js +27 -0
  158. package/packages/adapters-pino/package.json +49 -0
  159. package/packages/adapters-pino/src/index.test.ts +44 -0
  160. package/packages/adapters-pino/src/index.ts +322 -0
  161. package/packages/adapters-pino/src/log-ring-buffer.ts +142 -0
  162. package/packages/adapters-pino/src/manifest.ts +49 -0
  163. package/packages/adapters-pino/tsconfig.build.json +15 -0
  164. package/packages/adapters-pino/tsconfig.json +9 -0
  165. package/packages/adapters-pino/tsup.config.ts +9 -0
  166. package/packages/adapters-pino-http/README.md +141 -0
  167. package/packages/adapters-pino-http/eslint.config.js +27 -0
  168. package/packages/adapters-pino-http/package.json +46 -0
  169. package/packages/adapters-pino-http/src/index.ts +229 -0
  170. package/packages/adapters-pino-http/tsconfig.build.json +15 -0
  171. package/packages/adapters-pino-http/tsconfig.json +9 -0
  172. package/packages/adapters-pino-http/tsup.config.ts +9 -0
  173. package/packages/adapters-qdrant/README.md +166 -0
  174. package/packages/adapters-qdrant/eslint.config.js +27 -0
  175. package/packages/adapters-qdrant/package.json +49 -0
  176. package/packages/adapters-qdrant/src/index.ts +490 -0
  177. package/packages/adapters-qdrant/src/manifest.ts +54 -0
  178. package/packages/adapters-qdrant/src/retry.ts +204 -0
  179. package/packages/adapters-qdrant/tsconfig.build.json +15 -0
  180. package/packages/adapters-qdrant/tsconfig.json +9 -0
  181. package/packages/adapters-qdrant/tsup.config.ts +9 -0
  182. package/packages/adapters-redis/README.md +159 -0
  183. package/packages/adapters-redis/eslint.config.js +27 -0
  184. package/packages/adapters-redis/package.json +49 -0
  185. package/packages/adapters-redis/src/index.ts +164 -0
  186. package/packages/adapters-redis/src/manifest.ts +49 -0
  187. package/packages/adapters-redis/tsconfig.build.json +15 -0
  188. package/packages/adapters-redis/tsconfig.json +9 -0
  189. package/packages/adapters-redis/tsup.config.ts +9 -0
  190. package/packages/adapters-snapshot-localfs/README.md +10 -0
  191. package/packages/adapters-snapshot-localfs/eslint.config.js +2 -0
  192. package/packages/adapters-snapshot-localfs/package.json +46 -0
  193. package/packages/adapters-snapshot-localfs/src/index.test.ts +40 -0
  194. package/packages/adapters-snapshot-localfs/src/index.ts +292 -0
  195. package/packages/adapters-snapshot-localfs/src/manifest.ts +32 -0
  196. package/packages/adapters-snapshot-localfs/tsconfig.build.json +15 -0
  197. package/packages/adapters-snapshot-localfs/tsconfig.json +16 -0
  198. package/packages/adapters-snapshot-localfs/tsup.config.ts +11 -0
  199. package/packages/adapters-sqlite/README.md +163 -0
  200. package/packages/adapters-sqlite/eslint.config.js +27 -0
  201. package/packages/adapters-sqlite/package.json +54 -0
  202. package/packages/adapters-sqlite/src/index.test.ts +245 -0
  203. package/packages/adapters-sqlite/src/index.ts +382 -0
  204. package/packages/adapters-sqlite/src/manifest.ts +47 -0
  205. package/packages/adapters-sqlite/src/secure-sql.test.ts +290 -0
  206. package/packages/adapters-sqlite/src/secure-sql.ts +281 -0
  207. package/packages/adapters-sqlite/tsconfig.build.json +15 -0
  208. package/packages/adapters-sqlite/tsconfig.json +9 -0
  209. package/packages/adapters-sqlite/tsup.config.ts +8 -0
  210. package/packages/adapters-sqlite/vitest.config.ts +19 -0
  211. package/packages/adapters-transport/README.md +170 -0
  212. package/packages/adapters-transport/eslint.config.js +27 -0
  213. package/packages/adapters-transport/package.json +49 -0
  214. package/packages/adapters-transport/src/__tests__/unix-socket-server.test.ts +550 -0
  215. package/packages/adapters-transport/src/index.ts +101 -0
  216. package/packages/adapters-transport/src/ipc-transport.ts +228 -0
  217. package/packages/adapters-transport/src/transport.ts +224 -0
  218. package/packages/adapters-transport/src/types.ts +92 -0
  219. package/packages/adapters-transport/src/unix-socket-server.ts +193 -0
  220. package/packages/adapters-transport/src/unix-socket-transport.ts +280 -0
  221. package/packages/adapters-transport/tsconfig.build.json +15 -0
  222. package/packages/adapters-transport/tsconfig.json +9 -0
  223. package/packages/adapters-transport/tsup.config.ts +9 -0
  224. package/packages/adapters-vibeproxy/README.md +159 -0
  225. package/packages/adapters-vibeproxy/eslint.config.js +27 -0
  226. package/packages/adapters-vibeproxy/package.json +51 -0
  227. package/packages/adapters-vibeproxy/src/index.ts +13 -0
  228. package/packages/adapters-vibeproxy/src/llm.ts +437 -0
  229. package/packages/adapters-vibeproxy/src/manifest.ts +51 -0
  230. package/packages/adapters-vibeproxy/tsconfig.build.json +15 -0
  231. package/packages/adapters-vibeproxy/tsconfig.json +9 -0
  232. package/packages/adapters-vibeproxy/tsup.config.ts +8 -0
  233. package/packages/adapters-workspace-agent/package.json +46 -0
  234. package/packages/adapters-workspace-agent/src/__tests__/adapter.test.ts +212 -0
  235. package/packages/adapters-workspace-agent/src/index.ts +220 -0
  236. package/packages/adapters-workspace-agent/src/manifest.ts +36 -0
  237. package/packages/adapters-workspace-agent/tsconfig.build.json +15 -0
  238. package/packages/adapters-workspace-agent/tsconfig.json +16 -0
  239. package/packages/adapters-workspace-agent/tsup.config.ts +11 -0
  240. package/packages/adapters-workspace-localfs/README.md +9 -0
  241. package/packages/adapters-workspace-localfs/eslint.config.js +2 -0
  242. package/packages/adapters-workspace-localfs/package.json +46 -0
  243. package/packages/adapters-workspace-localfs/src/index.test.ts +27 -0
  244. package/packages/adapters-workspace-localfs/src/index.ts +172 -0
  245. package/packages/adapters-workspace-localfs/src/manifest.ts +32 -0
  246. package/packages/adapters-workspace-localfs/tsconfig.build.json +15 -0
  247. package/packages/adapters-workspace-localfs/tsconfig.json +16 -0
  248. package/packages/adapters-workspace-localfs/tsup.config.ts +11 -0
  249. package/packages/adapters-workspace-worktree/README.md +9 -0
  250. package/packages/adapters-workspace-worktree/eslint.config.js +2 -0
  251. package/packages/adapters-workspace-worktree/package.json +46 -0
  252. package/packages/adapters-workspace-worktree/src/index.test.ts +38 -0
  253. package/packages/adapters-workspace-worktree/src/index.ts +245 -0
  254. package/packages/adapters-workspace-worktree/src/manifest.ts +38 -0
  255. package/packages/adapters-workspace-worktree/tsconfig.build.json +15 -0
  256. package/packages/adapters-workspace-worktree/tsconfig.json +16 -0
  257. package/packages/adapters-workspace-worktree/tsup.config.ts +11 -0
  258. package/pnpm-workspace.yaml +2800 -0
  259. package/prettierrc.json +1 -0
  260. package/scripts/devkit-sync.mjs +37 -0
  261. package/scripts/hooks/post-push +9 -0
  262. package/scripts/hooks/pre-commit +9 -0
  263. package/scripts/hooks/pre-push +9 -0
  264. package/test-integration.ts +242 -0
  265. package/test.txt +1 -0
  266. package/tsconfig.base.json +6 -0
  267. package/tsconfig.build.json +15 -0
  268. package/tsconfig.json +9 -0
  269. package/tsconfig.paths.json +26 -0
  270. package/tsconfig.tools.json +17 -0
  271. package/tsup.config.bin.ts +34 -0
  272. package/tsup.config.cli.ts +41 -0
  273. package/tsup.config.dual.ts +46 -0
  274. package/tsup.config.ts +36 -0
  275. package/tsup.external.json +103 -0
  276. package/vitest.config.ts +2 -0
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@kb-labs/adapters-vibeproxy",
3
+ "version": "0.5.0",
4
+ "description": "VibeProxy adapter implementing ILLM interface for local Anthropic API proxy",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.js",
11
+ "types": "./dist/index.d.ts"
12
+ },
13
+ "./llm": {
14
+ "import": "./dist/llm.js",
15
+ "types": "./dist/llm.d.ts"
16
+ }
17
+ },
18
+ "files": [
19
+ "dist",
20
+ "README.md"
21
+ ],
22
+ "sideEffects": false,
23
+ "scripts": {
24
+ "clean": "rimraf dist",
25
+ "build": "tsup",
26
+ "dev": "tsup --watch",
27
+ "type-check": "tsc --noEmit",
28
+ "test": "vitest run --passWithNoTests",
29
+ "test:watch": "vitest",
30
+ "lint": "eslint src --ext .ts",
31
+ "lint:fix": "eslint . --fix"
32
+ },
33
+ "dependencies": {},
34
+ "peerDependencies": {
35
+ "@kb-labs/core-platform": "*"
36
+ },
37
+ "devDependencies": {
38
+ "@kb-labs/core-platform": "link:../../../../platform/kb-labs-core/packages/core-platform",
39
+ "@types/node": "^24.3.3",
40
+ "eslint": "^9",
41
+ "rimraf": "^6.0.1",
42
+ "tsup": "^8.5.0",
43
+ "typescript": "^5.6.3",
44
+ "vitest": "^3.2.4",
45
+ "@kb-labs/devkit": "link:../../../kb-labs-devkit"
46
+ },
47
+ "engines": {
48
+ "node": ">=20.0.0",
49
+ "pnpm": ">=9.0.0"
50
+ }
51
+ }
@@ -0,0 +1,13 @@
1
+ /**
2
+ * @module @kb-labs/adapters-vibeproxy
3
+ * VibeProxy LLM adapter entry point.
4
+ */
5
+
6
+ // Re-export LLM adapter as default
7
+ export { VibeProxyLLM, type VibeProxyLLMConfig, createAdapter } from "./llm.js";
8
+
9
+ // Re-export manifest
10
+ export { manifest } from "./manifest.js";
11
+
12
+ // Default export
13
+ export { createAdapter as default } from "./llm.js";
@@ -0,0 +1,437 @@
1
+ /**
2
+ * @module @kb-labs/adapters-vibeproxy/llm
3
+ * VibeProxy implementation of ILLM interface.
4
+ * Connects to local VibeProxy server (supports Claude, GPT, and other models).
5
+ */
6
+
7
+ import type {
8
+ ILLM,
9
+ LLMOptions,
10
+ LLMResponse,
11
+ LLMMessage,
12
+ LLMToolCallOptions,
13
+ LLMToolCallResponse,
14
+ LLMTool,
15
+ LLMToolCall,
16
+ LLMProtocolCapabilities,
17
+ LLMExecutionPolicy,
18
+ } from "@kb-labs/core-platform";
19
+
20
+ /**
21
+ * Configuration for VibeProxy LLM adapter.
22
+ */
23
+ export interface VibeProxyLLMConfig {
24
+ /** Base URL for VibeProxy (defaults to http://localhost:8317) */
25
+ baseURL?: string;
26
+ /** API key (can be any string for VibeProxy) */
27
+ apiKey?: string;
28
+ /** Default model to use */
29
+ defaultModel?: string;
30
+ /** Request timeout in ms (defaults to 120000) */
31
+ timeout?: number;
32
+ /** Default max output tokens when caller does not specify. Overrides the hardcoded 4096. */
33
+ defaultMaxTokens?: number;
34
+ }
35
+
36
+ /** Default max output tokens — avoids hitting the 4096 hardcoded limit mid-response. */
37
+ const DEFAULT_MAX_TOKENS = 16_384;
38
+
39
+ /**
40
+ * VibeProxy Messages API request format.
41
+ */
42
+ interface VibeProxyMessagesRequest {
43
+ model: string;
44
+ max_tokens: number;
45
+ messages: Array<{
46
+ role: "user" | "assistant";
47
+ content:
48
+ | string
49
+ | Array<
50
+ | { type: "text"; text: string }
51
+ | { type: "tool_use"; id: string; name: string; input: unknown }
52
+ | { type: "tool_result"; tool_use_id: string; content: string }
53
+ >;
54
+ }>;
55
+ system?: string;
56
+ temperature?: number;
57
+ stop_sequences?: string[];
58
+ tools?: Array<{
59
+ name: string;
60
+ description: string;
61
+ input_schema: Record<string, unknown>;
62
+ }>;
63
+ tool_choice?:
64
+ | { type: "auto" }
65
+ | { type: "any" }
66
+ | { type: "tool"; name: string };
67
+ }
68
+
69
+ /**
70
+ * VibeProxy Messages API response format.
71
+ */
72
+ interface VibeProxyMessagesResponse {
73
+ id: string;
74
+ type: "message";
75
+ role: "assistant";
76
+ model: string;
77
+ content: Array<
78
+ | { type: "text"; text: string }
79
+ | { type: "tool_use"; id: string; name: string; input: unknown }
80
+ >;
81
+ stop_reason: "end_turn" | "max_tokens" | "stop_sequence" | "tool_use";
82
+ stop_sequence: string | null;
83
+ usage: {
84
+ input_tokens: number;
85
+ output_tokens: number;
86
+ cache_creation_input_tokens?: number;
87
+ cache_read_input_tokens?: number;
88
+ };
89
+ }
90
+
91
+ /**
92
+ * VibeProxy implementation of ILLM interface.
93
+ * Supports multiple model providers through local VibeProxy server.
94
+ */
95
+ export class VibeProxyLLM implements ILLM {
96
+ private baseURL: string;
97
+ private apiKey: string;
98
+ private defaultModel: string;
99
+ private timeout: number;
100
+ private defaultMaxTokens: number;
101
+
102
+ constructor(config: VibeProxyLLMConfig = {}) {
103
+ this.baseURL =
104
+ config.baseURL ?? process.env.VIBEPROXY_URL ?? "http://localhost:8317";
105
+ this.apiKey =
106
+ config.apiKey ?? process.env.VIBEPROXY_API_KEY ?? "any-string";
107
+ this.defaultModel =
108
+ config.defaultModel ??
109
+ process.env.VIBEPROXY_MODEL ??
110
+ "claude-sonnet-4-20250514";
111
+ this.timeout = config.timeout ?? 120000;
112
+ this.defaultMaxTokens = config.defaultMaxTokens ?? DEFAULT_MAX_TOKENS;
113
+ }
114
+
115
+ getProtocolCapabilities(): LLMProtocolCapabilities {
116
+ return {
117
+ cache: {
118
+ supported: true,
119
+ protocol: "explicit_handle",
120
+ scopes: ["prefix", "segments", "full_request"],
121
+ },
122
+ // Current implementation yields complete() as one chunk (not true streaming)
123
+ stream: { supported: false },
124
+ };
125
+ }
126
+
127
+ /**
128
+ * Make a request to VibeProxy.
129
+ */
130
+ private async request<T>(
131
+ endpoint: string,
132
+ body: unknown,
133
+ headers?: Record<string, string>,
134
+ ): Promise<T> {
135
+ const controller = new AbortController();
136
+ const timeoutId = setTimeout(() => controller.abort(), this.timeout);
137
+
138
+ try {
139
+ const response = await fetch(`${this.baseURL}${endpoint}`, {
140
+ method: "POST",
141
+ headers: {
142
+ "Content-Type": "application/json",
143
+ "x-api-key": this.apiKey,
144
+ ...headers,
145
+ },
146
+ body: JSON.stringify(body),
147
+ signal: controller.signal,
148
+ });
149
+
150
+ if (!response.ok) {
151
+ const errorBody = (await response
152
+ .json()
153
+ .catch(() => ({ error: { message: response.statusText } }))) as {
154
+ error?: { message?: string };
155
+ };
156
+ throw new Error(
157
+ `VibeProxy error: ${errorBody.error?.message ?? response.statusText}`,
158
+ );
159
+ }
160
+
161
+ return response.json() as Promise<T>;
162
+ } finally {
163
+ clearTimeout(timeoutId);
164
+ }
165
+ }
166
+
167
+ private buildExecutionHeaders(execution?: LLMExecutionPolicy): Record<string, string> {
168
+ const headers: Record<string, string> = {};
169
+ const cache = execution?.cache;
170
+ if (!cache) {
171
+ return headers;
172
+ }
173
+
174
+ headers["x-kb-cache-mode"] = cache.mode ?? "prefer";
175
+ if (cache.scope) {
176
+ headers["x-kb-cache-scope"] = cache.scope;
177
+ }
178
+ if (typeof cache.ttlSec === "number") {
179
+ headers["x-kb-cache-ttl-sec"] = String(cache.ttlSec);
180
+ }
181
+ if (cache.key) {
182
+ headers["x-kb-cache-key"] = cache.key;
183
+ }
184
+
185
+ return headers;
186
+ }
187
+
188
+ private buildTraceHeaders(options?: LLMOptions): Record<string, string> {
189
+ const trace = options?.metadata?.cacheDecisionTrace;
190
+ if (!trace) {
191
+ return {};
192
+ }
193
+ return {
194
+ "x-kb-cache-decision": JSON.stringify(trace),
195
+ };
196
+ }
197
+
198
+ private extractTextContent(response: VibeProxyMessagesResponse): string {
199
+ return response.content
200
+ .filter((c): c is { type: "text"; text: string } => c.type === "text")
201
+ .map((c) => c.text)
202
+ .join("");
203
+ }
204
+
205
+ private convertMessagesForTools(
206
+ messages: LLMMessage[],
207
+ ): {
208
+ messages: VibeProxyMessagesRequest["messages"];
209
+ systemPrompt?: string;
210
+ } {
211
+ const vibeProxyMessages: VibeProxyMessagesRequest["messages"] = [];
212
+ let systemPrompt: string | undefined;
213
+
214
+ for (const msg of messages) {
215
+ if (msg.role === "system") {
216
+ systemPrompt = msg.content;
217
+ continue;
218
+ }
219
+ if (msg.role === "tool") {
220
+ vibeProxyMessages.push({
221
+ role: "user",
222
+ content: [
223
+ {
224
+ type: "tool_result",
225
+ tool_use_id: msg.toolCallId || "",
226
+ content: msg.content,
227
+ },
228
+ ],
229
+ });
230
+ continue;
231
+ }
232
+ if (msg.role === "assistant" && msg.toolCalls && msg.toolCalls.length > 0) {
233
+ vibeProxyMessages.push({
234
+ role: "assistant",
235
+ content: this.toAssistantToolContent(msg),
236
+ });
237
+ continue;
238
+ }
239
+ vibeProxyMessages.push({
240
+ role: msg.role as "user" | "assistant",
241
+ content: msg.content,
242
+ });
243
+ }
244
+
245
+ return { messages: vibeProxyMessages, systemPrompt };
246
+ }
247
+
248
+ private toAssistantToolContent(
249
+ message: LLMMessage,
250
+ ): Array<
251
+ | { type: "text"; text: string }
252
+ | { type: "tool_use"; id: string; name: string; input: unknown }
253
+ > {
254
+ const contentBlocks: Array<
255
+ | { type: "text"; text: string }
256
+ | { type: "tool_use"; id: string; name: string; input: unknown }
257
+ > = [];
258
+
259
+ if (message.content && message.content.trim()) {
260
+ contentBlocks.push({
261
+ type: "text",
262
+ text: message.content,
263
+ });
264
+ }
265
+
266
+ for (const toolCall of message.toolCalls ?? []) {
267
+ contentBlocks.push({
268
+ type: "tool_use",
269
+ id: toolCall.id,
270
+ name: toolCall.name,
271
+ input: toolCall.input,
272
+ });
273
+ }
274
+ return contentBlocks;
275
+ }
276
+
277
+ private buildToolChoice(
278
+ toolChoice: LLMToolCallOptions["toolChoice"],
279
+ ): VibeProxyMessagesRequest["tool_choice"] {
280
+ if (toolChoice === "auto") {
281
+ return { type: "auto" };
282
+ }
283
+ if (toolChoice === "required") {
284
+ return { type: "any" };
285
+ }
286
+ if (toolChoice && typeof toolChoice === "object") {
287
+ return { type: "tool", name: toolChoice.function.name };
288
+ }
289
+ return undefined;
290
+ }
291
+
292
+ private extractToolCalls(response: VibeProxyMessagesResponse): LLMToolCall[] {
293
+ return response.content
294
+ .filter(
295
+ (
296
+ c,
297
+ ): c is {
298
+ type: "tool_use";
299
+ id: string;
300
+ name: string;
301
+ input: unknown;
302
+ } => c.type === "tool_use",
303
+ )
304
+ .map((tc) => ({
305
+ id: tc.id,
306
+ name: tc.name,
307
+ input: tc.input,
308
+ }));
309
+ }
310
+
311
+ async complete(prompt: string, options?: LLMOptions): Promise<LLMResponse> {
312
+ const model = options?.model ?? this.defaultModel;
313
+
314
+ const requestBody: VibeProxyMessagesRequest = {
315
+ model,
316
+ max_tokens: options?.maxTokens ?? this.defaultMaxTokens,
317
+ messages: [{ role: "user", content: prompt }],
318
+ };
319
+
320
+ if (options?.systemPrompt) {
321
+ requestBody.system = options.systemPrompt;
322
+ }
323
+ if (options?.temperature !== undefined) {
324
+ requestBody.temperature = options.temperature;
325
+ }
326
+ if (options?.stop) {
327
+ requestBody.stop_sequences = options.stop;
328
+ }
329
+
330
+ const response = await this.request<VibeProxyMessagesResponse>(
331
+ "/v1/messages",
332
+ requestBody,
333
+ {
334
+ ...this.buildExecutionHeaders(options?.execution),
335
+ ...this.buildTraceHeaders(options),
336
+ },
337
+ );
338
+
339
+ return {
340
+ content: this.extractTextContent(response),
341
+ usage: {
342
+ promptTokens: response.usage.input_tokens,
343
+ completionTokens: response.usage.output_tokens,
344
+ cacheReadTokens: response.usage.cache_read_input_tokens ?? 0,
345
+ cacheWriteTokens: response.usage.cache_creation_input_tokens ?? 0,
346
+ providerUsage: {
347
+ stopReason: response.stop_reason,
348
+ },
349
+ },
350
+ model: response.model,
351
+ };
352
+ }
353
+
354
+ async *stream(prompt: string, options?: LLMOptions): AsyncIterable<string> {
355
+ // VibeProxy supports streaming via SSE, but for simplicity we'll use non-streaming
356
+ // and yield the full response. Can be enhanced later with proper SSE support.
357
+ const response = await this.complete(prompt, options);
358
+ yield response.content;
359
+ }
360
+
361
+ /**
362
+ * Chat with native tool calling support.
363
+ */
364
+ async chatWithTools(
365
+ messages: LLMMessage[],
366
+ options: LLMToolCallOptions,
367
+ ): Promise<LLMToolCallResponse> {
368
+ const model = options?.model ?? this.defaultModel;
369
+ const converted = this.convertMessagesForTools(messages);
370
+
371
+ // Convert LLMTool[] to VibeProxy tools format
372
+ const tools: VibeProxyMessagesRequest["tools"] = options.tools.map(
373
+ (tool: LLMTool) => ({
374
+ name: tool.name,
375
+ description: tool.description,
376
+ input_schema: tool.inputSchema,
377
+ }),
378
+ );
379
+ const toolChoice = this.buildToolChoice(options.toolChoice);
380
+
381
+ const requestBody: VibeProxyMessagesRequest = {
382
+ model,
383
+ max_tokens: options?.maxTokens ?? this.defaultMaxTokens,
384
+ messages: converted.messages,
385
+ tools: options.toolChoice !== "none" ? tools : undefined,
386
+ tool_choice: options.toolChoice !== "none" ? toolChoice : undefined,
387
+ };
388
+
389
+ if (converted.systemPrompt || options?.systemPrompt) {
390
+ requestBody.system = converted.systemPrompt ?? options.systemPrompt;
391
+ }
392
+ if (options?.temperature !== undefined) {
393
+ requestBody.temperature = options.temperature;
394
+ }
395
+ if (options?.stop) {
396
+ requestBody.stop_sequences = options.stop;
397
+ }
398
+
399
+ const response = await this.request<VibeProxyMessagesResponse>(
400
+ "/v1/messages",
401
+ requestBody,
402
+ {
403
+ ...this.buildExecutionHeaders(options?.execution),
404
+ ...this.buildTraceHeaders(options),
405
+ },
406
+ );
407
+ const textContent = this.extractTextContent(response);
408
+ const toolCalls = this.extractToolCalls(response);
409
+
410
+ return {
411
+ content: textContent,
412
+ usage: {
413
+ promptTokens: response.usage.input_tokens,
414
+ completionTokens: response.usage.output_tokens,
415
+ cacheReadTokens: response.usage.cache_read_input_tokens ?? 0,
416
+ cacheWriteTokens: response.usage.cache_creation_input_tokens ?? 0,
417
+ providerUsage: {
418
+ stopReason: response.stop_reason,
419
+ },
420
+ },
421
+ model: response.model,
422
+ toolCalls: toolCalls.length > 0 ? toolCalls : undefined,
423
+ stopReason: response.stop_reason,
424
+ };
425
+ }
426
+ }
427
+
428
+ /**
429
+ * Create VibeProxy LLM adapter.
430
+ * This is the factory function called by initPlatform() when loading adapters.
431
+ */
432
+ export function createAdapter(config?: VibeProxyLLMConfig): VibeProxyLLM {
433
+ return new VibeProxyLLM(config);
434
+ }
435
+
436
+ // Default export for direct import
437
+ export default createAdapter;
@@ -0,0 +1,51 @@
1
+ /**
2
+ * @module @kb-labs/adapters-vibeproxy/manifest
3
+ * Adapter manifest for VibeProxy LLM.
4
+ */
5
+
6
+ import type { AdapterManifest } from "@kb-labs/core-platform";
7
+
8
+ /**
9
+ * Adapter manifest for VibeProxy LLM.
10
+ */
11
+ export const manifest: AdapterManifest = {
12
+ manifestVersion: "1.0.0",
13
+ id: "vibeproxy-llm",
14
+ name: "VibeProxy LLM",
15
+ version: "0.1.0",
16
+ description:
17
+ "VibeProxy local adapter supporting multiple LLM providers (Claude, GPT, etc.)",
18
+ author: "KB Labs Team",
19
+ license: "KBPL-1.1",
20
+ type: "core",
21
+ implements: "ILLM",
22
+ capabilities: {
23
+ streaming: false, // TODO: implement SSE streaming
24
+ custom: {
25
+ functionCalling: true,
26
+ multiProvider: true,
27
+ },
28
+ },
29
+ configSchema: {
30
+ baseURL: {
31
+ type: "string",
32
+ default: "http://localhost:8317",
33
+ description: "VibeProxy server URL",
34
+ },
35
+ apiKey: {
36
+ type: "string",
37
+ default: "any-string",
38
+ description: "API key (any string works for local VibeProxy)",
39
+ },
40
+ model: {
41
+ type: "string",
42
+ default: "claude-sonnet-4-20250514",
43
+ description: "Model to use (claude-*, gpt-*, etc.)",
44
+ },
45
+ timeout: {
46
+ type: "number",
47
+ default: 120000,
48
+ description: "Request timeout in milliseconds",
49
+ },
50
+ },
51
+ };
@@ -0,0 +1,15 @@
1
+ {
2
+ "extends": "../../tsconfig.base.json",
3
+ "compilerOptions": {
4
+ "outDir": "dist",
5
+ "baseUrl": ".",
6
+ "paths": {}
7
+ },
8
+ "include": [
9
+ "src/**/*"
10
+ ],
11
+ "exclude": [
12
+ "dist",
13
+ "node_modules"
14
+ ]
15
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "$schema": "https://json.schemastore.org/tsconfig",
3
+ "extends": "@kb-labs/devkit/tsconfig/node.json",
4
+ "compilerOptions": {
5
+ "rootDir": "src",
6
+ "outDir": "dist"
7
+ },
8
+ "include": ["src"]
9
+ }
@@ -0,0 +1,8 @@
1
+ import { defineConfig } from 'tsup';
2
+ import nodePreset from '@kb-labs/devkit/tsup/node';
3
+
4
+ export default defineConfig({
5
+ ...nodePreset,
6
+ tsconfig: 'tsconfig.build.json',
7
+ dts: true,
8
+ });
@@ -0,0 +1,46 @@
1
+ {
2
+ "name": "@kb-labs/adapters-workspace-agent",
3
+ "version": "0.5.0",
4
+ "description": "Workspace adapter that materializes workspaces from a remote Host Agent via Gateway",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.js",
11
+ "types": "./dist/index.d.ts"
12
+ }
13
+ },
14
+ "files": [
15
+ "dist",
16
+ "README.md"
17
+ ],
18
+ "sideEffects": false,
19
+ "scripts": {
20
+ "clean": "rimraf dist",
21
+ "build": "tsup",
22
+ "dev": "tsup --watch",
23
+ "type-check": "tsc --noEmit",
24
+ "test": "vitest run --passWithNoTests",
25
+ "test:watch": "vitest",
26
+ "lint": "eslint src --ext .ts",
27
+ "lint:fix": "eslint . --fix"
28
+ },
29
+ "peerDependencies": {
30
+ "@kb-labs/core-platform": "*"
31
+ },
32
+ "devDependencies": {
33
+ "@kb-labs/core-platform": "link:../../../../platform/kb-labs-core/packages/core-platform",
34
+ "@types/node": "^24.3.3",
35
+ "eslint": "^9",
36
+ "tsup": "^8.5.0",
37
+ "typescript": "^5.6.3",
38
+ "vitest": "^3.2.4",
39
+ "@kb-labs/devkit": "link:../../../kb-labs-devkit",
40
+ "rimraf": "^6.0.1"
41
+ },
42
+ "engines": {
43
+ "node": ">=20.0.0",
44
+ "pnpm": ">=9.0.0"
45
+ }
46
+ }