whale-code 6.5.5 → 6.5.6

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 (847) hide show
  1. package/README.md +39 -31
  2. package/bin/{swagmanager-mcp.js → whale-code.js} +17 -2
  3. package/dist/cli/app.js +148 -72
  4. package/dist/cli/app.js.map +1 -0
  5. package/dist/cli/chat/AgentSelector.js +105 -10
  6. package/dist/cli/chat/AgentSelector.js.map +1 -0
  7. package/dist/cli/chat/ChatApp.d.ts +31 -0
  8. package/dist/cli/chat/ChatApp.js +539 -286
  9. package/dist/cli/chat/ChatApp.js.map +1 -0
  10. package/dist/cli/chat/ChatInput.js +1088 -770
  11. package/dist/cli/chat/ChatInput.js.map +1 -0
  12. package/dist/cli/chat/MarkdownText.js +39 -14
  13. package/dist/cli/chat/MarkdownText.js.map +1 -0
  14. package/dist/cli/chat/MemoryManager.js +181 -46
  15. package/dist/cli/chat/MemoryManager.js.map +1 -0
  16. package/dist/cli/chat/MessageList.d.ts +2 -3
  17. package/dist/cli/chat/MessageList.js +186 -45
  18. package/dist/cli/chat/MessageList.js.map +1 -0
  19. package/dist/cli/chat/ModelSelector.js +282 -63
  20. package/dist/cli/chat/ModelSelector.js.map +1 -0
  21. package/dist/cli/chat/NodeManager.js +165 -75
  22. package/dist/cli/chat/NodeManager.js.map +1 -0
  23. package/dist/cli/chat/NodeSelector.js +171 -30
  24. package/dist/cli/chat/NodeSelector.js.map +1 -0
  25. package/dist/cli/chat/PlanApproval.js +281 -57
  26. package/dist/cli/chat/PlanApproval.js.map +1 -0
  27. package/dist/cli/chat/RewindViewer.js +559 -144
  28. package/dist/cli/chat/RewindViewer.js.map +1 -0
  29. package/dist/cli/chat/SessionManager.js +137 -30
  30. package/dist/cli/chat/SessionManager.js.map +1 -0
  31. package/dist/cli/chat/SlashMenu.js +293 -164
  32. package/dist/cli/chat/SlashMenu.js.map +1 -0
  33. package/dist/cli/chat/StatusBar.js +172 -9
  34. package/dist/cli/chat/StatusBar.js.map +1 -0
  35. package/dist/cli/chat/StoreSelector.js +147 -18
  36. package/dist/cli/chat/StoreSelector.js.map +1 -0
  37. package/dist/cli/chat/StreamingText.d.ts +1 -5
  38. package/dist/cli/chat/StreamingText.js +22 -7
  39. package/dist/cli/chat/StreamingText.js.map +1 -0
  40. package/dist/cli/chat/SubagentPanel.d.ts +1 -2
  41. package/dist/cli/chat/SubagentPanel.js +612 -72
  42. package/dist/cli/chat/SubagentPanel.js.map +1 -0
  43. package/dist/cli/chat/TeamPanel.d.ts +1 -0
  44. package/dist/cli/chat/TeamPanel.js +230 -30
  45. package/dist/cli/chat/TeamPanel.js.map +1 -0
  46. package/dist/cli/chat/ThemeSelector.js +84 -24
  47. package/dist/cli/chat/ThemeSelector.js.map +1 -0
  48. package/dist/cli/chat/ToolIndicator.js +1476 -371
  49. package/dist/cli/chat/ToolIndicator.js.map +1 -0
  50. package/dist/cli/chat/hooks/useAgentLoop.d.ts +1 -0
  51. package/dist/cli/chat/hooks/useAgentLoop.js +481 -367
  52. package/dist/cli/chat/hooks/useAgentLoop.js.map +1 -0
  53. package/dist/cli/chat/hooks/useSlashCommands.d.ts +3 -14
  54. package/dist/cli/chat/hooks/useSlashCommands.js +744 -572
  55. package/dist/cli/chat/hooks/useSlashCommands.js.map +1 -0
  56. package/dist/cli/commands/config-cmd.js +56 -57
  57. package/dist/cli/commands/config-cmd.js.map +1 -0
  58. package/dist/cli/commands/db.js +184 -169
  59. package/dist/cli/commands/db.js.map +1 -0
  60. package/dist/cli/commands/doctor.js +212 -122
  61. package/dist/cli/commands/doctor.js.map +1 -0
  62. package/dist/cli/commands/init.js +211 -244
  63. package/dist/cli/commands/init.js.map +1 -0
  64. package/dist/cli/commands/mcp.js +127 -122
  65. package/dist/cli/commands/mcp.js.map +1 -0
  66. package/dist/cli/login/LoginApp.js +355 -141
  67. package/dist/cli/login/LoginApp.js.map +1 -0
  68. package/dist/cli/print-mode.js +196 -177
  69. package/dist/cli/print-mode.js.map +1 -0
  70. package/dist/cli/serve-mode.js +615 -530
  71. package/dist/cli/serve-mode.js.map +1 -0
  72. package/dist/cli/services/agent-config.d.ts +5 -1
  73. package/dist/cli/services/agent-config.js +66 -36
  74. package/dist/cli/services/agent-config.js.map +1 -0
  75. package/dist/cli/services/agent-definitions.d.ts +4 -1
  76. package/dist/cli/services/agent-definitions.js +97 -56
  77. package/dist/cli/services/agent-definitions.js.map +1 -0
  78. package/dist/cli/services/agent-events.js +225 -162
  79. package/dist/cli/services/agent-events.js.map +1 -0
  80. package/dist/cli/services/agent-loop.js +976 -688
  81. package/dist/cli/services/agent-loop.js.map +1 -0
  82. package/dist/cli/services/agent-worker-base.d.ts +35 -5
  83. package/dist/cli/services/agent-worker-base.js +337 -153
  84. package/dist/cli/services/agent-worker-base.js.map +1 -0
  85. package/dist/cli/services/api-retry.js +69 -64
  86. package/dist/cli/services/api-retry.js.map +1 -0
  87. package/dist/cli/services/auth-service.d.ts +3 -3
  88. package/dist/cli/services/auth-service.js +209 -132
  89. package/dist/cli/services/auth-service.js.map +1 -0
  90. package/dist/cli/services/background-processes.js +343 -267
  91. package/dist/cli/services/background-processes.js.map +1 -0
  92. package/dist/cli/services/browser-auth.d.ts +2 -2
  93. package/dist/cli/services/browser-auth.js +159 -118
  94. package/dist/cli/services/browser-auth.js.map +1 -0
  95. package/dist/cli/services/claude-md-loader.js +40 -36
  96. package/dist/cli/services/claude-md-loader.js.map +1 -0
  97. package/dist/cli/services/config-store.d.ts +9 -4
  98. package/dist/cli/services/config-store.js +164 -117
  99. package/dist/cli/services/config-store.js.map +1 -0
  100. package/dist/cli/services/debug-log.d.ts +1 -1
  101. package/dist/cli/services/debug-log.js +34 -35
  102. package/dist/cli/services/debug-log.js.map +1 -0
  103. package/dist/cli/services/env-detect.d.ts +7 -0
  104. package/dist/cli/services/env-detect.js +9 -0
  105. package/dist/cli/services/env-detect.js.map +1 -0
  106. package/dist/cli/services/error-logger.js +187 -169
  107. package/dist/cli/services/error-logger.js.map +1 -0
  108. package/dist/cli/services/file-history.d.ts +1 -1
  109. package/dist/cli/services/file-history.js +50 -54
  110. package/dist/cli/services/file-history.js.map +1 -0
  111. package/dist/cli/services/format-server-response.js +332 -372
  112. package/dist/cli/services/format-server-response.js.map +1 -0
  113. package/dist/cli/services/git-context.js +61 -45
  114. package/dist/cli/services/git-context.js.map +1 -0
  115. package/dist/cli/services/hooks.d.ts +2 -2
  116. package/dist/cli/services/hooks.js +195 -180
  117. package/dist/cli/services/hooks.js.map +1 -0
  118. package/dist/cli/services/ink-incremental.d.ts +19 -0
  119. package/dist/cli/services/ink-incremental.js +59 -0
  120. package/dist/cli/services/ink-incremental.js.map +1 -0
  121. package/dist/cli/services/ink-resize-fix.js +54 -44
  122. package/dist/cli/services/ink-resize-fix.js.map +1 -0
  123. package/dist/cli/services/ink-sync-output.d.ts +12 -0
  124. package/dist/cli/services/ink-sync-output.js +16 -0
  125. package/dist/cli/services/ink-sync-output.js.map +1 -0
  126. package/dist/cli/services/interactive-tools.js +268 -212
  127. package/dist/cli/services/interactive-tools.js.map +1 -0
  128. package/dist/cli/services/keybinding-manager.d.ts +11 -1
  129. package/dist/cli/services/keybinding-manager.js +126 -63
  130. package/dist/cli/services/keybinding-manager.js.map +1 -0
  131. package/dist/cli/services/local-tools.d.ts +1 -1
  132. package/dist/cli/services/local-tools.js +939 -656
  133. package/dist/cli/services/local-tools.js.map +1 -0
  134. package/dist/cli/services/lsp-manager.js +757 -594
  135. package/dist/cli/services/lsp-manager.js.map +1 -0
  136. package/dist/cli/services/mcp-client.d.ts +1 -1
  137. package/dist/cli/services/mcp-client.js +173 -134
  138. package/dist/cli/services/mcp-client.js.map +1 -0
  139. package/dist/cli/services/memory-manager.js +53 -40
  140. package/dist/cli/services/memory-manager.js.map +1 -0
  141. package/dist/cli/services/model-manager.js +55 -40
  142. package/dist/cli/services/model-manager.js.map +1 -0
  143. package/dist/cli/services/model-router.js +115 -85
  144. package/dist/cli/services/model-router.js.map +1 -0
  145. package/dist/cli/services/paths.d.ts +30 -0
  146. package/dist/cli/services/paths.js +81 -0
  147. package/dist/cli/services/paths.js.map +1 -0
  148. package/dist/cli/services/permission-modes.js +32 -25
  149. package/dist/cli/services/permission-modes.js.map +1 -0
  150. package/dist/cli/services/rewind.js +182 -168
  151. package/dist/cli/services/rewind.js.map +1 -0
  152. package/dist/cli/services/ripgrep.js +115 -115
  153. package/dist/cli/services/ripgrep.js.map +1 -0
  154. package/dist/cli/services/sandbox.d.ts +1 -1
  155. package/dist/cli/services/sandbox.js +58 -37
  156. package/dist/cli/services/sandbox.js.map +1 -0
  157. package/dist/cli/services/server-tools.js +738 -565
  158. package/dist/cli/services/server-tools.js.map +1 -0
  159. package/dist/cli/services/session-persistence.js +69 -74
  160. package/dist/cli/services/session-persistence.js.map +1 -0
  161. package/dist/cli/services/subagent-worker.js +42 -27
  162. package/dist/cli/services/subagent-worker.js.map +1 -0
  163. package/dist/cli/services/subagent.d.ts +2 -0
  164. package/dist/cli/services/subagent.js +605 -433
  165. package/dist/cli/services/subagent.js.map +1 -0
  166. package/dist/cli/services/system-prompt.js +86 -78
  167. package/dist/cli/services/system-prompt.js.map +1 -0
  168. package/dist/cli/services/task-decomposer.d.ts +1 -1
  169. package/dist/cli/services/task-decomposer.js +172 -139
  170. package/dist/cli/services/task-decomposer.js.map +1 -0
  171. package/dist/cli/services/team-lead.d.ts +2 -2
  172. package/dist/cli/services/team-lead.js +727 -529
  173. package/dist/cli/services/team-lead.js.map +1 -0
  174. package/dist/cli/services/team-state.js +319 -319
  175. package/dist/cli/services/team-state.js.map +1 -0
  176. package/dist/cli/services/teammate.d.ts +8 -2
  177. package/dist/cli/services/teammate.js +857 -569
  178. package/dist/cli/services/teammate.js.map +1 -0
  179. package/dist/cli/services/telemetry.d.ts +6 -1
  180. package/dist/cli/services/telemetry.js +180 -157
  181. package/dist/cli/services/telemetry.js.map +1 -0
  182. package/dist/cli/services/tools/agent-tools.d.ts +3 -3
  183. package/dist/cli/services/tools/agent-tools.js +480 -322
  184. package/dist/cli/services/tools/agent-tools.js.map +1 -0
  185. package/dist/cli/services/tools/file-ops.js +563 -450
  186. package/dist/cli/services/tools/file-ops.js.map +1 -0
  187. package/dist/cli/services/tools/search-tools.js +231 -162
  188. package/dist/cli/services/tools/search-tools.js.map +1 -0
  189. package/dist/cli/services/tools/shell-exec.js +197 -151
  190. package/dist/cli/services/tools/shell-exec.js.map +1 -0
  191. package/dist/cli/services/tools/task-manager.js +206 -173
  192. package/dist/cli/services/tools/task-manager.js.map +1 -0
  193. package/dist/cli/services/tools/web-tools.js +388 -341
  194. package/dist/cli/services/tools/web-tools.js.map +1 -0
  195. package/dist/cli/setup/SetupApp.d.ts +2 -2
  196. package/dist/cli/setup/SetupApp.js +608 -160
  197. package/dist/cli/setup/SetupApp.js.map +1 -0
  198. package/dist/cli/shared/ErrorBoundary.d.ts +22 -0
  199. package/dist/cli/shared/ErrorBoundary.js +73 -0
  200. package/dist/cli/shared/ErrorBoundary.js.map +1 -0
  201. package/dist/cli/shared/MatrixIntro.js +66 -69
  202. package/dist/cli/shared/MatrixIntro.js.map +1 -0
  203. package/dist/cli/shared/SpinnerSlot.d.ts +14 -0
  204. package/dist/cli/shared/SpinnerSlot.js +63 -0
  205. package/dist/cli/shared/SpinnerSlot.js.map +1 -0
  206. package/dist/cli/shared/Theme.d.ts +1 -1
  207. package/dist/cli/shared/Theme.js +136 -92
  208. package/dist/cli/shared/Theme.js.map +1 -0
  209. package/dist/cli/shared/WhaleBanner.js +99 -11
  210. package/dist/cli/shared/WhaleBanner.js.map +1 -0
  211. package/dist/cli/shared/markdown.d.ts +3 -1
  212. package/dist/cli/shared/markdown.js +736 -674
  213. package/dist/cli/shared/markdown.js.map +1 -0
  214. package/dist/cli/shared/marked-terminal.d.js +2 -0
  215. package/dist/cli/shared/marked-terminal.d.js.map +1 -0
  216. package/dist/cli/shared/theme-manager.js +99 -90
  217. package/dist/cli/shared/theme-manager.js.map +1 -0
  218. package/dist/cli/shared/theme-presets.js +256 -254
  219. package/dist/cli/shared/theme-presets.js.map +1 -0
  220. package/dist/cli/status/StatusApp.js +235 -86
  221. package/dist/cli/status/StatusApp.js.map +1 -0
  222. package/dist/cli/stores/StoreApp.js +275 -65
  223. package/dist/cli/stores/StoreApp.js.map +1 -0
  224. package/dist/index.d.ts +2 -2
  225. package/dist/index.js +509 -396
  226. package/dist/index.js.map +1 -0
  227. package/dist/local-agent/connection.d.ts +2 -2
  228. package/dist/local-agent/connection.js +352 -293
  229. package/dist/local-agent/connection.js.map +1 -0
  230. package/dist/local-agent/discovery.js +259 -122
  231. package/dist/local-agent/discovery.js.map +1 -0
  232. package/dist/local-agent/executor.js +216 -193
  233. package/dist/local-agent/executor.js.map +1 -0
  234. package/dist/local-agent/index.d.ts +2 -2
  235. package/dist/local-agent/index.js +156 -156
  236. package/dist/local-agent/index.js.map +1 -0
  237. package/dist/node/adapters/base.js +18 -8
  238. package/dist/node/adapters/base.js.map +1 -0
  239. package/dist/node/adapters/discord.js +286 -275
  240. package/dist/node/adapters/discord.js.map +1 -0
  241. package/dist/node/adapters/email.js +189 -202
  242. package/dist/node/adapters/email.js.map +1 -0
  243. package/dist/node/adapters/imessage.js +145 -142
  244. package/dist/node/adapters/imessage.js.map +1 -0
  245. package/dist/node/adapters/slack.js +237 -236
  246. package/dist/node/adapters/slack.js.map +1 -0
  247. package/dist/node/adapters/sms.js +149 -151
  248. package/dist/node/adapters/sms.js.map +1 -0
  249. package/dist/node/adapters/telegram.js +88 -92
  250. package/dist/node/adapters/telegram.js.map +1 -0
  251. package/dist/node/adapters/webchat.js +160 -136
  252. package/dist/node/adapters/webchat.js.map +1 -0
  253. package/dist/node/adapters/whatsapp.js +212 -215
  254. package/dist/node/adapters/whatsapp.js.map +1 -0
  255. package/dist/node/cli.js +884 -653
  256. package/dist/node/cli.js.map +1 -0
  257. package/dist/node/config.js +20 -18
  258. package/dist/node/config.js.map +1 -0
  259. package/dist/node/gateway-client.js +191 -181
  260. package/dist/node/gateway-client.js.map +1 -0
  261. package/dist/node/portal/clipboard.js +161 -130
  262. package/dist/node/portal/clipboard.js.map +1 -0
  263. package/dist/node/portal/discovery.js +51 -45
  264. package/dist/node/portal/discovery.js.map +1 -0
  265. package/dist/node/portal/forward.js +64 -58
  266. package/dist/node/portal/forward.js.map +1 -0
  267. package/dist/node/portal/index.js +246 -221
  268. package/dist/node/portal/index.js.map +1 -0
  269. package/dist/node/portal/multiplexer.js +192 -182
  270. package/dist/node/portal/multiplexer.js.map +1 -0
  271. package/dist/node/portal/permissions.js +102 -70
  272. package/dist/node/portal/permissions.js.map +1 -0
  273. package/dist/node/portal/protocol.js +153 -116
  274. package/dist/node/portal/protocol.js.map +1 -0
  275. package/dist/node/portal/screen.js +80 -69
  276. package/dist/node/portal/screen.js.map +1 -0
  277. package/dist/node/portal/session.js +124 -117
  278. package/dist/node/portal/session.js.map +1 -0
  279. package/dist/node/portal/shell.js +140 -113
  280. package/dist/node/portal/shell.js.map +1 -0
  281. package/dist/node/portal/stream.js +77 -75
  282. package/dist/node/portal/stream.js.map +1 -0
  283. package/dist/node/portal/transfer.js +190 -167
  284. package/dist/node/portal/transfer.js.map +1 -0
  285. package/dist/node/portal/ui.js +124 -99
  286. package/dist/node/portal/ui.js.map +1 -0
  287. package/dist/node/remote-desktop/compile-helper.js +50 -45
  288. package/dist/node/remote-desktop/compile-helper.js.map +1 -0
  289. package/dist/node/remote-desktop/index.js +215 -187
  290. package/dist/node/remote-desktop/index.js.map +1 -0
  291. package/dist/node/remote-desktop/protocol.js +45 -29
  292. package/dist/node/remote-desktop/protocol.js.map +1 -0
  293. package/dist/node/runtime.js +493 -410
  294. package/dist/node/runtime.js.map +1 -0
  295. package/dist/server/handlers/__test-utils__/test-db.js +39 -89
  296. package/dist/server/handlers/__test-utils__/test-db.js.map +1 -0
  297. package/dist/server/handlers/analytics.js +467 -261
  298. package/dist/server/handlers/analytics.js.map +1 -0
  299. package/dist/server/handlers/api-docs.js +1030 -895
  300. package/dist/server/handlers/api-docs.js.map +1 -0
  301. package/dist/server/handlers/api-keys.js +291 -242
  302. package/dist/server/handlers/api-keys.js.map +1 -0
  303. package/dist/server/handlers/billing.js +330 -239
  304. package/dist/server/handlers/billing.js.map +1 -0
  305. package/dist/server/handlers/browser.js +468 -395
  306. package/dist/server/handlers/browser.js.map +1 -0
  307. package/dist/server/handlers/catalog.js +1377 -978
  308. package/dist/server/handlers/catalog.js.map +1 -0
  309. package/dist/server/handlers/clickhouse.js +157 -109
  310. package/dist/server/handlers/clickhouse.js.map +1 -0
  311. package/dist/server/handlers/comms.js +1439 -984
  312. package/dist/server/handlers/comms.js.map +1 -0
  313. package/dist/server/handlers/creations.js +461 -394
  314. package/dist/server/handlers/creations.js.map +1 -0
  315. package/dist/server/handlers/crm.js +1082 -791
  316. package/dist/server/handlers/crm.js.map +1 -0
  317. package/dist/server/handlers/discovery.js +251 -232
  318. package/dist/server/handlers/discovery.js.map +1 -0
  319. package/dist/server/handlers/embeddings.js +241 -164
  320. package/dist/server/handlers/embeddings.js.map +1 -0
  321. package/dist/server/handlers/enrichment.js +887 -718
  322. package/dist/server/handlers/enrichment.js.map +1 -0
  323. package/dist/server/handlers/image-gen.js +467 -376
  324. package/dist/server/handlers/image-gen.js.map +1 -0
  325. package/dist/server/handlers/inventory.js +797 -424
  326. package/dist/server/handlers/inventory.js.map +1 -0
  327. package/dist/server/handlers/kali.js +272 -230
  328. package/dist/server/handlers/kali.js.map +1 -0
  329. package/dist/server/handlers/llm-providers.js +803 -580
  330. package/dist/server/handlers/llm-providers.js.map +1 -0
  331. package/dist/server/handlers/local-agent.js +133 -105
  332. package/dist/server/handlers/local-agent.js.map +1 -0
  333. package/dist/server/handlers/media.js +1179 -857
  334. package/dist/server/handlers/media.js.map +1 -0
  335. package/dist/server/handlers/meta-ads.js +2669 -2093
  336. package/dist/server/handlers/meta-ads.js.map +1 -0
  337. package/dist/server/handlers/nodes.js +1321 -913
  338. package/dist/server/handlers/nodes.js.map +1 -0
  339. package/dist/server/handlers/operations.js +183 -157
  340. package/dist/server/handlers/operations.js.map +1 -0
  341. package/dist/server/handlers/platform.js +346 -210
  342. package/dist/server/handlers/platform.js.map +1 -0
  343. package/dist/server/handlers/remove-bg.js +118 -86
  344. package/dist/server/handlers/remove-bg.js.map +1 -0
  345. package/dist/server/handlers/storefront.js +586 -446
  346. package/dist/server/handlers/storefront.js.map +1 -0
  347. package/dist/server/handlers/supply-chain.js +546 -326
  348. package/dist/server/handlers/supply-chain.js.map +1 -0
  349. package/dist/server/handlers/transcription.js +106 -97
  350. package/dist/server/handlers/transcription.js.map +1 -0
  351. package/dist/server/handlers/video-gen.js +593 -424
  352. package/dist/server/handlers/video-gen.js.map +1 -0
  353. package/dist/server/handlers/voice.js +1458 -1039
  354. package/dist/server/handlers/voice.js.map +1 -0
  355. package/dist/server/handlers/workflow-steps.js +2837 -2116
  356. package/dist/server/handlers/workflow-steps.js.map +1 -0
  357. package/dist/server/handlers/workflows.js +1630 -933
  358. package/dist/server/handlers/workflows.js.map +1 -0
  359. package/dist/server/index.js +3167 -2422
  360. package/dist/server/index.js.map +1 -0
  361. package/dist/server/lib/batch-client.js +471 -409
  362. package/dist/server/lib/batch-client.js.map +1 -0
  363. package/dist/server/lib/clickhouse-buffer.js +118 -104
  364. package/dist/server/lib/clickhouse-buffer.js.map +1 -0
  365. package/dist/server/lib/clickhouse-client.js +107 -107
  366. package/dist/server/lib/clickhouse-client.js.map +1 -0
  367. package/dist/server/lib/coa-renderer.js +1786 -356
  368. package/dist/server/lib/coa-renderer.js.map +1 -0
  369. package/dist/server/lib/code-worker-pool.js +227 -177
  370. package/dist/server/lib/code-worker-pool.js.map +1 -0
  371. package/dist/server/lib/code-worker.js +174 -164
  372. package/dist/server/lib/code-worker.js.map +1 -0
  373. package/dist/server/lib/compaction-service.d.ts +2 -12
  374. package/dist/server/lib/compaction-service.js +74 -184
  375. package/dist/server/lib/compaction-service.js.map +1 -0
  376. package/dist/server/lib/logger.js +36 -24
  377. package/dist/server/lib/logger.js.map +1 -0
  378. package/dist/server/lib/otel.js +101 -80
  379. package/dist/server/lib/otel.js.map +1 -0
  380. package/dist/server/lib/pdf-renderer.js +952 -788
  381. package/dist/server/lib/pdf-renderer.js.map +1 -0
  382. package/dist/server/lib/prompt-sanitizer.js +188 -108
  383. package/dist/server/lib/prompt-sanitizer.js.map +1 -0
  384. package/dist/server/lib/provider-capabilities.js +136 -138
  385. package/dist/server/lib/provider-capabilities.js.map +1 -0
  386. package/dist/server/lib/provider-failover.js +190 -168
  387. package/dist/server/lib/provider-failover.js.map +1 -0
  388. package/dist/server/lib/rate-limiter.js +186 -117
  389. package/dist/server/lib/rate-limiter.js.map +1 -0
  390. package/dist/server/lib/react-pdf-layout.js +551 -382
  391. package/dist/server/lib/react-pdf-layout.js.map +1 -0
  392. package/dist/server/lib/server-agent-loop.d.ts +4 -1
  393. package/dist/server/lib/server-agent-loop.js +906 -634
  394. package/dist/server/lib/server-agent-loop.js.map +1 -0
  395. package/dist/server/lib/server-subagent.js +260 -164
  396. package/dist/server/lib/server-subagent.js.map +1 -0
  397. package/dist/server/lib/session-checkpoint.js +105 -96
  398. package/dist/server/lib/session-checkpoint.js.map +1 -0
  399. package/dist/server/lib/ssrf-guard.js +193 -184
  400. package/dist/server/lib/ssrf-guard.js.map +1 -0
  401. package/dist/server/lib/supabase-client.js +94 -82
  402. package/dist/server/lib/supabase-client.js.map +1 -0
  403. package/dist/server/lib/template-resolver.js +154 -176
  404. package/dist/server/lib/template-resolver.js.map +1 -0
  405. package/dist/server/lib/utils.js +242 -133
  406. package/dist/server/lib/utils.js.map +1 -0
  407. package/dist/server/local-agent-gateway.d.ts +2 -2
  408. package/dist/server/local-agent-gateway.js +785 -627
  409. package/dist/server/local-agent-gateway.js.map +1 -0
  410. package/dist/server/providers/anthropic.js +250 -172
  411. package/dist/server/providers/anthropic.js.map +1 -0
  412. package/dist/server/providers/bedrock.js +217 -158
  413. package/dist/server/providers/bedrock.js.map +1 -0
  414. package/dist/server/providers/gemini.js +548 -418
  415. package/dist/server/providers/gemini.js.map +1 -0
  416. package/dist/server/providers/openai.js +571 -437
  417. package/dist/server/providers/openai.js.map +1 -0
  418. package/dist/server/providers/registry.js +23 -18
  419. package/dist/server/providers/registry.js.map +1 -0
  420. package/dist/server/providers/shared.js +123 -95
  421. package/dist/server/providers/shared.js.map +1 -0
  422. package/dist/server/providers/types.js +1 -11
  423. package/dist/server/providers/types.js.map +1 -0
  424. package/dist/server/proxy-handlers.js +209 -165
  425. package/dist/server/proxy-handlers.js.map +1 -0
  426. package/dist/server/tool-router.js +959 -599
  427. package/dist/server/tool-router.js.map +1 -0
  428. package/dist/server/validation.js +248 -188
  429. package/dist/server/validation.js.map +1 -0
  430. package/dist/server/worker.js +202 -133
  431. package/dist/server/worker.js.map +1 -0
  432. package/dist/setup.d.ts +2 -2
  433. package/dist/setup.js +151 -147
  434. package/dist/setup.js.map +1 -0
  435. package/dist/shared/agent-core.d.ts +115 -26
  436. package/dist/shared/agent-core.js +956 -522
  437. package/dist/shared/agent-core.js.map +1 -0
  438. package/dist/shared/anthropic-types.js +1 -6
  439. package/dist/shared/anthropic-types.js.map +1 -0
  440. package/dist/shared/api-client.d.ts +16 -9
  441. package/dist/shared/api-client.js +419 -327
  442. package/dist/shared/api-client.js.map +1 -0
  443. package/dist/shared/compaction.d.ts +36 -0
  444. package/dist/shared/compaction.js +138 -0
  445. package/dist/shared/compaction.js.map +1 -0
  446. package/dist/shared/constants.js +67 -64
  447. package/dist/shared/constants.js.map +1 -0
  448. package/dist/shared/sse-parser.js +221 -219
  449. package/dist/shared/sse-parser.js.map +1 -0
  450. package/dist/shared/tool-dispatch.d.ts +4 -0
  451. package/dist/shared/tool-dispatch.js +226 -165
  452. package/dist/shared/tool-dispatch.js.map +1 -0
  453. package/dist/shared/types.js +1 -6
  454. package/dist/shared/types.js.map +1 -0
  455. package/dist/types/cli-highlight.d.js +2 -0
  456. package/dist/types/cli-highlight.d.js.map +1 -0
  457. package/dist/types/diff.d.js +2 -0
  458. package/dist/types/diff.d.js.map +1 -0
  459. package/dist/types/pdf-parse.d.js +2 -0
  460. package/dist/types/pdf-parse.d.js.map +1 -0
  461. package/dist/updater.d.ts +1 -1
  462. package/dist/updater.js +118 -92
  463. package/dist/updater.js.map +1 -0
  464. package/dist/webchat/widget.js +227 -380
  465. package/dist/webchat/widget.js.map +1 -0
  466. package/package.json +22 -10
  467. package/vendor/ink/build/ansi-tokenizer.d.ts +38 -0
  468. package/vendor/ink/build/ansi-tokenizer.js +316 -0
  469. package/vendor/ink/build/ansi-tokenizer.js.map +1 -0
  470. package/vendor/ink/build/apply-styles.js +175 -0
  471. package/vendor/ink/build/build-layout.js +77 -0
  472. package/vendor/ink/build/calculate-wrapped-text.js +53 -0
  473. package/vendor/ink/build/colorize.d.ts +3 -0
  474. package/vendor/ink/build/colorize.js +48 -0
  475. package/vendor/ink/build/colorize.js.map +1 -0
  476. package/vendor/ink/build/components/AccessibilityContext.d.ts +3 -0
  477. package/vendor/ink/build/components/AccessibilityContext.js +5 -0
  478. package/vendor/ink/build/components/AccessibilityContext.js.map +1 -0
  479. package/vendor/ink/build/components/App.d.ts +18 -0
  480. package/vendor/ink/build/components/App.js +351 -0
  481. package/vendor/ink/build/components/App.js.map +1 -0
  482. package/vendor/ink/build/components/AppContext.d.ts +15 -0
  483. package/vendor/ink/build/components/AppContext.js +11 -0
  484. package/vendor/ink/build/components/AppContext.js.map +1 -0
  485. package/vendor/ink/build/components/BackgroundContext.d.ts +4 -0
  486. package/vendor/ink/build/components/BackgroundContext.js +3 -0
  487. package/vendor/ink/build/components/BackgroundContext.js.map +1 -0
  488. package/vendor/ink/build/components/Box.d.ts +117 -0
  489. package/vendor/ink/build/components/Box.js +34 -0
  490. package/vendor/ink/build/components/Box.js.map +1 -0
  491. package/vendor/ink/build/components/Color.js +62 -0
  492. package/vendor/ink/build/components/Cursor.d.ts +83 -0
  493. package/vendor/ink/build/components/Cursor.js +53 -0
  494. package/vendor/ink/build/components/Cursor.js.map +1 -0
  495. package/vendor/ink/build/components/CursorContext.d.ts +11 -0
  496. package/vendor/ink/build/components/CursorContext.js +8 -0
  497. package/vendor/ink/build/components/CursorContext.js.map +1 -0
  498. package/vendor/ink/build/components/ErrorBoundary.d.ts +18 -0
  499. package/vendor/ink/build/components/ErrorBoundary.js +23 -0
  500. package/vendor/ink/build/components/ErrorBoundary.js.map +1 -0
  501. package/vendor/ink/build/components/ErrorOverview.d.ts +6 -0
  502. package/vendor/ink/build/components/ErrorOverview.js +84 -0
  503. package/vendor/ink/build/components/ErrorOverview.js.map +1 -0
  504. package/vendor/ink/build/components/FocusContext.d.ts +16 -0
  505. package/vendor/ink/build/components/FocusContext.js +17 -0
  506. package/vendor/ink/build/components/FocusContext.js.map +1 -0
  507. package/vendor/ink/build/components/Newline.d.ts +13 -0
  508. package/vendor/ink/build/components/Newline.js +8 -0
  509. package/vendor/ink/build/components/Newline.js.map +1 -0
  510. package/vendor/ink/build/components/Spacer.d.ts +7 -0
  511. package/vendor/ink/build/components/Spacer.js +11 -0
  512. package/vendor/ink/build/components/Spacer.js.map +1 -0
  513. package/vendor/ink/build/components/Static.d.ts +24 -0
  514. package/vendor/ink/build/components/Static.js +28 -0
  515. package/vendor/ink/build/components/Static.js.map +1 -0
  516. package/vendor/ink/build/components/StderrContext.d.ts +15 -0
  517. package/vendor/ink/build/components/StderrContext.js +13 -0
  518. package/vendor/ink/build/components/StderrContext.js.map +1 -0
  519. package/vendor/ink/build/components/StdinContext.d.ts +22 -0
  520. package/vendor/ink/build/components/StdinContext.js +19 -0
  521. package/vendor/ink/build/components/StdinContext.js.map +1 -0
  522. package/vendor/ink/build/components/StdoutContext.d.ts +15 -0
  523. package/vendor/ink/build/components/StdoutContext.js +13 -0
  524. package/vendor/ink/build/components/StdoutContext.js.map +1 -0
  525. package/vendor/ink/build/components/Text.d.ts +55 -0
  526. package/vendor/ink/build/components/Text.js +50 -0
  527. package/vendor/ink/build/components/Text.js.map +1 -0
  528. package/vendor/ink/build/components/Transform.d.ts +16 -0
  529. package/vendor/ink/build/components/Transform.js +15 -0
  530. package/vendor/ink/build/components/Transform.js.map +1 -0
  531. package/vendor/ink/build/cursor-helpers.d.ts +38 -0
  532. package/vendor/ink/build/cursor-helpers.js +56 -0
  533. package/vendor/ink/build/cursor-helpers.js.map +1 -0
  534. package/vendor/ink/build/devtools-window-polyfill.d.ts +1 -0
  535. package/vendor/ink/build/devtools-window-polyfill.js +65 -0
  536. package/vendor/ink/build/devtools-window-polyfill.js.map +1 -0
  537. package/vendor/ink/build/devtools.d.ts +1 -0
  538. package/vendor/ink/build/devtools.js +11 -0
  539. package/vendor/ink/build/devtools.js.map +1 -0
  540. package/vendor/ink/build/dom.d.ts +56 -0
  541. package/vendor/ink/build/dom.js +124 -0
  542. package/vendor/ink/build/dom.js.map +1 -0
  543. package/vendor/ink/build/experimental/apply-style.js +140 -0
  544. package/vendor/ink/build/experimental/dom.js +123 -0
  545. package/vendor/ink/build/experimental/output.js +91 -0
  546. package/vendor/ink/build/experimental/reconciler.js +141 -0
  547. package/vendor/ink/build/experimental/renderer.js +81 -0
  548. package/vendor/ink/build/get-max-width.d.ts +3 -0
  549. package/vendor/ink/build/get-max-width.js +10 -0
  550. package/vendor/ink/build/get-max-width.js.map +1 -0
  551. package/vendor/ink/build/hooks/use-app.d.ts +5 -0
  552. package/vendor/ink/build/hooks/use-app.js +8 -0
  553. package/vendor/ink/build/hooks/use-app.js.map +1 -0
  554. package/vendor/ink/build/hooks/use-cursor.d.ts +12 -0
  555. package/vendor/ink/build/hooks/use-cursor.js +29 -0
  556. package/vendor/ink/build/hooks/use-cursor.js.map +1 -0
  557. package/vendor/ink/build/hooks/use-focus-manager.d.ts +28 -0
  558. package/vendor/ink/build/hooks/use-focus-manager.js +17 -0
  559. package/vendor/ink/build/hooks/use-focus-manager.js.map +1 -0
  560. package/vendor/ink/build/hooks/use-focus.d.ts +29 -0
  561. package/vendor/ink/build/hooks/use-focus.js +42 -0
  562. package/vendor/ink/build/hooks/use-focus.js.map +1 -0
  563. package/vendor/ink/build/hooks/use-input.d.ts +131 -0
  564. package/vendor/ink/build/hooks/use-input.js +124 -0
  565. package/vendor/ink/build/hooks/use-input.js.map +1 -0
  566. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.d.ts +5 -0
  567. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js +11 -0
  568. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js.map +1 -0
  569. package/vendor/ink/build/hooks/use-stderr.d.ts +5 -0
  570. package/vendor/ink/build/hooks/use-stderr.js +8 -0
  571. package/vendor/ink/build/hooks/use-stderr.js.map +1 -0
  572. package/vendor/ink/build/hooks/use-stdin.d.ts +5 -0
  573. package/vendor/ink/build/hooks/use-stdin.js +8 -0
  574. package/vendor/ink/build/hooks/use-stdin.js.map +1 -0
  575. package/vendor/ink/build/hooks/use-stdout.d.ts +5 -0
  576. package/vendor/ink/build/hooks/use-stdout.js +8 -0
  577. package/vendor/ink/build/hooks/use-stdout.js.map +1 -0
  578. package/vendor/ink/build/hooks/useInput.js +38 -0
  579. package/vendor/ink/build/index.d.ts +34 -0
  580. package/vendor/ink/build/index.js +20 -0
  581. package/vendor/ink/build/index.js.map +1 -0
  582. package/vendor/ink/build/ink.d.ts +90 -0
  583. package/vendor/ink/build/ink.js +654 -0
  584. package/vendor/ink/build/ink.js.map +1 -0
  585. package/vendor/ink/build/input-parser.d.ts +7 -0
  586. package/vendor/ink/build/input-parser.js +154 -0
  587. package/vendor/ink/build/input-parser.js.map +1 -0
  588. package/vendor/ink/build/instance.js +205 -0
  589. package/vendor/ink/build/instances.d.ts +3 -0
  590. package/vendor/ink/build/instances.js +8 -0
  591. package/vendor/ink/build/instances.js.map +1 -0
  592. package/vendor/ink/build/kitty-keyboard.d.ts +23 -0
  593. package/vendor/ink/build/kitty-keyboard.js +32 -0
  594. package/vendor/ink/build/kitty-keyboard.js.map +1 -0
  595. package/vendor/ink/build/layout.d.ts +7 -0
  596. package/vendor/ink/build/layout.js +33 -0
  597. package/vendor/ink/build/layout.js.map +1 -0
  598. package/vendor/ink/build/log-update.d.ts +19 -0
  599. package/vendor/ink/build/log-update.js +243 -0
  600. package/vendor/ink/build/log-update.js.map +1 -0
  601. package/vendor/ink/build/measure-element.d.ts +16 -0
  602. package/vendor/ink/build/measure-element.js +9 -0
  603. package/vendor/ink/build/measure-element.js.map +1 -0
  604. package/vendor/ink/build/measure-text.d.ts +6 -0
  605. package/vendor/ink/build/measure-text.js +21 -0
  606. package/vendor/ink/build/measure-text.js.map +1 -0
  607. package/vendor/ink/build/options.d.ts +52 -0
  608. package/vendor/ink/build/options.js +2 -0
  609. package/vendor/ink/build/options.js.map +1 -0
  610. package/vendor/ink/build/output.d.ts +35 -0
  611. package/vendor/ink/build/output.js +183 -0
  612. package/vendor/ink/build/output.js.map +1 -0
  613. package/vendor/ink/build/parse-keypress.d.ts +22 -0
  614. package/vendor/ink/build/parse-keypress.js +493 -0
  615. package/vendor/ink/build/parse-keypress.js.map +1 -0
  616. package/vendor/ink/build/reconciler.d.ts +4 -0
  617. package/vendor/ink/build/reconciler.js +274 -0
  618. package/vendor/ink/build/reconciler.js.map +1 -0
  619. package/vendor/ink/build/render-background.d.ts +4 -0
  620. package/vendor/ink/build/render-background.js +25 -0
  621. package/vendor/ink/build/render-background.js.map +1 -0
  622. package/vendor/ink/build/render-border.d.ts +4 -0
  623. package/vendor/ink/build/render-border.js +73 -0
  624. package/vendor/ink/build/render-border.js.map +1 -0
  625. package/vendor/ink/build/render-node-to-output.d.ts +14 -0
  626. package/vendor/ink/build/render-node-to-output.js +147 -0
  627. package/vendor/ink/build/render-node-to-output.js.map +1 -0
  628. package/vendor/ink/build/render-to-string.d.ts +38 -0
  629. package/vendor/ink/build/render-to-string.js +115 -0
  630. package/vendor/ink/build/render-to-string.js.map +1 -0
  631. package/vendor/ink/build/render.d.ts +121 -0
  632. package/vendor/ink/build/render.js +55 -0
  633. package/vendor/ink/build/render.js.map +1 -0
  634. package/vendor/ink/build/renderer.d.ts +8 -0
  635. package/vendor/ink/build/renderer.js +55 -0
  636. package/vendor/ink/build/renderer.js.map +1 -0
  637. package/vendor/ink/build/sanitize-ansi.d.ts +2 -0
  638. package/vendor/ink/build/sanitize-ansi.js +27 -0
  639. package/vendor/ink/build/sanitize-ansi.js.map +1 -0
  640. package/vendor/ink/build/screen-reader-update.d.ts +13 -0
  641. package/vendor/ink/build/screen-reader-update.js +38 -0
  642. package/vendor/ink/build/screen-reader-update.js.map +1 -0
  643. package/vendor/ink/build/squash-text-nodes.d.ts +3 -0
  644. package/vendor/ink/build/squash-text-nodes.js +36 -0
  645. package/vendor/ink/build/squash-text-nodes.js.map +1 -0
  646. package/vendor/ink/build/styles.d.ts +240 -0
  647. package/vendor/ink/build/styles.js +232 -0
  648. package/vendor/ink/build/styles.js.map +1 -0
  649. package/vendor/ink/build/utils.d.ts +2 -0
  650. package/vendor/ink/build/utils.js +4 -0
  651. package/vendor/ink/build/utils.js.map +1 -0
  652. package/vendor/ink/build/wrap-text.d.ts +3 -0
  653. package/vendor/ink/build/wrap-text.js +31 -0
  654. package/vendor/ink/build/wrap-text.js.map +1 -0
  655. package/vendor/ink/build/write-synchronized.d.ts +4 -0
  656. package/vendor/ink/build/write-synchronized.js +7 -0
  657. package/vendor/ink/build/write-synchronized.js.map +1 -0
  658. package/vendor/ink/license +10 -0
  659. package/vendor/ink/node_modules/@types/node/LICENSE +21 -0
  660. package/vendor/ink/node_modules/@types/node/README.md +15 -0
  661. package/vendor/ink/node_modules/@types/node/assert/strict.d.ts +105 -0
  662. package/vendor/ink/node_modules/@types/node/assert.d.ts +955 -0
  663. package/vendor/ink/node_modules/@types/node/async_hooks.d.ts +623 -0
  664. package/vendor/ink/node_modules/@types/node/buffer.buffer.d.ts +466 -0
  665. package/vendor/ink/node_modules/@types/node/buffer.d.ts +1810 -0
  666. package/vendor/ink/node_modules/@types/node/child_process.d.ts +1428 -0
  667. package/vendor/ink/node_modules/@types/node/cluster.d.ts +486 -0
  668. package/vendor/ink/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
  669. package/vendor/ink/node_modules/@types/node/console.d.ts +151 -0
  670. package/vendor/ink/node_modules/@types/node/constants.d.ts +20 -0
  671. package/vendor/ink/node_modules/@types/node/crypto.d.ts +4065 -0
  672. package/vendor/ink/node_modules/@types/node/dgram.d.ts +564 -0
  673. package/vendor/ink/node_modules/@types/node/diagnostics_channel.d.ts +576 -0
  674. package/vendor/ink/node_modules/@types/node/dns/promises.d.ts +503 -0
  675. package/vendor/ink/node_modules/@types/node/dns.d.ts +922 -0
  676. package/vendor/ink/node_modules/@types/node/domain.d.ts +166 -0
  677. package/vendor/ink/node_modules/@types/node/events.d.ts +1054 -0
  678. package/vendor/ink/node_modules/@types/node/fs/promises.d.ts +1329 -0
  679. package/vendor/ink/node_modules/@types/node/fs.d.ts +4676 -0
  680. package/vendor/ink/node_modules/@types/node/globals.d.ts +150 -0
  681. package/vendor/ink/node_modules/@types/node/globals.typedarray.d.ts +101 -0
  682. package/vendor/ink/node_modules/@types/node/http.d.ts +2167 -0
  683. package/vendor/ink/node_modules/@types/node/http2.d.ts +2480 -0
  684. package/vendor/ink/node_modules/@types/node/https.d.ts +405 -0
  685. package/vendor/ink/node_modules/@types/node/index.d.ts +115 -0
  686. package/vendor/ink/node_modules/@types/node/inspector/promises.d.ts +41 -0
  687. package/vendor/ink/node_modules/@types/node/inspector.d.ts +224 -0
  688. package/vendor/ink/node_modules/@types/node/inspector.generated.d.ts +4226 -0
  689. package/vendor/ink/node_modules/@types/node/module.d.ts +819 -0
  690. package/vendor/ink/node_modules/@types/node/net.d.ts +933 -0
  691. package/vendor/ink/node_modules/@types/node/os.d.ts +507 -0
  692. package/vendor/ink/node_modules/@types/node/package.json +155 -0
  693. package/vendor/ink/node_modules/@types/node/path/posix.d.ts +8 -0
  694. package/vendor/ink/node_modules/@types/node/path/win32.d.ts +8 -0
  695. package/vendor/ink/node_modules/@types/node/path.d.ts +187 -0
  696. package/vendor/ink/node_modules/@types/node/perf_hooks.d.ts +643 -0
  697. package/vendor/ink/node_modules/@types/node/process.d.ts +2156 -0
  698. package/vendor/ink/node_modules/@types/node/punycode.d.ts +117 -0
  699. package/vendor/ink/node_modules/@types/node/querystring.d.ts +152 -0
  700. package/vendor/ink/node_modules/@types/node/quic.d.ts +910 -0
  701. package/vendor/ink/node_modules/@types/node/readline/promises.d.ts +161 -0
  702. package/vendor/ink/node_modules/@types/node/readline.d.ts +541 -0
  703. package/vendor/ink/node_modules/@types/node/repl.d.ts +415 -0
  704. package/vendor/ink/node_modules/@types/node/sea.d.ts +162 -0
  705. package/vendor/ink/node_modules/@types/node/sqlite.d.ts +955 -0
  706. package/vendor/ink/node_modules/@types/node/stream/consumers.d.ts +38 -0
  707. package/vendor/ink/node_modules/@types/node/stream/promises.d.ts +211 -0
  708. package/vendor/ink/node_modules/@types/node/stream/web.d.ts +296 -0
  709. package/vendor/ink/node_modules/@types/node/stream.d.ts +1760 -0
  710. package/vendor/ink/node_modules/@types/node/string_decoder.d.ts +67 -0
  711. package/vendor/ink/node_modules/@types/node/test/reporters.d.ts +96 -0
  712. package/vendor/ink/node_modules/@types/node/test.d.ts +2240 -0
  713. package/vendor/ink/node_modules/@types/node/timers/promises.d.ts +108 -0
  714. package/vendor/ink/node_modules/@types/node/timers.d.ts +159 -0
  715. package/vendor/ink/node_modules/@types/node/tls.d.ts +1198 -0
  716. package/vendor/ink/node_modules/@types/node/trace_events.d.ts +197 -0
  717. package/vendor/ink/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +462 -0
  718. package/vendor/ink/node_modules/@types/node/ts5.6/compatibility/float16array.d.ts +71 -0
  719. package/vendor/ink/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +36 -0
  720. package/vendor/ink/node_modules/@types/node/ts5.6/index.d.ts +117 -0
  721. package/vendor/ink/node_modules/@types/node/ts5.7/compatibility/float16array.d.ts +72 -0
  722. package/vendor/ink/node_modules/@types/node/ts5.7/index.d.ts +117 -0
  723. package/vendor/ink/node_modules/@types/node/tty.d.ts +250 -0
  724. package/vendor/ink/node_modules/@types/node/url.d.ts +519 -0
  725. package/vendor/ink/node_modules/@types/node/util/types.d.ts +558 -0
  726. package/vendor/ink/node_modules/@types/node/util.d.ts +1662 -0
  727. package/vendor/ink/node_modules/@types/node/v8.d.ts +983 -0
  728. package/vendor/ink/node_modules/@types/node/vm.d.ts +1208 -0
  729. package/vendor/ink/node_modules/@types/node/wasi.d.ts +202 -0
  730. package/vendor/ink/node_modules/@types/node/web-globals/abortcontroller.d.ts +59 -0
  731. package/vendor/ink/node_modules/@types/node/web-globals/blob.d.ts +23 -0
  732. package/vendor/ink/node_modules/@types/node/web-globals/console.d.ts +9 -0
  733. package/vendor/ink/node_modules/@types/node/web-globals/crypto.d.ts +39 -0
  734. package/vendor/ink/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  735. package/vendor/ink/node_modules/@types/node/web-globals/encoding.d.ts +11 -0
  736. package/vendor/ink/node_modules/@types/node/web-globals/events.d.ts +106 -0
  737. package/vendor/ink/node_modules/@types/node/web-globals/fetch.d.ts +69 -0
  738. package/vendor/ink/node_modules/@types/node/web-globals/importmeta.d.ts +13 -0
  739. package/vendor/ink/node_modules/@types/node/web-globals/messaging.d.ts +23 -0
  740. package/vendor/ink/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
  741. package/vendor/ink/node_modules/@types/node/web-globals/performance.d.ts +45 -0
  742. package/vendor/ink/node_modules/@types/node/web-globals/storage.d.ts +24 -0
  743. package/vendor/ink/node_modules/@types/node/web-globals/streams.d.ts +115 -0
  744. package/vendor/ink/node_modules/@types/node/web-globals/timers.d.ts +44 -0
  745. package/vendor/ink/node_modules/@types/node/web-globals/url.d.ts +24 -0
  746. package/vendor/ink/node_modules/@types/node/worker_threads.d.ts +717 -0
  747. package/vendor/ink/node_modules/@types/node/zlib.d.ts +618 -0
  748. package/vendor/ink/node_modules/node-pty/LICENSE +69 -0
  749. package/vendor/ink/node_modules/node-pty/README.md +164 -0
  750. package/vendor/ink/node_modules/node-pty/binding.gyp +150 -0
  751. package/vendor/ink/node_modules/node-pty/lib/conpty_console_list_agent.js +25 -0
  752. package/vendor/ink/node_modules/node-pty/lib/eventEmitter2.js +47 -0
  753. package/vendor/ink/node_modules/node-pty/lib/index.js +52 -0
  754. package/vendor/ink/node_modules/node-pty/lib/interfaces.js +7 -0
  755. package/vendor/ink/node_modules/node-pty/lib/shared/conout.js +11 -0
  756. package/vendor/ink/node_modules/node-pty/lib/terminal.js +190 -0
  757. package/vendor/ink/node_modules/node-pty/lib/types.js +7 -0
  758. package/vendor/ink/node_modules/node-pty/lib/unixTerminal.js +349 -0
  759. package/vendor/ink/node_modules/node-pty/lib/utils.js +39 -0
  760. package/vendor/ink/node_modules/node-pty/lib/windowsConoutConnection.js +125 -0
  761. package/vendor/ink/node_modules/node-pty/lib/windowsPtyAgent.js +287 -0
  762. package/vendor/ink/node_modules/node-pty/lib/windowsTerminal.js +201 -0
  763. package/vendor/ink/node_modules/node-pty/lib/worker/conoutSocketWorker.js +22 -0
  764. package/vendor/ink/node_modules/node-pty/package.json +65 -0
  765. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/pty.node +0 -0
  766. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/spawn-helper +0 -0
  767. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/pty.node +0 -0
  768. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/spawn-helper +0 -0
  769. package/vendor/ink/node_modules/node-pty/prebuilds/linux-arm64/pty.node +0 -0
  770. package/vendor/ink/node_modules/node-pty/prebuilds/linux-x64/pty.node +0 -0
  771. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/OpenConsole.exe +0 -0
  772. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/conpty.dll +0 -0
  773. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.node +0 -0
  774. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.pdb +0 -0
  775. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.node +0 -0
  776. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.pdb +0 -0
  777. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/OpenConsole.exe +0 -0
  778. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/conpty.dll +0 -0
  779. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.node +0 -0
  780. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.pdb +0 -0
  781. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.node +0 -0
  782. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.pdb +0 -0
  783. package/vendor/ink/node_modules/node-pty/scripts/post-install.js +76 -0
  784. package/vendor/ink/node_modules/node-pty/scripts/prebuild.js +34 -0
  785. package/vendor/ink/node_modules/node-pty/src/unix/pty.cc +875 -0
  786. package/vendor/ink/node_modules/node-pty/src/unix/spawn-helper.cc +23 -0
  787. package/vendor/ink/node_modules/node-pty/src/win/conpty.cc +582 -0
  788. package/vendor/ink/node_modules/node-pty/src/win/conpty.h +41 -0
  789. package/vendor/ink/node_modules/node-pty/src/win/conpty_console_list.cc +44 -0
  790. package/vendor/ink/node_modules/node-pty/src/win/path_util.cc +95 -0
  791. package/vendor/ink/node_modules/node-pty/src/win/path_util.h +26 -0
  792. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/OpenConsole.exe +0 -0
  793. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/conpty.dll +0 -0
  794. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/OpenConsole.exe +0 -0
  795. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/conpty.dll +0 -0
  796. package/vendor/ink/node_modules/node-pty/typings/node-pty.d.ts +215 -0
  797. package/vendor/ink/node_modules/undici-types/LICENSE +21 -0
  798. package/vendor/ink/node_modules/undici-types/README.md +6 -0
  799. package/vendor/ink/node_modules/undici-types/agent.d.ts +32 -0
  800. package/vendor/ink/node_modules/undici-types/api.d.ts +43 -0
  801. package/vendor/ink/node_modules/undici-types/balanced-pool.d.ts +30 -0
  802. package/vendor/ink/node_modules/undici-types/cache-interceptor.d.ts +173 -0
  803. package/vendor/ink/node_modules/undici-types/cache.d.ts +36 -0
  804. package/vendor/ink/node_modules/undici-types/client-stats.d.ts +15 -0
  805. package/vendor/ink/node_modules/undici-types/client.d.ts +108 -0
  806. package/vendor/ink/node_modules/undici-types/connector.d.ts +34 -0
  807. package/vendor/ink/node_modules/undici-types/content-type.d.ts +21 -0
  808. package/vendor/ink/node_modules/undici-types/cookies.d.ts +30 -0
  809. package/vendor/ink/node_modules/undici-types/diagnostics-channel.d.ts +74 -0
  810. package/vendor/ink/node_modules/undici-types/dispatcher.d.ts +276 -0
  811. package/vendor/ink/node_modules/undici-types/env-http-proxy-agent.d.ts +22 -0
  812. package/vendor/ink/node_modules/undici-types/errors.d.ts +161 -0
  813. package/vendor/ink/node_modules/undici-types/eventsource.d.ts +66 -0
  814. package/vendor/ink/node_modules/undici-types/fetch.d.ts +211 -0
  815. package/vendor/ink/node_modules/undici-types/formdata.d.ts +108 -0
  816. package/vendor/ink/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  817. package/vendor/ink/node_modules/undici-types/global-origin.d.ts +7 -0
  818. package/vendor/ink/node_modules/undici-types/h2c-client.d.ts +73 -0
  819. package/vendor/ink/node_modules/undici-types/handlers.d.ts +15 -0
  820. package/vendor/ink/node_modules/undici-types/header.d.ts +160 -0
  821. package/vendor/ink/node_modules/undici-types/index.d.ts +88 -0
  822. package/vendor/ink/node_modules/undici-types/interceptors.d.ts +73 -0
  823. package/vendor/ink/node_modules/undici-types/mock-agent.d.ts +68 -0
  824. package/vendor/ink/node_modules/undici-types/mock-call-history.d.ts +111 -0
  825. package/vendor/ink/node_modules/undici-types/mock-client.d.ts +27 -0
  826. package/vendor/ink/node_modules/undici-types/mock-errors.d.ts +12 -0
  827. package/vendor/ink/node_modules/undici-types/mock-interceptor.d.ts +94 -0
  828. package/vendor/ink/node_modules/undici-types/mock-pool.d.ts +27 -0
  829. package/vendor/ink/node_modules/undici-types/package.json +55 -0
  830. package/vendor/ink/node_modules/undici-types/patch.d.ts +29 -0
  831. package/vendor/ink/node_modules/undici-types/pool-stats.d.ts +19 -0
  832. package/vendor/ink/node_modules/undici-types/pool.d.ts +41 -0
  833. package/vendor/ink/node_modules/undici-types/proxy-agent.d.ts +29 -0
  834. package/vendor/ink/node_modules/undici-types/readable.d.ts +68 -0
  835. package/vendor/ink/node_modules/undici-types/retry-agent.d.ts +8 -0
  836. package/vendor/ink/node_modules/undici-types/retry-handler.d.ts +125 -0
  837. package/vendor/ink/node_modules/undici-types/round-robin-pool.d.ts +41 -0
  838. package/vendor/ink/node_modules/undici-types/snapshot-agent.d.ts +109 -0
  839. package/vendor/ink/node_modules/undici-types/util.d.ts +18 -0
  840. package/vendor/ink/node_modules/undici-types/utility.d.ts +7 -0
  841. package/vendor/ink/node_modules/undici-types/webidl.d.ts +341 -0
  842. package/vendor/ink/node_modules/undici-types/websocket.d.ts +186 -0
  843. package/vendor/ink/package.json +201 -0
  844. package/vendor/ink/readme.md +2636 -0
  845. package/bin/swag-agent.js +0 -9
  846. package/dist/server/lib/pg-rate-limiter.d.ts +0 -21
  847. package/dist/server/lib/pg-rate-limiter.js +0 -86
