whale-code 6.5.4 → 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 (853) 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 +29 -0
  73. package/dist/cli/services/agent-config.js +91 -0
  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 +978 -669
  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.d.ts +2 -3
  107. package/dist/cli/services/error-logger.js +189 -180
  108. package/dist/cli/services/error-logger.js.map +1 -0
  109. package/dist/cli/services/file-history.d.ts +1 -1
  110. package/dist/cli/services/file-history.js +50 -54
  111. package/dist/cli/services/file-history.js.map +1 -0
  112. package/dist/cli/services/format-server-response.js +332 -372
  113. package/dist/cli/services/format-server-response.js.map +1 -0
  114. package/dist/cli/services/git-context.js +61 -45
  115. package/dist/cli/services/git-context.js.map +1 -0
  116. package/dist/cli/services/hooks.d.ts +2 -2
  117. package/dist/cli/services/hooks.js +195 -180
  118. package/dist/cli/services/hooks.js.map +1 -0
  119. package/dist/cli/services/ink-incremental.d.ts +19 -0
  120. package/dist/cli/services/ink-incremental.js +59 -0
  121. package/dist/cli/services/ink-incremental.js.map +1 -0
  122. package/dist/cli/services/ink-resize-fix.js +54 -44
  123. package/dist/cli/services/ink-resize-fix.js.map +1 -0
  124. package/dist/cli/services/ink-sync-output.d.ts +12 -0
  125. package/dist/cli/services/ink-sync-output.js +16 -0
  126. package/dist/cli/services/ink-sync-output.js.map +1 -0
  127. package/dist/cli/services/interactive-tools.js +268 -212
  128. package/dist/cli/services/interactive-tools.js.map +1 -0
  129. package/dist/cli/services/keybinding-manager.d.ts +11 -1
  130. package/dist/cli/services/keybinding-manager.js +126 -63
  131. package/dist/cli/services/keybinding-manager.js.map +1 -0
  132. package/dist/cli/services/local-tools.d.ts +1 -1
  133. package/dist/cli/services/local-tools.js +939 -656
  134. package/dist/cli/services/local-tools.js.map +1 -0
  135. package/dist/cli/services/lsp-manager.js +757 -594
  136. package/dist/cli/services/lsp-manager.js.map +1 -0
  137. package/dist/cli/services/mcp-client.d.ts +1 -1
  138. package/dist/cli/services/mcp-client.js +173 -134
  139. package/dist/cli/services/mcp-client.js.map +1 -0
  140. package/dist/cli/services/memory-manager.js +53 -40
  141. package/dist/cli/services/memory-manager.js.map +1 -0
  142. package/dist/cli/services/model-manager.js +55 -40
  143. package/dist/cli/services/model-manager.js.map +1 -0
  144. package/dist/cli/services/model-router.js +115 -85
  145. package/dist/cli/services/model-router.js.map +1 -0
  146. package/dist/cli/services/paths.d.ts +30 -0
  147. package/dist/cli/services/paths.js +81 -0
  148. package/dist/cli/services/paths.js.map +1 -0
  149. package/dist/cli/services/permission-modes.js +32 -25
  150. package/dist/cli/services/permission-modes.js.map +1 -0
  151. package/dist/cli/services/rewind.js +182 -168
  152. package/dist/cli/services/rewind.js.map +1 -0
  153. package/dist/cli/services/ripgrep.js +115 -115
  154. package/dist/cli/services/ripgrep.js.map +1 -0
  155. package/dist/cli/services/sandbox.d.ts +1 -1
  156. package/dist/cli/services/sandbox.js +58 -37
  157. package/dist/cli/services/sandbox.js.map +1 -0
  158. package/dist/cli/services/server-tools.js +738 -565
  159. package/dist/cli/services/server-tools.js.map +1 -0
  160. package/dist/cli/services/session-persistence.js +69 -74
  161. package/dist/cli/services/session-persistence.js.map +1 -0
  162. package/dist/cli/services/subagent-worker.js +42 -27
  163. package/dist/cli/services/subagent-worker.js.map +1 -0
  164. package/dist/cli/services/subagent.d.ts +2 -0
  165. package/dist/cli/services/subagent.js +606 -430
  166. package/dist/cli/services/subagent.js.map +1 -0
  167. package/dist/cli/services/system-prompt.js +86 -78
  168. package/dist/cli/services/system-prompt.js.map +1 -0
  169. package/dist/cli/services/task-decomposer.d.ts +1 -1
  170. package/dist/cli/services/task-decomposer.js +172 -139
  171. package/dist/cli/services/task-decomposer.js.map +1 -0
  172. package/dist/cli/services/team-lead.d.ts +2 -2
  173. package/dist/cli/services/team-lead.js +727 -529
  174. package/dist/cli/services/team-lead.js.map +1 -0
  175. package/dist/cli/services/team-state.js +319 -319
  176. package/dist/cli/services/team-state.js.map +1 -0
  177. package/dist/cli/services/teammate.d.ts +8 -2
  178. package/dist/cli/services/teammate.js +862 -560
  179. package/dist/cli/services/teammate.js.map +1 -0
  180. package/dist/cli/services/telemetry.d.ts +6 -1
  181. package/dist/cli/services/telemetry.js +180 -157
  182. package/dist/cli/services/telemetry.js.map +1 -0
  183. package/dist/cli/services/tools/agent-tools.d.ts +3 -3
  184. package/dist/cli/services/tools/agent-tools.js +480 -322
  185. package/dist/cli/services/tools/agent-tools.js.map +1 -0
  186. package/dist/cli/services/tools/file-ops.js +563 -450
  187. package/dist/cli/services/tools/file-ops.js.map +1 -0
  188. package/dist/cli/services/tools/search-tools.js +231 -162
  189. package/dist/cli/services/tools/search-tools.js.map +1 -0
  190. package/dist/cli/services/tools/shell-exec.js +197 -151
  191. package/dist/cli/services/tools/shell-exec.js.map +1 -0
  192. package/dist/cli/services/tools/task-manager.js +206 -173
  193. package/dist/cli/services/tools/task-manager.js.map +1 -0
  194. package/dist/cli/services/tools/web-tools.js +388 -341
  195. package/dist/cli/services/tools/web-tools.js.map +1 -0
  196. package/dist/cli/setup/SetupApp.d.ts +2 -2
  197. package/dist/cli/setup/SetupApp.js +608 -160
  198. package/dist/cli/setup/SetupApp.js.map +1 -0
  199. package/dist/cli/shared/ErrorBoundary.d.ts +22 -0
  200. package/dist/cli/shared/ErrorBoundary.js +73 -0
  201. package/dist/cli/shared/ErrorBoundary.js.map +1 -0
  202. package/dist/cli/shared/MatrixIntro.js +66 -69
  203. package/dist/cli/shared/MatrixIntro.js.map +1 -0
  204. package/dist/cli/shared/SpinnerSlot.d.ts +14 -0
  205. package/dist/cli/shared/SpinnerSlot.js +63 -0
  206. package/dist/cli/shared/SpinnerSlot.js.map +1 -0
  207. package/dist/cli/shared/Theme.d.ts +1 -1
  208. package/dist/cli/shared/Theme.js +136 -92
  209. package/dist/cli/shared/Theme.js.map +1 -0
  210. package/dist/cli/shared/WhaleBanner.js +99 -11
  211. package/dist/cli/shared/WhaleBanner.js.map +1 -0
  212. package/dist/cli/shared/markdown.d.ts +3 -1
  213. package/dist/cli/shared/markdown.js +736 -674
  214. package/dist/cli/shared/markdown.js.map +1 -0
  215. package/dist/cli/shared/marked-terminal.d.js +2 -0
  216. package/dist/cli/shared/marked-terminal.d.js.map +1 -0
  217. package/dist/cli/shared/theme-manager.js +99 -90
  218. package/dist/cli/shared/theme-manager.js.map +1 -0
  219. package/dist/cli/shared/theme-presets.js +256 -254
  220. package/dist/cli/shared/theme-presets.js.map +1 -0
  221. package/dist/cli/status/StatusApp.js +235 -86
  222. package/dist/cli/status/StatusApp.js.map +1 -0
  223. package/dist/cli/stores/StoreApp.js +275 -65
  224. package/dist/cli/stores/StoreApp.js.map +1 -0
  225. package/dist/index.d.ts +2 -2
  226. package/dist/index.js +509 -396
  227. package/dist/index.js.map +1 -0
  228. package/dist/local-agent/connection.d.ts +2 -2
  229. package/dist/local-agent/connection.js +352 -293
  230. package/dist/local-agent/connection.js.map +1 -0
  231. package/dist/local-agent/discovery.js +259 -122
  232. package/dist/local-agent/discovery.js.map +1 -0
  233. package/dist/local-agent/executor.js +216 -193
  234. package/dist/local-agent/executor.js.map +1 -0
  235. package/dist/local-agent/index.d.ts +2 -2
  236. package/dist/local-agent/index.js +156 -156
  237. package/dist/local-agent/index.js.map +1 -0
  238. package/dist/node/adapters/base.js +18 -8
  239. package/dist/node/adapters/base.js.map +1 -0
  240. package/dist/node/adapters/discord.js +286 -275
  241. package/dist/node/adapters/discord.js.map +1 -0
  242. package/dist/node/adapters/email.js +189 -202
  243. package/dist/node/adapters/email.js.map +1 -0
  244. package/dist/node/adapters/imessage.js +145 -142
  245. package/dist/node/adapters/imessage.js.map +1 -0
  246. package/dist/node/adapters/slack.js +237 -236
  247. package/dist/node/adapters/slack.js.map +1 -0
  248. package/dist/node/adapters/sms.js +149 -151
  249. package/dist/node/adapters/sms.js.map +1 -0
  250. package/dist/node/adapters/telegram.js +88 -92
  251. package/dist/node/adapters/telegram.js.map +1 -0
  252. package/dist/node/adapters/webchat.js +160 -136
  253. package/dist/node/adapters/webchat.js.map +1 -0
  254. package/dist/node/adapters/whatsapp.js +212 -215
  255. package/dist/node/adapters/whatsapp.js.map +1 -0
  256. package/dist/node/cli.js +884 -653
  257. package/dist/node/cli.js.map +1 -0
  258. package/dist/node/config.js +20 -18
  259. package/dist/node/config.js.map +1 -0
  260. package/dist/node/gateway-client.js +191 -181
  261. package/dist/node/gateway-client.js.map +1 -0
  262. package/dist/node/portal/clipboard.js +161 -130
  263. package/dist/node/portal/clipboard.js.map +1 -0
  264. package/dist/node/portal/discovery.js +51 -45
  265. package/dist/node/portal/discovery.js.map +1 -0
  266. package/dist/node/portal/forward.js +64 -58
  267. package/dist/node/portal/forward.js.map +1 -0
  268. package/dist/node/portal/index.js +246 -221
  269. package/dist/node/portal/index.js.map +1 -0
  270. package/dist/node/portal/multiplexer.js +192 -182
  271. package/dist/node/portal/multiplexer.js.map +1 -0
  272. package/dist/node/portal/permissions.js +102 -70
  273. package/dist/node/portal/permissions.js.map +1 -0
  274. package/dist/node/portal/protocol.js +153 -116
  275. package/dist/node/portal/protocol.js.map +1 -0
  276. package/dist/node/portal/screen.js +80 -69
  277. package/dist/node/portal/screen.js.map +1 -0
  278. package/dist/node/portal/session.js +124 -117
  279. package/dist/node/portal/session.js.map +1 -0
  280. package/dist/node/portal/shell.js +140 -113
  281. package/dist/node/portal/shell.js.map +1 -0
  282. package/dist/node/portal/stream.js +77 -75
  283. package/dist/node/portal/stream.js.map +1 -0
  284. package/dist/node/portal/transfer.js +190 -167
  285. package/dist/node/portal/transfer.js.map +1 -0
  286. package/dist/node/portal/ui.js +124 -99
  287. package/dist/node/portal/ui.js.map +1 -0
  288. package/dist/node/remote-desktop/compile-helper.js +50 -45
  289. package/dist/node/remote-desktop/compile-helper.js.map +1 -0
  290. package/dist/node/remote-desktop/index.js +215 -187
  291. package/dist/node/remote-desktop/index.js.map +1 -0
  292. package/dist/node/remote-desktop/protocol.js +45 -29
  293. package/dist/node/remote-desktop/protocol.js.map +1 -0
  294. package/dist/node/runtime.js +493 -410
  295. package/dist/node/runtime.js.map +1 -0
  296. package/dist/server/handlers/__test-utils__/test-db.js +39 -89
  297. package/dist/server/handlers/__test-utils__/test-db.js.map +1 -0
  298. package/dist/server/handlers/analytics.js +467 -261
  299. package/dist/server/handlers/analytics.js.map +1 -0
  300. package/dist/server/handlers/api-docs.d.ts +6 -0
  301. package/dist/server/handlers/api-docs.js +1613 -0
  302. package/dist/server/handlers/api-docs.js.map +1 -0
  303. package/dist/server/handlers/api-keys.js +295 -232
  304. package/dist/server/handlers/api-keys.js.map +1 -0
  305. package/dist/server/handlers/billing.js +330 -239
  306. package/dist/server/handlers/billing.js.map +1 -0
  307. package/dist/server/handlers/browser.js +468 -395
  308. package/dist/server/handlers/browser.js.map +1 -0
  309. package/dist/server/handlers/catalog.js +1377 -978
  310. package/dist/server/handlers/catalog.js.map +1 -0
  311. package/dist/server/handlers/clickhouse.js +157 -109
  312. package/dist/server/handlers/clickhouse.js.map +1 -0
  313. package/dist/server/handlers/comms.d.ts +0 -53
  314. package/dist/server/handlers/comms.js +1443 -970
  315. package/dist/server/handlers/comms.js.map +1 -0
  316. package/dist/server/handlers/creations.js +461 -394
  317. package/dist/server/handlers/creations.js.map +1 -0
  318. package/dist/server/handlers/crm.js +1082 -791
  319. package/dist/server/handlers/crm.js.map +1 -0
  320. package/dist/server/handlers/discovery.js +251 -232
  321. package/dist/server/handlers/discovery.js.map +1 -0
  322. package/dist/server/handlers/embeddings.js +241 -164
  323. package/dist/server/handlers/embeddings.js.map +1 -0
  324. package/dist/server/handlers/enrichment.js +887 -718
  325. package/dist/server/handlers/enrichment.js.map +1 -0
  326. package/dist/server/handlers/image-gen.js +467 -376
  327. package/dist/server/handlers/image-gen.js.map +1 -0
  328. package/dist/server/handlers/inventory.js +797 -424
  329. package/dist/server/handlers/inventory.js.map +1 -0
  330. package/dist/server/handlers/kali.js +272 -230
  331. package/dist/server/handlers/kali.js.map +1 -0
  332. package/dist/server/handlers/llm-providers.js +803 -580
  333. package/dist/server/handlers/llm-providers.js.map +1 -0
  334. package/dist/server/handlers/local-agent.js +133 -105
  335. package/dist/server/handlers/local-agent.js.map +1 -0
  336. package/dist/server/handlers/media.js +1179 -857
  337. package/dist/server/handlers/media.js.map +1 -0
  338. package/dist/server/handlers/meta-ads.js +2669 -2093
  339. package/dist/server/handlers/meta-ads.js.map +1 -0
  340. package/dist/server/handlers/nodes.js +1321 -913
  341. package/dist/server/handlers/nodes.js.map +1 -0
  342. package/dist/server/handlers/operations.js +183 -157
  343. package/dist/server/handlers/operations.js.map +1 -0
  344. package/dist/server/handlers/platform.js +346 -210
  345. package/dist/server/handlers/platform.js.map +1 -0
  346. package/dist/server/handlers/remove-bg.js +118 -86
  347. package/dist/server/handlers/remove-bg.js.map +1 -0
  348. package/dist/server/handlers/storefront.js +586 -446
  349. package/dist/server/handlers/storefront.js.map +1 -0
  350. package/dist/server/handlers/supply-chain.js +546 -326
  351. package/dist/server/handlers/supply-chain.js.map +1 -0
  352. package/dist/server/handlers/transcription.js +106 -97
  353. package/dist/server/handlers/transcription.js.map +1 -0
  354. package/dist/server/handlers/video-gen.js +593 -424
  355. package/dist/server/handlers/video-gen.js.map +1 -0
  356. package/dist/server/handlers/voice.js +1458 -1017
  357. package/dist/server/handlers/voice.js.map +1 -0
  358. package/dist/server/handlers/workflow-steps.js +2837 -2116
  359. package/dist/server/handlers/workflow-steps.js.map +1 -0
  360. package/dist/server/handlers/workflows.js +1630 -933
  361. package/dist/server/handlers/workflows.js.map +1 -0
  362. package/dist/server/index.js +3166 -2390
  363. package/dist/server/index.js.map +1 -0
  364. package/dist/server/lib/batch-client.js +471 -409
  365. package/dist/server/lib/batch-client.js.map +1 -0
  366. package/dist/server/lib/clickhouse-buffer.js +118 -104
  367. package/dist/server/lib/clickhouse-buffer.js.map +1 -0
  368. package/dist/server/lib/clickhouse-client.js +107 -107
  369. package/dist/server/lib/clickhouse-client.js.map +1 -0
  370. package/dist/server/lib/coa-renderer.js +1786 -356
  371. package/dist/server/lib/coa-renderer.js.map +1 -0
  372. package/dist/server/lib/code-worker-pool.js +227 -177
  373. package/dist/server/lib/code-worker-pool.js.map +1 -0
  374. package/dist/server/lib/code-worker.js +174 -164
  375. package/dist/server/lib/code-worker.js.map +1 -0
  376. package/dist/server/lib/compaction-service.d.ts +2 -12
  377. package/dist/server/lib/compaction-service.js +74 -184
  378. package/dist/server/lib/compaction-service.js.map +1 -0
  379. package/dist/server/lib/logger.js +36 -24
  380. package/dist/server/lib/logger.js.map +1 -0
  381. package/dist/server/lib/otel.js +101 -80
  382. package/dist/server/lib/otel.js.map +1 -0
  383. package/dist/server/lib/pdf-renderer.d.ts +1 -1
  384. package/dist/server/lib/pdf-renderer.js +954 -776
  385. package/dist/server/lib/pdf-renderer.js.map +1 -0
  386. package/dist/server/lib/prompt-sanitizer.js +188 -108
  387. package/dist/server/lib/prompt-sanitizer.js.map +1 -0
  388. package/dist/server/lib/provider-capabilities.js +136 -138
  389. package/dist/server/lib/provider-capabilities.js.map +1 -0
  390. package/dist/server/lib/provider-failover.js +190 -168
  391. package/dist/server/lib/provider-failover.js.map +1 -0
  392. package/dist/server/lib/rate-limiter.js +186 -117
  393. package/dist/server/lib/rate-limiter.js.map +1 -0
  394. package/dist/server/lib/react-pdf-layout.js +551 -382
  395. package/dist/server/lib/react-pdf-layout.js.map +1 -0
  396. package/dist/server/lib/server-agent-loop.d.ts +9 -0
  397. package/dist/server/lib/server-agent-loop.js +906 -624
  398. package/dist/server/lib/server-agent-loop.js.map +1 -0
  399. package/dist/server/lib/server-subagent.d.ts +2 -0
  400. package/dist/server/lib/server-subagent.js +260 -162
  401. package/dist/server/lib/server-subagent.js.map +1 -0
  402. package/dist/server/lib/session-checkpoint.js +105 -96
  403. package/dist/server/lib/session-checkpoint.js.map +1 -0
  404. package/dist/server/lib/ssrf-guard.js +193 -184
  405. package/dist/server/lib/ssrf-guard.js.map +1 -0
  406. package/dist/server/lib/supabase-client.js +94 -82
  407. package/dist/server/lib/supabase-client.js.map +1 -0
  408. package/dist/server/lib/template-resolver.js +154 -176
  409. package/dist/server/lib/template-resolver.js.map +1 -0
  410. package/dist/server/lib/utils.js +242 -133
  411. package/dist/server/lib/utils.js.map +1 -0
  412. package/dist/server/local-agent-gateway.d.ts +2 -2
  413. package/dist/server/local-agent-gateway.js +785 -627
  414. package/dist/server/local-agent-gateway.js.map +1 -0
  415. package/dist/server/providers/anthropic.js +254 -176
  416. package/dist/server/providers/anthropic.js.map +1 -0
  417. package/dist/server/providers/bedrock.js +221 -162
  418. package/dist/server/providers/bedrock.js.map +1 -0
  419. package/dist/server/providers/gemini.js +548 -418
  420. package/dist/server/providers/gemini.js.map +1 -0
  421. package/dist/server/providers/openai.js +571 -437
  422. package/dist/server/providers/openai.js.map +1 -0
  423. package/dist/server/providers/registry.js +23 -18
  424. package/dist/server/providers/registry.js.map +1 -0
  425. package/dist/server/providers/shared.js +123 -95
  426. package/dist/server/providers/shared.js.map +1 -0
  427. package/dist/server/providers/types.js +1 -11
  428. package/dist/server/providers/types.js.map +1 -0
  429. package/dist/server/proxy-handlers.js +209 -165
  430. package/dist/server/proxy-handlers.js.map +1 -0
  431. package/dist/server/tool-router.d.ts +13 -0
  432. package/dist/server/tool-router.js +960 -598
  433. package/dist/server/tool-router.js.map +1 -0
  434. package/dist/server/validation.js +248 -188
  435. package/dist/server/validation.js.map +1 -0
  436. package/dist/server/worker.js +202 -133
  437. package/dist/server/worker.js.map +1 -0
  438. package/dist/setup.d.ts +2 -2
  439. package/dist/setup.js +151 -147
  440. package/dist/setup.js.map +1 -0
  441. package/dist/shared/agent-core.d.ts +191 -24
  442. package/dist/shared/agent-core.js +971 -462
  443. package/dist/shared/agent-core.js.map +1 -0
  444. package/dist/shared/anthropic-types.js +1 -6
  445. package/dist/shared/anthropic-types.js.map +1 -0
  446. package/dist/shared/api-client.d.ts +17 -9
  447. package/dist/shared/api-client.js +419 -327
  448. package/dist/shared/api-client.js.map +1 -0
  449. package/dist/shared/compaction.d.ts +36 -0
  450. package/dist/shared/compaction.js +138 -0
  451. package/dist/shared/compaction.js.map +1 -0
  452. package/dist/shared/constants.js +67 -64
  453. package/dist/shared/constants.js.map +1 -0
  454. package/dist/shared/sse-parser.js +221 -219
  455. package/dist/shared/sse-parser.js.map +1 -0
  456. package/dist/shared/tool-dispatch.d.ts +4 -2
  457. package/dist/shared/tool-dispatch.js +226 -165
  458. package/dist/shared/tool-dispatch.js.map +1 -0
  459. package/dist/shared/types.js +1 -6
  460. package/dist/shared/types.js.map +1 -0
  461. package/dist/types/cli-highlight.d.js +2 -0
  462. package/dist/types/cli-highlight.d.js.map +1 -0
  463. package/dist/types/diff.d.js +2 -0
  464. package/dist/types/diff.d.js.map +1 -0
  465. package/dist/types/pdf-parse.d.js +2 -0
  466. package/dist/types/pdf-parse.d.js.map +1 -0
  467. package/dist/updater.d.ts +1 -1
  468. package/dist/updater.js +118 -92
  469. package/dist/updater.js.map +1 -0
  470. package/dist/webchat/widget.js +227 -380
  471. package/dist/webchat/widget.js.map +1 -0
  472. package/package.json +22 -10
  473. package/vendor/ink/build/ansi-tokenizer.d.ts +38 -0
  474. package/vendor/ink/build/ansi-tokenizer.js +316 -0
  475. package/vendor/ink/build/ansi-tokenizer.js.map +1 -0
  476. package/vendor/ink/build/apply-styles.js +175 -0
  477. package/vendor/ink/build/build-layout.js +77 -0
  478. package/vendor/ink/build/calculate-wrapped-text.js +53 -0
  479. package/vendor/ink/build/colorize.d.ts +3 -0
  480. package/vendor/ink/build/colorize.js +48 -0
  481. package/vendor/ink/build/colorize.js.map +1 -0
  482. package/vendor/ink/build/components/AccessibilityContext.d.ts +3 -0
  483. package/vendor/ink/build/components/AccessibilityContext.js +5 -0
  484. package/vendor/ink/build/components/AccessibilityContext.js.map +1 -0
  485. package/vendor/ink/build/components/App.d.ts +18 -0
  486. package/vendor/ink/build/components/App.js +351 -0
  487. package/vendor/ink/build/components/App.js.map +1 -0
  488. package/vendor/ink/build/components/AppContext.d.ts +15 -0
  489. package/vendor/ink/build/components/AppContext.js +11 -0
  490. package/vendor/ink/build/components/AppContext.js.map +1 -0
  491. package/vendor/ink/build/components/BackgroundContext.d.ts +4 -0
  492. package/vendor/ink/build/components/BackgroundContext.js +3 -0
  493. package/vendor/ink/build/components/BackgroundContext.js.map +1 -0
  494. package/vendor/ink/build/components/Box.d.ts +117 -0
  495. package/vendor/ink/build/components/Box.js +34 -0
  496. package/vendor/ink/build/components/Box.js.map +1 -0
  497. package/vendor/ink/build/components/Color.js +62 -0
  498. package/vendor/ink/build/components/Cursor.d.ts +83 -0
  499. package/vendor/ink/build/components/Cursor.js +53 -0
  500. package/vendor/ink/build/components/Cursor.js.map +1 -0
  501. package/vendor/ink/build/components/CursorContext.d.ts +11 -0
  502. package/vendor/ink/build/components/CursorContext.js +8 -0
  503. package/vendor/ink/build/components/CursorContext.js.map +1 -0
  504. package/vendor/ink/build/components/ErrorBoundary.d.ts +18 -0
  505. package/vendor/ink/build/components/ErrorBoundary.js +23 -0
  506. package/vendor/ink/build/components/ErrorBoundary.js.map +1 -0
  507. package/vendor/ink/build/components/ErrorOverview.d.ts +6 -0
  508. package/vendor/ink/build/components/ErrorOverview.js +84 -0
  509. package/vendor/ink/build/components/ErrorOverview.js.map +1 -0
  510. package/vendor/ink/build/components/FocusContext.d.ts +16 -0
  511. package/vendor/ink/build/components/FocusContext.js +17 -0
  512. package/vendor/ink/build/components/FocusContext.js.map +1 -0
  513. package/vendor/ink/build/components/Newline.d.ts +13 -0
  514. package/vendor/ink/build/components/Newline.js +8 -0
  515. package/vendor/ink/build/components/Newline.js.map +1 -0
  516. package/vendor/ink/build/components/Spacer.d.ts +7 -0
  517. package/vendor/ink/build/components/Spacer.js +11 -0
  518. package/vendor/ink/build/components/Spacer.js.map +1 -0
  519. package/vendor/ink/build/components/Static.d.ts +24 -0
  520. package/vendor/ink/build/components/Static.js +28 -0
  521. package/vendor/ink/build/components/Static.js.map +1 -0
  522. package/vendor/ink/build/components/StderrContext.d.ts +15 -0
  523. package/vendor/ink/build/components/StderrContext.js +13 -0
  524. package/vendor/ink/build/components/StderrContext.js.map +1 -0
  525. package/vendor/ink/build/components/StdinContext.d.ts +22 -0
  526. package/vendor/ink/build/components/StdinContext.js +19 -0
  527. package/vendor/ink/build/components/StdinContext.js.map +1 -0
  528. package/vendor/ink/build/components/StdoutContext.d.ts +15 -0
  529. package/vendor/ink/build/components/StdoutContext.js +13 -0
  530. package/vendor/ink/build/components/StdoutContext.js.map +1 -0
  531. package/vendor/ink/build/components/Text.d.ts +55 -0
  532. package/vendor/ink/build/components/Text.js +50 -0
  533. package/vendor/ink/build/components/Text.js.map +1 -0
  534. package/vendor/ink/build/components/Transform.d.ts +16 -0
  535. package/vendor/ink/build/components/Transform.js +15 -0
  536. package/vendor/ink/build/components/Transform.js.map +1 -0
  537. package/vendor/ink/build/cursor-helpers.d.ts +38 -0
  538. package/vendor/ink/build/cursor-helpers.js +56 -0
  539. package/vendor/ink/build/cursor-helpers.js.map +1 -0
  540. package/vendor/ink/build/devtools-window-polyfill.d.ts +1 -0
  541. package/vendor/ink/build/devtools-window-polyfill.js +65 -0
  542. package/vendor/ink/build/devtools-window-polyfill.js.map +1 -0
  543. package/vendor/ink/build/devtools.d.ts +1 -0
  544. package/vendor/ink/build/devtools.js +11 -0
  545. package/vendor/ink/build/devtools.js.map +1 -0
  546. package/vendor/ink/build/dom.d.ts +56 -0
  547. package/vendor/ink/build/dom.js +124 -0
  548. package/vendor/ink/build/dom.js.map +1 -0
  549. package/vendor/ink/build/experimental/apply-style.js +140 -0
  550. package/vendor/ink/build/experimental/dom.js +123 -0
  551. package/vendor/ink/build/experimental/output.js +91 -0
  552. package/vendor/ink/build/experimental/reconciler.js +141 -0
  553. package/vendor/ink/build/experimental/renderer.js +81 -0
  554. package/vendor/ink/build/get-max-width.d.ts +3 -0
  555. package/vendor/ink/build/get-max-width.js +10 -0
  556. package/vendor/ink/build/get-max-width.js.map +1 -0
  557. package/vendor/ink/build/hooks/use-app.d.ts +5 -0
  558. package/vendor/ink/build/hooks/use-app.js +8 -0
  559. package/vendor/ink/build/hooks/use-app.js.map +1 -0
  560. package/vendor/ink/build/hooks/use-cursor.d.ts +12 -0
  561. package/vendor/ink/build/hooks/use-cursor.js +29 -0
  562. package/vendor/ink/build/hooks/use-cursor.js.map +1 -0
  563. package/vendor/ink/build/hooks/use-focus-manager.d.ts +28 -0
  564. package/vendor/ink/build/hooks/use-focus-manager.js +17 -0
  565. package/vendor/ink/build/hooks/use-focus-manager.js.map +1 -0
  566. package/vendor/ink/build/hooks/use-focus.d.ts +29 -0
  567. package/vendor/ink/build/hooks/use-focus.js +42 -0
  568. package/vendor/ink/build/hooks/use-focus.js.map +1 -0
  569. package/vendor/ink/build/hooks/use-input.d.ts +131 -0
  570. package/vendor/ink/build/hooks/use-input.js +124 -0
  571. package/vendor/ink/build/hooks/use-input.js.map +1 -0
  572. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.d.ts +5 -0
  573. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js +11 -0
  574. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js.map +1 -0
  575. package/vendor/ink/build/hooks/use-stderr.d.ts +5 -0
  576. package/vendor/ink/build/hooks/use-stderr.js +8 -0
  577. package/vendor/ink/build/hooks/use-stderr.js.map +1 -0
  578. package/vendor/ink/build/hooks/use-stdin.d.ts +5 -0
  579. package/vendor/ink/build/hooks/use-stdin.js +8 -0
  580. package/vendor/ink/build/hooks/use-stdin.js.map +1 -0
  581. package/vendor/ink/build/hooks/use-stdout.d.ts +5 -0
  582. package/vendor/ink/build/hooks/use-stdout.js +8 -0
  583. package/vendor/ink/build/hooks/use-stdout.js.map +1 -0
  584. package/vendor/ink/build/hooks/useInput.js +38 -0
  585. package/vendor/ink/build/index.d.ts +34 -0
  586. package/vendor/ink/build/index.js +20 -0
  587. package/vendor/ink/build/index.js.map +1 -0
  588. package/vendor/ink/build/ink.d.ts +90 -0
  589. package/vendor/ink/build/ink.js +654 -0
  590. package/vendor/ink/build/ink.js.map +1 -0
  591. package/vendor/ink/build/input-parser.d.ts +7 -0
  592. package/vendor/ink/build/input-parser.js +154 -0
  593. package/vendor/ink/build/input-parser.js.map +1 -0
  594. package/vendor/ink/build/instance.js +205 -0
  595. package/vendor/ink/build/instances.d.ts +3 -0
  596. package/vendor/ink/build/instances.js +8 -0
  597. package/vendor/ink/build/instances.js.map +1 -0
  598. package/vendor/ink/build/kitty-keyboard.d.ts +23 -0
  599. package/vendor/ink/build/kitty-keyboard.js +32 -0
  600. package/vendor/ink/build/kitty-keyboard.js.map +1 -0
  601. package/vendor/ink/build/layout.d.ts +7 -0
  602. package/vendor/ink/build/layout.js +33 -0
  603. package/vendor/ink/build/layout.js.map +1 -0
  604. package/vendor/ink/build/log-update.d.ts +19 -0
  605. package/vendor/ink/build/log-update.js +243 -0
  606. package/vendor/ink/build/log-update.js.map +1 -0
  607. package/vendor/ink/build/measure-element.d.ts +16 -0
  608. package/vendor/ink/build/measure-element.js +9 -0
  609. package/vendor/ink/build/measure-element.js.map +1 -0
  610. package/vendor/ink/build/measure-text.d.ts +6 -0
  611. package/vendor/ink/build/measure-text.js +21 -0
  612. package/vendor/ink/build/measure-text.js.map +1 -0
  613. package/vendor/ink/build/options.d.ts +52 -0
  614. package/vendor/ink/build/options.js +2 -0
  615. package/vendor/ink/build/options.js.map +1 -0
  616. package/vendor/ink/build/output.d.ts +35 -0
  617. package/vendor/ink/build/output.js +183 -0
  618. package/vendor/ink/build/output.js.map +1 -0
  619. package/vendor/ink/build/parse-keypress.d.ts +22 -0
  620. package/vendor/ink/build/parse-keypress.js +493 -0
  621. package/vendor/ink/build/parse-keypress.js.map +1 -0
  622. package/vendor/ink/build/reconciler.d.ts +4 -0
  623. package/vendor/ink/build/reconciler.js +274 -0
  624. package/vendor/ink/build/reconciler.js.map +1 -0
  625. package/vendor/ink/build/render-background.d.ts +4 -0
  626. package/vendor/ink/build/render-background.js +25 -0
  627. package/vendor/ink/build/render-background.js.map +1 -0
  628. package/vendor/ink/build/render-border.d.ts +4 -0
  629. package/vendor/ink/build/render-border.js +73 -0
  630. package/vendor/ink/build/render-border.js.map +1 -0
  631. package/vendor/ink/build/render-node-to-output.d.ts +14 -0
  632. package/vendor/ink/build/render-node-to-output.js +147 -0
  633. package/vendor/ink/build/render-node-to-output.js.map +1 -0
  634. package/vendor/ink/build/render-to-string.d.ts +38 -0
  635. package/vendor/ink/build/render-to-string.js +115 -0
  636. package/vendor/ink/build/render-to-string.js.map +1 -0
  637. package/vendor/ink/build/render.d.ts +121 -0
  638. package/vendor/ink/build/render.js +55 -0
  639. package/vendor/ink/build/render.js.map +1 -0
  640. package/vendor/ink/build/renderer.d.ts +8 -0
  641. package/vendor/ink/build/renderer.js +55 -0
  642. package/vendor/ink/build/renderer.js.map +1 -0
  643. package/vendor/ink/build/sanitize-ansi.d.ts +2 -0
  644. package/vendor/ink/build/sanitize-ansi.js +27 -0
  645. package/vendor/ink/build/sanitize-ansi.js.map +1 -0
  646. package/vendor/ink/build/screen-reader-update.d.ts +13 -0
  647. package/vendor/ink/build/screen-reader-update.js +38 -0
  648. package/vendor/ink/build/screen-reader-update.js.map +1 -0
  649. package/vendor/ink/build/squash-text-nodes.d.ts +3 -0
  650. package/vendor/ink/build/squash-text-nodes.js +36 -0
  651. package/vendor/ink/build/squash-text-nodes.js.map +1 -0
  652. package/vendor/ink/build/styles.d.ts +240 -0
  653. package/vendor/ink/build/styles.js +232 -0
  654. package/vendor/ink/build/styles.js.map +1 -0
  655. package/vendor/ink/build/utils.d.ts +2 -0
  656. package/vendor/ink/build/utils.js +4 -0
  657. package/vendor/ink/build/utils.js.map +1 -0
  658. package/vendor/ink/build/wrap-text.d.ts +3 -0
  659. package/vendor/ink/build/wrap-text.js +31 -0
  660. package/vendor/ink/build/wrap-text.js.map +1 -0
  661. package/vendor/ink/build/write-synchronized.d.ts +4 -0
  662. package/vendor/ink/build/write-synchronized.js +7 -0
  663. package/vendor/ink/build/write-synchronized.js.map +1 -0
  664. package/vendor/ink/license +10 -0
  665. package/vendor/ink/node_modules/@types/node/LICENSE +21 -0
  666. package/vendor/ink/node_modules/@types/node/README.md +15 -0
  667. package/vendor/ink/node_modules/@types/node/assert/strict.d.ts +105 -0
  668. package/vendor/ink/node_modules/@types/node/assert.d.ts +955 -0
  669. package/vendor/ink/node_modules/@types/node/async_hooks.d.ts +623 -0
  670. package/vendor/ink/node_modules/@types/node/buffer.buffer.d.ts +466 -0
  671. package/vendor/ink/node_modules/@types/node/buffer.d.ts +1810 -0
  672. package/vendor/ink/node_modules/@types/node/child_process.d.ts +1428 -0
  673. package/vendor/ink/node_modules/@types/node/cluster.d.ts +486 -0
  674. package/vendor/ink/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
  675. package/vendor/ink/node_modules/@types/node/console.d.ts +151 -0
  676. package/vendor/ink/node_modules/@types/node/constants.d.ts +20 -0
  677. package/vendor/ink/node_modules/@types/node/crypto.d.ts +4065 -0
  678. package/vendor/ink/node_modules/@types/node/dgram.d.ts +564 -0
  679. package/vendor/ink/node_modules/@types/node/diagnostics_channel.d.ts +576 -0
  680. package/vendor/ink/node_modules/@types/node/dns/promises.d.ts +503 -0
  681. package/vendor/ink/node_modules/@types/node/dns.d.ts +922 -0
  682. package/vendor/ink/node_modules/@types/node/domain.d.ts +166 -0
  683. package/vendor/ink/node_modules/@types/node/events.d.ts +1054 -0
  684. package/vendor/ink/node_modules/@types/node/fs/promises.d.ts +1329 -0
  685. package/vendor/ink/node_modules/@types/node/fs.d.ts +4676 -0
  686. package/vendor/ink/node_modules/@types/node/globals.d.ts +150 -0
  687. package/vendor/ink/node_modules/@types/node/globals.typedarray.d.ts +101 -0
  688. package/vendor/ink/node_modules/@types/node/http.d.ts +2167 -0
  689. package/vendor/ink/node_modules/@types/node/http2.d.ts +2480 -0
  690. package/vendor/ink/node_modules/@types/node/https.d.ts +405 -0
  691. package/vendor/ink/node_modules/@types/node/index.d.ts +115 -0
  692. package/vendor/ink/node_modules/@types/node/inspector/promises.d.ts +41 -0
  693. package/vendor/ink/node_modules/@types/node/inspector.d.ts +224 -0
  694. package/vendor/ink/node_modules/@types/node/inspector.generated.d.ts +4226 -0
  695. package/vendor/ink/node_modules/@types/node/module.d.ts +819 -0
  696. package/vendor/ink/node_modules/@types/node/net.d.ts +933 -0
  697. package/vendor/ink/node_modules/@types/node/os.d.ts +507 -0
  698. package/vendor/ink/node_modules/@types/node/package.json +155 -0
  699. package/vendor/ink/node_modules/@types/node/path/posix.d.ts +8 -0
  700. package/vendor/ink/node_modules/@types/node/path/win32.d.ts +8 -0
  701. package/vendor/ink/node_modules/@types/node/path.d.ts +187 -0
  702. package/vendor/ink/node_modules/@types/node/perf_hooks.d.ts +643 -0
  703. package/vendor/ink/node_modules/@types/node/process.d.ts +2156 -0
  704. package/vendor/ink/node_modules/@types/node/punycode.d.ts +117 -0
  705. package/vendor/ink/node_modules/@types/node/querystring.d.ts +152 -0
  706. package/vendor/ink/node_modules/@types/node/quic.d.ts +910 -0
  707. package/vendor/ink/node_modules/@types/node/readline/promises.d.ts +161 -0
  708. package/vendor/ink/node_modules/@types/node/readline.d.ts +541 -0
  709. package/vendor/ink/node_modules/@types/node/repl.d.ts +415 -0
  710. package/vendor/ink/node_modules/@types/node/sea.d.ts +162 -0
  711. package/vendor/ink/node_modules/@types/node/sqlite.d.ts +955 -0
  712. package/vendor/ink/node_modules/@types/node/stream/consumers.d.ts +38 -0
  713. package/vendor/ink/node_modules/@types/node/stream/promises.d.ts +211 -0
  714. package/vendor/ink/node_modules/@types/node/stream/web.d.ts +296 -0
  715. package/vendor/ink/node_modules/@types/node/stream.d.ts +1760 -0
  716. package/vendor/ink/node_modules/@types/node/string_decoder.d.ts +67 -0
  717. package/vendor/ink/node_modules/@types/node/test/reporters.d.ts +96 -0
  718. package/vendor/ink/node_modules/@types/node/test.d.ts +2240 -0
  719. package/vendor/ink/node_modules/@types/node/timers/promises.d.ts +108 -0
  720. package/vendor/ink/node_modules/@types/node/timers.d.ts +159 -0
  721. package/vendor/ink/node_modules/@types/node/tls.d.ts +1198 -0
  722. package/vendor/ink/node_modules/@types/node/trace_events.d.ts +197 -0
  723. package/vendor/ink/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +462 -0
  724. package/vendor/ink/node_modules/@types/node/ts5.6/compatibility/float16array.d.ts +71 -0
  725. package/vendor/ink/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +36 -0
  726. package/vendor/ink/node_modules/@types/node/ts5.6/index.d.ts +117 -0
  727. package/vendor/ink/node_modules/@types/node/ts5.7/compatibility/float16array.d.ts +72 -0
  728. package/vendor/ink/node_modules/@types/node/ts5.7/index.d.ts +117 -0
  729. package/vendor/ink/node_modules/@types/node/tty.d.ts +250 -0
  730. package/vendor/ink/node_modules/@types/node/url.d.ts +519 -0
  731. package/vendor/ink/node_modules/@types/node/util/types.d.ts +558 -0
  732. package/vendor/ink/node_modules/@types/node/util.d.ts +1662 -0
  733. package/vendor/ink/node_modules/@types/node/v8.d.ts +983 -0
  734. package/vendor/ink/node_modules/@types/node/vm.d.ts +1208 -0
  735. package/vendor/ink/node_modules/@types/node/wasi.d.ts +202 -0
  736. package/vendor/ink/node_modules/@types/node/web-globals/abortcontroller.d.ts +59 -0
  737. package/vendor/ink/node_modules/@types/node/web-globals/blob.d.ts +23 -0
  738. package/vendor/ink/node_modules/@types/node/web-globals/console.d.ts +9 -0
  739. package/vendor/ink/node_modules/@types/node/web-globals/crypto.d.ts +39 -0
  740. package/vendor/ink/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  741. package/vendor/ink/node_modules/@types/node/web-globals/encoding.d.ts +11 -0
  742. package/vendor/ink/node_modules/@types/node/web-globals/events.d.ts +106 -0
  743. package/vendor/ink/node_modules/@types/node/web-globals/fetch.d.ts +69 -0
  744. package/vendor/ink/node_modules/@types/node/web-globals/importmeta.d.ts +13 -0
  745. package/vendor/ink/node_modules/@types/node/web-globals/messaging.d.ts +23 -0
  746. package/vendor/ink/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
  747. package/vendor/ink/node_modules/@types/node/web-globals/performance.d.ts +45 -0
  748. package/vendor/ink/node_modules/@types/node/web-globals/storage.d.ts +24 -0
  749. package/vendor/ink/node_modules/@types/node/web-globals/streams.d.ts +115 -0
  750. package/vendor/ink/node_modules/@types/node/web-globals/timers.d.ts +44 -0
  751. package/vendor/ink/node_modules/@types/node/web-globals/url.d.ts +24 -0
  752. package/vendor/ink/node_modules/@types/node/worker_threads.d.ts +717 -0
  753. package/vendor/ink/node_modules/@types/node/zlib.d.ts +618 -0
  754. package/vendor/ink/node_modules/node-pty/LICENSE +69 -0
  755. package/vendor/ink/node_modules/node-pty/README.md +164 -0
  756. package/vendor/ink/node_modules/node-pty/binding.gyp +150 -0
  757. package/vendor/ink/node_modules/node-pty/lib/conpty_console_list_agent.js +25 -0
  758. package/vendor/ink/node_modules/node-pty/lib/eventEmitter2.js +47 -0
  759. package/vendor/ink/node_modules/node-pty/lib/index.js +52 -0
  760. package/vendor/ink/node_modules/node-pty/lib/interfaces.js +7 -0
  761. package/vendor/ink/node_modules/node-pty/lib/shared/conout.js +11 -0
  762. package/vendor/ink/node_modules/node-pty/lib/terminal.js +190 -0
  763. package/vendor/ink/node_modules/node-pty/lib/types.js +7 -0
  764. package/vendor/ink/node_modules/node-pty/lib/unixTerminal.js +349 -0
  765. package/vendor/ink/node_modules/node-pty/lib/utils.js +39 -0
  766. package/vendor/ink/node_modules/node-pty/lib/windowsConoutConnection.js +125 -0
  767. package/vendor/ink/node_modules/node-pty/lib/windowsPtyAgent.js +287 -0
  768. package/vendor/ink/node_modules/node-pty/lib/windowsTerminal.js +201 -0
  769. package/vendor/ink/node_modules/node-pty/lib/worker/conoutSocketWorker.js +22 -0
  770. package/vendor/ink/node_modules/node-pty/package.json +65 -0
  771. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/pty.node +0 -0
  772. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/spawn-helper +0 -0
  773. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/pty.node +0 -0
  774. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/spawn-helper +0 -0
  775. package/vendor/ink/node_modules/node-pty/prebuilds/linux-arm64/pty.node +0 -0
  776. package/vendor/ink/node_modules/node-pty/prebuilds/linux-x64/pty.node +0 -0
  777. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/OpenConsole.exe +0 -0
  778. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/conpty.dll +0 -0
  779. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.node +0 -0
  780. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.pdb +0 -0
  781. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.node +0 -0
  782. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.pdb +0 -0
  783. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/OpenConsole.exe +0 -0
  784. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/conpty.dll +0 -0
  785. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.node +0 -0
  786. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.pdb +0 -0
  787. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.node +0 -0
  788. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.pdb +0 -0
  789. package/vendor/ink/node_modules/node-pty/scripts/post-install.js +76 -0
  790. package/vendor/ink/node_modules/node-pty/scripts/prebuild.js +34 -0
  791. package/vendor/ink/node_modules/node-pty/src/unix/pty.cc +875 -0
  792. package/vendor/ink/node_modules/node-pty/src/unix/spawn-helper.cc +23 -0
  793. package/vendor/ink/node_modules/node-pty/src/win/conpty.cc +582 -0
  794. package/vendor/ink/node_modules/node-pty/src/win/conpty.h +41 -0
  795. package/vendor/ink/node_modules/node-pty/src/win/conpty_console_list.cc +44 -0
  796. package/vendor/ink/node_modules/node-pty/src/win/path_util.cc +95 -0
  797. package/vendor/ink/node_modules/node-pty/src/win/path_util.h +26 -0
  798. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/OpenConsole.exe +0 -0
  799. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/conpty.dll +0 -0
  800. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/OpenConsole.exe +0 -0
  801. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/conpty.dll +0 -0
  802. package/vendor/ink/node_modules/node-pty/typings/node-pty.d.ts +215 -0
  803. package/vendor/ink/node_modules/undici-types/LICENSE +21 -0
  804. package/vendor/ink/node_modules/undici-types/README.md +6 -0
  805. package/vendor/ink/node_modules/undici-types/agent.d.ts +32 -0
  806. package/vendor/ink/node_modules/undici-types/api.d.ts +43 -0
  807. package/vendor/ink/node_modules/undici-types/balanced-pool.d.ts +30 -0
  808. package/vendor/ink/node_modules/undici-types/cache-interceptor.d.ts +173 -0
  809. package/vendor/ink/node_modules/undici-types/cache.d.ts +36 -0
  810. package/vendor/ink/node_modules/undici-types/client-stats.d.ts +15 -0
  811. package/vendor/ink/node_modules/undici-types/client.d.ts +108 -0
  812. package/vendor/ink/node_modules/undici-types/connector.d.ts +34 -0
  813. package/vendor/ink/node_modules/undici-types/content-type.d.ts +21 -0
  814. package/vendor/ink/node_modules/undici-types/cookies.d.ts +30 -0
  815. package/vendor/ink/node_modules/undici-types/diagnostics-channel.d.ts +74 -0
  816. package/vendor/ink/node_modules/undici-types/dispatcher.d.ts +276 -0
  817. package/vendor/ink/node_modules/undici-types/env-http-proxy-agent.d.ts +22 -0
  818. package/vendor/ink/node_modules/undici-types/errors.d.ts +161 -0
  819. package/vendor/ink/node_modules/undici-types/eventsource.d.ts +66 -0
  820. package/vendor/ink/node_modules/undici-types/fetch.d.ts +211 -0
  821. package/vendor/ink/node_modules/undici-types/formdata.d.ts +108 -0
  822. package/vendor/ink/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  823. package/vendor/ink/node_modules/undici-types/global-origin.d.ts +7 -0
  824. package/vendor/ink/node_modules/undici-types/h2c-client.d.ts +73 -0
  825. package/vendor/ink/node_modules/undici-types/handlers.d.ts +15 -0
  826. package/vendor/ink/node_modules/undici-types/header.d.ts +160 -0
  827. package/vendor/ink/node_modules/undici-types/index.d.ts +88 -0
  828. package/vendor/ink/node_modules/undici-types/interceptors.d.ts +73 -0
  829. package/vendor/ink/node_modules/undici-types/mock-agent.d.ts +68 -0
  830. package/vendor/ink/node_modules/undici-types/mock-call-history.d.ts +111 -0
  831. package/vendor/ink/node_modules/undici-types/mock-client.d.ts +27 -0
  832. package/vendor/ink/node_modules/undici-types/mock-errors.d.ts +12 -0
  833. package/vendor/ink/node_modules/undici-types/mock-interceptor.d.ts +94 -0
  834. package/vendor/ink/node_modules/undici-types/mock-pool.d.ts +27 -0
  835. package/vendor/ink/node_modules/undici-types/package.json +55 -0
  836. package/vendor/ink/node_modules/undici-types/patch.d.ts +29 -0
  837. package/vendor/ink/node_modules/undici-types/pool-stats.d.ts +19 -0
  838. package/vendor/ink/node_modules/undici-types/pool.d.ts +41 -0
  839. package/vendor/ink/node_modules/undici-types/proxy-agent.d.ts +29 -0
  840. package/vendor/ink/node_modules/undici-types/readable.d.ts +68 -0
  841. package/vendor/ink/node_modules/undici-types/retry-agent.d.ts +8 -0
  842. package/vendor/ink/node_modules/undici-types/retry-handler.d.ts +125 -0
  843. package/vendor/ink/node_modules/undici-types/round-robin-pool.d.ts +41 -0
  844. package/vendor/ink/node_modules/undici-types/snapshot-agent.d.ts +109 -0
  845. package/vendor/ink/node_modules/undici-types/util.d.ts +18 -0
  846. package/vendor/ink/node_modules/undici-types/utility.d.ts +7 -0
  847. package/vendor/ink/node_modules/undici-types/webidl.d.ts +341 -0
  848. package/vendor/ink/node_modules/undici-types/websocket.d.ts +186 -0
  849. package/vendor/ink/package.json +201 -0
  850. package/vendor/ink/readme.md +2636 -0
  851. package/bin/swag-agent.js +0 -9
  852. package/dist/server/lib/pg-rate-limiter.d.ts +0 -21
  853. package/dist/server/lib/pg-rate-limiter.js +0 -86
