luca 2.0.0 → 3.0.2

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 (532) hide show
  1. package/.github/workflows/release.yaml +170 -0
  2. package/AGENTS.md +99 -0
  3. package/CLAUDE.md +123 -0
  4. package/CNAME +1 -0
  5. package/README.md +275 -9
  6. package/RUNME.md +56 -0
  7. package/assistants/codingAssistant/ABOUT.md +5 -0
  8. package/assistants/codingAssistant/CORE.md +33 -0
  9. package/assistants/codingAssistant/hooks.ts +21 -0
  10. package/assistants/codingAssistant/tools.ts +12 -0
  11. package/assistants/inkbot/ABOUT.md +16 -0
  12. package/assistants/inkbot/CORE.md +330 -0
  13. package/assistants/inkbot/hooks.ts +6 -0
  14. package/assistants/inkbot/tools.ts +53 -0
  15. package/assistants/researcher/ABOUT.md +5 -0
  16. package/assistants/researcher/CORE.md +46 -0
  17. package/assistants/researcher/hooks.ts +16 -0
  18. package/assistants/researcher/tools.ts +237 -0
  19. package/bun.lock +2667 -0
  20. package/bunfig.toml +3 -0
  21. package/commands/audit-docs.ts +740 -0
  22. package/commands/build-bootstrap.ts +117 -0
  23. package/commands/build-python-bridge.ts +42 -0
  24. package/commands/build-scaffolds.ts +175 -0
  25. package/commands/bundle-consumer-project.ts +521 -0
  26. package/commands/generate-api-docs.ts +114 -0
  27. package/commands/inkbot.ts +874 -0
  28. package/commands/release.ts +80 -0
  29. package/commands/try-all-challenges.ts +543 -0
  30. package/commands/try-challenge.ts +100 -0
  31. package/dist/agi/container.server.d.ts +63 -0
  32. package/dist/agi/container.server.d.ts.map +1 -0
  33. package/dist/agi/endpoints/ask.d.ts +20 -0
  34. package/dist/agi/endpoints/ask.d.ts.map +1 -0
  35. package/dist/agi/endpoints/conversations/[id].d.ts +27 -0
  36. package/dist/agi/endpoints/conversations/[id].d.ts.map +1 -0
  37. package/dist/agi/endpoints/conversations.d.ts +18 -0
  38. package/dist/agi/endpoints/conversations.d.ts.map +1 -0
  39. package/dist/agi/endpoints/experts.d.ts +8 -0
  40. package/dist/agi/endpoints/experts.d.ts.map +1 -0
  41. package/dist/agi/feature.d.ts +9 -0
  42. package/dist/agi/feature.d.ts.map +1 -0
  43. package/dist/agi/features/assistant.d.ts +509 -0
  44. package/dist/agi/features/assistant.d.ts.map +1 -0
  45. package/dist/agi/features/assistants-manager.d.ts +236 -0
  46. package/dist/agi/features/assistants-manager.d.ts.map +1 -0
  47. package/dist/agi/features/autonomous-assistant.d.ts +281 -0
  48. package/dist/agi/features/autonomous-assistant.d.ts.map +1 -0
  49. package/dist/agi/features/browser-use.d.ts +479 -0
  50. package/dist/agi/features/browser-use.d.ts.map +1 -0
  51. package/dist/agi/features/claude-code.d.ts +824 -0
  52. package/dist/agi/features/claude-code.d.ts.map +1 -0
  53. package/dist/agi/features/conversation-history.d.ts +245 -0
  54. package/dist/agi/features/conversation-history.d.ts.map +1 -0
  55. package/dist/agi/features/conversation.d.ts +464 -0
  56. package/dist/agi/features/conversation.d.ts.map +1 -0
  57. package/dist/agi/features/docs-reader.d.ts +72 -0
  58. package/dist/agi/features/docs-reader.d.ts.map +1 -0
  59. package/dist/agi/features/file-tools.d.ts +110 -0
  60. package/dist/agi/features/file-tools.d.ts.map +1 -0
  61. package/dist/agi/features/luca-coder.d.ts +323 -0
  62. package/dist/agi/features/luca-coder.d.ts.map +1 -0
  63. package/dist/agi/features/openai-codex.d.ts +381 -0
  64. package/dist/agi/features/openai-codex.d.ts.map +1 -0
  65. package/dist/agi/features/openapi.d.ts +200 -0
  66. package/dist/agi/features/openapi.d.ts.map +1 -0
  67. package/dist/agi/features/skills-library.d.ts +167 -0
  68. package/dist/agi/features/skills-library.d.ts.map +1 -0
  69. package/dist/agi/index.d.ts +5 -0
  70. package/dist/agi/index.d.ts.map +1 -0
  71. package/dist/agi/lib/interceptor-chain.d.ts +44 -0
  72. package/dist/agi/lib/interceptor-chain.d.ts.map +1 -0
  73. package/dist/agi/lib/token-counter.d.ts +13 -0
  74. package/dist/agi/lib/token-counter.d.ts.map +1 -0
  75. package/dist/bootstrap/generated.d.ts +5 -0
  76. package/dist/bootstrap/generated.d.ts.map +1 -0
  77. package/dist/browser.d.ts +12 -0
  78. package/dist/browser.d.ts.map +1 -0
  79. package/dist/bus.d.ts +29 -0
  80. package/dist/bus.d.ts.map +1 -0
  81. package/dist/cli/build-info.d.ts +4 -0
  82. package/dist/cli/build-info.d.ts.map +1 -0
  83. package/dist/cli/cli.d.ts +3 -12
  84. package/dist/cli/cli.d.ts.map +1 -0
  85. package/dist/client.d.ts +60 -0
  86. package/dist/client.d.ts.map +1 -0
  87. package/dist/clients/civitai/index.d.ts +472 -0
  88. package/dist/clients/civitai/index.d.ts.map +1 -0
  89. package/dist/clients/client-template.d.ts +30 -0
  90. package/dist/clients/client-template.d.ts.map +1 -0
  91. package/dist/clients/comfyui/index.d.ts +281 -0
  92. package/dist/clients/comfyui/index.d.ts.map +1 -0
  93. package/dist/clients/elevenlabs/index.d.ts +197 -0
  94. package/dist/clients/elevenlabs/index.d.ts.map +1 -0
  95. package/dist/clients/graph.d.ts +64 -0
  96. package/dist/clients/graph.d.ts.map +1 -0
  97. package/dist/clients/openai/index.d.ts +247 -0
  98. package/dist/clients/openai/index.d.ts.map +1 -0
  99. package/dist/clients/rest.d.ts +92 -0
  100. package/dist/clients/rest.d.ts.map +1 -0
  101. package/dist/clients/supabase/index.d.ts +176 -0
  102. package/dist/clients/supabase/index.d.ts.map +1 -0
  103. package/dist/clients/websocket.d.ts +127 -0
  104. package/dist/clients/websocket.d.ts.map +1 -0
  105. package/dist/command.d.ts +163 -0
  106. package/dist/command.d.ts.map +1 -0
  107. package/dist/commands/bootstrap.d.ts +20 -0
  108. package/dist/commands/bootstrap.d.ts.map +1 -0
  109. package/dist/commands/chat.d.ts +37 -0
  110. package/dist/commands/chat.d.ts.map +1 -0
  111. package/dist/commands/code.d.ts +28 -0
  112. package/dist/commands/code.d.ts.map +1 -0
  113. package/dist/commands/console.d.ts +22 -0
  114. package/dist/commands/console.d.ts.map +1 -0
  115. package/dist/commands/describe.d.ts +50 -0
  116. package/dist/commands/describe.d.ts.map +1 -0
  117. package/dist/commands/eval.d.ts +23 -0
  118. package/dist/commands/eval.d.ts.map +1 -0
  119. package/dist/commands/help.d.ts +25 -0
  120. package/dist/commands/help.d.ts.map +1 -0
  121. package/dist/commands/index.d.ts +18 -0
  122. package/dist/commands/index.d.ts.map +1 -0
  123. package/dist/commands/introspect.d.ts +24 -0
  124. package/dist/commands/introspect.d.ts.map +1 -0
  125. package/dist/commands/mcp.d.ts +35 -0
  126. package/dist/commands/mcp.d.ts.map +1 -0
  127. package/dist/commands/prompt.d.ts +38 -0
  128. package/dist/commands/prompt.d.ts.map +1 -0
  129. package/dist/commands/run.d.ts +24 -0
  130. package/dist/commands/run.d.ts.map +1 -0
  131. package/dist/commands/sandbox-mcp.d.ts +34 -0
  132. package/dist/commands/sandbox-mcp.d.ts.map +1 -0
  133. package/dist/commands/save-api-docs.d.ts +21 -0
  134. package/dist/commands/save-api-docs.d.ts.map +1 -0
  135. package/dist/commands/scaffold.d.ts +24 -0
  136. package/dist/commands/scaffold.d.ts.map +1 -0
  137. package/dist/commands/select.d.ts +22 -0
  138. package/dist/commands/select.d.ts.map +1 -0
  139. package/dist/commands/serve.d.ts +29 -0
  140. package/dist/commands/serve.d.ts.map +1 -0
  141. package/dist/container-describer.d.ts +144 -0
  142. package/dist/container-describer.d.ts.map +1 -0
  143. package/dist/container.d.ts +451 -0
  144. package/dist/container.d.ts.map +1 -0
  145. package/dist/endpoint.d.ts +113 -0
  146. package/dist/endpoint.d.ts.map +1 -0
  147. package/dist/feature.d.ts +47 -0
  148. package/dist/feature.d.ts.map +1 -0
  149. package/dist/graft.d.ts +29 -0
  150. package/dist/graft.d.ts.map +1 -0
  151. package/dist/hash-object.d.ts +8 -0
  152. package/dist/hash-object.d.ts.map +1 -0
  153. package/dist/helper.d.ts +209 -0
  154. package/dist/helper.d.ts.map +1 -0
  155. package/dist/introspection/generated.node.d.ts +44623 -0
  156. package/dist/introspection/generated.node.d.ts.map +1 -0
  157. package/dist/introspection/generated.web.d.ts +1412 -0
  158. package/dist/introspection/generated.web.d.ts.map +1 -0
  159. package/dist/introspection/index.d.ts +156 -0
  160. package/dist/introspection/index.d.ts.map +1 -0
  161. package/dist/introspection/scan.d.ts +147 -0
  162. package/dist/introspection/scan.d.ts.map +1 -0
  163. package/dist/node/container.d.ts +256 -0
  164. package/dist/node/container.d.ts.map +1 -0
  165. package/dist/node/feature.d.ts +9 -0
  166. package/dist/node/feature.d.ts.map +1 -0
  167. package/dist/node/features/container-link.d.ts +213 -0
  168. package/dist/node/features/container-link.d.ts.map +1 -0
  169. package/dist/node/features/content-db.d.ts +354 -0
  170. package/dist/node/features/content-db.d.ts.map +1 -0
  171. package/dist/node/features/disk-cache.d.ts +236 -0
  172. package/dist/node/features/disk-cache.d.ts.map +1 -0
  173. package/dist/node/features/dns.d.ts +511 -0
  174. package/dist/node/features/dns.d.ts.map +1 -0
  175. package/dist/node/features/docker.d.ts +485 -0
  176. package/dist/node/features/docker.d.ts.map +1 -0
  177. package/dist/node/features/downloader.d.ts +73 -0
  178. package/dist/node/features/downloader.d.ts.map +1 -0
  179. package/dist/node/features/figlet-fonts.d.ts +4 -0
  180. package/dist/node/features/figlet-fonts.d.ts.map +1 -0
  181. package/dist/node/features/file-manager.d.ts +177 -0
  182. package/dist/node/features/file-manager.d.ts.map +1 -0
  183. package/dist/node/features/fs.d.ts +635 -0
  184. package/dist/node/features/fs.d.ts.map +1 -0
  185. package/dist/node/features/git.d.ts +329 -0
  186. package/dist/node/features/git.d.ts.map +1 -0
  187. package/dist/node/features/google-auth.d.ts +200 -0
  188. package/dist/node/features/google-auth.d.ts.map +1 -0
  189. package/dist/node/features/google-calendar.d.ts +194 -0
  190. package/dist/node/features/google-calendar.d.ts.map +1 -0
  191. package/dist/node/features/google-docs.d.ts +138 -0
  192. package/dist/node/features/google-docs.d.ts.map +1 -0
  193. package/dist/node/features/google-drive.d.ts +202 -0
  194. package/dist/node/features/google-drive.d.ts.map +1 -0
  195. package/dist/node/features/google-mail.d.ts +221 -0
  196. package/dist/node/features/google-mail.d.ts.map +1 -0
  197. package/dist/node/features/google-sheets.d.ts +157 -0
  198. package/dist/node/features/google-sheets.d.ts.map +1 -0
  199. package/dist/node/features/grep.d.ts +207 -0
  200. package/dist/node/features/grep.d.ts.map +1 -0
  201. package/dist/node/features/helpers.d.ts +236 -0
  202. package/dist/node/features/helpers.d.ts.map +1 -0
  203. package/dist/node/features/ink.d.ts +332 -0
  204. package/dist/node/features/ink.d.ts.map +1 -0
  205. package/dist/node/features/ipc-socket.d.ts +298 -0
  206. package/dist/node/features/ipc-socket.d.ts.map +1 -0
  207. package/dist/node/features/json-tree.d.ts +140 -0
  208. package/dist/node/features/json-tree.d.ts.map +1 -0
  209. package/dist/node/features/networking.d.ts +373 -0
  210. package/dist/node/features/networking.d.ts.map +1 -0
  211. package/dist/node/features/nlp.d.ts +125 -0
  212. package/dist/node/features/nlp.d.ts.map +1 -0
  213. package/dist/node/features/opener.d.ts +93 -0
  214. package/dist/node/features/opener.d.ts.map +1 -0
  215. package/dist/node/features/os.d.ts +168 -0
  216. package/dist/node/features/os.d.ts.map +1 -0
  217. package/dist/node/features/package-finder.d.ts +419 -0
  218. package/dist/node/features/package-finder.d.ts.map +1 -0
  219. package/dist/node/features/postgres.d.ts +173 -0
  220. package/dist/node/features/postgres.d.ts.map +1 -0
  221. package/dist/node/features/proc.d.ts +285 -0
  222. package/dist/node/features/proc.d.ts.map +1 -0
  223. package/dist/node/features/process-manager.d.ts +427 -0
  224. package/dist/node/features/process-manager.d.ts.map +1 -0
  225. package/dist/node/features/python.d.ts +477 -0
  226. package/dist/node/features/python.d.ts.map +1 -0
  227. package/dist/node/features/redis.d.ts +247 -0
  228. package/dist/node/features/redis.d.ts.map +1 -0
  229. package/dist/node/features/repl.d.ts +84 -0
  230. package/dist/node/features/repl.d.ts.map +1 -0
  231. package/dist/node/features/runpod.d.ts +527 -0
  232. package/dist/node/features/runpod.d.ts.map +1 -0
  233. package/dist/node/features/secure-shell.d.ts +145 -0
  234. package/dist/node/features/secure-shell.d.ts.map +1 -0
  235. package/dist/node/features/semantic-search.d.ts +207 -0
  236. package/dist/node/features/semantic-search.d.ts.map +1 -0
  237. package/dist/node/features/sqlite.d.ts +180 -0
  238. package/dist/node/features/sqlite.d.ts.map +1 -0
  239. package/dist/node/features/telegram.d.ts +173 -0
  240. package/dist/node/features/telegram.d.ts.map +1 -0
  241. package/dist/node/features/transpiler.d.ts +51 -0
  242. package/dist/node/features/transpiler.d.ts.map +1 -0
  243. package/dist/node/features/tts.d.ts +108 -0
  244. package/dist/node/features/tts.d.ts.map +1 -0
  245. package/dist/node/features/ui.d.ts +562 -0
  246. package/dist/node/features/ui.d.ts.map +1 -0
  247. package/dist/node/features/vault.d.ts +90 -0
  248. package/dist/node/features/vault.d.ts.map +1 -0
  249. package/dist/node/features/vm.d.ts +285 -0
  250. package/dist/node/features/vm.d.ts.map +1 -0
  251. package/dist/node/features/yaml-tree.d.ts +118 -0
  252. package/dist/node/features/yaml-tree.d.ts.map +1 -0
  253. package/dist/node/features/yaml.d.ts +127 -0
  254. package/dist/node/features/yaml.d.ts.map +1 -0
  255. package/dist/node.d.ts +67 -0
  256. package/dist/node.d.ts.map +1 -0
  257. package/dist/python/generated.d.ts +2 -0
  258. package/dist/python/generated.d.ts.map +1 -0
  259. package/dist/react/index.d.ts +36 -0
  260. package/dist/react/index.d.ts.map +1 -0
  261. package/dist/registry.d.ts +97 -0
  262. package/dist/registry.d.ts.map +1 -0
  263. package/dist/scaffolds/generated.d.ts +13 -0
  264. package/dist/scaffolds/generated.d.ts.map +1 -0
  265. package/dist/scaffolds/template.d.ts +11 -0
  266. package/dist/scaffolds/template.d.ts.map +1 -0
  267. package/dist/schemas/base.d.ts +254 -0
  268. package/dist/schemas/base.d.ts.map +1 -0
  269. package/dist/selector.d.ts +130 -0
  270. package/dist/selector.d.ts.map +1 -0
  271. package/dist/server.d.ts +89 -0
  272. package/dist/server.d.ts.map +1 -0
  273. package/dist/servers/express.d.ts +104 -0
  274. package/dist/servers/express.d.ts.map +1 -0
  275. package/dist/servers/mcp.d.ts +201 -0
  276. package/dist/servers/mcp.d.ts.map +1 -0
  277. package/dist/servers/socket.d.ts +121 -0
  278. package/dist/servers/socket.d.ts.map +1 -0
  279. package/dist/state.d.ts +24 -0
  280. package/dist/state.d.ts.map +1 -0
  281. package/dist/web/clients/socket.d.ts +37 -0
  282. package/dist/web/clients/socket.d.ts.map +1 -0
  283. package/dist/web/container.d.ts +55 -0
  284. package/dist/web/container.d.ts.map +1 -0
  285. package/dist/web/extension.d.ts +4 -0
  286. package/dist/web/extension.d.ts.map +1 -0
  287. package/dist/web/feature.d.ts +8 -0
  288. package/dist/web/feature.d.ts.map +1 -0
  289. package/dist/web/features/asset-loader.d.ts +35 -0
  290. package/dist/web/features/asset-loader.d.ts.map +1 -0
  291. package/dist/web/features/container-link.d.ts +167 -0
  292. package/dist/web/features/container-link.d.ts.map +1 -0
  293. package/dist/web/features/esbuild.d.ts +51 -0
  294. package/dist/web/features/esbuild.d.ts.map +1 -0
  295. package/dist/web/features/helpers.d.ts +140 -0
  296. package/dist/web/features/helpers.d.ts.map +1 -0
  297. package/dist/web/features/network.d.ts +69 -0
  298. package/dist/web/features/network.d.ts.map +1 -0
  299. package/dist/web/features/speech.d.ts +71 -0
  300. package/dist/web/features/speech.d.ts.map +1 -0
  301. package/dist/web/features/vault.d.ts +62 -0
  302. package/dist/web/features/vault.d.ts.map +1 -0
  303. package/dist/web/features/vm.d.ts +48 -0
  304. package/dist/web/features/vm.d.ts.map +1 -0
  305. package/dist/web/features/voice-recognition.d.ts +96 -0
  306. package/dist/web/features/voice-recognition.d.ts.map +1 -0
  307. package/dist/web/shims/isomorphic-vm.d.ts +22 -0
  308. package/dist/web/shims/isomorphic-vm.d.ts.map +1 -0
  309. package/index.html +1457 -0
  310. package/index.ts +1 -0
  311. package/install.sh +84 -0
  312. package/luca.cli.ts +16 -0
  313. package/luca.console.ts +9 -0
  314. package/main.py +6 -0
  315. package/package.json +219 -58
  316. package/public/index.html +1457 -0
  317. package/public/slides-ai-native.html +902 -0
  318. package/public/slides-intro.html +974 -0
  319. package/pyproject.toml +7 -0
  320. package/scripts/build-web.ts +28 -0
  321. package/scripts/examples/ask-luca-expert.ts +42 -0
  322. package/scripts/examples/assistant-questions.ts +12 -0
  323. package/scripts/examples/excalidraw-expert.ts +75 -0
  324. package/scripts/examples/expert-chat.ts +0 -0
  325. package/scripts/examples/file-manager.ts +14 -0
  326. package/scripts/examples/ideas.ts +12 -0
  327. package/scripts/examples/interactive-chat.ts +20 -0
  328. package/scripts/examples/openai-tool-calls.ts +113 -0
  329. package/scripts/examples/opening-a-web-browser.ts +5 -0
  330. package/scripts/examples/telegram-bot.ts +79 -0
  331. package/scripts/examples/using-assistant-with-mcp.ts +555 -0
  332. package/scripts/examples/using-claude-code.ts +10 -0
  333. package/scripts/examples/using-contentdb.ts +35 -0
  334. package/scripts/examples/using-conversations.ts +35 -0
  335. package/scripts/examples/using-disk-cache.ts +10 -0
  336. package/scripts/examples/using-docker-shell.ts +75 -0
  337. package/scripts/examples/using-elevenlabs.ts +25 -0
  338. package/scripts/examples/using-google-calendar.ts +57 -0
  339. package/scripts/examples/using-google-docs.ts +74 -0
  340. package/scripts/examples/using-google-drive.ts +74 -0
  341. package/scripts/examples/using-google-sheets.ts +89 -0
  342. package/scripts/examples/using-nlp.ts +55 -0
  343. package/scripts/examples/using-ollama.ts +11 -0
  344. package/scripts/examples/using-postgres.ts +55 -0
  345. package/scripts/examples/using-runpod.ts +32 -0
  346. package/scripts/examples/using-tts.ts +40 -0
  347. package/scripts/scaffold.ts +391 -0
  348. package/scripts/scratch.ts +15 -0
  349. package/scripts/stamp-build.sh +12 -0
  350. package/scripts/test-assistant-hooks.ts +13 -0
  351. package/scripts/test-docs-reader.ts +10 -0
  352. package/scripts/test-linux-binary.sh +80 -0
  353. package/scripts/update-introspection-data.ts +58 -0
  354. package/src/agi/README.md +14 -0
  355. package/src/agi/container.server.ts +156 -0
  356. package/src/agi/feature.ts +13 -0
  357. package/src/agi/features/agent-memory.ts +694 -0
  358. package/src/agi/features/assistant.ts +1653 -0
  359. package/src/agi/features/assistants-manager.ts +534 -0
  360. package/src/agi/features/autonomous-assistant.ts +431 -0
  361. package/src/agi/features/browser-use.ts +672 -0
  362. package/src/agi/features/claude-code.ts +1584 -0
  363. package/src/agi/features/coding-tools.ts +175 -0
  364. package/src/agi/features/conversation-history.ts +672 -0
  365. package/src/agi/features/conversation.ts +1494 -0
  366. package/src/agi/features/docs-reader.ts +167 -0
  367. package/src/agi/features/file-tools.ts +340 -0
  368. package/src/agi/features/luca-coder.ts +641 -0
  369. package/src/agi/features/mcp-bridge.ts +532 -0
  370. package/src/agi/features/openai-codex.ts +651 -0
  371. package/src/agi/features/openapi.ts +445 -0
  372. package/src/agi/features/skills-library.ts +557 -0
  373. package/src/agi/index.ts +6 -0
  374. package/src/agi/lib/interceptor-chain.ts +89 -0
  375. package/src/agi/lib/token-counter.ts +202 -0
  376. package/src/bootstrap/generated.ts +9791 -0
  377. package/src/browser.ts +25 -0
  378. package/src/bus.ts +122 -0
  379. package/src/cli/build-info.ts +4 -0
  380. package/src/cli/cli.ts +355 -0
  381. package/src/client.ts +170 -0
  382. package/src/clients/civitai/index.ts +537 -0
  383. package/src/clients/client-template.ts +41 -0
  384. package/src/clients/comfyui/index.ts +604 -0
  385. package/src/clients/elevenlabs/index.ts +317 -0
  386. package/src/clients/graph.ts +87 -0
  387. package/src/clients/openai/index.ts +456 -0
  388. package/src/clients/rest.ts +207 -0
  389. package/src/clients/supabase/index.ts +357 -0
  390. package/src/clients/voicebox/index.ts +300 -0
  391. package/src/clients/websocket.ts +251 -0
  392. package/src/command.ts +506 -0
  393. package/src/commands/bootstrap.ts +244 -0
  394. package/src/commands/chat.ts +309 -0
  395. package/src/commands/code.ts +371 -0
  396. package/src/commands/console.ts +189 -0
  397. package/src/commands/describe.ts +243 -0
  398. package/src/commands/eval.ts +67 -0
  399. package/src/commands/help.ts +240 -0
  400. package/src/commands/index.ts +19 -0
  401. package/src/commands/introspect.ts +218 -0
  402. package/src/commands/mcp.ts +64 -0
  403. package/src/commands/prompt.ts +1014 -0
  404. package/src/commands/run.ts +278 -0
  405. package/src/commands/sandbox-mcp.ts +343 -0
  406. package/src/commands/save-api-docs.ts +51 -0
  407. package/src/commands/scaffold.ts +225 -0
  408. package/src/commands/select.ts +99 -0
  409. package/src/commands/serve.ts +208 -0
  410. package/src/container-describer.ts +1091 -0
  411. package/src/container.ts +1199 -0
  412. package/src/endpoint.ts +365 -0
  413. package/src/entity.ts +173 -0
  414. package/src/feature.ts +118 -0
  415. package/src/graft.ts +181 -0
  416. package/src/hash-object.ts +97 -0
  417. package/src/helper.ts +849 -0
  418. package/src/introspection/generated.agi.ts +41200 -0
  419. package/src/introspection/generated.node.ts +28773 -0
  420. package/src/introspection/generated.web.ts +2272 -0
  421. package/src/introspection/index.ts +296 -0
  422. package/src/introspection/scan.ts +1136 -0
  423. package/src/node/container.ts +409 -0
  424. package/src/node/feature.ts +13 -0
  425. package/src/node/features/container-link.ts +559 -0
  426. package/src/node/features/content-db.ts +849 -0
  427. package/src/node/features/disk-cache.ts +388 -0
  428. package/src/node/features/display-result.ts +57 -0
  429. package/src/node/features/dns.ts +669 -0
  430. package/src/node/features/docker.ts +921 -0
  431. package/src/node/features/downloader.ts +79 -0
  432. package/src/node/features/figlet-fonts.ts +600 -0
  433. package/src/node/features/file-manager.ts +535 -0
  434. package/src/node/features/fs.ts +1050 -0
  435. package/src/node/features/git.ts +592 -0
  436. package/src/node/features/google-auth.ts +504 -0
  437. package/src/node/features/google-calendar.ts +306 -0
  438. package/src/node/features/google-docs.ts +412 -0
  439. package/src/node/features/google-drive.ts +346 -0
  440. package/src/node/features/google-mail.ts +540 -0
  441. package/src/node/features/google-sheets.ts +286 -0
  442. package/src/node/features/grep.ts +427 -0
  443. package/src/node/features/helpers.ts +762 -0
  444. package/src/node/features/ink.ts +490 -0
  445. package/src/node/features/ipc-socket.ts +649 -0
  446. package/src/node/features/json-tree.ts +170 -0
  447. package/src/node/features/networking.ts +961 -0
  448. package/src/node/features/nlp.ts +212 -0
  449. package/src/node/features/opener.ts +180 -0
  450. package/src/node/features/os.ts +403 -0
  451. package/src/node/features/package-finder.ts +540 -0
  452. package/src/node/features/postgres.ts +289 -0
  453. package/src/node/features/proc.ts +503 -0
  454. package/src/node/features/process-manager.ts +844 -0
  455. package/src/node/features/python.ts +912 -0
  456. package/src/node/features/redis.ts +446 -0
  457. package/src/node/features/repl.ts +212 -0
  458. package/src/node/features/runpod.ts +811 -0
  459. package/src/node/features/secure-shell.ts +261 -0
  460. package/src/node/features/semantic-search.ts +935 -0
  461. package/src/node/features/sqlite.ts +289 -0
  462. package/src/node/features/telegram.ts +343 -0
  463. package/src/node/features/transpiler.ts +160 -0
  464. package/src/node/features/tts.ts +185 -0
  465. package/src/node/features/ui.ts +791 -0
  466. package/src/node/features/vault.ts +153 -0
  467. package/src/node/features/vm.ts +462 -0
  468. package/src/node/features/yaml-tree.ts +148 -0
  469. package/src/node/features/yaml.ts +133 -0
  470. package/src/node.ts +76 -0
  471. package/src/python/bridge.py +220 -0
  472. package/src/python/generated.ts +226 -0
  473. package/src/react/index.ts +175 -0
  474. package/src/registry.ts +210 -0
  475. package/src/scaffolds/generated.ts +1814 -0
  476. package/src/scaffolds/template.ts +46 -0
  477. package/src/schemas/base.ts +296 -0
  478. package/src/selector.ts +352 -0
  479. package/src/server.ts +229 -0
  480. package/src/servers/express.ts +283 -0
  481. package/src/servers/mcp.ts +802 -0
  482. package/src/servers/socket.ts +258 -0
  483. package/src/state.ts +101 -0
  484. package/src/web/clients/socket.ts +99 -0
  485. package/src/web/container.ts +75 -0
  486. package/src/web/extension.ts +30 -0
  487. package/src/web/feature.ts +12 -0
  488. package/src/web/features/asset-loader.ts +72 -0
  489. package/src/web/features/container-link.ts +382 -0
  490. package/src/web/features/esbuild.ts +93 -0
  491. package/src/web/features/helpers.ts +291 -0
  492. package/src/web/features/network.ts +85 -0
  493. package/src/web/features/speech.ts +104 -0
  494. package/src/web/features/vault.ts +207 -0
  495. package/src/web/features/vm.ts +85 -0
  496. package/src/web/features/voice-recognition.ts +161 -0
  497. package/src/web/shims/isomorphic-vm.ts +149 -0
  498. package/tsconfig.build.json +12 -0
  499. package/tsconfig.json +58 -0
  500. package/uv.lock +8 -0
  501. package/LICENSE +0 -21
  502. package/dist/cli/cli.js +0 -48
  503. package/dist/cli/common.d.ts +0 -2
  504. package/dist/cli/common.js +0 -6
  505. package/dist/cli/index.d.ts +0 -2
  506. package/dist/cli/index.js +0 -5
  507. package/dist/cli/run.d.ts +0 -1
  508. package/dist/cli/run.js +0 -38
  509. package/dist/core/index.d.ts +0 -4
  510. package/dist/core/index.js +0 -32
  511. package/dist/core/read.d.ts +0 -2
  512. package/dist/core/read.js +0 -29
  513. package/dist/core/request.d.ts +0 -1
  514. package/dist/core/request.js +0 -2
  515. package/dist/core/write.d.ts +0 -2
  516. package/dist/core/write.js +0 -21
  517. package/dist/index.d.ts +0 -1
  518. package/dist/index.js +0 -5
  519. package/dist/utils/common.d.ts +0 -9
  520. package/dist/utils/common.js +0 -57
  521. package/dist/utils/consts.d.ts +0 -3
  522. package/dist/utils/consts.js +0 -11
  523. package/dist/utils/dict.d.ts +0 -1
  524. package/dist/utils/dict.js +0 -7
  525. package/dist/utils/index.d.ts +0 -5
  526. package/dist/utils/index.js +0 -21
  527. package/dist/utils/log.d.ts +0 -1
  528. package/dist/utils/log.js +0 -5
  529. package/dist/utils/types.d.ts +0 -1
  530. package/dist/utils/types.js +0 -2
  531. package/dist/utils/utils.test.d.ts +0 -1
  532. package/dist/utils/utils.test.js +0 -7