@@ -1,447 +1,820 @@
1
1
  // server/handlers/inventory.ts — Inventory management handlers
2
+
2
3
  export async function handleInventory(sb, args, storeId) {
3
- const sid = storeId;
4
- switch (args.action) {
5
- case "adjust": {
6
- const productId = args.product_id;
7
- const locationId = args.location_id;
8
- const adjustment = args.adjustment;
9
- const reason = args.reason || "Manual adjustment";
10
- const { data: product } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
11
- const { data: location } = await sb.from("locations").select("name").eq("id", locationId).eq("store_id", sid).single();
12
- // Atomic RPC — row-locked, includes audit trail
13
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_adjust", {
14
- p_store_id: sid, p_product_id: productId, p_location_id: locationId,
15
- p_adjustment: adjustment, p_reason: reason,
16
- });
17
- if (rpcError)
18
- return { success: false, error: rpcError.message };
19
- const rpcResult = result;
20
- if (!rpcResult.success)
21
- return { success: false, error: rpcResult.error || "Adjust failed" };
22
- const d = rpcResult.data || {};
23
- const sign = adjustment >= 0 ? "+" : "";
24
- return {
25
- success: true,
26
- data: {
27
- intent: `Adjust inventory for ${product?.name || 'product'} at ${location?.name || 'location'}: ${sign}${adjustment} units`,
28
- product: product ? { id: productId, name: product.name, sku: product.sku } : { id: productId },
29
- location: location ? { id: locationId, name: location.name } : { id: locationId },
30
- adjustment, reason,
31
- before_state: { quantity: d.before },
32
- after_state: { quantity: d.after },
33
- change: { from: d.before, to: d.after, delta: adjustment }
34
- }
35
- };
36
- }
37
- case "set": {
38
- const productId = args.product_id;
39
- const locationId = args.location_id;
40
- const newQty = args.quantity;
41
- const { data: product } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
42
- const { data: location } = await sb.from("locations").select("name").eq("id", locationId).eq("store_id", sid).single();
43
- // Atomic RPC row-locked, includes audit trail
44
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_set", {
45
- p_store_id: sid, p_product_id: productId, p_location_id: locationId,
46
- p_quantity: newQty, p_reason: `Set to ${newQty}`,
47
- });
48
- if (rpcError)
49
- return { success: false, error: rpcError.message };
50
- const rpcResult = result;
51
- if (!rpcResult.success)
52
- return { success: false, error: rpcResult.error || "Set failed" };
53
- const d = rpcResult.data || {};
54
- const delta = d.delta || 0;
55
- const sign = delta >= 0 ? "+" : "";
56
- return {
57
- success: true,
58
- data: {
59
- intent: `Set inventory for ${product?.name || 'product'} at ${location?.name || 'location'} to ${newQty} units`,
60
- product: product ? { id: productId, name: product.name, sku: product.sku } : { id: productId },
61
- location: location ? { id: locationId, name: location.name } : { id: locationId },
62
- before_state: { quantity: d.before },
63
- after_state: { quantity: d.after },
64
- change: { from: d.before, to: d.after, delta, description: `${sign}${delta} units` }
65
- }
66
- };
67
- }
68
- case "transfer": {
69
- // C3 FIX: Use atomic RPC with row-level locking instead of separate upserts
70
- const qty = args.quantity;
71
- const productId = args.product_id;
72
- const fromLocationId = args.from_location_id;
73
- const toLocationId = args.to_location_id;
74
- const { data: product } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
75
- const { data: fromLocation } = await sb.from("locations").select("name").eq("id", fromLocationId).eq("store_id", sid).single();
76
- const { data: toLocation } = await sb.from("locations").select("name").eq("id", toLocationId).eq("store_id", sid).single();
77
- // Atomic transfer — row-locked, transactional, no race conditions
78
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_transfer", {
79
- p_store_id: sid,
80
- p_product_id: productId,
81
- p_from_location_id: fromLocationId,
82
- p_to_location_id: toLocationId,
83
- p_quantity: qty,
84
- });
85
- if (rpcError) {
86
- return { success: false, error: rpcError.message };
4
+ const sid = storeId;
5
+ switch (args.action) {
6
+ case "adjust":
7
+ {
8
+ const productId = args.product_id;
9
+ const locationId = args.location_id;
10
+ const adjustment = args.adjustment;
11
+ const reason = args.reason || "Manual adjustment";
12
+ const {
13
+ data: product
14
+ } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
15
+ const {
16
+ data: location
17
+ } = await sb.from("locations").select("name").eq("id", locationId).eq("store_id", sid).single();
18
+
19
+ // Atomic RPC — row-locked, includes audit trail
20
+ const {
21
+ data: result,
22
+ error: rpcError
23
+ } = await sb.rpc("atomic_inventory_adjust", {
24
+ p_store_id: sid,
25
+ p_product_id: productId,
26
+ p_location_id: locationId,
27
+ p_adjustment: adjustment,
28
+ p_reason: reason
29
+ });
30
+ if (rpcError) return {
31
+ success: false,
32
+ error: rpcError.message
33
+ };
34
+ const rpcResult = result;
35
+ if (!rpcResult.success) return {
36
+ success: false,
37
+ error: rpcResult.error || "Adjust failed"
38
+ };
39
+ const d = rpcResult.data || {};
40
+ const sign = adjustment >= 0 ? "+" : "";
41
+ return {
42
+ success: true,
43
+ data: {
44
+ intent: `Adjust inventory for ${product?.name || 'product'} at ${location?.name || 'location'}: ${sign}${adjustment} units`,
45
+ product: product ? {
46
+ id: productId,
47
+ name: product.name,
48
+ sku: product.sku
49
+ } : {
50
+ id: productId
51
+ },
52
+ location: location ? {
53
+ id: locationId,
54
+ name: location.name
55
+ } : {
56
+ id: locationId
57
+ },
58
+ adjustment,
59
+ reason,
60
+ before_state: {
61
+ quantity: d.before
62
+ },
63
+ after_state: {
64
+ quantity: d.after
65
+ },
66
+ change: {
67
+ from: d.before,
68
+ to: d.after,
69
+ delta: adjustment
87
70
  }
88
- const rpcResult = result;
89
- if (!rpcResult.success) {
90
- return { success: false, error: rpcResult.error || "Transfer failed" };
71
+ }
72
+ };
73
+ }
74
+ case "set":
75
+ {
76
+ const productId = args.product_id;
77
+ const locationId = args.location_id;
78
+ const newQty = args.quantity;
79
+ const {
80
+ data: product
81
+ } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
82
+ const {
83
+ data: location
84
+ } = await sb.from("locations").select("name").eq("id", locationId).eq("store_id", sid).single();
85
+
86
+ // Atomic RPC — row-locked, includes audit trail
87
+ const {
88
+ data: result,
89
+ error: rpcError
90
+ } = await sb.rpc("atomic_inventory_set", {
91
+ p_store_id: sid,
92
+ p_product_id: productId,
93
+ p_location_id: locationId,
94
+ p_quantity: newQty,
95
+ p_reason: `Set to ${newQty}`
96
+ });
97
+ if (rpcError) return {
98
+ success: false,
99
+ error: rpcError.message
100
+ };
101
+ const rpcResult = result;
102
+ if (!rpcResult.success) return {
103
+ success: false,
104
+ error: rpcResult.error || "Set failed"
105
+ };
106
+ const d = rpcResult.data || {};
107
+ const delta = d.delta || 0;
108
+ const sign = delta >= 0 ? "+" : "";
109
+ return {
110
+ success: true,
111
+ data: {
112
+ intent: `Set inventory for ${product?.name || 'product'} at ${location?.name || 'location'} to ${newQty} units`,
113
+ product: product ? {
114
+ id: productId,
115
+ name: product.name,
116
+ sku: product.sku
117
+ } : {
118
+ id: productId
119
+ },
120
+ location: location ? {
121
+ id: locationId,
122
+ name: location.name
123
+ } : {
124
+ id: locationId
125
+ },
126
+ before_state: {
127
+ quantity: d.before
128
+ },
129
+ after_state: {
130
+ quantity: d.after
131
+ },
132
+ change: {
133
+ from: d.before,
134
+ to: d.after,
135
+ delta,
136
+ description: `${sign}${delta} units`
91
137
  }
92
- const transferData = rpcResult.data || {};
93
- return {
94
- success: true,
95
- data: {
96
- intent: `Transfer ${qty} units of ${product?.name || 'product'} from ${fromLocation?.name || 'source'} to ${toLocation?.name || 'destination'}`,
97
- product: product ? { id: productId, name: product.name, sku: product.sku } : { id: productId },
98
- from_location: fromLocation ? { id: fromLocationId, name: fromLocation.name } : { id: fromLocationId },
99
- to_location: toLocation ? { id: toLocationId, name: toLocation.name } : { id: toLocationId },
100
- quantity_transferred: qty,
101
- before_state: { from_quantity: transferData.source_before, to_quantity: transferData.dest_before, total: (transferData.source_before || 0) + (transferData.dest_before || 0) },
102
- after_state: { from_quantity: transferData.source_after, to_quantity: transferData.dest_after, total: (transferData.source_after || 0) + (transferData.dest_after || 0) }
103
- }
104
- };
138
+ }
139
+ };
140
+ }
141
+ case "transfer":
142
+ {
143
+ // C3 FIX: Use atomic RPC with row-level locking instead of separate upserts
144
+ const qty = args.quantity;
145
+ const productId = args.product_id;
146
+ const fromLocationId = args.from_location_id;
147
+ const toLocationId = args.to_location_id;
148
+ const {
149
+ data: product
150
+ } = await sb.from("products").select("name, sku").eq("id", productId).eq("store_id", sid).single();
151
+ const {
152
+ data: fromLocation
153
+ } = await sb.from("locations").select("name").eq("id", fromLocationId).eq("store_id", sid).single();
154
+ const {
155
+ data: toLocation
156
+ } = await sb.from("locations").select("name").eq("id", toLocationId).eq("store_id", sid).single();
157
+
158
+ // Atomic transfer — row-locked, transactional, no race conditions
159
+ const {
160
+ data: result,
161
+ error: rpcError
162
+ } = await sb.rpc("atomic_inventory_transfer", {
163
+ p_store_id: sid,
164
+ p_product_id: productId,
165
+ p_from_location_id: fromLocationId,
166
+ p_to_location_id: toLocationId,
167
+ p_quantity: qty
168
+ });
169
+ if (rpcError) {
170
+ return {
171
+ success: false,
172
+ error: rpcError.message
173
+ };
105
174
  }
106
- case "bulk_set": {
107
- const items = args.items;
108
- if (!items || !Array.isArray(items) || items.length === 0)
109
- return { success: false, error: "items array is required" };
110
- const results = [];
111
- for (const item of items) {
112
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_set", {
113
- p_store_id: sid, p_product_id: item.product_id, p_location_id: item.location_id,
114
- p_quantity: item.quantity, p_reason: "Bulk set",
115
- });
116
- if (rpcError) {
117
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "no", error: rpcError.message });
118
- continue;
119
- }
120
- const r = result;
121
- if (!r.success) {
122
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "no", error: r.error });
123
- continue;
124
- }
125
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "yes", before: r.data?.before, after: r.data?.after });
126
- }
127
- const succeeded = results.filter(r => r.ok === "yes").length;
128
- return { success: true, data: { total: items.length, succeeded, failed: items.length - succeeded, results } };
175
+ const rpcResult = result;
176
+ if (!rpcResult.success) {
177
+ return {
178
+ success: false,
179
+ error: rpcResult.error || "Transfer failed"
180
+ };
129
181
  }