@@ -5,341 +5,561 @@
5
5
  // mark_transfer_in_transit, complete_inventory_transfer,
6
6
  // cancel_inventory_transfer
7
7
  // ============================================================================
8
+
8
9
  export async function handlePurchaseOrders(sb, args, storeId) {
9
- const sid = storeId;
10
- switch (args.action) {
11
- case "list": {
12
- let q = sb.from("purchase_orders").select("*, supplier:suppliers(external_name, external_company), location:locations(name)")
13
- .eq("store_id", sid).order("created_at", { ascending: false }).limit(args.limit || 25);
14
- if (args.status)
15
- q = q.eq("status", args.status);
16
- const { data, error } = await q;
17
- if (error)
18
- return { success: false, error: error.message };
19
- // Flatten supplier/location joins for table display
20
- const flattened = (data || []).map((row) => {
21
- const { supplier, location, ...rest } = row;
22
- return { ...rest, supplier_name: supplier?.external_name || supplier?.external_company || "—", location_name: location?.name || "—" };
23
- });
24
- return { success: true, data: flattened };
25
- }
26
- case "get": {
27
- const { data, error } = await sb.from("purchase_orders")
28
- .select("*, items:purchase_order_items(id, product_id, quantity, unit_price, received_quantity, subtotal, product:products(name, sku)), supplier:suppliers(id, external_name, external_company, contact_email, contact_phone)")
29
- .eq("id", args.purchase_order_id).eq("store_id", sid).single();
30
- if (error)
31
- return { success: false, error: error.message };
32
- // Flatten items so product names appear as columns (formatter drops nested objects in sub-tables)
33
- const po = data;
34
- const items = (po.items || []).map((item) => ({
35
- id: item.id, product_id: item.product_id,
36
- product_name: item.product?.name || "—", product_sku: item.product?.sku || "—",
37
- quantity: item.quantity, unit_price: item.unit_price,
38
- received: item.received_quantity || 0, subtotal: item.subtotal,
39
- }));
40
- const { items: _, supplier, ...poFields } = po;
41
- return {
42
- success: true,
43
- data: {
44
- ...poFields,
45
- supplier_name: supplier?.external_name || supplier?.external_company || "—",
46
- supplier_email: supplier?.contact_email || null,
47
- items,
48
- }
49
- };
50
- }
51
- case "create": {
52
- // create_purchase_order_atomic RPC — SECURITY DEFINER, returns JSONB {success, po_id, po_number}
53
- // p_items is TEXT type (JSON string), not JSONB
54
- const items = (args.items || []).map(item => ({
55
- product_id: item.product_id,
56
- quantity: Math.max(Number(item.quantity) || 1, 0),
57
- unit_cost: Math.max(Number(item.unit_cost || item.unit_price) || 0, 0),
58
- }));
59
- const { data: result, error: rpcError } = await sb.rpc("create_purchase_order_atomic", {
60
- p_store_id: sid,
61
- p_po_type: "inbound",
62
- p_supplier_id: args.supplier_id || null,
63
- p_location_id: args.location_id || null,
64
- p_expected_delivery_date: args.expected_delivery_date || null,
65
- p_notes: args.notes || null,
66
- p_items: JSON.stringify(items),
67
- });
68
- if (rpcError)
69
- return { success: false, error: rpcError.message };
70
- const rpcResult = parseRpcResult(result);
71
- if (!rpcResult.success)
72
- return { success: false, error: rpcResult.error || "PO creation failed" };
73
- // Fetch full PO for response — flatten nested joins
74
- const { data: fullPo } = await sb.from("purchase_orders")
75
- .select("*, items:purchase_order_items(id, product_id, quantity, unit_price, subtotal, product:products(name, sku)), supplier:suppliers(id, external_name, external_company)")
76
- .eq("id", rpcResult.po_id).single();
77
- if (!fullPo)
78
- return { success: true, data: { po_id: rpcResult.po_id, po_number: rpcResult.po_number } };
79
- const po = fullPo;
80
- const flatItems = (po.items || []).map((item) => ({
81
- id: item.id, product_id: item.product_id,
82
- product_name: item.product?.name || "", product_sku: item.product?.sku || "—",
83
- quantity: item.quantity, unit_price: item.unit_price, subtotal: item.subtotal,
84
- }));
85
- const { items: _poItems, supplier, ...poFields } = po;
86
- return {
87
- success: true,
88
- data: {
89
- ...poFields,
90
- supplier_name: supplier?.external_name || supplier?.external_company || "—",
91
- items: flatItems,
92
- }
93
- };
94
- }
95
- case "add_items": {
96
- // No atomic RPC exists for adding items to an existing PO — direct insert
97
- const poId = args.purchase_order_id;
98
- if (!poId)
99
- return { success: false, error: "purchase_order_id is required" };
100
- const items = args.items;
101
- if (!items || !Array.isArray(items) || !items.length)
102
- return { success: false, error: "items array is required" };
103
- const { data: po } = await sb.from("purchase_orders").select("status").eq("id", poId).eq("store_id", sid).single();
104
- if (!po)
105
- return { success: false, error: "PO not found" };
106
- if (po.status === "received")
107
- return { success: false, error: "Cannot add items — PO already received" };
108
- if (po.status === "cancelled")
109
- return { success: false, error: "Cannot add items — PO is cancelled" };
110
- const rows = items.map(item => {
111
- const qty = Math.max(Number(item.quantity) || 1, 0);
112
- const price = Math.max(Number(item.unit_cost || item.unit_price) || 0, 0);
113
- return { purchase_order_id: poId, product_id: item.product_id, quantity: qty, unit_price: price, subtotal: qty * price };
114
- });
115
- const { data, error } = await sb.from("purchase_order_items").insert(rows).select("*, product:products(name, sku)");
116
- return error ? { success: false, error: error.message } : { success: true, data };
117
- }
118
- case "approve":
119
- case "mark_ordered": {
120
- // PO flow: draft → ordered. "approve" = mark as ordered.
121
- // update_po_status RPC — SECURITY DEFINER, returns JSONB {success, old_status, new_status}
122
- const { data: result, error: rpcError } = await sb.rpc("update_po_status", {
123
- p_po_id: args.purchase_order_id,
124
- p_status: "ordered",
125
- });
126
- if (rpcError)
127
- return { success: false, error: rpcError.message };
128
- const rpcResult = parseRpcResult(result);
129
- if (!rpcResult.success)
130
- return { success: false, error: rpcResult.error || "Status update failed" };
131
- return { success: true, data: { old_status: rpcResult.old_status, new_status: rpcResult.new_status } };
132
- }
133
- case "receive": {
134
- // receive_po_items RPC — SECURITY DEFINER, returns JSONB {success, items_processed}
135
- // Params: p_po_id, p_location_id, p_items [{item_id, quantity}]
136
- const poId = args.purchase_order_id;
137
- const { data: po, error: poErr } = await sb.from("purchase_orders")
138
- .select("location_id, items:purchase_order_items(id, quantity, received_quantity)")
139
- .eq("id", poId).eq("store_id", sid).single();
140
- if (poErr || !po)
141
- return { success: false, error: poErr?.message || "PO not found" };
142
- // If caller provides specific items use those, otherwise receive all remaining
143
- const poItems = po.items || [];
144
- let receiveItems;
145
- if (args.items) {
146
- // Normalize caller-provided items: accept item_id, po_item_id, or product_id
147
- const callerItems = args.items;
148
- receiveItems = callerItems.map((ci) => {
149
- let itemId = ci.item_id || ci.po_item_id || ci.line_item_id;
150
- // If caller used product_id instead, resolve to PO line item ID
151
- if (!itemId && ci.product_id) {
152
- const match = poItems.find((pi) => pi.id === ci.product_id || pi.product_id === ci.product_id);
153
- if (match)
154
- itemId = match.id;
155
- }
156
- return { item_id: itemId || null, quantity: Number(ci.quantity) || 0 };
157
- }).filter((i) => i.item_id && i.quantity > 0);
158
- if (!receiveItems.length)
159
- return { success: false, error: "No valid items to receive — provide item_id or product_id matching a PO line item" };
10
+ const sid = storeId;
11
+ switch (args.action) {
12
+ case "list":
13
+ {
14
+ let q = sb.from("purchase_orders").select("*, supplier:suppliers(external_name, external_company), location:locations(name)").eq("store_id", sid).order("created_at", {
15
+ ascending: false
16
+ }).limit(args.limit || 25);
17
+ if (args.status) q = q.eq("status", args.status);
18
+ const {
19
+ data,
20
+ error
21
+ } = await q;
22
+ if (error) return {
23
+ success: false,
24
+ error: error.message
25
+ };
26
+ // Flatten supplier/location joins for table display
27
+ const flattened = (data || []).map(row => {
28
+ const {
29
+ supplier,
30
+ location,
31
+ ...rest
32
+ } = row;
33
+ return {
34
+ ...rest,
35
+ supplier_name: supplier?.external_name || supplier?.external_company || "—",
36
+ location_name: location?.name || "—"
37
+ };
38
+ });
39
+ return {
40
+ success: true,
41
+ data: flattened
42
+ };
43
+ }
44
+ case "get":
45
+ {
46
+ const {
47
+ data,
48
+ error
49
+ } = await sb.from("purchase_orders").select("*, items:purchase_order_items(id, product_id, quantity, unit_price, received_quantity, subtotal, product:products(name, sku)), supplier:suppliers(id, external_name, external_company, contact_email, contact_phone)").eq("id", args.purchase_order_id).eq("store_id", sid).single();
50
+ if (error) return {
51
+ success: false,
52
+ error: error.message
53
+ };
54
+ // Flatten items so product names appear as columns (formatter drops nested objects in sub-tables)
55
+ const po = data;
56
+ const items = (po.items || []).map(item => ({
57
+ id: item.id,
58
+ product_id: item.product_id,
59
+ product_name: item.product?.name || "—",
60
+ product_sku: item.product?.sku || "",
61
+ quantity: item.quantity,
62
+ unit_price: item.unit_price,
63
+ received: item.received_quantity || 0,
64
+ subtotal: item.subtotal
65
+ }));
66
+ const {
67
+ items: _,
68
+ supplier,
69
+ ...poFields
70
+ } = po;
71
+ return {
72
+ success: true,
73
+ data: {
74
+ ...poFields,
75
+ supplier_name: supplier?.external_name || supplier?.external_company || "",
76
+ supplier_email: supplier?.contact_email || null,
77
+ items
78
+ }
79
+ };
80
+ }
81
+ case "create":
82
+ {
83
+ // create_purchase_order_atomic RPC SECURITY DEFINER, returns JSONB {success, po_id, po_number}
84
+ // p_items is TEXT type (JSON string), not JSONB
85
+ const items = (args.items || []).map(item => ({
86
+ product_id: item.product_id,
87
+ quantity: Math.max(Number(item.quantity) || 1, 0),
88
+ unit_cost: Math.max(Number(item.unit_cost || item.unit_price) || 0, 0)
89
+ }));
90
+ const {
91
+ data: result,
92
+ error: rpcError
93
+ } = await sb.rpc("create_purchase_order_atomic", {
94
+ p_store_id: sid,
95
+ p_po_type: "inbound",
96
+ p_supplier_id: args.supplier_id || null,
97
+ p_location_id: args.location_id || null,
98
+ p_expected_delivery_date: args.expected_delivery_date || null,
99
+ p_notes: args.notes || null,
100
+ p_items: JSON.stringify(items)
101
+ });
102
+ if (rpcError) return {
103
+ success: false,
104
+ error: rpcError.message
105
+ };
106
+ const rpcResult = parseRpcResult(result);
107
+ if (!rpcResult.success) return {
108
+ success: false,
109
+ error: rpcResult.error || "PO creation failed"
110
+ };
111
+
112
+ // Fetch full PO for response — flatten nested joins
113
+ const {
114
+ data: fullPo
115
+ } = await sb.from("purchase_orders").select("*, items:purchase_order_items(id, product_id, quantity, unit_price, subtotal, product:products(name, sku)), supplier:suppliers(id, external_name, external_company)").eq("id", rpcResult.po_id).single();
116
+ if (!fullPo) return {
117
+ success: true,
118
+ data: {
119
+ po_id: rpcResult.po_id,
120
+ po_number: rpcResult.po_number
121
+ }
122
+ };
123
+ const po = fullPo;
124
+ const flatItems = (po.items || []).map(item => ({
125
+ id: item.id,
126
+ product_id: item.product_id,
127
+ product_name: item.product?.name || "—",
128
+ product_sku: item.product?.sku || "—",
129
+ quantity: item.quantity,
130
+ unit_price: item.unit_price,
131
+ subtotal: item.subtotal
132
+ }));
133
+ const {
134
+ items: _poItems,
135
+ supplier,
136
+ ...poFields
137
+ } = po;
138
+ return {
139
+ success: true,
140
+ data: {
141
+ ...poFields,
142
+ supplier_name: supplier?.external_name || supplier?.external_company || "",
143
+ items: flatItems
144
+ }
145
+ };
146
+ }
147
+ case "add_items":
148
+ {
149
+ // No atomic RPC exists for adding items to an existing PO — direct insert
150
+ const poId = args.purchase_order_id;
151
+ if (!poId) return {
152
+ success: false,
153
+ error: "purchase_order_id is required"
154
+ };
155
+ const items = args.items;
156
+ if (!items || !Array.isArray(items) || !items.length) return {
157
+ success: false,
158
+ error: "items array is required"
159
+ };
160
+ const {
161
+ data: po
162
+ } = await sb.from("purchase_orders").select("status").eq("id", poId).eq("store_id", sid).single();
163
+ if (!po) return {
164
+ success: false,
165
+ error: "PO not found"
166
+ };
167
+ if (po.status === "received") return {
168
+ success: false,
169
+ error: "Cannot add items — PO already received"
170
+ };
171
+ if (po.status === "cancelled") return {
172
+ success: false,
173
+ error: "Cannot add items — PO is cancelled"
174
+ };
175
+ const rows = items.map(item => {
176
+ const qty = Math.max(Number(item.quantity) || 1, 0);
177
+ const price = Math.max(Number(item.unit_cost || item.unit_price) || 0, 0);
178
+ return {
179
+ purchase_order_id: poId,
180
+ product_id: item.product_id,
181
+ quantity: qty,
182
+ unit_price: price,
183
+ subtotal: qty * price
184
+ };
185
+ });
186
+ const {
187
+ data,
188
+ error
189
+ } = await sb.from("purchase_order_items").insert(rows).select("*, product:products(name, sku)");
190
+ return error ? {
191
+ success: false,
192
+ error: error.message
193
+ } : {
194
+ success: true,
195
+ data
196
+ };
197
+ }
198
+ case "approve":
199
+ case "mark_ordered":
200
+ {
201
+ // PO flow: draft → ordered. "approve" = mark as ordered.
202
+ // update_po_status RPC — SECURITY DEFINER, returns JSONB {success, old_status, new_status}
203
+ const {
204
+ data: result,
205
+ error: rpcError
206
+ } = await sb.rpc("update_po_status", {
207
+ p_po_id: args.purchase_order_id,
208
+ p_status: "ordered"
209
+ });
210
+ if (rpcError) return {
211
+ success: false,
212
+ error: rpcError.message
213
+ };
214
+ const rpcResult = parseRpcResult(result);
215
+ if (!rpcResult.success) return {
216
+ success: false,
217
+ error: rpcResult.error || "Status update failed"
218
+ };
219
+ return {
220
+ success: true,
221
+ data: {
222
+ old_status: rpcResult.old_status,
223
+ new_status: rpcResult.new_status
224
+ }
225
+ };
226
+ }
227
+ case "receive":
228
+ {
229
+ // receive_po_items RPC — SECURITY DEFINER, returns JSONB {success, items_processed}
230
+ // Params: p_po_id, p_location_id, p_items [{item_id, quantity}]
231
+ const poId = args.purchase_order_id;
232
+ const {
233
+ data: po,
234
+ error: poErr
235
+ } = await sb.from("purchase_orders").select("location_id, items:purchase_order_items(id, quantity, received_quantity)").eq("id", poId).eq("store_id", sid).single();
236
+ if (poErr || !po) return {
237
+ success: false,
238
+ error: poErr?.message || "PO not found"
239
+ };
240
+
241
+ // If caller provides specific items use those, otherwise receive all remaining
242
+ const poItems = po.items || [];
243
+ let receiveItems;
244
+ if (args.items) {
245
+ // Normalize caller-provided items: accept item_id, po_item_id, or product_id
246
+ const callerItems = args.items;
247
+ receiveItems = callerItems.map(ci => {
248
+ let itemId = ci.item_id || ci.po_item_id || ci.line_item_id;
249
+ // If caller used product_id instead, resolve to PO line item ID
250
+ if (!itemId && ci.product_id) {
251
+ const match = poItems.find(pi => pi.id === ci.product_id || pi.product_id === ci.product_id);
252
+ if (match) itemId = match.id;
160
253
  }
161
- else {
162
- receiveItems = poItems
163
- .map((item) => ({
164
- item_id: item.id,
165
- quantity: Math.max((item.quantity || 0) - (item.received_quantity || 0), 0),
166
- }))
167
- .filter((item) => item.quantity > 0);
168
- }
169
- if (!receiveItems.length)
170
- return { success: false, error: "No items to receive (all fully received)" };
171
- const locationId = args.location_id || po.location_id;
172
- if (!locationId)
173
- return { success: false, error: "No location_id on PO — cannot receive" };
174
- const { data: result, error: rpcError } = await sb.rpc("receive_po_items", {
175
- p_po_id: poId,
176
- p_location_id: locationId,
177
- p_items: receiveItems,
178
- });
179
- if (rpcError)
180
- return { success: false, error: rpcError.message };
181
- const rpcResult = parseRpcResult(result);
182
- if (!rpcResult.success)
183
- return { success: false, error: rpcResult.error || "PO receive failed" };
184
254
  return {
185
- success: true,
186
- data: {
187
- po_id: poId,
188
- items_processed: rpcResult.items_processed,
189
- message: `Received ${rpcResult.items_processed || 0} item(s) into inventory`,
190
- }
255
+ item_id: itemId || null,
256
+ quantity: Number(ci.quantity) || 0
191
257
  };
258
+ }).filter(i => i.item_id && i.quantity > 0);
259
+ if (!receiveItems.length) return {
260
+ success: false,
261
+ error: "No valid items to receive — provide item_id or product_id matching a PO line item"
262
+ };
263
+ } else {
264
+ receiveItems = poItems.map(item => ({
265
+ item_id: item.id,
266
+ quantity: Math.max((item.quantity || 0) - (item.received_quantity || 0), 0)
267
+ })).filter(item => item.quantity > 0);
192
268
  }
193
- case "cancel": {
194
- // update_po_status RPC — SECURITY DEFINER, returns JSONB {success, old_status, new_status}
195
- const { data: result, error: rpcError } = await sb.rpc("update_po_status", {
196
- p_po_id: args.purchase_order_id,
197
- p_status: "cancelled",
198
- });
199
- if (rpcError)
200
- return { success: false, error: rpcError.message };
201
- const rpcResult = parseRpcResult(result);
202
- if (!rpcResult.success)
203
- return { success: false, error: rpcResult.error || "Cancel failed" };
204
- return { success: true, data: { old_status: rpcResult.old_status, new_status: rpcResult.new_status } };
205
- }
206
- default:
207
- return { success: false, error: `Unknown purchase_orders action: ${args.action}. Valid: list, get, create, add_items, approve, mark_ordered, receive, cancel` };
208
- }
269
+ if (!receiveItems.length) return {
270
+ success: false,
271
+ error: "No items to receive (all fully received)"
272
+ };
273
+ const locationId = args.location_id || po.location_id;
274
+ if (!locationId) return {
275
+ success: false,
276
+ error: "No location_id on PO cannot receive"
277
+ };
278
+ const {
279
+ data: result,
280
+ error: rpcError
281
+ } = await sb.rpc("receive_po_items", {
282
+ p_po_id: poId,
283
+ p_location_id: locationId,
284
+ p_items: receiveItems
285
+ });
286
+ if (rpcError) return {
287
+ success: false,
288
+ error: rpcError.message
289
+ };
290
+ const rpcResult = parseRpcResult(result);
291
+ if (!rpcResult.success) return {
292
+ success: false,
293
+ error: rpcResult.error || "PO receive failed"
294
+ };
295
+ return {
296
+ success: true,
297
+ data: {
298
+ po_id: poId,
299
+ items_processed: rpcResult.items_processed,
300
+ message: `Received ${rpcResult.items_processed || 0} item(s) into inventory`
301
+ }
302
+ };
303
+ }
304
+ case "cancel":
305
+ {
306
+ // update_po_status RPC — SECURITY DEFINER, returns JSONB {success, old_status, new_status}
307
+ const {
308
+ data: result,
309
+ error: rpcError
310
+ } = await sb.rpc("update_po_status", {
311
+ p_po_id: args.purchase_order_id,
312
+ p_status: "cancelled"
313
+ });
314
+ if (rpcError) return {
315
+ success: false,
316
+ error: rpcError.message
317
+ };
318
+ const rpcResult = parseRpcResult(result);
319
+ if (!rpcResult.success) return {
320
+ success: false,
321
+ error: rpcResult.error || "Cancel failed"
322
+ };
323
+ return {
324
+ success: true,
325
+ data: {
326
+ old_status: rpcResult.old_status,
327
+ new_status: rpcResult.new_status
328
+ }
329
+ };
330
+ }
331
+ default:
332
+ return {
333
+ success: false,
334
+ error: `Unknown purchase_orders action: ${args.action}. Valid: list, get, create, add_items, approve, mark_ordered, receive, cancel`
335
+ };
336
+ }
209
337
  }
210
338
  export async function handleTransfers(sb, args, storeId) {
211
- const sid = storeId;
212
- switch (args.action) {
213
- case "list": {
214
- let q = sb.from("inventory_transfers")
215
- .select("*, from_location:locations!source_location_id(name), to_location:locations!destination_location_id(name)")
216
- .eq("store_id", sid).order("created_at", { ascending: false }).limit(args.limit || 25);
217
- if (args.status)
218
- q = q.eq("status", args.status);
219
- const { data, error } = await q;
220
- if (error)
221
- return { success: false, error: error.message };
222
- // Flatten location joins for table display
223
- const flattened = (data || []).map((row) => {
224
- const { from_location, to_location, ...rest } = row;
225
- return { ...rest, from_location: from_location?.name || "—", to_location: to_location?.name || "—" };
226
- });
227
- return { success: true, data: flattened };
228
- }
229
- case "create": {
230
- // create_inventory_transfer RPC — SECURITY DEFINER, returns JSONB {success, transfer_id, transfer_number}
231
- // p_items is JSONB (pass as object, not string)
232
- const sourceLocId = (args.from_location_id || args.source_location_id);
233
- const destLocId = (args.to_location_id || args.destination_location_id);
234
- const items = (args.items || []).map(i => ({
235
- product_id: i.product_id,
236
- quantity: i.quantity,
237
- }));
238
- const params = {
239
- p_store_id: sid,
240
- p_source_location_id: sourceLocId,
241
- p_destination_location_id: destLocId,
242
- p_items: items,
243
- };
244
- if (args.notes)
245
- params.p_notes = args.notes;
246
- const { data: result, error: rpcError } = await sb.rpc("create_inventory_transfer", params);
247
- if (rpcError)
248
- return { success: false, error: rpcError.message };
249
- const rpcResult = parseRpcResult(result);
250
- if (!rpcResult.success)
251
- return { success: false, error: rpcResult.error || "Transfer creation failed" };
252
- return { success: true, data: { transfer_id: rpcResult.transfer_id, transfer_number: rpcResult.transfer_number } };
253
- }
254
- case "get": {
255
- const { data, error } = await sb.from("inventory_transfers")
256
- .select("*, items:inventory_transfer_items(id, product_id, quantity, product:products(name, sku)), from_location:locations!source_location_id(id, name), to_location:locations!destination_location_id(id, name)")
257
- .eq("id", args.transfer_id).eq("store_id", sid).single();
258
- if (error)
259
- return { success: false, error: error.message };
260
- // Flatten nested joins so items and locations are visible
261
- const transfer = data;
262
- const items = (transfer.items || []).map((item) => ({
263
- id: item.id, product_id: item.product_id,
264
- product_name: item.product?.name || "—", product_sku: item.product?.sku || "—",
265
- quantity: item.quantity,
266
- }));
267
- const { items: _, from_location, to_location, ...transferFields } = transfer;
268
- return {
269
- success: true,
270
- data: {
271
- ...transferFields,
272
- from_location_name: from_location?.name || "—",
273
- to_location_name: to_location?.name || "",
274
- items,
275
- }
276
- };
277
- }
278
- case "approve": {
279
- // approve_inventory_transfer RPC — SECURITY DEFINER, returns boolean
280
- // Validates stock, draft → approved
281
- const { data: result, error: rpcError } = await sb.rpc("approve_inventory_transfer", {
282
- p_transfer_id: args.transfer_id,
283
- });
284
- if (rpcError)
285
- return { success: false, error: rpcError.message };
286
- return { success: true, data: { approved: result } };
287
- }
288
- case "ship":
289
- case "mark_in_transit": {
290
- // mark_transfer_in_transit RPC — SECURITY DEFINER, returns boolean
291
- // Validates stock, creates holds, draft/approved → in_transit
292
- const { data: result, error: rpcError } = await sb.rpc("mark_transfer_in_transit", {
293
- p_transfer_id: args.transfer_id,
294
- });
295
- if (rpcError)
296
- return { success: false, error: rpcError.message };
297
- return { success: true, data: { in_transit: result } };
298
- }
299
- case "receive":
300
- case "complete": {
301
- // complete_inventory_transfer RPC — SECURITY DEFINER, returns JSONB {success, items_processed}
302
- // Deducts source, adds to destination, releases holds
303
- const { data: result, error: rpcError } = await sb.rpc("complete_inventory_transfer", {
304
- p_transfer_id: args.transfer_id,
305
- });
306
- if (rpcError)
307
- return { success: false, error: rpcError.message };
308
- const rpcResult = parseRpcResult(result);
309
- if (!rpcResult.success)
310
- return { success: false, error: rpcResult.error || "Transfer complete failed" };
311
- return {
312
- success: true,
313
- data: {
314
- transfer_id: args.transfer_id,
315
- items_processed: rpcResult.items_processed,
316
- message: `Completed transfer, ${rpcResult.items_processed || 0} item(s) moved to destination`,
317
- }
318
- };
319
- }
320
- case "cancel": {
321
- // cancel_inventory_transfer RPC SECURITY DEFINER, returns boolean
322
- // Releases holds, any non-final → cancelled
323
- const { data: result, error: rpcError } = await sb.rpc("cancel_inventory_transfer", {
324
- p_transfer_id: args.transfer_id,
325
- });
326
- if (rpcError)
327
- return { success: false, error: rpcError.message };
328
- return { success: true, data: { cancelled: result, message: "Transfer cancelled" } };
329
- }
330
- default:
331
- return { success: false, error: `Unknown transfers action: ${args.action}. Valid: list, get, create, approve, ship, mark_in_transit, receive, complete, cancel` };
332
- }
339
+ const sid = storeId;
340
+ switch (args.action) {
341
+ case "list":
342
+ {
343
+ let q = sb.from("inventory_transfers").select("*, from_location:locations!source_location_id(name), to_location:locations!destination_location_id(name)").eq("store_id", sid).order("created_at", {
344
+ ascending: false
345
+ }).limit(args.limit || 25);
346
+ if (args.status) q = q.eq("status", args.status);
347
+ const {
348
+ data,
349
+ error
350
+ } = await q;
351
+ if (error) return {
352
+ success: false,
353
+ error: error.message
354
+ };
355
+ // Flatten location joins for table display
356
+ const flattened = (data || []).map(row => {
357
+ const {
358
+ from_location,
359
+ to_location,
360
+ ...rest
361
+ } = row;
362
+ return {
363
+ ...rest,
364
+ from_location: from_location?.name || "—",
365
+ to_location: to_location?.name || "—"
366
+ };
367
+ });
368
+ return {
369
+ success: true,
370
+ data: flattened
371
+ };
372
+ }
373
+ case "create":
374
+ {
375
+ // create_inventory_transfer RPC — SECURITY DEFINER, returns JSONB {success, transfer_id, transfer_number}
376
+ // p_items is JSONB (pass as object, not string)
377
+ const sourceLocId = args.from_location_id || args.source_location_id;
378
+ const destLocId = args.to_location_id || args.destination_location_id;
379
+ const items = (args.items || []).map(i => ({
380
+ product_id: i.product_id,
381
+ quantity: i.quantity
382
+ }));
383
+ const params = {
384
+ p_store_id: sid,
385
+ p_source_location_id: sourceLocId,
386
+ p_destination_location_id: destLocId,
387
+ p_items: items
388
+ };
389
+ if (args.notes) params.p_notes = args.notes;
390
+ const {
391
+ data: result,
392
+ error: rpcError
393
+ } = await sb.rpc("create_inventory_transfer", params);
394
+ if (rpcError) return {
395
+ success: false,
396
+ error: rpcError.message
397
+ };
398
+ const rpcResult = parseRpcResult(result);
399
+ if (!rpcResult.success) return {
400
+ success: false,
401
+ error: rpcResult.error || "Transfer creation failed"
402
+ };
403
+ return {
404
+ success: true,
405
+ data: {
406
+ transfer_id: rpcResult.transfer_id,
407
+ transfer_number: rpcResult.transfer_number
408
+ }
409
+ };
410
+ }
411
+ case "get":
412
+ {
413
+ const {
414
+ data,
415
+ error
416
+ } = await sb.from("inventory_transfers").select("*, items:inventory_transfer_items(id, product_id, quantity, product:products(name, sku)), from_location:locations!source_location_id(id, name), to_location:locations!destination_location_id(id, name)").eq("id", args.transfer_id).eq("store_id", sid).single();
417
+ if (error) return {
418
+ success: false,
419
+ error: error.message
420
+ };
421
+ // Flatten nested joins so items and locations are visible
422
+ const transfer = data;
423
+ const items = (transfer.items || []).map(item => ({
424
+ id: item.id,
425
+ product_id: item.product_id,
426
+ product_name: item.product?.name || "—",
427
+ product_sku: item.product?.sku || "",
428
+ quantity: item.quantity
429
+ }));
430
+ const {
431
+ items: _,
432
+ from_location,
433
+ to_location,
434
+ ...transferFields
435
+ } = transfer;
436
+ return {
437
+ success: true,
438
+ data: {
439
+ ...transferFields,
440
+ from_location_name: from_location?.name || "—",
441
+ to_location_name: to_location?.name || "—",
442
+ items
443
+ }
444
+ };
445
+ }
446
+ case "approve":
447
+ {
448
+ // approve_inventory_transfer RPC — SECURITY DEFINER, returns boolean
449
+ // Validates stock, draft approved
450
+ const {
451
+ data: result,
452
+ error: rpcError
453
+ } = await sb.rpc("approve_inventory_transfer", {
454
+ p_transfer_id: args.transfer_id
455
+ });
456
+ if (rpcError) return {
457
+ success: false,
458
+ error: rpcError.message
459
+ };
460
+ return {
461
+ success: true,
462
+ data: {
463
+ approved: result
464
+ }
465
+ };
466
+ }
467
+ case "ship":
468
+ case "mark_in_transit":
469
+ {
470
+ // mark_transfer_in_transit RPC — SECURITY DEFINER, returns boolean
471
+ // Validates stock, creates holds, draft/approved → in_transit
472
+ const {
473
+ data: result,
474
+ error: rpcError
475
+ } = await sb.rpc("mark_transfer_in_transit", {
476
+ p_transfer_id: args.transfer_id
477
+ });
478
+ if (rpcError) return {
479
+ success: false,
480
+ error: rpcError.message
481
+ };
482
+ return {
483
+ success: true,
484
+ data: {
485
+ in_transit: result
486
+ }
487
+ };
488
+ }
489
+ case "receive":
490
+ case "complete":
491
+ {
492
+ // complete_inventory_transfer RPC — SECURITY DEFINER, returns JSONB {success, items_processed}
493
+ // Deducts source, adds to destination, releases holds
494
+ const {
495
+ data: result,
496
+ error: rpcError
497
+ } = await sb.rpc("complete_inventory_transfer", {
498
+ p_transfer_id: args.transfer_id
499
+ });
500
+ if (rpcError) return {
501
+ success: false,
502
+ error: rpcError.message
503
+ };
504
+ const rpcResult = parseRpcResult(result);
505
+ if (!rpcResult.success) return {
506
+ success: false,
507
+ error: rpcResult.error || "Transfer complete failed"
508
+ };
509
+ return {
510
+ success: true,
511
+ data: {
512
+ transfer_id: args.transfer_id,
513
+ items_processed: rpcResult.items_processed,
514
+ message: `Completed transfer, ${rpcResult.items_processed || 0} item(s) moved to destination`
515
+ }
516
+ };
517
+ }
518
+ case "cancel":
519
+ {
520
+ // cancel_inventory_transfer RPC — SECURITY DEFINER, returns boolean
521
+ // Releases holds, any non-final → cancelled
522
+ const {
523
+ data: result,
524
+ error: rpcError
525
+ } = await sb.rpc("cancel_inventory_transfer", {
526
+ p_transfer_id: args.transfer_id
527
+ });
528
+ if (rpcError) return {
529
+ success: false,
530
+ error: rpcError.message
531
+ };
532
+ return {
533
+ success: true,
534
+ data: {
535
+ cancelled: result,
536
+ message: "Transfer cancelled"
537
+ }
538
+ };
539
+ }
540
+ default:
541
+ return {
542
+ success: false,
543
+ error: `Unknown transfers action: ${args.action}. Valid: list, get, create, approve, ship, mark_in_transit, receive, complete, cancel`
544
+ };
545
+ }
333
546
  }
547
+
334
548
  /** Parse RPC result — handles both raw objects and stringified JSON */
335
549
  function parseRpcResult(result) {
336
- if (typeof result === "string") {
337
- try {
338
- return JSON.parse(result);
339
- }
340
- catch {
341
- return { success: false, error: result };
342
- }
550
+ if (typeof result === "string") {
551
+ try {
552
+ return JSON.parse(result);
553
+ } catch {
554
+ return {
555
+ success: false,
556
+ error: result
557
+ };
343
558
  }
344
- return result || { success: false, error: "Empty RPC response" };
559
+ }
560
+ return result || {
561
+ success: false,
562
+ error: "Empty RPC response"
563
+ };
345
564
  }
565
+ //# sourceMappingURL=supply-chain.js.map