@@ -0,0 +1,357 @@
1
+ import {
2
+ Client,
3
+ } from "luca/client";
4
+ import type { ContainerContext } from "luca/container";
5
+ import { z } from "zod";
6
+ import {
7
+ ClientStateSchema,
8
+ ClientOptionsSchema,
9
+ ClientEventsSchema,
10
+ } from "luca/schemas/base.js";
11
+ import {
12
+ createClient,
13
+ type SupabaseClient as SupabaseSDKClient,
14
+ type SupabaseClientOptions as SupabaseSDKOptions,
15
+ type RealtimeChannel,
16
+ } from "@supabase/supabase-js";
17
+
18
+ declare module "luca/client" {
19
+ interface AvailableClients {
20
+ supabase: typeof SupabaseClient;
21
+ }
22
+ }
23
+
24
+ // ---------------------------------------------------------------------------
25
+ // Schemas
26
+ // ---------------------------------------------------------------------------
27
+
28
+ export const SupabaseClientOptionsSchema = ClientOptionsSchema.extend({
29
+ supabaseUrl: z
30
+ .string()
31
+ .describe("The Supabase project URL (e.g. https://xyz.supabase.co)"),
32
+ supabaseKey: z
33
+ .string()
34
+ .describe("The Supabase anon or service-role key"),
35
+ clientOptions: z
36
+ .record(z.string(), z.any())
37
+ .optional()
38
+ .describe(
39
+ "Pass-through options forwarded directly to the Supabase SDK createClient()"
40
+ ),
41
+ }).describe("Options for creating a Supabase client");
42
+
43
+ export const SupabaseClientStateSchema = ClientStateSchema.extend({
44
+ authenticated: z
45
+ .boolean()
46
+ .default(false)
47
+ .describe("Whether a user session is currently active"),
48
+ userId: z
49
+ .string()
50
+ .nullable()
51
+ .default(null)
52
+ .describe("The authenticated user's ID, if any"),
53
+ userEmail: z
54
+ .string()
55
+ .nullable()
56
+ .default(null)
57
+ .describe("The authenticated user's email, if any"),
58
+ realtimeChannels: z
59
+ .array(z.string())
60
+ .default([])
61
+ .describe("Names of currently subscribed realtime channels"),
62
+ lastError: z
63
+ .string()
64
+ .nullable()
65
+ .default(null)
66
+ .describe("The most recent error message, if any"),
67
+ }).describe("Supabase client state");
68
+
69
+ export const SupabaseClientEventsSchema = ClientEventsSchema.extend({
70
+ authStateChange: z
71
+ .tuple([
72
+ z.string().describe("The auth event name (e.g. SIGNED_IN, SIGNED_OUT)"),
73
+ z.any().describe("The session object"),
74
+ ])
75
+ .describe("Emitted when the auth state changes"),
76
+ realtimeMessage: z
77
+ .tuple([
78
+ z.string().describe("The channel name"),
79
+ z.any().describe("The payload"),
80
+ ])
81
+ .describe("Emitted when a realtime message is received"),
82
+ realtimeStatus: z
83
+ .tuple([
84
+ z.string().describe("The channel name"),
85
+ z.string().describe("The status (e.g. SUBSCRIBED, CLOSED)"),
86
+ ])
87
+ .describe("Emitted when a realtime channel status changes"),
88
+ error: z
89
+ .tuple([z.any().describe("The error object")])
90
+ .describe("Emitted on any Supabase error"),
91
+ }).describe("Supabase client events");
92
+
93
+ export type SupabaseClientOptions = z.infer<typeof SupabaseClientOptionsSchema>;
94
+ export type SupabaseClientState = z.infer<typeof SupabaseClientStateSchema>;
95
+
96
+ // ---------------------------------------------------------------------------
97
+ // Client
98
+ // ---------------------------------------------------------------------------
99
+
100
+ /**
101
+ * Supabase client for the Luca container system.
102
+ *
103
+ * Wraps the official `@supabase/supabase-js` SDK and exposes it through Luca's
104
+ * typed state, events, and introspection system. The SDK is isomorphic so this
105
+ * single implementation works in both Node and browser containers.
106
+ *
107
+ * Use `client.sdk` for full SDK access, or use the convenience wrappers for
108
+ * common operations (auth, database queries, storage, edge functions, realtime).
109
+ *
110
+ * @example
111
+ * ```typescript
112
+ * const supabase = container.client('supabase', {
113
+ * supabaseUrl: 'https://xyz.supabase.co',
114
+ * supabaseKey: 'your-anon-key',
115
+ * })
116
+ *
117
+ * // Query data
118
+ * const { data } = await supabase.from('users').select('*')
119
+ *
120
+ * // Auth
121
+ * await supabase.signInWithPassword('user@example.com', 'password')
122
+ *
123
+ * // Realtime
124
+ * supabase.subscribe('changes', 'users', (payload) => {
125
+ * console.log('Change:', payload)
126
+ * })
127
+ * ```
128
+ */
129
+ export class SupabaseClient extends Client<
130
+ SupabaseClientState,
131
+ SupabaseClientOptions
132
+ > {
133
+ static override shortcut = "clients.supabase" as const;
134
+ static override description =
135
+ "Supabase client wrapping the official SDK with typed state, events, and realtime channel management";
136
+
137
+ static override stateSchema = SupabaseClientStateSchema;
138
+ static override optionsSchema = SupabaseClientOptionsSchema;
139
+ static override eventsSchema = SupabaseClientEventsSchema;
140
+
141
+ static { Client.register(this, 'supabase') }
142
+
143
+ private _sdk!: SupabaseSDKClient<any, any>;
144
+ private _channels = new Map<string, RealtimeChannel>();
145
+
146
+ constructor(options: SupabaseClientOptions, context: ContainerContext) {
147
+ super(options, context);
148
+
149
+ const sdkOptions = (options.clientOptions ?? {}) as SupabaseSDKOptions<string>;
150
+ this._sdk = createClient(options.supabaseUrl, options.supabaseKey, sdkOptions);
151
+
152
+ this._sdk.auth.onAuthStateChange((event, session) => {
153
+ const user = session?.user;
154
+ this.state.set("authenticated", !!session);
155
+ this.state.set("userId", user?.id ?? null);
156
+ this.state.set("userEmail", user?.email ?? null);
157
+ this.emit("authStateChange" as any, event, session);
158
+ });
159
+
160
+ this.state.set("connected", true);
161
+ }
162
+
163
+ // ---------------------------------------------------------------------------
164
+ // SDK access
165
+ // ---------------------------------------------------------------------------
166
+
167
+ /** Returns the raw Supabase SDK client for full access to all SDK methods. */
168
+ get sdk(): SupabaseSDKClient<any, any> {
169
+ return this._sdk;
170
+ }
171
+
172
+ // ---------------------------------------------------------------------------
173
+ // Database
174
+ // ---------------------------------------------------------------------------
175
+
176
+ /**
177
+ * Start a query on a Postgres table or view.
178
+ * @param table - The table or view name to query
179
+ */
180
+ from(table: string) {
181
+ return this._sdk.from(table);
182
+ }
183
+
184
+ /**
185
+ * Call a Postgres function (RPC).
186
+ * @param fn - The function name
187
+ * @param params - Arguments to pass to the function
188
+ * @param options - Optional settings (head, get, count)
189
+ */
190
+ rpc(fn: string, params?: Record<string, unknown>, options?: { head?: boolean; get?: boolean; count?: "exact" | "planned" | "estimated" }) {
191
+ return this._sdk.rpc(fn, params, options);
192
+ }
193
+
194
+ // ---------------------------------------------------------------------------
195
+ // Auth
196
+ // ---------------------------------------------------------------------------
197
+
198
+ /** Sign in with email and password. */
199
+ async signInWithPassword(email: string, password: string) {
200
+ const result = await this._sdk.auth.signInWithPassword({ email, password });
201
+ if (result.error) {
202
+ this._setError(result.error.message);
203
+ }
204
+ return result;
205
+ }
206
+
207
+ /** Create a new user account with email and password. */
208
+ async signUp(email: string, password: string) {
209
+ const result = await this._sdk.auth.signUp({ email, password });
210
+ if (result.error) {
211
+ this._setError(result.error.message);
212
+ }
213
+ return result;
214
+ }
215
+
216
+ /** Sign the current user out. */
217
+ async signOut() {
218
+ const result = await this._sdk.auth.signOut();
219
+ if (result.error) {
220
+ this._setError(result.error.message);
221
+ }
222
+ return result;
223
+ }
224
+
225
+ /** Get the current session, if any. */
226
+ async getSession() {
227
+ return this._sdk.auth.getSession();
228
+ }
229
+
230
+ /** Get the current user, if any. */
231
+ async getUser() {
232
+ return this._sdk.auth.getUser();
233
+ }
234
+
235
+ // ---------------------------------------------------------------------------
236
+ // Storage
237
+ // ---------------------------------------------------------------------------
238
+
239
+ /** Returns the Supabase Storage client for managing buckets and files. */
240
+ get storage() {
241
+ return this._sdk.storage;
242
+ }
243
+
244
+ // ---------------------------------------------------------------------------
245
+ // Edge Functions
246
+ // ---------------------------------------------------------------------------
247
+
248
+ /** Returns the Supabase Functions client. */
249
+ get functions() {
250
+ return this._sdk.functions;
251
+ }
252
+
253
+ /** Invoke a Supabase Edge Function by name. */
254
+ async invoke(name: string, body?: any) {
255
+ const result = await this._sdk.functions.invoke(name, { body });
256
+ if (result.error) {
257
+ this._setError(result.error.message);
258
+ }
259
+ return result;
260
+ }
261
+
262
+ // ---------------------------------------------------------------------------
263
+ // Realtime
264
+ // ---------------------------------------------------------------------------
265
+
266
+ /**
267
+ * Subscribe to realtime changes on a Postgres table.
268
+ * @param channelName - A name for this subscription channel
269
+ * @param table - The table to listen to
270
+ * @param callback - Called with the payload on each change
271
+ * @param event - The event type to listen for (default: all changes)
272
+ */
273
+ subscribe(
274
+ channelName: string,
275
+ table: string,
276
+ callback: (payload: any) => void,
277
+ event: "INSERT" | "UPDATE" | "DELETE" | "*" = "*"
278
+ ): RealtimeChannel {
279
+ const channel = this._sdk
280
+ .channel(channelName)
281
+ .on(
282
+ "postgres_changes" as any,
283
+ { event, schema: "public", table },
284
+ (payload: any) => {
285
+ this.emit("realtimeMessage" as any, channelName, payload);
286
+ callback(payload);
287
+ }
288
+ )
289
+ .subscribe((status: string) => {
290
+ this.emit("realtimeStatus" as any, channelName, status);
291
+ });
292
+
293
+ this._channels.set(channelName, channel);
294
+ this._syncChannelState();
295
+ return channel;
296
+ }
297
+
298
+ /**
299
+ * Unsubscribe and remove a realtime channel by name.
300
+ * @param channelName - The channel name to remove
301
+ */
302
+ async unsubscribe(channelName: string) {
303
+ const channel = this._channels.get(channelName);
304
+ if (channel) {
305
+ await this._sdk.removeChannel(channel);
306
+ this._channels.delete(channelName);
307
+ this._syncChannelState();
308
+ }
309
+ }
310
+
311
+ /** Unsubscribe and remove all realtime channels. */
312
+ async unsubscribeAll() {
313
+ await this._sdk.removeAllChannels();
314
+ this._channels.clear();
315
+ this._syncChannelState();
316
+ }
317
+
318
+ // ---------------------------------------------------------------------------
319
+ // Lifecycle
320
+ // ---------------------------------------------------------------------------
321
+
322
+ /**
323
+ * Connect is a no-op since the Supabase SDK initializes on construction.
324
+ * The client is ready to use immediately after creation.
325
+ */
326
+ override async connect() {
327
+ this.state.set("connected", true);
328
+ return this;
329
+ }
330
+
331
+ /**
332
+ * Disconnect by signing out and removing all realtime channels.
333
+ */
334
+ async disconnect() {
335
+ await this.unsubscribeAll();
336
+ await this._sdk.auth.signOut();
337
+ this.state.set("connected", false);
338
+ this.state.set("authenticated", false);
339
+ this.state.set("userId", null);
340
+ this.state.set("userEmail", null);
341
+ }
342
+
343
+ // ---------------------------------------------------------------------------
344
+ // Internal
345
+ // ---------------------------------------------------------------------------
346
+
347
+ private _syncChannelState() {
348
+ this.state.set("realtimeChannels", Array.from(this._channels.keys()));
349
+ }
350
+
351
+ private _setError(message: string) {
352
+ this.state.set("lastError", message);
353
+ this.emit("error" as any, new Error(message));
354
+ }
355
+ }
356
+
357
+ export default SupabaseClient;
@@ -0,0 +1,300 @@
1
+ import { z } from 'zod'
2
+ import { ClientStateSchema, ClientOptionsSchema, ClientEventsSchema } from 'luca/schemas/base.js'
3
+ import { Client } from "luca/client";
4
+ import { RestClient } from "../rest";
5
+ import type { ContainerContext } from "luca/container";
6
+ import type { NodeContainer } from "../../node/container.js";
7
+
8
+ declare module "luca/client" {
9
+ interface AvailableClients {
10
+ voicebox: typeof VoiceBoxClient;
11
+ }
12
+ }
13
+
14
+ export const VoiceBoxClientOptionsSchema = ClientOptionsSchema.extend({
15
+ baseURL: z.string().optional().describe('VoiceBox server URL (falls back to VOICEBOX_URL env var, default http://127.0.0.1:17493)'),
16
+ defaultProfileId: z.string().optional().describe('Default voice profile ID for synthesis'),
17
+ defaultEngine: z.string().optional().default('qwen').describe('Default TTS engine (qwen, luxtts, chatterbox, chatterbox_turbo)'),
18
+ defaultModelSize: z.string().optional().default('1.7B').describe('Default model size (1.7B or 0.6B)'),
19
+ defaultLanguage: z.string().optional().default('en').describe('Default language code'),
20
+ })
21
+ export type VoiceBoxClientOptions = z.infer<typeof VoiceBoxClientOptionsSchema>
22
+
23
+ export const VoiceBoxClientStateSchema = ClientStateSchema.extend({
24
+ requestCount: z.number().default(0).describe('Total number of API requests made'),
25
+ characterCount: z.number().default(0).describe('Total characters sent for synthesis'),
26
+ lastRequestTime: z.number().nullable().default(null).describe('Timestamp of the last API request'),
27
+ })
28
+ export type VoiceBoxClientState = z.infer<typeof VoiceBoxClientStateSchema>
29
+
30
+ export const VoiceBoxClientEventsSchema = ClientEventsSchema.extend({
31
+ speech: z.tuple([z.object({
32
+ profileId: z.string(),
33
+ text: z.string(),
34
+ audioSize: z.number(),
35
+ })]).describe('Emitted after speech synthesis completes'),
36
+ profiles: z.tuple([z.array(z.any())]).describe('Emitted after listing profiles'),
37
+ })
38
+
39
+ export type EffectConfig = {
40
+ type: string
41
+ enabled?: boolean
42
+ params?: Record<string, any>
43
+ }
44
+
45
+ export type SynthesizeOptions = {
46
+ profileId?: string
47
+ engine?: string
48
+ modelSize?: string
49
+ language?: string
50
+ instruct?: string
51
+ seed?: number
52
+ maxChunkChars?: number
53
+ crossfadeMs?: number
54
+ normalize?: boolean
55
+ effectsChain?: EffectConfig[]
56
+ disableCache?: boolean
57
+ }
58
+
59
+ /**
60
+ * VoiceBox client — local TTS synthesis via VoiceBox.sh REST API (Qwen3-TTS).
61
+ *
62
+ * Provides methods for managing voice profiles and generating speech audio locally.
63
+ * Uses the streaming endpoint for synchronous synthesis (returns WAV buffer).
64
+ *
65
+ * @example
66
+ * ```typescript
67
+ * const vb = container.client('voicebox')
68
+ * await vb.connect()
69
+ * const profiles = await vb.listProfiles()
70
+ * const audio = await vb.synthesize('Hello world', { profileId: profiles[0].id })
71
+ * // audio is a Buffer of WAV data
72
+ * ```
73
+ */
74
+ export class VoiceBoxClient extends RestClient<VoiceBoxClientState, VoiceBoxClientOptions> {
75
+ static override shortcut = "clients.voicebox" as const
76
+ static override envVars = ['VOICEBOX_URL']
77
+ static override stateSchema = VoiceBoxClientStateSchema
78
+ static override optionsSchema = VoiceBoxClientOptionsSchema
79
+ static override eventsSchema = VoiceBoxClientEventsSchema
80
+
81
+ static { Client.register(this, 'voicebox') }
82
+
83
+ override get initialState(): VoiceBoxClientState {
84
+ return {
85
+ ...super.initialState,
86
+ requestCount: 0,
87
+ characterCount: 0,
88
+ lastRequestTime: null,
89
+ }
90
+ }
91
+
92
+ constructor(options: VoiceBoxClientOptions, context: ContainerContext) {
93
+ options = {
94
+ ...options,
95
+ baseURL: options.baseURL || process.env.VOICEBOX_URL || 'http://127.0.0.1:17493',
96
+ }
97
+ super(options, context)
98
+ }
99
+
100
+ override get container(): NodeContainer {
101
+ return super.container as unknown as NodeContainer
102
+ }
103
+
104
+ private trackRequest(characters = 0) {
105
+ const requestCount = this.state.get('requestCount') || 0
106
+ const characterCount = this.state.get('characterCount') || 0
107
+ this.setState({
108
+ requestCount: requestCount + 1,
109
+ characterCount: characterCount + characters,
110
+ lastRequestTime: Date.now(),
111
+ })
112
+ }
113
+
114
+ /**
115
+ * Validate the VoiceBox server is reachable by hitting the health endpoint.
116
+ */
117
+ override async connect(): Promise<this> {
118
+ try {
119
+ const health = await this.get('/health')
120
+ if (health?.status !== 'ok' && health?.status !== 'healthy') {
121
+ // Accept any 200 response as healthy
122
+ }
123
+ await super.connect()
124
+ this.emit('connected' as any)
125
+ return this
126
+ } catch (error) {
127
+ this.emit('failure', error)
128
+ throw error
129
+ }
130
+ }
131
+
132
+ /**
133
+ * List all voice profiles.
134
+ *
135
+ * @returns Array of voice profile objects
136
+ *
137
+ * @example
138
+ * ```typescript
139
+ * const profiles = await vb.listProfiles()
140
+ * console.log(profiles.map(p => `${p.name} (${p.sample_count} samples)`))
141
+ * ```
142
+ */
143
+ async listProfiles(): Promise<any[]> {
144
+ this.trackRequest()
145
+ const result = await this.get('/profiles')
146
+ const profiles = Array.isArray(result) ? result : []
147
+ this.emit('profiles', profiles)
148
+ return profiles
149
+ }
150
+
151
+ /**
152
+ * Get a single voice profile by ID.
153
+ */
154
+ async getProfile(profileId: string): Promise<any> {
155
+ this.trackRequest()
156
+ return this.get(`/profiles/${profileId}`)
157
+ }
158
+
159
+ /**
160
+ * Create a new voice profile.
161
+ */
162
+ async createProfile(name: string, options: { description?: string; language?: string } = {}): Promise<any> {
163
+ this.trackRequest()
164
+ return this.post('/profiles', { name, ...options })
165
+ }
166
+
167
+ /**
168
+ * List available audio effects and their parameter definitions.
169
+ */
170
+ async listEffects(): Promise<any> {
171
+ this.trackRequest()
172
+ return this.get('/effects/available')
173
+ }
174
+
175
+ /**
176
+ * Synthesize speech from text using the streaming endpoint.
177
+ * Returns audio as a WAV Buffer (synchronous — blocks until audio is ready).
178
+ *
179
+ * @param text - The text to convert to speech
180
+ * @param options - Profile, engine, model, and other synthesis options
181
+ * @returns Audio data as a WAV Buffer
182
+ *
183
+ * @example
184
+ * ```typescript
185
+ * const audio = await vb.synthesize('Hello world', { profileId: 'abc-123' })
186
+ * // audio is a Buffer of WAV data
187
+ * ```
188
+ */
189
+ async synthesize(text: string, options: SynthesizeOptions = {}): Promise<Buffer> {
190
+ const profileId = options.profileId || this.options.defaultProfileId
191
+ if (!profileId) throw new Error('profileId is required for VoiceBox synthesis')
192
+
193
+ const engine = options.engine || this.options.defaultEngine || 'qwen'
194
+ const modelSize = options.modelSize || this.options.defaultModelSize || '1.7B'
195
+ const language = options.language || this.options.defaultLanguage || 'en'
196
+
197
+ const body: Record<string, any> = {
198
+ profile_id: profileId,
199
+ text,
200
+ language,
201
+ engine,
202
+ model_size: modelSize,
203
+ }
204
+
205
+ if (options.instruct) body.instruct = options.instruct
206
+ if (options.seed != null) body.seed = options.seed
207
+ if (options.maxChunkChars != null) body.max_chunk_chars = options.maxChunkChars
208
+ if (options.crossfadeMs != null) body.crossfade_ms = options.crossfadeMs
209
+ if (options.normalize != null) body.normalize = options.normalize
210
+ if (options.effectsChain) body.effects_chain = options.effectsChain
211
+
212
+ // Check disk cache
213
+ if (!options.disableCache) {
214
+ const { hashObject } = this.container.utils
215
+ const cacheKey = `voicebox:${hashObject({ text, profileId, engine, modelSize, language, instruct: options.instruct })}`
216
+ const diskCache = this.container.feature('diskCache')
217
+
218
+ if (await diskCache.has(cacheKey)) {
219
+ const cached = await diskCache.get(cacheKey)
220
+ const audioBuffer = Buffer.from(cached, 'base64')
221
+ this.emit('speech', { profileId, text, audioSize: audioBuffer.length })
222
+ return audioBuffer
223
+ }
224
+
225
+ const audioBuffer = await this.fetchStreamAudio(body, text.length)
226
+ await diskCache.set(cacheKey, audioBuffer.toString('base64'))
227
+ this.emit('speech', { profileId, text, audioSize: audioBuffer.length })
228
+ return audioBuffer
229
+ }
230
+
231
+ const audioBuffer = await this.fetchStreamAudio(body, text.length)
232
+ this.emit('speech', { profileId, text, audioSize: audioBuffer.length })
233
+ return audioBuffer
234
+ }
235
+
236
+ /**
237
+ * Generate speech asynchronously (returns metadata, not audio).
238
+ * Use getAudio() to fetch the audio after generation completes.
239
+ */
240
+ async generate(text: string, options: SynthesizeOptions = {}): Promise<any> {
241
+ const profileId = options.profileId || this.options.defaultProfileId
242
+ if (!profileId) throw new Error('profileId is required for VoiceBox generation')
243
+
244
+ const body: Record<string, any> = {
245
+ profile_id: profileId,
246
+ text,
247
+ language: options.language || this.options.defaultLanguage || 'en',
248
+ engine: options.engine || this.options.defaultEngine || 'qwen',
249
+ model_size: options.modelSize || this.options.defaultModelSize || '1.7B',
250
+ }
251
+
252
+ if (options.instruct) body.instruct = options.instruct
253
+ if (options.seed != null) body.seed = options.seed
254
+ if (options.effectsChain) body.effects_chain = options.effectsChain
255
+
256
+ this.trackRequest(text.length)
257
+ return this.post('/generate', body)
258
+ }
259
+
260
+ /**
261
+ * Fetch generated audio by generation ID. Returns WAV Buffer.
262
+ */
263
+ async getAudio(generationId: string): Promise<Buffer> {
264
+ this.trackRequest()
265
+ const response = await this.axios({
266
+ method: 'GET',
267
+ url: `/audio/${generationId}`,
268
+ responseType: 'arraybuffer',
269
+ headers: { Accept: 'audio/wav' },
270
+ })
271
+ return Buffer.from(response.data)
272
+ }
273
+
274
+ /**
275
+ * Synthesize and write audio to a file.
276
+ */
277
+ async say(text: string, outputPath: string, options: SynthesizeOptions = {}): Promise<string> {
278
+ const audio = await this.synthesize(text, options)
279
+ const resolvedPath = this.container.paths.resolve(outputPath)
280
+ await this.container.fs.writeFileAsync(resolvedPath, audio)
281
+ return resolvedPath
282
+ }
283
+
284
+ private async fetchStreamAudio(body: Record<string, any>, charCount: number): Promise<Buffer> {
285
+ this.trackRequest(charCount)
286
+ const response = await this.axios({
287
+ method: 'POST',
288
+ url: '/generate/stream',
289
+ data: body,
290
+ responseType: 'arraybuffer',
291
+ headers: {
292
+ 'Content-Type': 'application/json',
293
+ Accept: 'audio/wav',
294
+ },
295
+ })
296
+ return Buffer.from(response.data)
297
+ }
298
+ }
299
+
300
+ export default VoiceBoxClient