130
- case "bulk_adjust": {
131
- const items = args.items;
132
- if (!items || !Array.isArray(items) || items.length === 0)
133
- return { success: false, error: "items array is required" };
134
- const results = [];
135
- for (const item of items) {
136
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_adjust", {
137
- p_store_id: sid, p_product_id: item.product_id, p_location_id: item.location_id,
138
- p_adjustment: item.adjustment, p_reason: "Bulk adjustment",
139
- });
140
- if (rpcError) {
141
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "no", error: rpcError.message });
142
- continue;
143
- }
144
- const r = result;
145
- if (!r.success) {
146
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "no", error: r.error });
147
- continue;
148
- }
149
- results.push({ product_id: item.product_id, location_id: item.location_id, ok: "yes", before: r.data?.before, after: r.data?.after });
182
+ const transferData = rpcResult.data || {};
183
+ return {
184
+ success: true,
185
+ data: {
186
+ intent: `Transfer ${qty} units of ${product?.name || 'product'} from ${fromLocation?.name || 'source'} to ${toLocation?.name || 'destination'}`,
187
+ product: product ? {
188
+ id: productId,
189
+ name: product.name,
190
+ sku: product.sku
191
+ } : {
192
+ id: productId
193
+ },
194
+ from_location: fromLocation ? {
195
+ id: fromLocationId,
196
+ name: fromLocation.name
197
+ } : {
198
+ id: fromLocationId
199
+ },
200
+ to_location: toLocation ? {
201
+ id: toLocationId,
202
+ name: toLocation.name
203
+ } : {
204
+ id: toLocationId
205
+ },
206
+ quantity_transferred: qty,
207
+ before_state: {
208
+ from_quantity: transferData.source_before,
209
+ to_quantity: transferData.dest_before,
210
+ total: (transferData.source_before || 0) + (transferData.dest_before || 0)
211
+ },
212
+ after_state: {
213
+ from_quantity: transferData.source_after,
214
+ to_quantity: transferData.dest_after,
215
+ total: (transferData.source_after || 0) + (transferData.dest_after || 0)
150
216
  }
151
- const succeeded = results.filter(r => r.ok === "yes").length;
152
- return { success: true, data: { total: items.length, succeeded, failed: items.length - succeeded, results } };
217
+ }
218
+ };
219
+ }
220
+ case "bulk_set":
221
+ {
222
+ const items = args.items;
223
+ if (!items || !Array.isArray(items) || items.length === 0) return {
224
+ success: false,
225
+ error: "items array is required"
226
+ };
227
+ const results = [];
228
+ for (const item of items) {
229
+ const {
230
+ data: result,
231
+ error: rpcError
232
+ } = await sb.rpc("atomic_inventory_set", {
233
+ p_store_id: sid,
234
+ p_product_id: item.product_id,
235
+ p_location_id: item.location_id,
236
+ p_quantity: item.quantity,
237
+ p_reason: "Bulk set"
238
+ });
239
+ if (rpcError) {
240
+ results.push({
241
+ product_id: item.product_id,
242
+ location_id: item.location_id,
243
+ ok: "no",
244
+ error: rpcError.message
245
+ });
246
+ continue;
247
+ }
248
+ const r = result;
249
+ if (!r.success) {
250
+ results.push({
251
+ product_id: item.product_id,
252
+ location_id: item.location_id,
253
+ ok: "no",
254
+ error: r.error
255
+ });
256
+ continue;
257
+ }
258
+ results.push({
259
+ product_id: item.product_id,
260
+ location_id: item.location_id,
261
+ ok: "yes",
262
+ before: r.data?.before,
263
+ after: r.data?.after
264
+ });
153
265
  }
154
- case "bulk_clear": {
155
- const locationId = args.location_id;
156
- if (!locationId)
157
- return { success: false, error: "location_id is required" };
158
- // Fetch items with stock > 0, then use atomic_inventory_set for audit trail
159
- const { data: items, error: fetchErr } = await sb.from("inventory")
160
- .select("product_id, quantity").eq("store_id", sid).eq("location_id", locationId).gt("quantity", 0);
161
- if (fetchErr)
162
- return { success: false, error: fetchErr.message };
163
- if (!items || items.length === 0)
164
- return { success: true, data: { location_id: locationId, items_cleared: 0 } };
165
- const results = [];
166
- for (const item of items) {
167
- const { data: result, error: rpcError } = await sb.rpc("atomic_inventory_set", {
168
- p_store_id: sid, p_product_id: item.product_id, p_location_id: locationId,
169
- p_quantity: 0, p_reason: "Bulk clear",
170
- });
171
- if (rpcError) {
172
- results.push({ product_id: item.product_id, success: false, error: rpcError.message });
173
- continue;
174
- }
175
- const r = result;
176
- if (!r.success) {
177
- results.push({ product_id: item.product_id, success: false, error: r.error });
178
- continue;
179
- }
180
- results.push({ product_id: item.product_id, success: true, before: r.data?.before });
181
- }
182
- const succeeded = results.filter(r => r.success).length;
183
- return { success: true, data: { location_id: locationId, items_cleared: succeeded, total: items.length, results } };
266
+ const succeeded = results.filter(r => r.ok === "yes").length;
267
+ return {
268
+ success: true,
269
+ data: {
270
+ total: items.length,
271
+ succeeded,
272
+ failed: items.length - succeeded,
273
+ results
274
+ }
275
+ };
276
+ }
277
+ case "bulk_adjust":
278
+ {
279
+ const items = args.items;
280
+ if (!items || !Array.isArray(items) || items.length === 0) return {
281
+ success: false,
282
+ error: "items array is required"
283
+ };
284
+ const results = [];
285
+ for (const item of items) {
286
+ const {
287
+ data: result,
288
+ error: rpcError
289
+ } = await sb.rpc("atomic_inventory_adjust", {
290
+ p_store_id: sid,
291
+ p_product_id: item.product_id,
292
+ p_location_id: item.location_id,
293
+ p_adjustment: item.adjustment,
294
+ p_reason: "Bulk adjustment"
295
+ });
296
+ if (rpcError) {
297
+ results.push({
298
+ product_id: item.product_id,
299
+ location_id: item.location_id,
300
+ ok: "no",
301
+ error: rpcError.message
302
+ });
303
+ continue;
304
+ }
305
+ const r = result;
306
+ if (!r.success) {
307
+ results.push({
308
+ product_id: item.product_id,
309
+ location_id: item.location_id,
310
+ ok: "no",
311
+ error: r.error
312
+ });
313
+ continue;
314
+ }
315
+ results.push({
316
+ product_id: item.product_id,
317
+ location_id: item.location_id,
318
+ ok: "yes",
319
+ before: r.data?.before,
320
+ after: r.data?.after
321
+ });
184
322
  }
185
- default:
186
- return { success: false, error: `Unknown inventory action: ${args.action}` };
187
- }
323
+ const succeeded = results.filter(r => r.ok === "yes").length;
324
+ return {
325
+ success: true,
326
+ data: {
327
+ total: items.length,
328
+ succeeded,
329
+ failed: items.length - succeeded,
330
+ results
331
+ }
332
+ };
333
+ }
334
+ case "bulk_clear":
335
+ {
336
+ const locationId = args.location_id;
337
+ if (!locationId) return {
338
+ success: false,
339
+ error: "location_id is required"
340
+ };
341
+ // Fetch items with stock > 0, then use atomic_inventory_set for audit trail
342
+ const {
343
+ data: items,
344
+ error: fetchErr
345
+ } = await sb.from("inventory").select("product_id, quantity").eq("store_id", sid).eq("location_id", locationId).gt("quantity", 0);
346
+ if (fetchErr) return {
347
+ success: false,
348
+ error: fetchErr.message
349
+ };
350
+ if (!items || items.length === 0) return {
351
+ success: true,
352
+ data: {
353
+ location_id: locationId,
354
+ items_cleared: 0
355
+ }
356
+ };
357
+ const results = [];
358
+ for (const item of items) {
359
+ const {
360
+ data: result,
361
+ error: rpcError
362
+ } = await sb.rpc("atomic_inventory_set", {
363
+ p_store_id: sid,
364
+ p_product_id: item.product_id,
365
+ p_location_id: locationId,
366
+ p_quantity: 0,
367
+ p_reason: "Bulk clear"
368
+ });
369
+ if (rpcError) {
370
+ results.push({
371
+ product_id: item.product_id,
372
+ success: false,
373
+ error: rpcError.message
374
+ });
375
+ continue;
376
+ }
377
+ const r = result;
378
+ if (!r.success) {
379
+ results.push({
380
+ product_id: item.product_id,
381
+ success: false,
382
+ error: r.error
383
+ });
384
+ continue;
385
+ }
386
+ results.push({
387
+ product_id: item.product_id,
388
+ success: true,
389
+ before: r.data?.before
390
+ });
391
+ }
392
+ const succeeded = results.filter(r => r.success).length;
393
+ return {
394
+ success: true,
395
+ data: {
396
+ location_id: locationId,
397
+ items_cleared: succeeded,
398
+ total: items.length,
399
+ results
400
+ }
401
+ };
402
+ }
403
+ default:
404
+ return {
405
+ success: false,
406
+ error: `Unknown inventory action: ${args.action}`
407
+ };
408
+ }
188
409
  }
410
+
189
411
  // Resolve location name/slug to UUID — accepts UUID passthrough, name, or slug
190
412
  async function resolveLocationId(sb, sid, input) {
191
- if (/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(input)) {
192
- const { data } = await sb.from("locations").select("id, name").eq("id", input).eq("store_id", sid).single();
193
- return data;
194
- }
195
- const clean = input.replace(/-/g, " ");
196
- const { data } = await sb.from("locations").select("id, name").eq("store_id", sid)
197
- .or(`name.ilike.%${clean}%,slug.ilike.%${input}%`).limit(1);
198
- return data?.[0] || null;
413
+ if (/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i.test(input)) {
414
+ const {
415
+ data
416
+ } = await sb.from("locations").select("id, name").eq("id", input).eq("store_id", sid).single();
417
+ return data;
418
+ }
419
+ const clean = input.replace(/-/g, " ");
420
+ const {
421
+ data
422
+ } = await sb.from("locations").select("id, name").eq("store_id", sid).or(`name.ilike.%${clean}%,slug.ilike.%${input}%`).limit(1);
423
+ return data?.[0] || null;
199
424
  }
200
425
  export async function handleInventoryQuery(sb, args, storeId) {
201
- const sid = storeId;
202
- switch (args.action) {
203
- case "summary": {
204
- const { data, error } = await sb.from("inventory")
205
- .select("*, product:products(name, sku), location:locations(name)")
206
- .eq("store_id", sid).limit(1000);
207
- if (error)
208
- return { success: false, error: error.message };
209
- const byLocation = {};
210
- for (const row of data || []) {
211
- const locId = row.location_id;
212
- if (!byLocation[locId])
213
- byLocation[locId] = { location_id: locId, location_name: row.location?.name || locId, items: 0, total_qty: 0 };
214
- byLocation[locId].items++;
215
- byLocation[locId].total_qty += row.quantity || 0;
216
- }
217
- return { success: true, data: { total_items: data?.length || 0, by_location: Object.values(byLocation) } };
426
+ const sid = storeId;
427
+ switch (args.action) {
428
+ case "summary":
429
+ {
430
+ const {
431
+ data,
432
+ error
433
+ } = await sb.from("inventory").select("*, product:products(name, sku), location:locations(name)").eq("store_id", sid).limit(1000);
434
+ if (error) return {
435
+ success: false,
436
+ error: error.message
437
+ };
438
+ const byLocation = {};
439
+ for (const row of data || []) {
440
+ const locId = row.location_id;
441
+ if (!byLocation[locId]) byLocation[locId] = {
442
+ location_id: locId,
443
+ location_name: row.location?.name || locId,
444
+ items: 0,
445
+ total_qty: 0
446
+ };
447
+ byLocation[locId].items++;
448
+ byLocation[locId].total_qty += row.quantity || 0;
218
449
  }
219
- case "velocity": {
220
- const days = args.days || 30;
221
- const categoryId = args.category_id;
222
- const productId = args.product_id;
223
- const locationId = args.location_id;
224
- const limit = args.limit || 50;
225
- const { data, error } = await sb.rpc("get_product_velocity", {
226
- p_store_id: sid, p_days: days, p_location_id: locationId || null,
227
- p_category_id: categoryId || null, p_product_id: productId || null, p_limit: limit
228
- });
229
- if (error)
230
- return { success: false, error: error.message };
231
- const products = (data || []).map((row) => ({
232
- productId: row.product_id, name: row.product_name, sku: row.product_sku,
233
- category: row.category_name, locationId: row.location_id, locationName: row.location_name,
234
- totalQty: row.units_sold, totalRevenue: row.revenue, orderCount: row.order_count,
235
- velocityPerDay: row.daily_velocity, revenuePerDay: row.daily_revenue,
236
- currentStock: row.current_stock, daysOfStock: row.days_of_stock,
237
- avgPrice: row.avg_unit_price, stockAlert: row.stock_status
238
- }));
239
- return { success: true, data: { days, filters: { categoryId, locationId, productId }, products } };
240
- }
241
- case "by_location": {
242
- let q = sb.from("inventory").select("product_id, location_id, quantity, product:products(name, sku, category:categories!primary_category_id(name)), location:locations(name)")
243
- .eq("store_id", sid);
244
- if (args.location_id || args.location) {
245
- const locInput = (args.location_id || args.location);
246
- const loc = await resolveLocationId(sb, sid, locInput);
247
- if (!loc)
248
- return { success: false, error: `Location not found: "${locInput}". Use locations tool to list available locations.` };
249
- q = q.eq("location_id", loc.id);
250
- }
251
- if (args.limit)
252
- q = q.limit(args.limit);
253
- const { data, error } = await q.order("quantity", { ascending: false });
254
- if (error)
255
- return { success: false, error: error.message };
256
- const flattened = (data || []).map((row) => ({
257
- product_id: row.product_id,
258
- product_name: row.product?.name || "—",
259
- product_sku: row.product?.sku || "—",
260
- category: row.product?.category?.name || null,
261
- location_id: row.location_id,
262
- location_name: row.location?.name || "—",
263
- quantity: row.quantity,
264
- }));
265
- return { success: true, count: flattened.length, data: flattened };
450
+ return {
451
+ success: true,
452
+ data: {
453
+ total_items: data?.length || 0,
454
+ by_location: Object.values(byLocation)
455
+ }
456
+ };
457
+ }
458
+ case "velocity":
459
+ {
460
+ const days = args.days || 30;
461
+ const categoryId = args.category_id;
462
+ const productId = args.product_id;
463
+ const locationId = args.location_id;
464
+ const limit = args.limit || 50;
465
+ const {
466
+ data,
467
+ error
468
+ } = await sb.rpc("get_product_velocity", {
469
+ p_store_id: sid,
470
+ p_days: days,
471
+ p_location_id: locationId || null,
472
+ p_category_id: categoryId || null,
473
+ p_product_id: productId || null,
474
+ p_limit: limit
475
+ });
476
+ if (error) return {
477
+ success: false,
478
+ error: error.message
479
+ };
480
+ const products = (data || []).map(row => ({
481
+ productId: row.product_id,
482
+ name: row.product_name,
483
+ sku: row.product_sku,
484
+ category: row.category_name,
485
+ locationId: row.location_id,
486
+ locationName: row.location_name,
487
+ totalQty: row.units_sold,
488
+ totalRevenue: row.revenue,
489
+ orderCount: row.order_count,
490
+ velocityPerDay: row.daily_velocity,
491
+ revenuePerDay: row.daily_revenue,
492
+ currentStock: row.current_stock,
493
+ daysOfStock: row.days_of_stock,
494
+ avgPrice: row.avg_unit_price,
495
+ stockAlert: row.stock_status
496
+ }));
497
+ return {
498
+ success: true,
499
+ data: {
500
+ days,
501
+ filters: {
502
+ categoryId,
503
+ locationId,
504
+ productId
505
+ },
506
+ products
507
+ }
508
+ };
509
+ }
510
+ case "by_location":
511
+ {
512
+ let q = sb.from("inventory").select("product_id, location_id, quantity, product:products(name, sku, category:categories!primary_category_id(name)), location:locations(name)").eq("store_id", sid);
513
+ if (args.location_id || args.location) {
514
+ const locInput = args.location_id || args.location;
515
+ const loc = await resolveLocationId(sb, sid, locInput);
516
+ if (!loc) return {
517
+ success: false,
518
+ error: `Location not found: "${locInput}". Use locations tool to list available locations.`
519
+ };
520
+ q = q.eq("location_id", loc.id);
266
521
  }
267
- case "in_stock": {
268
- let inStockQ = sb.from("inventory")
269
- .select("product_id, location_id, quantity, product:products(name, sku, category:categories!primary_category_id(name)), location:locations(name)")
270
- .eq("store_id", sid).gt("quantity", 0);
271
- if (args.location_id || args.location) {
272
- const locInput = (args.location_id || args.location);
273
- const loc = await resolveLocationId(sb, sid, locInput);
274
- if (!loc)
275
- return { success: false, error: `Location not found: "${locInput}". Use locations tool to list available locations.` };
276
- inStockQ = inStockQ.eq("location_id", loc.id);
277
- }
278
- if (args.limit)
279
- inStockQ = inStockQ.limit(args.limit);
280
- const { data, error } = await inStockQ.order("quantity", { ascending: false });
281
- if (error)
282
- return { success: false, error: error.message };
283
- const flattened = (data || []).map((row) => ({
284
- product_id: row.product_id,
285
- product_name: row.product?.name || "—",
286
- product_sku: row.product?.sku || "—",
287
- category: row.product?.category?.name || null,
288
- location_id: row.location_id,
289
- location_name: row.location?.name || "—",
290
- quantity: row.quantity,
291
- }));
292
- return { success: true, count: flattened.length, data: flattened };
293
- }
294
- case "by_category": {
295
- // Pre-grouped inventory by category compact summary the LLM can use directly
296
- let catQ = sb.from("inventory")
297
- .select("product_id, location_id, quantity, product:products!inner(name, sku, status, primary_category_id, category:categories!primary_category_id(name, parent_id)), location:locations(name)")
298
- .eq("store_id", sid).gt("quantity", 0)
299
- .eq("product.status", "published");
300
- // Optional location filter
301
- let locationName = null;
302
- if (args.location_id || args.location) {
303
- const locInput = (args.location_id || args.location);
304
- const loc = await resolveLocationId(sb, sid, locInput);
305
- if (!loc)
306
- return { success: false, error: `Location not found: "${locInput}". Use locations tool to list available locations.` };
307
- catQ = catQ.eq("location_id", loc.id);
308
- locationName = loc.name;
309
- }
310
- const { data, error } = await catQ;
311
- // Optional category filter — includes sub-categories
312
- let categoryFilter = null;
313
- if (args.category) {
314
- const catInput = args.category;
315
- const isUuid = /^[0-9a-f]{8}-/i.test(catInput);
316
- let parentId = null;
317
- if (isUuid) {
318
- parentId = catInput;
319
- }
320
- else {
321
- const { data: cats } = await sb.from("categories").select("id").ilike("name", `%${catInput}%`).eq("store_id", sid).limit(1);
322
- if (cats?.length)
323
- parentId = cats[0].id;
324
- }
325
- if (parentId) {
326
- const { data: children } = await sb.from("categories").select("id").eq("parent_id", parentId).eq("store_id", sid);
327
- categoryFilter = new Set([parentId, ...(children || []).map(c => c.id)]);
328
- }
329
- else {
330
- // Category name didn't match anything — filter out everything
331
- categoryFilter = new Set();
332
- }
333
- }
334
- if (error)
335
- return { success: false, error: error.message };
336
- // Group by category
337
- const catMap = {};
338
- for (const row of data || []) {
339
- // Apply category filter if set
340
- if (categoryFilter) {
341
- const prodCatId = row.product?.primary_category_id;
342
- if (!prodCatId || !categoryFilter.has(prodCatId))
343
- continue;
344
- }
345
- const cat = row.product?.category?.name || "Uncategorized";
346
- const pName = row.product?.name || "—";
347
- const pSku = row.product?.sku || "—";
348
- const locName = row.location?.name || "—";
349
- const qty = row.quantity || 0;
350
- if (!catMap[cat])
351
- catMap[cat] = { products: {}, total_qty: 0 };
352
- catMap[cat].total_qty += qty;
353
- const pKey = row.product_id;
354
- if (!catMap[cat].products[pKey])
355
- catMap[cat].products[pKey] = { name: pName, sku: pSku, total_qty: 0, locations: [] };
356
- catMap[cat].products[pKey].total_qty += qty;
357
- if (!catMap[cat].products[pKey].locations.includes(locName))
358
- catMap[cat].products[pKey].locations.push(locName);
359
- }
360
- // Format as pre-rendered markdown — the CLI formatter drops nested arrays,
361
- // so we render products-per-category here to prevent the agent from losing
362
- // the product→category mapping and reconstructing it incorrectly.
363
- const categories = Object.entries(catMap)
364
- .sort((a, b) => b[1].total_qty - a[1].total_qty)
365
- .map(([cat, info]) => ({
366
- category: cat,
367
- total_qty: Math.round(info.total_qty * 100) / 100,
368
- product_count: Object.keys(info.products).length,
369
- products: Object.values(info.products)
370
- .sort((a, b) => b.total_qty - a.total_qty)
371
- .map(p => ({ name: p.name, sku: p.sku, qty: Math.round(p.total_qty * 100) / 100 })),
372
- }));
373
- const totalProducts = categories.reduce((s, c) => s + c.product_count, 0);
374
- const header = locationName ? `Inventory at ${locationName}` : "Inventory by Category";
375
- const lines = [
376
- `## ${header}${args.category ? ` — ${args.category}` : ""}`,
377
- `${categories.length} categories, ${totalProducts} products in stock\n`,
378
- ];
379
- for (const cat of categories) {
380
- lines.push(`### ${cat.category} (${cat.product_count} products, ${cat.total_qty} units)`);
381
- lines.push("| Product | SKU | Qty |");
382
- lines.push("| --- | --- | ---: |");
383
- for (const p of cat.products) {
384
- lines.push(`| ${p.name} | ${p.sku} | ${p.qty} |`);
385
- }
386
- lines.push("");
387
- }
388
- lines.push("This is the COMPLETE inventory breakdown. Every in-stock product is listed under its correct category. Do NOT re-fetch individual categories or call in_stock — all data is here.");
389
- return { success: true, data: lines.join("\n") };
522
+ if (args.limit) q = q.limit(args.limit);
523
+ const {
524
+ data,
525
+ error
526
+ } = await q.order("quantity", {
527
+ ascending: false
528
+ });
529
+ if (error) return {
530
+ success: false,
531
+ error: error.message
532
+ };
533
+ const flattened = (data || []).map(row => ({
534
+ product_id: row.product_id,
535
+ product_name: row.product?.name || "",
536
+ product_sku: row.product?.sku || "—",
537
+ category: row.product?.category?.name || null,
538
+ location_id: row.location_id,
539
+ location_name: row.location?.name || "—",
540
+ quantity: row.quantity
541
+ }));
542
+ return {
543
+ success: true,
544
+ count: flattened.length,
545
+ data: flattened
546
+ };
547
+ }
548
+ case "in_stock":
549
+ {
550
+ let inStockQ = sb.from("inventory").select("product_id, location_id, quantity, product:products(name, sku, category:categories!primary_category_id(name)), location:locations(name)").eq("store_id", sid).gt("quantity", 0);
551
+ if (args.location_id || args.location) {
552
+ const locInput = args.location_id || args.location;
553
+ const loc = await resolveLocationId(sb, sid, locInput);
554
+ if (!loc) return {
555
+ success: false,
556
+ error: `Location not found: "${locInput}". Use locations tool to list available locations.`
557
+ };
558
+ inStockQ = inStockQ.eq("location_id", loc.id);
390
559
  }
391
- case "out_of_stock": {
392
- // Find all published products with zero or no inventory across all locations
393
- const { data: products, error: pErr } = await sb.from("products")
394
- .select("id, name, sku, category:categories!primary_category_id(name)").eq("store_id", sid).eq("status", "published");
395
- if (pErr)
396
- return { success: false, error: pErr.message };
397
- const { data: inv } = await sb.from("inventory")
398
- .select("product_id, quantity").eq("store_id", sid);
399
- // Sum stock per product
400
- const stockMap = {};
401
- for (const row of inv || []) {
402
- stockMap[row.product_id] = (stockMap[row.product_id] || 0) + (row.quantity || 0);
403
- }
404
- const outOfStock = (products || [])
405
- .filter(p => !stockMap[p.id] || stockMap[p.id] <= 0)
406
- .map(p => ({ product_id: p.id, name: p.name, sku: p.sku, category: p.category?.name || null, total_stock: stockMap[p.id] || 0 }));
407
- return { success: true, count: outOfStock.length, total_products: products?.length || 0, data: outOfStock };
560
+ if (args.limit) inStockQ = inStockQ.limit(args.limit);
561
+ const {
562
+ data,
563
+ error
564
+ } = await inStockQ.order("quantity", {
565
+ ascending: false
566
+ });
567
+ if (error) return {
568
+ success: false,
569
+ error: error.message
570
+ };
571
+ const flattened = (data || []).map(row => ({
572
+ product_id: row.product_id,
573
+ product_name: row.product?.name || "—",
574
+ product_sku: row.product?.sku || "—",
575
+ category: row.product?.category?.name || null,
576
+ location_id: row.location_id,
577
+ location_name: row.location?.name || "—",
578
+ quantity: row.quantity
579
+ }));
580
+ return {
581
+ success: true,
582
+ count: flattened.length,
583
+ data: flattened
584
+ };
585
+ }
586
+ case "by_category":
587
+ {
588
+ // Pre-grouped inventory by category — compact summary the LLM can use directly
589
+ let catQ = sb.from("inventory").select("product_id, location_id, quantity, product:products!inner(name, sku, status, primary_category_id, category:categories!primary_category_id(name, parent_id)), location:locations(name)").eq("store_id", sid).gt("quantity", 0).eq("product.status", "published");
590
+ // Optional location filter
591
+ let locationName = null;
592
+ if (args.location_id || args.location) {
593
+ const locInput = args.location_id || args.location;
594
+ const loc = await resolveLocationId(sb, sid, locInput);
595
+ if (!loc) return {
596
+ success: false,
597
+ error: `Location not found: "${locInput}". Use locations tool to list available locations.`
598
+ };
599
+ catQ = catQ.eq("location_id", loc.id);
600
+ locationName = loc.name;
408
601
  }
409
- default:
410
- return { success: false, error: `Unknown inventory_query action: ${args.action}` };
411
- }
412
- }
413
- export async function handleInventoryAudit(sb, args, storeId) {
414
- const sid = storeId;
415
- switch (args.action) {
416
- case "start": {
417
- const { data, error } = await sb.from("inventory_audits")
418
- .insert({ store_id: sid, location_id: args.location_id, audit_type: args.audit_type || "full", status: "in_progress", started_at: new Date().toISOString() })
419
- .select().single();
420
- return error ? { success: false, error: error.message } : { success: true, data };
602
+ const {
603
+ data,
604
+ error
605
+ } = await catQ;
606
+ // Optional category filter includes sub-categories
607
+ let categoryFilter = null;
608
+ if (args.category) {
609
+ const catInput = args.category;
610
+ const isUuid = /^[0-9a-f]{8}-/i.test(catInput);
611
+ let parentId = null;
612
+ if (isUuid) {
613
+ parentId = catInput;
614
+ } else {
615
+ const {
616
+ data: cats
617
+ } = await sb.from("categories").select("id").ilike("name", `%${catInput}%`).eq("store_id", sid).limit(1);
618
+ if (cats?.length) parentId = cats[0].id;
619
+ }
620
+ if (parentId) {
621
+ const {
622
+ data: children
623
+ } = await sb.from("categories").select("id").eq("parent_id", parentId).eq("store_id", sid);
624
+ categoryFilter = new Set([parentId, ...(children || []).map(c => c.id)]);
625
+ } else {
626
+ // Category name didn't match anything — filter out everything
627
+ categoryFilter = new Set();
628
+ }
421
629
  }
422
- case "count": {
423
- // Verify the parent audit belongs to this store before updating items
424
- const { data: audit } = await sb.from("inventory_audits").select("id").eq("id", args.audit_id).eq("store_id", sid).single();
425
- if (!audit)
426
- return { success: false, error: "Audit not found" };
427
- const { data, error } = await sb.from("inventory_audit_items")
428
- .update({ counted_quantity: args.counted })
429
- .eq("audit_id", args.audit_id).eq("product_id", args.product_id).select().single();
430
- return error ? { success: false, error: error.message } : { success: true, data };
630
+ if (error) return {
631
+ success: false,
632
+ error: error.message
633
+ };
634
+ // Group by category
635
+ const catMap = {};
636
+ for (const row of data || []) {
637
+ // Apply category filter if set
638
+ if (categoryFilter) {
639
+ const prodCatId = row.product?.primary_category_id;
640
+ if (!prodCatId || !categoryFilter.has(prodCatId)) continue;
641
+ }
642
+ const cat = row.product?.category?.name || "Uncategorized";
643
+ const pName = row.product?.name || "—";
644
+ const pSku = row.product?.sku || "—";
645
+ const locName = row.location?.name || "—";
646
+ const qty = row.quantity || 0;
647
+ if (!catMap[cat]) catMap[cat] = {
648
+ products: {},
649
+ total_qty: 0
650
+ };
651
+ catMap[cat].total_qty += qty;
652
+ const pKey = row.product_id;
653
+ if (!catMap[cat].products[pKey]) catMap[cat].products[pKey] = {
654
+ name: pName,
655
+ sku: pSku,
656
+ total_qty: 0,
657
+ locations: []
658
+ };
659
+ catMap[cat].products[pKey].total_qty += qty;
660
+ if (!catMap[cat].products[pKey].locations.includes(locName)) catMap[cat].products[pKey].locations.push(locName);
431
661
  }
432
- case "complete": {
433
- const { data, error } = await sb.from("inventory_audits")
434
- .update({ status: "completed", completed_at: new Date().toISOString() })
435
- .eq("id", args.audit_id).eq("store_id", sid).select().single();
436
- return error ? { success: false, error: error.message } : { success: true, data };
662
+ // Format as pre-rendered markdown — the CLI formatter drops nested arrays,
663
+ // so we render products-per-category here to prevent the agent from losing
664
+ // the product→category mapping and reconstructing it incorrectly.
665
+ const categories = Object.entries(catMap).sort((a, b) => b[1].total_qty - a[1].total_qty).map(([cat, info]) => ({
666
+ category: cat,
667
+ total_qty: Math.round(info.total_qty * 100) / 100,
668
+ product_count: Object.keys(info.products).length,
669
+ products: Object.values(info.products).sort((a, b) => b.total_qty - a.total_qty).map(p => ({
670
+ name: p.name,
671
+ sku: p.sku,
672
+ qty: Math.round(p.total_qty * 100) / 100
673
+ }))
674
+ }));
675
+ const totalProducts = categories.reduce((s, c) => s + c.product_count, 0);
676
+ const header = locationName ? `Inventory at ${locationName}` : "Inventory by Category";
677
+ const lines = [`## ${header}${args.category ? ` — ${args.category}` : ""}`, `${categories.length} categories, ${totalProducts} products in stock\n`];
678
+ for (const cat of categories) {
679
+ lines.push(`### ${cat.category} (${cat.product_count} products, ${cat.total_qty} units)`);
680
+ lines.push("| Product | SKU | Qty |");
681
+ lines.push("| --- | --- | ---: |");
682
+ for (const p of cat.products) {
683
+ lines.push(`| ${p.name} | ${p.sku} | ${p.qty} |`);
684
+ }
685
+ lines.push("");
437
686
  }
438
- case "summary": {
439
- const { data, error } = await sb.from("inventory_audits")
440
- .select("*, items:inventory_audit_items(*)").eq("store_id", sid)
441
- .order("created_at", { ascending: false }).limit(args.limit || 5);
442
- return error ? { success: false, error: error.message } : { success: true, data };
687
+ lines.push("This is the COMPLETE inventory breakdown. Every in-stock product is listed under its correct category. Do NOT re-fetch individual categories or call in_stock — all data is here.");
688
+ return {
689
+ success: true,
690
+ data: lines.join("\n")
691
+ };
692
+ }
693
+ case "out_of_stock":
694
+ {
695
+ // Find all published products with zero or no inventory across all locations
696
+ const {
697
+ data: products,
698
+ error: pErr
699
+ } = await sb.from("products").select("id, name, sku, category:categories!primary_category_id(name)").eq("store_id", sid).eq("status", "published");
700
+ if (pErr) return {
701
+ success: false,
702
+ error: pErr.message
703
+ };
704
+ const {
705
+ data: inv
706
+ } = await sb.from("inventory").select("product_id, quantity").eq("store_id", sid);
707
+ // Sum stock per product
708
+ const stockMap = {};
709
+ for (const row of inv || []) {
710
+ stockMap[row.product_id] = (stockMap[row.product_id] || 0) + (row.quantity || 0);
443
711
  }
444
- default:
445
- return { success: false, error: `Unknown inventory_audit action: ${args.action}` };
446
- }
712
+ const outOfStock = (products || []).filter(p => !stockMap[p.id] || stockMap[p.id] <= 0).map(p => ({
713
+ product_id: p.id,
714
+ name: p.name,
715
+ sku: p.sku,
716
+ category: p.category?.name || null,
717
+ total_stock: stockMap[p.id] || 0
718
+ }));
719
+ return {
720
+ success: true,
721
+ count: outOfStock.length,
722
+ total_products: products?.length || 0,
723
+ data: outOfStock
724
+ };
725
+ }
726
+ default:
727
+ return {
728
+ success: false,
729
+ error: `Unknown inventory_query action: ${args.action}`
730
+ };
731
+ }
732
+ }
733
+ export async function handleInventoryAudit(sb, args, storeId) {
734
+ const sid = storeId;
735
+ switch (args.action) {
736
+ case "start":
737
+ {
738
+ const {
739
+ data,
740
+ error
741
+ } = await sb.from("inventory_audits").insert({
742
+ store_id: sid,
743
+ location_id: args.location_id,
744
+ audit_type: args.audit_type || "full",
745
+ status: "in_progress",
746
+ started_at: new Date().toISOString()
747
+ }).select().single();
748
+ return error ? {
749
+ success: false,
750
+ error: error.message
751
+ } : {
752
+ success: true,
753
+ data
754
+ };
755
+ }
756
+ case "count":
757
+ {
758
+ // Verify the parent audit belongs to this store before updating items
759
+ const {
760
+ data: audit
761
+ } = await sb.from("inventory_audits").select("id").eq("id", args.audit_id).eq("store_id", sid).single();
762
+ if (!audit) return {
763
+ success: false,
764
+ error: "Audit not found"
765
+ };
766
+ const {
767
+ data,
768
+ error
769
+ } = await sb.from("inventory_audit_items").update({
770
+ counted_quantity: args.counted
771
+ }).eq("audit_id", args.audit_id).eq("product_id", args.product_id).select().single();
772
+ return error ? {
773
+ success: false,
774
+ error: error.message
775
+ } : {
776
+ success: true,
777
+ data
778
+ };
779
+ }
780
+ case "complete":
781
+ {
782
+ const {
783
+ data,
784
+ error
785
+ } = await sb.from("inventory_audits").update({
786
+ status: "completed",
787
+ completed_at: new Date().toISOString()
788
+ }).eq("id", args.audit_id).eq("store_id", sid).select().single();
789
+ return error ? {
790
+ success: false,
791
+ error: error.message
792
+ } : {
793
+ success: true,
794
+ data
795
+ };
796
+ }
797
+ case "summary":
798
+ {
799
+ const {
800
+ data,
801
+ error
802
+ } = await sb.from("inventory_audits").select("*, items:inventory_audit_items(*)").eq("store_id", sid).order("created_at", {
803
+ ascending: false
804
+ }).limit(args.limit || 5);
805
+ return error ? {
806
+ success: false,
807
+ error: error.message
808
+ } : {
809
+ success: true,
810
+ data
811
+ };
812
+ }
813
+ default:
814
+ return {
815
+ success: false,
816
+ error: `Unknown inventory_audit action: ${args.action}`
817
+ };
818
+ }
447
819
  }
820
+ //# sourceMappingURL=inventory.js.map