whale-code 6.5.5 → 6.5.7

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 (2089) hide show
  1. package/README.md +39 -31
  2. package/bin/{swagmanager-mcp.js → whale-code.js} +40 -2
  3. package/dist/cli/__tests__/print-mode-streaming.test.js +270 -0
  4. package/dist/cli/__tests__/print-mode.basic-output.test.js +230 -0
  5. package/dist/cli/__tests__/print-mode.session-errors.test.js +252 -0
  6. package/dist/cli/__tests__/print-mode.test.js +273 -0
  7. package/dist/cli/__tests__/serve-mode-messages.test.js +338 -0
  8. package/dist/cli/__tests__/serve-mode.messages.part2.test.js +266 -0
  9. package/dist/cli/__tests__/serve-mode.messages.test.js +277 -0
  10. package/dist/cli/__tests__/serve-mode.startup-http.test.js +279 -0
  11. package/dist/cli/__tests__/serve-mode.test.js +345 -0
  12. package/dist/cli/app.d.ts +1 -0
  13. package/dist/cli/app.js +154 -72
  14. package/dist/cli/app.js.map +1 -0
  15. package/dist/cli/chat/AgentSelector.js +105 -10
  16. package/dist/cli/chat/AgentSelector.js.map +1 -0
  17. package/dist/cli/chat/ChatApp.d.ts +8 -5
  18. package/dist/cli/chat/ChatApp.js +253 -315
  19. package/dist/cli/chat/ChatApp.js.map +1 -0
  20. package/dist/cli/chat/ChatInput.d.ts +3 -2
  21. package/dist/cli/chat/ChatInput.js +1111 -770
  22. package/dist/cli/chat/ChatInput.js.map +1 -0
  23. package/dist/cli/chat/ImsgManager.d.ts +20 -0
  24. package/dist/cli/chat/ImsgManager.js +341 -0
  25. package/dist/cli/chat/ImsgManager.js.map +1 -0
  26. package/dist/cli/chat/MarkdownText.d.ts +2 -1
  27. package/dist/cli/chat/MarkdownText.js +44 -15
  28. package/dist/cli/chat/MarkdownText.js.map +1 -0
  29. package/dist/cli/chat/MemoryManager.js +182 -46
  30. package/dist/cli/chat/MemoryManager.js.map +1 -0
  31. package/dist/cli/chat/MessageList.d.ts +3 -4
  32. package/dist/cli/chat/MessageList.js +195 -49
  33. package/dist/cli/chat/MessageList.js.map +1 -0
  34. package/dist/cli/chat/ModelSelector.js +282 -63
  35. package/dist/cli/chat/ModelSelector.js.map +1 -0
  36. package/dist/cli/chat/NodeManager.js +61 -84
  37. package/dist/cli/chat/NodeManager.js.map +1 -0
  38. package/dist/cli/chat/NodeSelector.js +171 -30
  39. package/dist/cli/chat/NodeSelector.js.map +1 -0
  40. package/dist/cli/chat/OverlayContext.d.ts +27 -0
  41. package/dist/cli/chat/OverlayContext.js +2 -0
  42. package/dist/cli/chat/OverlayContext.js.map +1 -0
  43. package/dist/cli/chat/PlanApproval.js +282 -57
  44. package/dist/cli/chat/PlanApproval.js.map +1 -0
  45. package/dist/cli/chat/RewindConfirmation.d.ts +12 -0
  46. package/dist/cli/chat/RewindConfirmation.js +243 -0
  47. package/dist/cli/chat/RewindConfirmation.js.map +1 -0
  48. package/dist/cli/chat/RewindViewer.js +560 -144
  49. package/dist/cli/chat/RewindViewer.js.map +1 -0
  50. package/dist/cli/chat/SessionManager.js +138 -30
  51. package/dist/cli/chat/SessionManager.js.map +1 -0
  52. package/dist/cli/chat/SlashMenu.d.ts +7 -24
  53. package/dist/cli/chat/SlashMenu.js +150 -190
  54. package/dist/cli/chat/SlashMenu.js.map +1 -0
  55. package/dist/cli/chat/StatusBar.d.ts +5 -2
  56. package/dist/cli/chat/StatusBar.js +188 -10
  57. package/dist/cli/chat/StatusBar.js.map +1 -0
  58. package/dist/cli/chat/StoreSelector.js +147 -18
  59. package/dist/cli/chat/StoreSelector.js.map +1 -0
  60. package/dist/cli/chat/StreamingText.d.ts +0 -3
  61. package/dist/cli/chat/StreamingText.js +21 -6
  62. package/dist/cli/chat/StreamingText.js.map +1 -0
  63. package/dist/cli/chat/SubagentPanel.d.ts +6 -7
  64. package/dist/cli/chat/SubagentPanel.js +253 -91
  65. package/dist/cli/chat/SubagentPanel.js.map +1 -0
  66. package/dist/cli/chat/TeamPanel.d.ts +1 -0
  67. package/dist/cli/chat/TeamPanel.js +201 -29
  68. package/dist/cli/chat/TeamPanel.js.map +1 -0
  69. package/dist/cli/chat/ThemeSelector.js +84 -24
  70. package/dist/cli/chat/ThemeSelector.js.map +1 -0
  71. package/dist/cli/chat/ToolIndicator.d.ts +7 -23
  72. package/dist/cli/chat/ToolIndicator.js +635 -430
  73. package/dist/cli/chat/ToolIndicator.js.map +1 -0
  74. package/dist/cli/chat/chat-input-menu-handler.d.ts +32 -0
  75. package/dist/cli/chat/components/LiveArea.d.ts +12 -0
  76. package/dist/cli/chat/components/LiveArea.js +252 -0
  77. package/dist/cli/chat/components/LiveArea.js.map +1 -0
  78. package/dist/cli/chat/components/OverlayRouter.d.ts +13 -0
  79. package/dist/cli/chat/components/OverlayRouter.js +257 -0
  80. package/dist/cli/chat/components/OverlayRouter.js.map +1 -0
  81. package/dist/cli/chat/components/StaticMessages.d.ts +9 -0
  82. package/dist/cli/chat/components/StaticMessages.js +132 -0
  83. package/dist/cli/chat/components/StaticMessages.js.map +1 -0
  84. package/dist/cli/chat/hooks/agent-loop-events.d.ts +77 -0
  85. package/dist/cli/chat/hooks/agent-loop-events.js +171 -0
  86. package/dist/cli/chat/hooks/agent-loop-events.js.map +1 -0
  87. package/dist/cli/chat/hooks/slash-command-config-system.d.ts +11 -0
  88. package/dist/cli/chat/hooks/slash-command-config-system.js +177 -0
  89. package/dist/cli/chat/hooks/slash-command-config-system.js.map +1 -0
  90. package/dist/cli/chat/hooks/slash-command-handlers-system.d.ts +12 -0
  91. package/dist/cli/chat/hooks/slash-command-handlers-system.js +127 -0
  92. package/dist/cli/chat/hooks/slash-command-handlers-system.js.map +1 -0
  93. package/dist/cli/chat/hooks/slash-command-handlers.d.ts +21 -0
  94. package/dist/cli/chat/hooks/slash-command-handlers.js +222 -0
  95. package/dist/cli/chat/hooks/slash-command-handlers.js.map +1 -0
  96. package/dist/cli/chat/hooks/slash-imsg-handlers.js +148 -0
  97. package/dist/cli/chat/hooks/slash-imsg-handlers.js.map +1 -0
  98. package/dist/cli/chat/hooks/slash-node-handlers.d.ts +26 -0
  99. package/dist/cli/chat/hooks/slash-node-handlers.js +226 -0
  100. package/dist/cli/chat/hooks/slash-node-handlers.js.map +1 -0
  101. package/dist/cli/chat/hooks/useAgentLoop.d.ts +2 -20
  102. package/dist/cli/chat/hooks/useAgentLoop.js +344 -373
  103. package/dist/cli/chat/hooks/useAgentLoop.js.map +1 -0
  104. package/dist/cli/chat/hooks/useElapsedClock.d.ts +19 -0
  105. package/dist/cli/chat/hooks/useElapsedClock.js +80 -0
  106. package/dist/cli/chat/hooks/useElapsedClock.js.map +1 -0
  107. package/dist/cli/chat/hooks/useOverlayHandlers.d.ts +23 -0
  108. package/dist/cli/chat/hooks/useOverlayHandlers.js +125 -0
  109. package/dist/cli/chat/hooks/useOverlayHandlers.js.map +1 -0
  110. package/dist/cli/chat/hooks/useSlashCommands.d.ts +14 -33
  111. package/dist/cli/chat/hooks/useSlashCommands.js +167 -616
  112. package/dist/cli/chat/hooks/useSlashCommands.js.map +1 -0
  113. package/dist/cli/chat/hooks/useStreamingReducer.d.ts +66 -0
  114. package/dist/cli/chat/imsg-manager-render.d.ts +29 -0
  115. package/dist/cli/chat/imsg-manager-render.js +294 -0
  116. package/dist/cli/chat/imsg-manager-render.js.map +1 -0
  117. package/dist/cli/chat/slash-commands.d.ts +37 -0
  118. package/dist/cli/chat/slash-commands.js +194 -0
  119. package/dist/cli/chat/slash-commands.js.map +1 -0
  120. package/dist/cli/chat/store.d.ts +115 -0
  121. package/dist/cli/chat/store.js +177 -0
  122. package/dist/cli/chat/store.js.map +1 -0
  123. package/dist/cli/chat/tool-indicator-helpers.d.ts +14 -0
  124. package/dist/cli/chat/tool-indicator-helpers.js +167 -0
  125. package/dist/cli/chat/tool-indicator-helpers.js.map +1 -0
  126. package/dist/cli/chat/tool-indicator-summary.d.ts +6 -0
  127. package/dist/cli/chat/tool-indicator-summary.js +103 -0
  128. package/dist/cli/chat/tool-indicator-summary.js.map +1 -0
  129. package/dist/cli/chat/tool-indicator-types.d.ts +66 -0
  130. package/dist/cli/chat/tool-indicator-types.js +177 -0
  131. package/dist/cli/chat/tool-indicator-types.js.map +1 -0
  132. package/dist/cli/commands/__tests__/config-cmd.test.js +270 -0
  133. package/dist/cli/commands/__tests__/doctor.test.js +257 -0
  134. package/dist/cli/commands/__tests__/imsg-node-bridge.test.js +99 -0
  135. package/dist/cli/commands/__tests__/imsg-utils.test.js +73 -0
  136. package/dist/cli/commands/__tests__/init.test.js +214 -0
  137. package/dist/cli/commands/__tests__/mcp.test.js +287 -0
  138. package/dist/cli/commands/config-cmd.js +56 -57
  139. package/dist/cli/commands/config-cmd.js.map +1 -0
  140. package/dist/cli/commands/db.js +184 -169
  141. package/dist/cli/commands/db.js.map +1 -0
  142. package/dist/cli/commands/doctor.js +212 -122
  143. package/dist/cli/commands/doctor.js.map +1 -0
  144. package/dist/cli/commands/imsg-config.d.ts +31 -0
  145. package/dist/cli/commands/imsg-config.js +104 -0
  146. package/dist/cli/commands/imsg-config.js.map +1 -0
  147. package/dist/cli/commands/imsg-node-bridge.d.ts +25 -0
  148. package/dist/cli/commands/imsg-node-bridge.js +229 -0
  149. package/dist/cli/commands/imsg-node-bridge.js.map +1 -0
  150. package/dist/cli/commands/imsg-utils.d.ts +14 -0
  151. package/dist/cli/commands/imsg-utils.js +42 -0
  152. package/dist/cli/commands/imsg-utils.js.map +1 -0
  153. package/dist/cli/commands/imsg-watcher-helpers.d.ts +40 -0
  154. package/dist/cli/commands/imsg-watcher-helpers.js +184 -0
  155. package/dist/cli/commands/imsg-watcher-helpers.js.map +1 -0
  156. package/dist/cli/commands/imsg-watcher.d.ts +11 -0
  157. package/dist/cli/commands/imsg-watcher.js +230 -0
  158. package/dist/cli/commands/imsg-watcher.js.map +1 -0
  159. package/dist/cli/commands/imsg.d.ts +14 -0
  160. package/dist/cli/commands/imsg.js +181 -0
  161. package/dist/cli/commands/imsg.js.map +1 -0
  162. package/dist/cli/commands/init.js +211 -244
  163. package/dist/cli/commands/init.js.map +1 -0
  164. package/dist/cli/commands/mcp.js +127 -122
  165. package/dist/cli/commands/mcp.js.map +1 -0
  166. package/dist/cli/commands/sessions.d.ts +9 -0
  167. package/dist/cli/commands/sessions.js +93 -0
  168. package/dist/cli/commands/sessions.js.map +1 -0
  169. package/dist/cli/login/LoginApp.js +358 -141
  170. package/dist/cli/login/LoginApp.js.map +1 -0
  171. package/dist/cli/print-mode.js +196 -177
  172. package/dist/cli/print-mode.js.map +1 -0
  173. package/dist/cli/serve-mode-persistence.d.ts +18 -0
  174. package/dist/cli/serve-mode-persistence.js +157 -0
  175. package/dist/cli/serve-mode-persistence.js.map +1 -0
  176. package/dist/cli/serve-mode-query.d.ts +9 -0
  177. package/dist/cli/serve-mode-query.js +247 -0
  178. package/dist/cli/serve-mode-query.js.map +1 -0
  179. package/dist/cli/serve-mode-types.d.ts +29 -0
  180. package/dist/cli/serve-mode-types.js +56 -0
  181. package/dist/cli/serve-mode-types.js.map +1 -0
  182. package/dist/cli/serve-mode.js +615 -530
  183. package/dist/cli/serve-mode.js.map +1 -0
  184. package/dist/cli/services/__tests__/agent-definitions.test.js +153 -0
  185. package/dist/cli/services/__tests__/agent-events-global.test.js +39 -0
  186. package/dist/cli/services/__tests__/agent-events.part2.test.js +113 -0
  187. package/dist/cli/services/__tests__/agent-events.test.js +157 -0
  188. package/dist/cli/services/__tests__/agent-loop-auth.test.js +392 -0
  189. package/dist/cli/services/__tests__/agent-loop-budget.test.js +389 -0
  190. package/dist/cli/services/__tests__/agent-loop-tools-lifecycle.test.js +430 -0
  191. package/dist/cli/services/__tests__/agent-loop-tools-maxturns.test.js +486 -0
  192. package/dist/cli/services/__tests__/agent-loop-utils-execution.test.js +528 -0
  193. package/dist/cli/services/__tests__/agent-loop-utils-helpers.test.js +466 -0
  194. package/dist/cli/services/__tests__/agent-worker-base-execute.test.js +257 -0
  195. package/dist/cli/services/__tests__/agent-worker-base-helpers.test.js +198 -0
  196. package/dist/cli/services/__tests__/agent-worker-base.test.js +278 -0
  197. package/dist/cli/services/__tests__/auth-service-exports.test.js +41 -0
  198. package/dist/cli/services/__tests__/auth-service.part2.test.js +169 -0
  199. package/dist/cli/services/__tests__/auth-service.test.js +242 -0
  200. package/dist/cli/services/__tests__/background-processes.test.js +282 -0
  201. package/dist/cli/services/__tests__/claude-md-loader.test.js +134 -0
  202. package/dist/cli/services/__tests__/config-store.test.js +247 -0
  203. package/dist/cli/services/__tests__/debug-log.test.js +199 -0
  204. package/dist/cli/services/__tests__/edge-cases-caching.test.js +174 -0
  205. package/dist/cli/services/__tests__/edge-cases-compaction-core.test.js +226 -0
  206. package/dist/cli/services/__tests__/edge-cases-compaction-openai.test.js +152 -0
  207. package/dist/cli/services/__tests__/edge-cases-compaction-shapes.test.js +53 -0
  208. package/dist/cli/services/__tests__/edge-cases-compaction-thinking.test.js +226 -0
  209. package/dist/cli/services/__tests__/edge-cases-compaction.test.js +131 -0
  210. package/dist/cli/services/__tests__/edge-cases-paths.test.js +86 -0
  211. package/dist/cli/services/__tests__/error-logger-messages.test.js +81 -0
  212. package/dist/cli/services/__tests__/error-logger-transport.test.js +119 -0
  213. package/dist/cli/services/__tests__/error-logger.test.js +264 -0
  214. package/dist/cli/services/__tests__/file-history.test.js +136 -0
  215. package/dist/cli/services/__tests__/git-context-cache-reset.test.js +223 -0
  216. package/dist/cli/services/__tests__/git-context.test.js +241 -0
  217. package/dist/cli/services/__tests__/interactive-tools-execute.test.js +166 -0
  218. package/dist/cli/services/__tests__/interactive-tools-plan.test.js +197 -0
  219. package/dist/cli/services/__tests__/interactive-tools.part2.test.js +168 -0
  220. package/dist/cli/services/__tests__/interactive-tools.test.js +179 -0
  221. package/dist/cli/services/__tests__/keybinding-manager.test.js +205 -0
  222. package/dist/cli/services/__tests__/local-tools-dispatch.test.js +404 -0
  223. package/dist/cli/services/__tests__/local-tools.test.js +238 -0
  224. package/dist/cli/services/__tests__/lsp-manager.test.js +364 -0
  225. package/dist/cli/services/__tests__/mcp-client-connect-disconnect.test.js +310 -0
  226. package/dist/cli/services/__tests__/mcp-client.test.js +93 -0
  227. package/dist/cli/services/__tests__/memory-manager.test.js +154 -0
  228. package/dist/cli/services/__tests__/model-manager-utils.test.js +154 -0
  229. package/dist/cli/services/__tests__/model-manager.test.js +175 -0
  230. package/dist/cli/services/__tests__/permission-modes.test.js +222 -0
  231. package/dist/cli/services/__tests__/ripgrep.test.js +328 -0
  232. package/dist/cli/services/__tests__/server-tools-execute.test.js +317 -0
  233. package/dist/cli/services/__tests__/server-tools.test.js +272 -0
  234. package/dist/cli/services/__tests__/session-persistence.test.js +245 -0
  235. package/dist/cli/services/__tests__/subagent-basic.test.js +489 -0
  236. package/dist/cli/services/__tests__/subagent-edge.test.js +545 -0
  237. package/dist/cli/services/__tests__/subagent-prompts.test.js +558 -0
  238. package/dist/cli/services/__tests__/subagent-worker-errors.test.js +255 -0
  239. package/dist/cli/services/__tests__/subagent-worker.test.js +242 -0
  240. package/dist/cli/services/__tests__/system-prompt.test.js +210 -0
  241. package/dist/cli/services/__tests__/team-lead-comms-messaging.test.js +250 -0
  242. package/dist/cli/services/__tests__/team-lead-comms-result.test.js +232 -0
  243. package/dist/cli/services/__tests__/team-lead-comms-stop.test.js +344 -0
  244. package/dist/cli/services/__tests__/team-lead-comms.test.js +285 -0
  245. package/dist/cli/services/__tests__/team-lead-create.test.js +327 -0
  246. package/dist/cli/services/__tests__/team-lead-run.test.js +318 -0
  247. package/dist/cli/services/__tests__/team-lead-stop.test.js +199 -0
  248. package/dist/cli/services/__tests__/team-state-comms.test.js +240 -0
  249. package/dist/cli/services/__tests__/team-state-core.test.js +230 -0
  250. package/dist/cli/services/__tests__/team-state-tasks-complete-fail-available.test.js +224 -0
  251. package/dist/cli/services/__tests__/team-state-tasks.test.js +184 -0
  252. package/dist/cli/services/__tests__/telemetry-ai-metadata.test.js +116 -0
  253. package/dist/cli/services/__tests__/telemetry.part2.test.js +195 -0
  254. package/dist/cli/services/__tests__/telemetry.test.js +176 -0
  255. package/dist/cli/services/agent-config.d.ts +5 -1
  256. package/dist/cli/services/agent-config.js +66 -36
  257. package/dist/cli/services/agent-config.js.map +1 -0
  258. package/dist/cli/services/agent-definitions.d.ts +4 -1
  259. package/dist/cli/services/agent-definitions.js +97 -56
  260. package/dist/cli/services/agent-definitions.js.map +1 -0
  261. package/dist/cli/services/agent-event-types.d.ts +148 -0
  262. package/dist/cli/services/agent-event-types.js +2 -0
  263. package/dist/cli/services/agent-event-types.js.map +1 -0
  264. package/dist/cli/services/agent-events.js +225 -162
  265. package/dist/cli/services/agent-events.js.map +1 -0
  266. package/dist/cli/services/agent-loop-iteration.d.ts +13 -0
  267. package/dist/cli/services/agent-loop-setup.d.ts +32 -0
  268. package/dist/cli/services/agent-loop-shell-summarize.d.ts +11 -0
  269. package/dist/cli/services/agent-loop-shell-summarize.js +94 -0
  270. package/dist/cli/services/agent-loop-shell-summarize.js.map +1 -0
  271. package/dist/cli/services/agent-loop-tools.d.ts +37 -0
  272. package/dist/cli/services/agent-loop-tools.js +243 -0
  273. package/dist/cli/services/agent-loop-tools.js.map +1 -0
  274. package/dist/cli/services/agent-loop-types.d.ts +52 -0
  275. package/dist/cli/services/agent-loop-types.js +25 -0
  276. package/dist/cli/services/agent-loop-types.js.map +1 -0
  277. package/dist/cli/services/agent-loop.d.ts +2 -2
  278. package/dist/cli/services/agent-loop.js +1135 -702
  279. package/dist/cli/services/agent-loop.js.map +1 -0
  280. package/dist/cli/services/agent-worker-base-api.d.ts +19 -0
  281. package/dist/cli/services/agent-worker-base-helpers.d.ts +27 -0
  282. package/dist/cli/services/agent-worker-base-tools.d.ts +16 -0
  283. package/dist/cli/services/agent-worker-base-types.d.ts +81 -0
  284. package/dist/cli/services/agent-worker-base.d.ts +35 -5
  285. package/dist/cli/services/agent-worker-base.js +337 -153
  286. package/dist/cli/services/agent-worker-base.js.map +1 -0
  287. package/dist/cli/services/api-retry.js +69 -64
  288. package/dist/cli/services/api-retry.js.map +1 -0
  289. package/dist/cli/services/auth-service.d.ts +3 -3
  290. package/dist/cli/services/auth-service.js +213 -136
  291. package/dist/cli/services/auth-service.js.map +1 -0
  292. package/dist/cli/services/background-agents.d.ts +26 -0
  293. package/dist/cli/services/background-processes-ops.d.ts +24 -0
  294. package/dist/cli/services/background-processes.d.ts +2 -1
  295. package/dist/cli/services/background-processes.js +347 -267
  296. package/dist/cli/services/background-processes.js.map +1 -0
  297. package/dist/cli/services/background-tool-defs.d.ts +50 -0
  298. package/dist/cli/services/browser-auth.d.ts +2 -2
  299. package/dist/cli/services/browser-auth.js +159 -118
  300. package/dist/cli/services/browser-auth.js.map +1 -0
  301. package/dist/cli/services/claude-md-loader.js +40 -36
  302. package/dist/cli/services/claude-md-loader.js.map +1 -0
  303. package/dist/cli/services/cli-agent-loop.d.ts +41 -0
  304. package/dist/cli/services/cli-agent-loop.js +104 -0
  305. package/dist/cli/services/cli-agent-loop.js.map +1 -0
  306. package/dist/cli/services/config-modules-model.test.js +133 -0
  307. package/dist/cli/services/config-modules-permission.test.js +85 -0
  308. package/dist/cli/services/config-modules-permissions.test.js +85 -0
  309. package/dist/cli/services/config-modules-session.test.js +297 -0
  310. package/dist/cli/services/config-store.d.ts +14 -4
  311. package/dist/cli/services/config-store.js +249 -117
  312. package/dist/cli/services/config-store.js.map +1 -0
  313. package/dist/cli/services/debug-log.d.ts +1 -1
  314. package/dist/cli/services/debug-log.js +34 -35
  315. package/dist/cli/services/debug-log.js.map +1 -0
  316. package/dist/cli/services/env-detect.d.ts +7 -0
  317. package/dist/cli/services/env-detect.js +9 -0
  318. package/dist/cli/services/env-detect.js.map +1 -0
  319. package/dist/cli/services/error-logger-internals.d.ts +25 -0
  320. package/dist/cli/services/error-logger-internals.js +111 -0
  321. package/dist/cli/services/error-logger-internals.js.map +1 -0
  322. package/dist/cli/services/error-logger.js +187 -169
  323. package/dist/cli/services/error-logger.js.map +1 -0
  324. package/dist/cli/services/file-history.d.ts +1 -1
  325. package/dist/cli/services/file-history.js +50 -54
  326. package/dist/cli/services/file-history.js.map +1 -0
  327. package/dist/cli/services/format-server-response-columns.test.js +265 -0
  328. package/dist/cli/services/format-server-response-fallback.test.js +65 -0
  329. package/dist/cli/services/format-server-response-formatters.d.ts +18 -0
  330. package/dist/cli/services/format-server-response-formatters.js +195 -0
  331. package/dist/cli/services/format-server-response-formatters.js.map +1 -0
  332. package/dist/cli/services/format-server-response-primitives-basic.test.js +261 -0
  333. package/dist/cli/services/format-server-response-primitives-nested.test.js +188 -0
  334. package/dist/cli/services/format-server-response-primitives.test.js +300 -0
  335. package/dist/cli/services/format-server-response-realworld.test.js +248 -0
  336. package/dist/cli/services/format-server-response-values.test.js +247 -0
  337. package/dist/cli/services/format-server-response.js +334 -372
  338. package/dist/cli/services/format-server-response.js.map +1 -0
  339. package/dist/cli/services/git-context.js +61 -45
  340. package/dist/cli/services/git-context.js.map +1 -0
  341. package/dist/cli/services/hooks-execute.d.ts +47 -0
  342. package/dist/cli/services/hooks-execute.js +181 -0
  343. package/dist/cli/services/hooks-execute.js.map +1 -0
  344. package/dist/cli/services/hooks-runners.test.js +184 -0
  345. package/dist/cli/services/hooks.d.ts +2 -2
  346. package/dist/cli/services/hooks.glob-load.test.js +233 -0
  347. package/dist/cli/services/hooks.js +195 -180
  348. package/dist/cli/services/hooks.js.map +1 -0
  349. package/dist/cli/services/hooks.run-hooks.test.js +184 -0
  350. package/dist/cli/services/hooks.test.js +233 -0
  351. package/dist/cli/services/ink-incremental.d.ts +19 -0
  352. package/dist/cli/services/ink-incremental.js +59 -0
  353. package/dist/cli/services/ink-incremental.js.map +1 -0
  354. package/dist/cli/services/ink-resize-fix.js +54 -44
  355. package/dist/cli/services/ink-resize-fix.js.map +1 -0
  356. package/dist/cli/services/ink-sync-output.d.ts +12 -0
  357. package/dist/cli/services/ink-sync-output.js +16 -0
  358. package/dist/cli/services/ink-sync-output.js.map +1 -0
  359. package/dist/cli/services/interactive-tool-defs.d.ts +80 -0
  360. package/dist/cli/services/interactive-tools.d.ts +5 -2
  361. package/dist/cli/services/interactive-tools.js +283 -213
  362. package/dist/cli/services/interactive-tools.js.map +1 -0
  363. package/dist/cli/services/keybinding-manager.d.ts +13 -1
  364. package/dist/cli/services/keybinding-manager.js +131 -63
  365. package/dist/cli/services/keybinding-manager.js.map +1 -0
  366. package/dist/cli/services/local-tools-agent-defs-tasks.d.ts +6 -0
  367. package/dist/cli/services/local-tools-agent-defs-tasks.js +245 -0
  368. package/dist/cli/services/local-tools-agent-defs-tasks.js.map +1 -0
  369. package/dist/cli/services/local-tools-agent-defs-utils.d.ts +6 -0
  370. package/dist/cli/services/local-tools-agent-defs-utils.js +198 -0
  371. package/dist/cli/services/local-tools-agent-defs-utils.js.map +1 -0
  372. package/dist/cli/services/local-tools-agent-defs.d.ts +10 -0
  373. package/dist/cli/services/local-tools-agent-defs.js +13 -0
  374. package/dist/cli/services/local-tools-agent-defs.js.map +1 -0
  375. package/dist/cli/services/local-tools-definitions.d.ts +6 -0
  376. package/dist/cli/services/local-tools-files.test.js +256 -0
  377. package/dist/cli/services/local-tools-read-many.d.ts +6 -0
  378. package/dist/cli/services/local-tools.d.ts +1 -1
  379. package/dist/cli/services/local-tools.js +938 -657
  380. package/dist/cli/services/local-tools.js.map +1 -0
  381. package/dist/cli/services/lsp-config.d.ts +13 -0
  382. package/dist/cli/services/lsp-config.js +72 -0
  383. package/dist/cli/services/lsp-config.js.map +1 -0
  384. package/dist/cli/services/lsp-formatters.d.ts +11 -0
  385. package/dist/cli/services/lsp-formatters.js +209 -0
  386. package/dist/cli/services/lsp-formatters.js.map +1 -0
  387. package/dist/cli/services/lsp-manager.js +757 -594
  388. package/dist/cli/services/lsp-manager.js.map +1 -0
  389. package/dist/cli/services/lsp-protocol.d.ts +9 -0
  390. package/dist/cli/services/lsp-protocol.js +40 -0
  391. package/dist/cli/services/lsp-protocol.js.map +1 -0
  392. package/dist/cli/services/lsp-server-docs.d.ts +8 -0
  393. package/dist/cli/services/lsp-server-docs.js +132 -0
  394. package/dist/cli/services/lsp-server-docs.js.map +1 -0
  395. package/dist/cli/services/lsp-server-documents.d.ts +8 -0
  396. package/dist/cli/services/lsp-server-documents.js +132 -0
  397. package/dist/cli/services/lsp-server-documents.js.map +1 -0
  398. package/dist/cli/services/lsp-server.d.ts +40 -0
  399. package/dist/cli/services/lsp-server.js +270 -0
  400. package/dist/cli/services/lsp-server.js.map +1 -0
  401. package/dist/cli/services/mcp-client.d.ts +1 -1
  402. package/dist/cli/services/mcp-client.js +173 -134
  403. package/dist/cli/services/mcp-client.js.map +1 -0
  404. package/dist/cli/services/memory-manager.js +53 -40
  405. package/dist/cli/services/memory-manager.js.map +1 -0
  406. package/dist/cli/services/model-manager.js +55 -40
  407. package/dist/cli/services/model-manager.js.map +1 -0
  408. package/dist/cli/services/model-router.js +115 -85
  409. package/dist/cli/services/model-router.js.map +1 -0
  410. package/dist/cli/services/model-router.test.js +245 -0
  411. package/dist/cli/services/paths.d.ts +30 -0
  412. package/dist/cli/services/paths.js +81 -0
  413. package/dist/cli/services/paths.js.map +1 -0
  414. package/dist/cli/services/permission-modes.js +45 -25
  415. package/dist/cli/services/permission-modes.js.map +1 -0
  416. package/dist/cli/services/project-index.d.ts +41 -0
  417. package/dist/cli/services/project-index.js +286 -0
  418. package/dist/cli/services/project-index.js.map +1 -0
  419. package/dist/cli/services/rewind-rewindTo.test.js +202 -0
  420. package/dist/cli/services/rewind.js +182 -168
  421. package/dist/cli/services/rewind.js.map +1 -0
  422. package/dist/cli/services/rewind.test.js +175 -0
  423. package/dist/cli/services/ripgrep.js +115 -115
  424. package/dist/cli/services/ripgrep.js.map +1 -0
  425. package/dist/cli/services/sandbox.d.ts +1 -1
  426. package/dist/cli/services/sandbox.js +58 -37
  427. package/dist/cli/services/sandbox.js.map +1 -0
  428. package/dist/cli/services/sandbox.test.js +198 -0
  429. package/dist/cli/services/server-tools-client.d.ts +46 -0
  430. package/dist/cli/services/server-tools-client.js +211 -0
  431. package/dist/cli/services/server-tools-client.js.map +1 -0
  432. package/dist/cli/services/server-tools-media.d.ts +21 -0
  433. package/dist/cli/services/server-tools-media.js +163 -0
  434. package/dist/cli/services/server-tools-media.js.map +1 -0
  435. package/dist/cli/services/server-tools-preprocess.d.ts +23 -0
  436. package/dist/cli/services/server-tools-preprocess.js +386 -0
  437. package/dist/cli/services/server-tools-preprocess.js.map +1 -0
  438. package/dist/cli/services/server-tools.d.ts +2 -0
  439. package/dist/cli/services/server-tools.js +763 -565
  440. package/dist/cli/services/server-tools.js.map +1 -0
  441. package/dist/cli/services/session-client.d.ts +78 -0
  442. package/dist/cli/services/session-client.js +197 -0
  443. package/dist/cli/services/session-client.js.map +1 -0
  444. package/dist/cli/services/session-persistence.d.ts +3 -0
  445. package/dist/cli/services/session-persistence.js +81 -74
  446. package/dist/cli/services/session-persistence.js.map +1 -0
  447. package/dist/cli/services/subagent-execution.d.ts +12 -0
  448. package/dist/cli/services/subagent-loop-v2.d.ts +36 -0
  449. package/dist/cli/services/subagent-loop-v2.js +238 -0
  450. package/dist/cli/services/subagent-loop-v2.js.map +1 -0
  451. package/dist/cli/services/subagent-tools.d.ts +10 -0
  452. package/dist/cli/services/subagent-tools.js +96 -0
  453. package/dist/cli/services/subagent-tools.js.map +1 -0
  454. package/dist/cli/services/subagent-types.d.ts +57 -0
  455. package/dist/cli/services/subagent-types.js +218 -0
  456. package/dist/cli/services/subagent-types.js.map +1 -0
  457. package/dist/cli/services/subagent-worker.js +42 -27
  458. package/dist/cli/services/subagent-worker.js.map +1 -0
  459. package/dist/cli/services/subagent.d.ts +2 -0
  460. package/dist/cli/services/subagent.js +606 -433
  461. package/dist/cli/services/subagent.js.map +1 -0
  462. package/dist/cli/services/system-prompt.js +111 -80
  463. package/dist/cli/services/system-prompt.js.map +1 -0
  464. package/dist/cli/services/task-decomposer.d.ts +1 -1
  465. package/dist/cli/services/task-decomposer.js +172 -139
  466. package/dist/cli/services/task-decomposer.js.map +1 -0
  467. package/dist/cli/services/team-lead-auto.d.ts +11 -0
  468. package/dist/cli/services/team-lead-execution.d.ts +28 -0
  469. package/dist/cli/services/team-lead-types.d.ts +37 -0
  470. package/dist/cli/services/team-lead-types.js +2 -0
  471. package/dist/cli/services/team-lead-types.js.map +1 -0
  472. package/dist/cli/services/team-lead.d.ts +62 -2
  473. package/dist/cli/services/team-lead.js +863 -528
  474. package/dist/cli/services/team-lead.js.map +1 -0
  475. package/dist/cli/services/team-state-members.d.ts +11 -0
  476. package/dist/cli/services/team-state-members.js +185 -0
  477. package/dist/cli/services/team-state-members.js.map +1 -0
  478. package/dist/cli/services/team-state-messaging.d.ts +16 -0
  479. package/dist/cli/services/team-state-messaging.js +90 -0
  480. package/dist/cli/services/team-state-messaging.js.map +1 -0
  481. package/dist/cli/services/team-state-tasks.d.ts +12 -0
  482. package/dist/cli/services/team-state-tasks.js +23 -0
  483. package/dist/cli/services/team-state-tasks.js.map +1 -0
  484. package/dist/cli/services/team-state-types.d.ts +54 -0
  485. package/dist/cli/services/team-state-types.js +129 -0
  486. package/dist/cli/services/team-state-types.js.map +1 -0
  487. package/dist/cli/services/team-state.d.ts +5 -0
  488. package/dist/cli/services/team-state.js +348 -319
  489. package/dist/cli/services/team-state.js.map +1 -0
  490. package/dist/cli/services/teammate-loop.js +557 -0
  491. package/dist/cli/services/teammate-loop.js.map +1 -0
  492. package/dist/cli/services/teammate-prompt.d.ts +2 -0
  493. package/dist/cli/services/teammate-prompt.js +68 -0
  494. package/dist/cli/services/teammate-prompt.js.map +1 -0
  495. package/dist/cli/services/teammate-tools.d.ts +6 -0
  496. package/dist/cli/services/teammate-tools.js +158 -0
  497. package/dist/cli/services/teammate-tools.js.map +1 -0
  498. package/dist/cli/services/teammate-types.d.ts +36 -0
  499. package/dist/cli/services/teammate-types.js +43 -0
  500. package/dist/cli/services/teammate-types.js.map +1 -0
  501. package/dist/cli/services/teammate-worker-helpers.d.ts +71 -0
  502. package/dist/cli/services/teammate-worker-helpers.js +183 -0
  503. package/dist/cli/services/teammate-worker-helpers.js.map +1 -0
  504. package/dist/cli/services/teammate-worker-task-cleanup.d.ts +27 -0
  505. package/dist/cli/services/teammate-worker-task-cleanup.js +91 -0
  506. package/dist/cli/services/teammate-worker-task-cleanup.js.map +1 -0
  507. package/dist/cli/services/teammate-worker-task-loop.d.ts +35 -0
  508. package/dist/cli/services/teammate-worker-task-loop.js +273 -0
  509. package/dist/cli/services/teammate-worker-task-loop.js.map +1 -0
  510. package/dist/cli/services/teammate-worker.d.ts +13 -0
  511. package/dist/cli/services/teammate-worker.js +294 -0
  512. package/dist/cli/services/teammate-worker.js.map +1 -0
  513. package/dist/cli/services/teammate.d.ts +8 -2
  514. package/dist/cli/services/teammate.js +857 -569
  515. package/dist/cli/services/teammate.js.map +1 -0
  516. package/dist/cli/services/telemetry-spans.d.ts +17 -0
  517. package/dist/cli/services/telemetry-spans.js +172 -0
  518. package/dist/cli/services/telemetry-spans.js.map +1 -0
  519. package/dist/cli/services/telemetry.d.ts +6 -1
  520. package/dist/cli/services/telemetry.js +180 -157
  521. package/dist/cli/services/telemetry.js.map +1 -0
  522. package/dist/cli/services/tools/__tests__/agent-tools-tasks-teams.test.js +250 -0
  523. package/dist/cli/services/tools/__tests__/agent-tools-teams.test.js +200 -0
  524. package/dist/cli/services/tools/__tests__/agent-tools.test.js +340 -0
  525. package/dist/cli/services/tools/__tests__/file-ops-cache.test.js +152 -0
  526. package/dist/cli/services/tools/__tests__/file-ops-notebook.test.js +249 -0
  527. package/dist/cli/services/tools/__tests__/file-ops-read.test.js +261 -0
  528. package/dist/cli/services/tools/__tests__/file-ops-write.test.js +292 -0
  529. package/dist/cli/services/tools/__tests__/search-tools-rg.test.js +92 -0
  530. package/dist/cli/services/tools/__tests__/search-tools.part2.test.js +174 -0
  531. package/dist/cli/services/tools/__tests__/search-tools.test.js +227 -0
  532. package/dist/cli/services/tools/__tests__/shell-exec-allowed-core.test.js +163 -0
  533. package/dist/cli/services/tools/__tests__/shell-exec-allowed-extended.test.js +220 -0
  534. package/dist/cli/services/tools/__tests__/shell-exec-allowed.part2.test.js +215 -0
  535. package/dist/cli/services/tools/__tests__/shell-exec-allowed.test.js +154 -0
  536. package/dist/cli/services/tools/__tests__/shell-exec-blocked.test.js +132 -0
  537. package/dist/cli/services/tools/__tests__/shell-exec-execution.test.js +245 -0
  538. package/dist/cli/services/tools/__tests__/task-manager-create.test.js +110 -0
  539. package/dist/cli/services/tools/__tests__/task-manager-crud.test.js +339 -0
  540. package/dist/cli/services/tools/__tests__/task-manager-list-get.test.js +343 -0
  541. package/dist/cli/services/tools/__tests__/task-manager-query.test.js +346 -0
  542. package/dist/cli/services/tools/__tests__/task-manager-routing.test.js +58 -0
  543. package/dist/cli/services/tools/__tests__/task-manager-update.test.js +224 -0
  544. package/dist/cli/services/tools/__tests__/task-manager.test.js +159 -0
  545. package/dist/cli/services/tools/__tests__/web-tools-html-search.test.js +227 -0
  546. package/dist/cli/services/tools/__tests__/web-tools.test.js +285 -0
  547. package/dist/cli/services/tools/agent-tools-tasks.d.ts +10 -0
  548. package/dist/cli/services/tools/agent-tools-tasks.js +216 -0
  549. package/dist/cli/services/tools/agent-tools-tasks.js.map +1 -0
  550. package/dist/cli/services/tools/agent-tools-team.d.ts +8 -0
  551. package/dist/cli/services/tools/agent-tools-team.js +101 -0
  552. package/dist/cli/services/tools/agent-tools-team.js.map +1 -0
  553. package/dist/cli/services/tools/agent-tools.d.ts +3 -3
  554. package/dist/cli/services/tools/agent-tools.js +555 -324
  555. package/dist/cli/services/tools/agent-tools.js.map +1 -0
  556. package/dist/cli/services/tools/file-ops-notebook.d.ts +9 -0
  557. package/dist/cli/services/tools/file-ops-notebook.js +186 -0
  558. package/dist/cli/services/tools/file-ops-notebook.js.map +1 -0
  559. package/dist/cli/services/tools/file-ops-read.d.ts +11 -0
  560. package/dist/cli/services/tools/file-ops-read.js +237 -0
  561. package/dist/cli/services/tools/file-ops-read.js.map +1 -0
  562. package/dist/cli/services/tools/file-ops-write.d.ts +8 -0
  563. package/dist/cli/services/tools/file-ops-write.js +260 -0
  564. package/dist/cli/services/tools/file-ops-write.js.map +1 -0
  565. package/dist/cli/services/tools/file-ops.d.ts +1 -0
  566. package/dist/cli/services/tools/file-ops.js +727 -447
  567. package/dist/cli/services/tools/file-ops.js.map +1 -0
  568. package/dist/cli/services/tools/html-to-text.d.ts +6 -0
  569. package/dist/cli/services/tools/html-to-text.js +118 -0
  570. package/dist/cli/services/tools/html-to-text.js.map +1 -0
  571. package/dist/cli/services/tools/search-tools.js +231 -162
  572. package/dist/cli/services/tools/search-tools.js.map +1 -0
  573. package/dist/cli/services/tools/shell-exec.js +197 -151
  574. package/dist/cli/services/tools/shell-exec.js.map +1 -0
  575. package/dist/cli/services/tools/shell-exec.test.js +148 -0
  576. package/dist/cli/services/tools/ssrf-guard.d.ts +6 -0
  577. package/dist/cli/services/tools/ssrf-guard.js +80 -0
  578. package/dist/cli/services/tools/ssrf-guard.js.map +1 -0
  579. package/dist/cli/services/tools/task-manager.js +206 -173
  580. package/dist/cli/services/tools/task-manager.js.map +1 -0
  581. package/dist/cli/services/tools/web-tools.js +388 -341
  582. package/dist/cli/services/tools/web-tools.js.map +1 -0
  583. package/dist/cli/setup/SetupApp.d.ts +2 -2
  584. package/dist/cli/setup/SetupApp.js +608 -160
  585. package/dist/cli/setup/SetupApp.js.map +1 -0
  586. package/dist/cli/setup/SetupComponents.d.ts +10 -0
  587. package/dist/cli/setup/SetupComponents.js +144 -0
  588. package/dist/cli/setup/SetupComponents.js.map +1 -0
  589. package/dist/cli/setup/setup-cli-targets.d.ts +9 -0
  590. package/dist/cli/setup/setup-cli-targets.js +49 -0
  591. package/dist/cli/setup/setup-cli-targets.js.map +1 -0
  592. package/dist/cli/shared/ErrorBoundary.d.ts +22 -0
  593. package/dist/cli/shared/ErrorBoundary.js +73 -0
  594. package/dist/cli/shared/ErrorBoundary.js.map +1 -0
  595. package/dist/cli/shared/InlineErrorBoundary.d.ts +22 -0
  596. package/dist/cli/shared/InlineErrorBoundary.js +35 -0
  597. package/dist/cli/shared/InlineErrorBoundary.js.map +1 -0
  598. package/dist/cli/shared/MatrixIntro.js +67 -69
  599. package/dist/cli/shared/MatrixIntro.js.map +1 -0
  600. package/dist/cli/shared/SharedTick.d.ts +10 -0
  601. package/dist/cli/shared/SpinnerSlot.d.ts +22 -0
  602. package/dist/cli/shared/SpinnerSlot.js +156 -0
  603. package/dist/cli/shared/SpinnerSlot.js.map +1 -0
  604. package/dist/cli/shared/Theme.d.ts +1 -1
  605. package/dist/cli/shared/Theme.js +136 -92
  606. package/dist/cli/shared/Theme.js.map +1 -0
  607. package/dist/cli/shared/WhaleBanner.js +100 -11
  608. package/dist/cli/shared/WhaleBanner.js.map +1 -0
  609. package/dist/cli/shared/__tests__/markdown.test.js +188 -0
  610. package/dist/cli/shared/format-utils.d.ts +16 -0
  611. package/dist/cli/shared/format-utils.js +121 -0
  612. package/dist/cli/shared/format-utils.js.map +1 -0
  613. package/dist/cli/shared/markdown-chart.d.ts +8 -0
  614. package/dist/cli/shared/markdown-chart.js +92 -0
  615. package/dist/cli/shared/markdown-chart.js.map +1 -0
  616. package/dist/cli/shared/markdown-diff.d.ts +15 -0
  617. package/dist/cli/shared/markdown-diff.js +205 -0
  618. package/dist/cli/shared/markdown-diff.js.map +1 -0
  619. package/dist/cli/shared/markdown-helpers.d.ts +33 -0
  620. package/dist/cli/shared/markdown-helpers.js +129 -0
  621. package/dist/cli/shared/markdown-helpers.js.map +1 -0
  622. package/dist/cli/shared/markdown-table.d.ts +10 -0
  623. package/dist/cli/shared/markdown-table.js +227 -0
  624. package/dist/cli/shared/markdown-table.js.map +1 -0
  625. package/dist/cli/shared/markdown.d.ts +2 -4
  626. package/dist/cli/shared/markdown.js +658 -703
  627. package/dist/cli/shared/markdown.js.map +1 -0
  628. package/dist/cli/shared/marked-terminal.d.js +2 -0
  629. package/dist/cli/shared/marked-terminal.d.js.map +1 -0
  630. package/dist/cli/shared/theme-manager.js +99 -90
  631. package/dist/cli/shared/theme-manager.js.map +1 -0
  632. package/dist/cli/shared/theme-presets.js +256 -254
  633. package/dist/cli/shared/theme-presets.js.map +1 -0
  634. package/dist/cli/shared/useLatestRef.d.ts +11 -0
  635. package/dist/cli/shared/useLatestRef.js +34 -0
  636. package/dist/cli/shared/useLatestRef.js.map +1 -0
  637. package/dist/cli/shared/useSyncState.d.ts +11 -0
  638. package/dist/cli/shared/useSyncState.js +39 -0
  639. package/dist/cli/shared/useSyncState.js.map +1 -0
  640. package/dist/cli/status/StatusApp.js +235 -86
  641. package/dist/cli/status/StatusApp.js.map +1 -0
  642. package/dist/cli/stores/StoreApp.js +278 -66
  643. package/dist/cli/stores/StoreApp.js.map +1 -0
  644. package/dist/index-agent.d.ts +11 -0
  645. package/dist/index-agent.js +83 -0
  646. package/dist/index-agent.js.map +1 -0
  647. package/dist/index-auth.d.ts +22 -0
  648. package/dist/index-auth.js +114 -0
  649. package/dist/index-auth.js.map +1 -0
  650. package/dist/index-handlers.d.ts +25 -0
  651. package/dist/index-handlers.js +164 -0
  652. package/dist/index-handlers.js.map +1 -0
  653. package/dist/index-tools.d.ts +22 -0
  654. package/dist/index-tools.js +115 -0
  655. package/dist/index-tools.js.map +1 -0
  656. package/dist/index.d.ts +2 -2
  657. package/dist/index.js +509 -396
  658. package/dist/index.js.map +1 -0
  659. package/dist/local-agent/__tests__/connection-disconnect.test.js +201 -0
  660. package/dist/local-agent/__tests__/connection-lifecycle.test.js +289 -0
  661. package/dist/local-agent/__tests__/connection-msghandling.test.js +311 -0
  662. package/dist/local-agent/__tests__/connection-reconnect.test.js +230 -0
  663. package/dist/local-agent/__tests__/connection-toolexec.test.js +253 -0
  664. package/dist/local-agent/__tests__/discovery.test.js +328 -0
  665. package/dist/local-agent/__tests__/executor-background.test.js +219 -0
  666. package/dist/local-agent/__tests__/executor-exec.test.js +221 -0
  667. package/dist/local-agent/__tests__/executor-jobs-sessions.test.js +220 -0
  668. package/dist/local-agent/__tests__/executor-system-info.test.js +133 -0
  669. package/dist/local-agent/__tests__/executor-systeminfo.test.js +109 -0
  670. package/dist/local-agent/__tests__/executor.test.js +235 -0
  671. package/dist/local-agent/__tests__/index.test.js +139 -0
  672. package/dist/local-agent/connection-handlers.d.ts +8 -0
  673. package/dist/local-agent/connection-handlers.js +112 -0
  674. package/dist/local-agent/connection-handlers.js.map +1 -0
  675. package/dist/local-agent/connection-tools.d.ts +8 -0
  676. package/dist/local-agent/connection-tools.js +111 -0
  677. package/dist/local-agent/connection-tools.js.map +1 -0
  678. package/dist/local-agent/connection.d.ts +2 -2
  679. package/dist/local-agent/connection.js +352 -293
  680. package/dist/local-agent/connection.js.map +1 -0
  681. package/dist/local-agent/discovery.js +259 -122
  682. package/dist/local-agent/discovery.js.map +1 -0
  683. package/dist/local-agent/executor-jobs.d.ts +12 -0
  684. package/dist/local-agent/executor-jobs.js +143 -0
  685. package/dist/local-agent/executor-jobs.js.map +1 -0
  686. package/dist/local-agent/executor.d.ts +3 -0
  687. package/dist/local-agent/executor.js +218 -195
  688. package/dist/local-agent/executor.js.map +1 -0
  689. package/dist/local-agent/index.d.ts +2 -2
  690. package/dist/local-agent/index.js +156 -156
  691. package/dist/local-agent/index.js.map +1 -0
  692. package/dist/node/__tests__/cli-channels.test.js +293 -0
  693. package/dist/node/__tests__/cli-config-edge.test.js +154 -0
  694. package/dist/node/__tests__/cli-config.test.js +215 -0
  695. package/dist/node/__tests__/config.test.js +292 -0
  696. package/dist/node/__tests__/runtime-heartbeat.test.js +153 -0
  697. package/dist/node/__tests__/runtime-lifecycle-init.test.js +263 -0
  698. package/dist/node/__tests__/runtime-lifecycle-stats.test.js +180 -0
  699. package/dist/node/__tests__/runtime-lifecycle.test.js +305 -0
  700. package/dist/node/__tests__/runtime-relay.test.js +341 -0
  701. package/dist/node/adapters/__tests__/base.test.js +286 -0
  702. package/dist/node/adapters/__tests__/discord.test.js +284 -0
  703. package/dist/node/adapters/__tests__/email-send.test.js +295 -0
  704. package/dist/node/adapters/__tests__/email.inbound-send.test.js +217 -0
  705. package/dist/node/adapters/__tests__/email.lifecycle.test.js +211 -0
  706. package/dist/node/adapters/__tests__/email.test.js +290 -0
  707. package/dist/node/adapters/__tests__/email.webhook-send.test.js +251 -0
  708. package/dist/node/adapters/__tests__/imessage-filter.test.js +183 -0
  709. package/dist/node/adapters/__tests__/imessage-lifecycle.test.js +215 -0
  710. package/dist/node/adapters/__tests__/imessage-send-restart.test.js +227 -0
  711. package/dist/node/adapters/__tests__/slack.part2.test.js +135 -0
  712. package/dist/node/adapters/__tests__/slack.test.js +241 -0
  713. package/dist/node/adapters/__tests__/sms-extras.test.js +108 -0
  714. package/dist/node/adapters/__tests__/sms-lifecycle.test.js +203 -0
  715. package/dist/node/adapters/__tests__/sms-messaging.test.js +266 -0
  716. package/dist/node/adapters/__tests__/sms.part2.test.js +174 -0
  717. package/dist/node/adapters/__tests__/sms.test.js +253 -0
  718. package/dist/node/adapters/__tests__/telegram-polling.test.js +256 -0
  719. package/dist/node/adapters/__tests__/telegram-send.test.js +166 -0
  720. package/dist/node/adapters/__tests__/webchat-inbound.test.js +188 -0
  721. package/dist/node/adapters/__tests__/webchat-outbound.test.js +178 -0
  722. package/dist/node/adapters/__tests__/whatsapp-inbound.test.js +200 -0
  723. package/dist/node/adapters/__tests__/whatsapp-send.test.js +212 -0
  724. package/dist/node/adapters/__tests__/whatsapp.test.js +280 -0
  725. package/dist/node/adapters/base.js +18 -8
  726. package/dist/node/adapters/base.js.map +1 -0
  727. package/dist/node/adapters/discord-gateway.d.ts +42 -0
  728. package/dist/node/adapters/discord-gateway.js +169 -0
  729. package/dist/node/adapters/discord-gateway.js.map +1 -0
  730. package/dist/node/adapters/discord.js +286 -275
  731. package/dist/node/adapters/discord.js.map +1 -0
  732. package/dist/node/adapters/email.js +189 -202
  733. package/dist/node/adapters/email.js.map +1 -0
  734. package/dist/node/adapters/imessage.d.ts +11 -0
  735. package/dist/node/adapters/imessage.js +165 -145
  736. package/dist/node/adapters/imessage.js.map +1 -0
  737. package/dist/node/adapters/slack.js +237 -236
  738. package/dist/node/adapters/slack.js.map +1 -0
  739. package/dist/node/adapters/sms.js +149 -151
  740. package/dist/node/adapters/sms.js.map +1 -0
  741. package/dist/node/adapters/telegram.js +88 -92
  742. package/dist/node/adapters/telegram.js.map +1 -0
  743. package/dist/node/adapters/webchat.js +160 -136
  744. package/dist/node/adapters/webchat.js.map +1 -0
  745. package/dist/node/adapters/whatsapp.js +212 -215
  746. package/dist/node/adapters/whatsapp.js.map +1 -0
  747. package/dist/node/cli-channels.d.ts +6 -0
  748. package/dist/node/cli-channels.js +229 -0
  749. package/dist/node/cli-channels.js.map +1 -0
  750. package/dist/node/cli-node.d.ts +9 -0
  751. package/dist/node/cli-node.js +186 -0
  752. package/dist/node/cli-node.js.map +1 -0
  753. package/dist/node/cli-portal.d.ts +11 -0
  754. package/dist/node/cli-portal.js +503 -0
  755. package/dist/node/cli-portal.js.map +1 -0
  756. package/dist/node/cli.js +884 -653
  757. package/dist/node/cli.js.map +1 -0
  758. package/dist/node/config.js +20 -18
  759. package/dist/node/config.js.map +1 -0
  760. package/dist/node/gateway-client.js +191 -181
  761. package/dist/node/gateway-client.js.map +1 -0
  762. package/dist/node/portal/clipboard.js +161 -130
  763. package/dist/node/portal/clipboard.js.map +1 -0
  764. package/dist/node/portal/discovery.js +51 -45
  765. package/dist/node/portal/discovery.js.map +1 -0
  766. package/dist/node/portal/forward.js +64 -58
  767. package/dist/node/portal/forward.js.map +1 -0
  768. package/dist/node/portal/index.js +246 -221
  769. package/dist/node/portal/index.js.map +1 -0
  770. package/dist/node/portal/multiplexer.js +192 -182
  771. package/dist/node/portal/multiplexer.js.map +1 -0
  772. package/dist/node/portal/permissions.js +102 -70
  773. package/dist/node/portal/permissions.js.map +1 -0
  774. package/dist/node/portal/portal-target.d.ts +16 -0
  775. package/dist/node/portal/portal-target.js +102 -0
  776. package/dist/node/portal/portal-target.js.map +1 -0
  777. package/dist/node/portal/protocol-frames.d.ts +33 -0
  778. package/dist/node/portal/protocol-frames.js +170 -0
  779. package/dist/node/portal/protocol-frames.js.map +1 -0
  780. package/dist/node/portal/protocol.js +153 -116
  781. package/dist/node/portal/protocol.js.map +1 -0
  782. package/dist/node/portal/screen.js +80 -69
  783. package/dist/node/portal/screen.js.map +1 -0
  784. package/dist/node/portal/session.js +124 -117
  785. package/dist/node/portal/session.js.map +1 -0
  786. package/dist/node/portal/shell.js +140 -113
  787. package/dist/node/portal/shell.js.map +1 -0
  788. package/dist/node/portal/stream.js +77 -75
  789. package/dist/node/portal/stream.js.map +1 -0
  790. package/dist/node/portal/transfer.js +190 -167
  791. package/dist/node/portal/transfer.js.map +1 -0
  792. package/dist/node/portal/ui.js +124 -99
  793. package/dist/node/portal/ui.js.map +1 -0
  794. package/dist/node/remote-desktop/compile-helper.js +50 -45
  795. package/dist/node/remote-desktop/compile-helper.js.map +1 -0
  796. package/dist/node/remote-desktop/index.js +215 -187
  797. package/dist/node/remote-desktop/index.js.map +1 -0
  798. package/dist/node/remote-desktop/protocol.js +45 -29
  799. package/dist/node/remote-desktop/protocol.js.map +1 -0
  800. package/dist/node/runtime-network.d.ts +25 -0
  801. package/dist/node/runtime-network.js +226 -0
  802. package/dist/node/runtime-network.js.map +1 -0
  803. package/dist/node/runtime-utils.d.ts +27 -0
  804. package/dist/node/runtime-utils.js +99 -0
  805. package/dist/node/runtime-utils.js.map +1 -0
  806. package/dist/node/runtime.d.ts +1 -0
  807. package/dist/node/runtime.js +562 -409
  808. package/dist/node/runtime.js.map +1 -0
  809. package/dist/node/task-runner.d.ts +33 -0
  810. package/dist/node/task-runner.js +276 -0
  811. package/dist/node/task-runner.js.map +1 -0
  812. package/dist/server/__tests__/gateway-fast-fail.test.js +160 -0
  813. package/dist/server/__tests__/local-agent-gateway.test.js +186 -0
  814. package/dist/server/__tests__/proxy-handlers-delegation.test.js +240 -0
  815. package/dist/server/__tests__/proxy-handlers-validation.test.js +211 -0
  816. package/dist/server/__tests__/proxy-handlers.part2.test.js +240 -0
  817. package/dist/server/__tests__/proxy-handlers.test.js +213 -0
  818. package/dist/server/__tests__/strip-base64-e2e.test.js +303 -0
  819. package/dist/server/__tests__/strip-base64.test.js +256 -0
  820. package/dist/server/__tests__/tool-router-agent-tools.test.js +324 -0
  821. package/dist/server/__tests__/tool-router-execute-core.test.js +357 -0
  822. package/dist/server/__tests__/tool-router-execute-permissions.test.js +332 -0
  823. package/dist/server/__tests__/tool-router-execute.test.js +348 -0
  824. package/dist/server/__tests__/tool-router-load.test.js +432 -0
  825. package/dist/server/__tests__/tool-router-permissions.test.js +359 -0
  826. package/dist/server/__tests__/tool-router-registry-cache.test.js +383 -0
  827. package/dist/server/__tests__/tool-router-registry-handlers.test.js +272 -0
  828. package/dist/server/__tests__/tool-router-registry.test.js +331 -0
  829. package/dist/server/__tests__/validation-inventory.test.js +250 -0
  830. package/dist/server/__tests__/validation-misc.test.js +243 -0
  831. package/dist/server/__tests__/validation-supply-chain.test.js +188 -0
  832. package/dist/server/__tests__/worker.test.js +265 -0
  833. package/dist/server/handlers/__test-utils__/test-db.d.ts +2 -0
  834. package/dist/server/handlers/__test-utils__/test-db.js +52 -89
  835. package/dist/server/handlers/__test-utils__/test-db.js.map +1 -0
  836. package/dist/server/handlers/__tests__/conversation-lock.test.js +117 -0
  837. package/dist/server/handlers/__tests__/e2e/auth-cross-platform-login.e2e.test.js +268 -0
  838. package/dist/server/handlers/__tests__/e2e/auth-cross-platform-tokens.e2e.test.js +264 -0
  839. package/dist/server/handlers/__tests__/e2e/email-pipeline-send.e2e.test.js +214 -0
  840. package/dist/server/handlers/__tests__/e2e/email-pipeline-threads.e2e.test.js +168 -0
  841. package/dist/server/handlers/__tests__/e2e/error-logging-pipeline-dedup.e2e.test.js +229 -0
  842. package/dist/server/handlers/__tests__/e2e/error-logging-pipeline.e2e.test.js +239 -0
  843. package/dist/server/handlers/__tests__/e2e/error-logging-rate-limit.e2e.test.js +150 -0
  844. package/dist/server/handlers/__tests__/e2e/inventory-sync-guards.e2e.test.js +177 -0
  845. package/dist/server/handlers/__tests__/e2e/inventory-sync.e2e.test.js +228 -0
  846. package/dist/server/handlers/__tests__/e2e/inventory-sync.part2.e2e.test.js +188 -0
  847. package/dist/server/handlers/__tests__/e2e/order-lifecycle-fulfillment.e2e.test.js +295 -0
  848. package/dist/server/handlers/__tests__/e2e/order-lifecycle.e2e.test.js +277 -0
  849. package/dist/server/handlers/__tests__/e2e/order-lifecycle.fulfillment.e2e.test.js +307 -0
  850. package/dist/server/handlers/__tests__/e2e/order-lifecycle.setup.e2e.test.js +177 -0
  851. package/dist/server/handlers/__tests__/e2e/storefront-checkout-cart.e2e.test.js +255 -0
  852. package/dist/server/handlers/__tests__/e2e/storefront-checkout-webhook.e2e.test.js +231 -0
  853. package/dist/server/handlers/__tests__/e2e/workflow-execution-failures.e2e.test.js +235 -0
  854. package/dist/server/handlers/__tests__/e2e/workflow-execution.e2e.test.js +294 -0
  855. package/dist/server/handlers/__tests__/e2e/workflow-security.e2e.test.js +311 -0
  856. package/dist/server/handlers/__tests__/e2e/workflow-security.part2.e2e.test.js +267 -0
  857. package/dist/server/handlers/__tests__/workflow-cache.test.js +237 -0
  858. package/dist/server/handlers/analytics-errors-edge.test.js +173 -0
  859. package/dist/server/handlers/analytics.js +553 -260
  860. package/dist/server/handlers/analytics.js.map +1 -0
  861. package/dist/server/handlers/analytics.test.js +280 -0
  862. package/dist/server/handlers/api-docs-examples-ext.d.ts +9 -0
  863. package/dist/server/handlers/api-docs-examples-ext.js +278 -0
  864. package/dist/server/handlers/api-docs-examples-ext.js.map +1 -0
  865. package/dist/server/handlers/api-docs-examples.d.ts +8 -0
  866. package/dist/server/handlers/api-docs-examples.js +221 -0
  867. package/dist/server/handlers/api-docs-examples.js.map +1 -0
  868. package/dist/server/handlers/api-docs-sections-ext.d.ts +2 -0
  869. package/dist/server/handlers/api-docs-sections-ext.js +497 -0
  870. package/dist/server/handlers/api-docs-sections-ext.js.map +1 -0
  871. package/dist/server/handlers/api-docs-sections.d.ts +21 -0
  872. package/dist/server/handlers/api-docs-sections.js +293 -0
  873. package/dist/server/handlers/api-docs-sections.js.map +1 -0
  874. package/dist/server/handlers/api-docs.d.ts +2 -0
  875. package/dist/server/handlers/api-docs.js +1205 -893
  876. package/dist/server/handlers/api-docs.js.map +1 -0
  877. package/dist/server/handlers/api-keys.js +291 -242
  878. package/dist/server/handlers/api-keys.js.map +1 -0
  879. package/dist/server/handlers/api-keys.part2.test.js +157 -0
  880. package/dist/server/handlers/api-keys.test.js +161 -0
  881. package/dist/server/handlers/billing-core.d.ts +28 -0
  882. package/dist/server/handlers/billing-core.js +126 -0
  883. package/dist/server/handlers/billing-core.js.map +1 -0
  884. package/dist/server/handlers/billing-routes.d.ts +9 -0
  885. package/dist/server/handlers/billing-routes.js +243 -0
  886. package/dist/server/handlers/billing-routes.js.map +1 -0
  887. package/dist/server/handlers/billing-routes.test.js +123 -0
  888. package/dist/server/handlers/billing.js +330 -239
  889. package/dist/server/handlers/billing.js.map +1 -0
  890. package/dist/server/handlers/billing.test.js +215 -0
  891. package/dist/server/handlers/browser-actions-errors.test.js +94 -0
  892. package/dist/server/handlers/browser-actions.d.ts +35 -0
  893. package/dist/server/handlers/browser-actions.js +171 -0
  894. package/dist/server/handlers/browser-actions.js.map +1 -0
  895. package/dist/server/handlers/browser-actions.part2.test.js +190 -0
  896. package/dist/server/handlers/browser-actions.test.js +190 -0
  897. package/dist/server/handlers/browser-captcha.d.ts +6 -0
  898. package/dist/server/handlers/browser-captcha.js +172 -0
  899. package/dist/server/handlers/browser-captcha.js.map +1 -0
  900. package/dist/server/handlers/browser-lifecycle.d.ts +9 -0
  901. package/dist/server/handlers/browser-lifecycle.js +142 -0
  902. package/dist/server/handlers/browser-lifecycle.js.map +1 -0
  903. package/dist/server/handlers/browser-validation.test.js +257 -0
  904. package/dist/server/handlers/browser.js +468 -395
  905. package/dist/server/handlers/browser.js.map +1 -0
  906. package/dist/server/handlers/catalog-advanced.d.ts +9 -0
  907. package/dist/server/handlers/catalog-advanced.js +352 -0
  908. package/dist/server/handlers/catalog-advanced.js.map +1 -0
  909. package/dist/server/handlers/catalog-categories.d.ts +5 -0
  910. package/dist/server/handlers/catalog-categories.js +181 -0
  911. package/dist/server/handlers/catalog-categories.js.map +1 -0
  912. package/dist/server/handlers/catalog-products.d.ts +5 -0
  913. package/dist/server/handlers/catalog-products.js +404 -0
  914. package/dist/server/handlers/catalog-products.js.map +1 -0
  915. package/dist/server/handlers/catalog-schemas.d.ts +5 -0
  916. package/dist/server/handlers/catalog-schemas.js +426 -0
  917. package/dist/server/handlers/catalog-schemas.js.map +1 -0
  918. package/dist/server/handlers/catalog.js +1377 -978
  919. package/dist/server/handlers/catalog.js.map +1 -0
  920. package/dist/server/handlers/catalog.test.js +297 -0
  921. package/dist/server/handlers/clickhouse.js +157 -109
  922. package/dist/server/handlers/clickhouse.js.map +1 -0
  923. package/dist/server/handlers/comms-documents-advanced.d.ts +8 -0
  924. package/dist/server/handlers/comms-documents-advanced.js +159 -0
  925. package/dist/server/handlers/comms-documents-advanced.js.map +1 -0
  926. package/dist/server/handlers/comms-documents.d.ts +10 -0
  927. package/dist/server/handlers/comms-documents.js +445 -0
  928. package/dist/server/handlers/comms-documents.js.map +1 -0
  929. package/dist/server/handlers/comms-email.d.ts +10 -0
  930. package/dist/server/handlers/comms-email.js +492 -0
  931. package/dist/server/handlers/comms-email.js.map +1 -0
  932. package/dist/server/handlers/comms-pdf-generation.d.ts +8 -0
  933. package/dist/server/handlers/comms-pdf-generation.js +327 -0
  934. package/dist/server/handlers/comms-pdf-generation.js.map +1 -0
  935. package/dist/server/handlers/comms-pdf-helpers.d.ts +9 -0
  936. package/dist/server/handlers/comms-pdf-helpers.js +126 -0
  937. package/dist/server/handlers/comms-pdf-helpers.js.map +1 -0
  938. package/dist/server/handlers/comms-shared.d.ts +3 -0
  939. package/dist/server/handlers/comms-shared.js +28 -0
  940. package/dist/server/handlers/comms-shared.js.map +1 -0
  941. package/dist/server/handlers/comms.js +1439 -984
  942. package/dist/server/handlers/comms.js.map +1 -0
  943. package/dist/server/handlers/comms.test.js +289 -0
  944. package/dist/server/handlers/creations-actions.d.ts +21 -0
  945. package/dist/server/handlers/creations-actions.js +250 -0
  946. package/dist/server/handlers/creations-actions.js.map +1 -0
  947. package/dist/server/handlers/creations-advanced-collections.test.js +214 -0
  948. package/dist/server/handlers/creations-advanced-generate.test.js +142 -0
  949. package/dist/server/handlers/creations-advanced.test.js +171 -0
  950. package/dist/server/handlers/creations-collections-preview.test.js +214 -0
  951. package/dist/server/handlers/creations-crud.d.ts +35 -0
  952. package/dist/server/handlers/creations-crud.js +248 -0
  953. package/dist/server/handlers/creations-crud.js.map +1 -0
  954. package/dist/server/handlers/creations-crud.test.js +260 -0
  955. package/dist/server/handlers/creations-generate.d.ts +21 -0
  956. package/dist/server/handlers/creations-generate.js +256 -0
  957. package/dist/server/handlers/creations-generate.js.map +1 -0
  958. package/dist/server/handlers/creations-mutations.test.js +197 -0
  959. package/dist/server/handlers/creations.js +461 -394
  960. package/dist/server/handlers/creations.js.map +1 -0
  961. package/dist/server/handlers/crm-customers-read.d.ts +58 -0
  962. package/dist/server/handlers/crm-customers-read.js +208 -0
  963. package/dist/server/handlers/crm-customers-read.js.map +1 -0
  964. package/dist/server/handlers/crm-customers-write.d.ts +54 -0
  965. package/dist/server/handlers/crm-customers-write.js +414 -0
  966. package/dist/server/handlers/crm-customers-write.js.map +1 -0
  967. package/dist/server/handlers/crm-utils.d.ts +6 -0
  968. package/dist/server/handlers/crm-utils.js +19 -0
  969. package/dist/server/handlers/crm-utils.js.map +1 -0
  970. package/dist/server/handlers/crm.js +1082 -791
  971. package/dist/server/handlers/crm.js.map +1 -0
  972. package/dist/server/handlers/crm.test.js +179 -0
  973. package/dist/server/handlers/discovery-advertise.d.ts +18 -0
  974. package/dist/server/handlers/discovery-advertise.js +101 -0
  975. package/dist/server/handlers/discovery-advertise.js.map +1 -0
  976. package/dist/server/handlers/discovery-advertise.test.js +185 -0
  977. package/dist/server/handlers/discovery-scan.d.ts +19 -0
  978. package/dist/server/handlers/discovery-scan.js +107 -0
  979. package/dist/server/handlers/discovery-scan.js.map +1 -0
  980. package/dist/server/handlers/discovery-scan.test.js +233 -0
  981. package/dist/server/handlers/discovery.js +251 -232
  982. package/dist/server/handlers/discovery.js.map +1 -0
  983. package/dist/server/handlers/embeddings-embed-search.test.js +196 -0
  984. package/dist/server/handlers/embeddings-index-delete-stats.test.js +140 -0
  985. package/dist/server/handlers/embeddings-search.test.js +221 -0
  986. package/dist/server/handlers/embeddings.js +241 -164
  987. package/dist/server/handlers/embeddings.js.map +1 -0
  988. package/dist/server/handlers/embeddings.test.js +137 -0
  989. package/dist/server/handlers/enrichment-breach.d.ts +8 -0
  990. package/dist/server/handlers/enrichment-breach.js +266 -0
  991. package/dist/server/handlers/enrichment-breach.js.map +1 -0
  992. package/dist/server/handlers/enrichment-data.d.ts +13 -0
  993. package/dist/server/handlers/enrichment-data.js +145 -0
  994. package/dist/server/handlers/enrichment-data.js.map +1 -0
  995. package/dist/server/handlers/enrichment-enrich.d.ts +6 -0
  996. package/dist/server/handlers/enrichment-enrich.js +235 -0
  997. package/dist/server/handlers/enrichment-enrich.js.map +1 -0
  998. package/dist/server/handlers/enrichment-helpers.d.ts +10 -0
  999. package/dist/server/handlers/enrichment-helpers.js +17 -0
  1000. package/dist/server/handlers/enrichment-helpers.js.map +1 -0
  1001. package/dist/server/handlers/enrichment-mutations.test.js +240 -0
  1002. package/dist/server/handlers/enrichment-queries.test.js +181 -0
  1003. package/dist/server/handlers/enrichment-validation.test.js +177 -0
  1004. package/dist/server/handlers/enrichment-writes.d.ts +16 -0
  1005. package/dist/server/handlers/enrichment-writes.js +226 -0
  1006. package/dist/server/handlers/enrichment-writes.js.map +1 -0
  1007. package/dist/server/handlers/enrichment.js +887 -718
  1008. package/dist/server/handlers/enrichment.js.map +1 -0
  1009. package/dist/server/handlers/image-gen-actions.d.ts +18 -0
  1010. package/dist/server/handlers/image-gen-actions.js +183 -0
  1011. package/dist/server/handlers/image-gen-actions.js.map +1 -0
  1012. package/dist/server/handlers/image-gen-providers.d.ts +29 -0
  1013. package/dist/server/handlers/image-gen-providers.js +161 -0
  1014. package/dist/server/handlers/image-gen-providers.js.map +1 -0
  1015. package/dist/server/handlers/image-gen.js +467 -376
  1016. package/dist/server/handlers/image-gen.js.map +1 -0
  1017. package/dist/server/handlers/image-gen.test.js +205 -0
  1018. package/dist/server/handlers/inventory-audit.d.ts +10 -0
  1019. package/dist/server/handlers/inventory-audit.js +90 -0
  1020. package/dist/server/handlers/inventory-audit.js.map +1 -0
  1021. package/dist/server/handlers/inventory-helpers.d.ts +8 -0
  1022. package/dist/server/handlers/inventory-helpers.js +19 -0
  1023. package/dist/server/handlers/inventory-helpers.js.map +1 -0
  1024. package/dist/server/handlers/inventory-query.d.ts +67 -0
  1025. package/dist/server/handlers/inventory-query.js +299 -0
  1026. package/dist/server/handlers/inventory-query.js.map +1 -0
  1027. package/dist/server/handlers/inventory.js +797 -424
  1028. package/dist/server/handlers/inventory.js.map +1 -0
  1029. package/dist/server/handlers/inventory.test.js +380 -0
  1030. package/dist/server/handlers/kali-background.test.js +222 -0
  1031. package/dist/server/handlers/kali-errors.test.js +92 -0
  1032. package/dist/server/handlers/kali-validation.test.js +234 -0
  1033. package/dist/server/handlers/kali.js +272 -230
  1034. package/dist/server/handlers/kali.js.map +1 -0
  1035. package/dist/server/handlers/llm-providers-actions.test.js +220 -0
  1036. package/dist/server/handlers/llm-providers-anthropic.test.js +239 -0
  1037. package/dist/server/handlers/llm-providers-clients.d.ts +6 -0
  1038. package/dist/server/handlers/llm-providers-clients.js +296 -0
  1039. package/dist/server/handlers/llm-providers-clients.js.map +1 -0
  1040. package/dist/server/handlers/llm-providers-credentials.d.ts +3 -0
  1041. package/dist/server/handlers/llm-providers-credentials.js +109 -0
  1042. package/dist/server/handlers/llm-providers-credentials.js.map +1 -0
  1043. package/dist/server/handlers/llm-providers-failover.test.js +232 -0
  1044. package/dist/server/handlers/llm-providers-models.d.ts +67 -0
  1045. package/dist/server/handlers/llm-providers-models.js +213 -0
  1046. package/dist/server/handlers/llm-providers-models.js.map +1 -0
  1047. package/dist/server/handlers/llm-providers-providers.test.js +300 -0
  1048. package/dist/server/handlers/llm-providers-validation.test.js +239 -0
  1049. package/dist/server/handlers/llm-providers.js +803 -580
  1050. package/dist/server/handlers/llm-providers.js.map +1 -0
  1051. package/dist/server/handlers/local-agent-tools.test.js +224 -0
  1052. package/dist/server/handlers/local-agent.js +133 -105
  1053. package/dist/server/handlers/local-agent.js.map +1 -0
  1054. package/dist/server/handlers/local-agent.test.js +198 -0
  1055. package/dist/server/handlers/local-agent.tools-status.test.js +204 -0
  1056. package/dist/server/handlers/local-agent.validation-exec.test.js +182 -0
  1057. package/dist/server/handlers/media-actions.d.ts +14 -0
  1058. package/dist/server/handlers/media-actions.js +398 -0
  1059. package/dist/server/handlers/media-actions.js.map +1 -0
  1060. package/dist/server/handlers/media-crud.d.ts +9 -0
  1061. package/dist/server/handlers/media-crud.js +365 -0
  1062. package/dist/server/handlers/media-crud.js.map +1 -0
  1063. package/dist/server/handlers/media-upload.d.ts +4 -0
  1064. package/dist/server/handlers/media-upload.js +179 -0
  1065. package/dist/server/handlers/media-upload.js.map +1 -0
  1066. package/dist/server/handlers/media-utils.d.ts +14 -0
  1067. package/dist/server/handlers/media-utils.js +33 -0
  1068. package/dist/server/handlers/media-utils.js.map +1 -0
  1069. package/dist/server/handlers/media.js +1179 -857
  1070. package/dist/server/handlers/media.js.map +1 -0
  1071. package/dist/server/handlers/meta-ads-advanced.d.ts +46 -0
  1072. package/dist/server/handlers/meta-ads-advanced.js +222 -0
  1073. package/dist/server/handlers/meta-ads-advanced.js.map +1 -0
  1074. package/dist/server/handlers/meta-ads-audience-rules.test.js +243 -0
  1075. package/dist/server/handlers/meta-ads-audience-targeting.test.js +205 -0
  1076. package/dist/server/handlers/meta-ads-audiences-targeting.test.js +383 -0
  1077. package/dist/server/handlers/meta-ads-audiences.d.ts +48 -0
  1078. package/dist/server/handlers/meta-ads-audiences.js +214 -0
  1079. package/dist/server/handlers/meta-ads-audiences.js.map +1 -0
  1080. package/dist/server/handlers/meta-ads-crud-ads.test.js +136 -0
  1081. package/dist/server/handlers/meta-ads-crud-campaigns.test.js +189 -0
  1082. package/dist/server/handlers/meta-ads-crud-create.test.js +303 -0
  1083. package/dist/server/handlers/meta-ads-crud-list-update.test.js +259 -0
  1084. package/dist/server/handlers/meta-ads-crud-read.d.ts +78 -0
  1085. package/dist/server/handlers/meta-ads-crud-read.js +204 -0
  1086. package/dist/server/handlers/meta-ads-crud-read.js.map +1 -0
  1087. package/dist/server/handlers/meta-ads-crud-write.d.ts +105 -0
  1088. package/dist/server/handlers/meta-ads-crud-write.js +390 -0
  1089. package/dist/server/handlers/meta-ads-crud-write.js.map +1 -0
  1090. package/dist/server/handlers/meta-ads-crud.d.ts +9 -0
  1091. package/dist/server/handlers/meta-ads-crud.js +12 -0
  1092. package/dist/server/handlers/meta-ads-crud.js.map +1 -0
  1093. package/dist/server/handlers/meta-ads-delete-publish-sync.test.js +282 -0
  1094. package/dist/server/handlers/meta-ads-graph-api.d.ts +25 -0
  1095. package/dist/server/handlers/meta-ads-graph-api.js +155 -0
  1096. package/dist/server/handlers/meta-ads-graph-api.js.map +1 -0
  1097. package/dist/server/handlers/meta-ads-insights.test.js +80 -0
  1098. package/dist/server/handlers/meta-ads-list-get.test.js +237 -0
  1099. package/dist/server/handlers/meta-ads-media.d.ts +16 -0
  1100. package/dist/server/handlers/meta-ads-media.js +205 -0
  1101. package/dist/server/handlers/meta-ads-media.js.map +1 -0
  1102. package/dist/server/handlers/meta-ads-pixels-rules.d.ts +127 -0
  1103. package/dist/server/handlers/meta-ads-pixels-rules.js +463 -0
  1104. package/dist/server/handlers/meta-ads-pixels-rules.js.map +1 -0
  1105. package/dist/server/handlers/meta-ads-publish-ad.d.ts +11 -0
  1106. package/dist/server/handlers/meta-ads-publish-ad.js +229 -0
  1107. package/dist/server/handlers/meta-ads-publish-ad.js.map +1 -0
  1108. package/dist/server/handlers/meta-ads-publish-delete.test.js +254 -0
  1109. package/dist/server/handlers/meta-ads-publish-helpers.js +117 -0
  1110. package/dist/server/handlers/meta-ads-publish-helpers.js.map +1 -0
  1111. package/dist/server/handlers/meta-ads-publish-sync.test.js +205 -0
  1112. package/dist/server/handlers/meta-ads-publish.d.ts +14 -0
  1113. package/dist/server/handlers/meta-ads-publish.js +194 -0
  1114. package/dist/server/handlers/meta-ads-publish.js.map +1 -0
  1115. package/dist/server/handlers/meta-ads-publish.test.js +254 -0
  1116. package/dist/server/handlers/meta-ads-sync-insights.test.js +184 -0
  1117. package/dist/server/handlers/meta-ads-targeting.d.ts +27 -0
  1118. package/dist/server/handlers/meta-ads-targeting.js +323 -0
  1119. package/dist/server/handlers/meta-ads-targeting.js.map +1 -0
  1120. package/dist/server/handlers/meta-ads-types.d.ts +49 -0
  1121. package/dist/server/handlers/meta-ads-types.js +59 -0
  1122. package/dist/server/handlers/meta-ads-types.js.map +1 -0
  1123. package/dist/server/handlers/meta-ads-update.test.js +117 -0
  1124. package/dist/server/handlers/meta-ads.d.ts +25 -0
  1125. package/dist/server/handlers/meta-ads.js +3049 -2084
  1126. package/dist/server/handlers/meta-ads.js.map +1 -0
  1127. package/dist/server/handlers/nodes-channels.test.js +413 -0
  1128. package/dist/server/handlers/nodes-events.test.js +131 -0
  1129. package/dist/server/handlers/nodes-handlers-channels-messages.d.ts +20 -0
  1130. package/dist/server/handlers/nodes-handlers-channels-messages.js +314 -0
  1131. package/dist/server/handlers/nodes-handlers-channels-messages.js.map +1 -0
  1132. package/dist/server/handlers/nodes-handlers-channels.d.ts +19 -0
  1133. package/dist/server/handlers/nodes-handlers-channels.js +225 -0
  1134. package/dist/server/handlers/nodes-handlers-channels.js.map +1 -0
  1135. package/dist/server/handlers/nodes-handlers-mgmt.d.ts +33 -0
  1136. package/dist/server/handlers/nodes-handlers-mgmt.js +418 -0
  1137. package/dist/server/handlers/nodes-handlers-mgmt.js.map +1 -0
  1138. package/dist/server/handlers/nodes-list-delete.test.js +171 -0
  1139. package/dist/server/handlers/nodes-messages-delivery.test.js +208 -0
  1140. package/dist/server/handlers/nodes-messages.test.js +211 -0
  1141. package/dist/server/handlers/nodes-register.test.js +277 -0
  1142. package/dist/server/handlers/nodes-routes-channels.d.ts +9 -0
  1143. package/dist/server/handlers/nodes-routes-channels.js +217 -0
  1144. package/dist/server/handlers/nodes-routes-channels.js.map +1 -0
  1145. package/dist/server/handlers/nodes-routes-crud.d.ts +9 -0
  1146. package/dist/server/handlers/nodes-routes-crud.js +290 -0
  1147. package/dist/server/handlers/nodes-routes-crud.js.map +1 -0
  1148. package/dist/server/handlers/nodes-routes-delivery.d.ts +9 -0
  1149. package/dist/server/handlers/nodes-routes-delivery.js +226 -0
  1150. package/dist/server/handlers/nodes-routes-delivery.js.map +1 -0
  1151. package/dist/server/handlers/nodes-routes-messages.d.ts +9 -0
  1152. package/dist/server/handlers/nodes-routes-messages.js +218 -0
  1153. package/dist/server/handlers/nodes-routes-messages.js.map +1 -0
  1154. package/dist/server/handlers/nodes-routes-register.d.ts +9 -0
  1155. package/dist/server/handlers/nodes-routes-register.js +239 -0
  1156. package/dist/server/handlers/nodes-routes-register.js.map +1 -0
  1157. package/dist/server/handlers/nodes-types.d.ts +82 -0
  1158. package/dist/server/handlers/nodes-types.js +220 -0
  1159. package/dist/server/handlers/nodes-types.js.map +1 -0
  1160. package/dist/server/handlers/nodes-utils.d.ts +70 -0
  1161. package/dist/server/handlers/nodes-utils.js +214 -0
  1162. package/dist/server/handlers/nodes-utils.js.map +1 -0
  1163. package/dist/server/handlers/nodes.js +1321 -913
  1164. package/dist/server/handlers/nodes.js.map +1 -0
  1165. package/dist/server/handlers/nodes.test.js +353 -0
  1166. package/dist/server/handlers/operations.js +183 -157
  1167. package/dist/server/handlers/operations.js.map +1 -0
  1168. package/dist/server/handlers/operations.test.js +136 -0
  1169. package/dist/server/handlers/platform-telemetry.d.ts +10 -0
  1170. package/dist/server/handlers/platform-telemetry.js +372 -0
  1171. package/dist/server/handlers/platform-telemetry.js.map +1 -0
  1172. package/dist/server/handlers/platform-telemetry.test.js +200 -0
  1173. package/dist/server/handlers/platform-websearch.test.js +160 -0
  1174. package/dist/server/handlers/platform.js +346 -210
  1175. package/dist/server/handlers/platform.js.map +1 -0
  1176. package/dist/server/handlers/remove-bg.js +118 -86
  1177. package/dist/server/handlers/remove-bg.js.map +1 -0
  1178. package/dist/server/handlers/sessions-handlers.d.ts +23 -0
  1179. package/dist/server/handlers/sessions-handlers.js +374 -0
  1180. package/dist/server/handlers/sessions-handlers.js.map +1 -0
  1181. package/dist/server/handlers/storefront-cart.d.ts +31 -0
  1182. package/dist/server/handlers/storefront-cart.js +381 -0
  1183. package/dist/server/handlers/storefront-cart.js.map +1 -0
  1184. package/dist/server/handlers/storefront.js +586 -446
  1185. package/dist/server/handlers/storefront.js.map +1 -0
  1186. package/dist/server/handlers/storefront.test.js +329 -0
  1187. package/dist/server/handlers/supply-chain-transfers.d.ts +10 -0
  1188. package/dist/server/handlers/supply-chain-transfers.js +214 -0
  1189. package/dist/server/handlers/supply-chain-transfers.js.map +1 -0
  1190. package/dist/server/handlers/supply-chain-utils.d.ts +2 -0
  1191. package/dist/server/handlers/supply-chain-utils.js +21 -0
  1192. package/dist/server/handlers/supply-chain-utils.js.map +1 -0
  1193. package/dist/server/handlers/supply-chain.js +546 -326
  1194. package/dist/server/handlers/supply-chain.js.map +1 -0
  1195. package/dist/server/handlers/supply-chain.test.js +347 -0
  1196. package/dist/server/handlers/transcription.js +106 -97
  1197. package/dist/server/handlers/transcription.js.map +1 -0
  1198. package/dist/server/handlers/transcription.test.js +118 -0
  1199. package/dist/server/handlers/video-gen-providers.d.ts +30 -0
  1200. package/dist/server/handlers/video-gen-providers.js +205 -0
  1201. package/dist/server/handlers/video-gen-providers.js.map +1 -0
  1202. package/dist/server/handlers/video-gen-sora.d.ts +5 -0
  1203. package/dist/server/handlers/video-gen-sora.js +87 -0
  1204. package/dist/server/handlers/video-gen-sora.js.map +1 -0
  1205. package/dist/server/handlers/video-gen-veo.js +114 -0
  1206. package/dist/server/handlers/video-gen-veo.js.map +1 -0
  1207. package/dist/server/handlers/video-gen.js +593 -424
  1208. package/dist/server/handlers/video-gen.js.map +1 -0
  1209. package/dist/server/handlers/video-gen.test.js +146 -0
  1210. package/dist/server/handlers/voice-handlers-audio.d.ts +9 -0
  1211. package/dist/server/handlers/voice-handlers-audio.js +229 -0
  1212. package/dist/server/handlers/voice-handlers-audio.js.map +1 -0
  1213. package/dist/server/handlers/voice-handlers-music.d.ts +5 -0
  1214. package/dist/server/handlers/voice-handlers-music.js +124 -0
  1215. package/dist/server/handlers/voice-handlers-music.js.map +1 -0
  1216. package/dist/server/handlers/voice-handlers-pvc.d.ts +8 -0
  1217. package/dist/server/handlers/voice-handlers-pvc.js +345 -0
  1218. package/dist/server/handlers/voice-handlers-pvc.js.map +1 -0
  1219. package/dist/server/handlers/voice-handlers-tts.d.ts +5 -0
  1220. package/dist/server/handlers/voice-handlers-tts.js +142 -0
  1221. package/dist/server/handlers/voice-handlers-tts.js.map +1 -0
  1222. package/dist/server/handlers/voice-handlers-voices.d.ts +8 -0
  1223. package/dist/server/handlers/voice-handlers-voices.js +321 -0
  1224. package/dist/server/handlers/voice-handlers-voices.js.map +1 -0
  1225. package/dist/server/handlers/voice-utils.d.ts +32 -0
  1226. package/dist/server/handlers/voice-utils.js +281 -0
  1227. package/dist/server/handlers/voice-utils.js.map +1 -0
  1228. package/dist/server/handlers/voice.js +1458 -1039
  1229. package/dist/server/handlers/voice.js.map +1 -0
  1230. package/dist/server/handlers/voice.test.js +153 -0
  1231. package/dist/server/handlers/workflow-crud-advanced.d.ts +8 -0
  1232. package/dist/server/handlers/workflow-crud-advanced.js +275 -0
  1233. package/dist/server/handlers/workflow-crud-advanced.js.map +1 -0
  1234. package/dist/server/handlers/workflow-crud-core.d.ts +8 -0
  1235. package/dist/server/handlers/workflow-crud-core.js +286 -0
  1236. package/dist/server/handlers/workflow-crud-core.js.map +1 -0
  1237. package/dist/server/handlers/workflow-crud-events.d.ts +8 -0
  1238. package/dist/server/handlers/workflow-crud-events.js +483 -0
  1239. package/dist/server/handlers/workflow-crud-events.js.map +1 -0
  1240. package/dist/server/handlers/workflow-crud-runs-lifecycle.d.ts +8 -0
  1241. package/dist/server/handlers/workflow-crud-runs-lifecycle.js +231 -0
  1242. package/dist/server/handlers/workflow-crud-runs-lifecycle.js.map +1 -0
  1243. package/dist/server/handlers/workflow-crud-runs-versioning.d.ts +8 -0
  1244. package/dist/server/handlers/workflow-crud-runs-versioning.js +319 -0
  1245. package/dist/server/handlers/workflow-crud-runs-versioning.js.map +1 -0
  1246. package/dist/server/handlers/workflow-crud-runs.d.ts +8 -0
  1247. package/dist/server/handlers/workflow-crud-runs.js +18 -0
  1248. package/dist/server/handlers/workflow-crud-runs.js.map +1 -0
  1249. package/dist/server/handlers/workflow-steps-advancement.d.ts +13 -0
  1250. package/dist/server/handlers/workflow-steps-advancement.js +197 -0
  1251. package/dist/server/handlers/workflow-steps-advancement.js.map +1 -0
  1252. package/dist/server/handlers/workflow-steps-circuit-breaker.d.ts +7 -0
  1253. package/dist/server/handlers/workflow-steps-circuit-breaker.js +131 -0
  1254. package/dist/server/handlers/workflow-steps-circuit-breaker.js.map +1 -0
  1255. package/dist/server/handlers/workflow-steps-completion.d.ts +5 -0
  1256. package/dist/server/handlers/workflow-steps-completion.js +254 -0
  1257. package/dist/server/handlers/workflow-steps-completion.js.map +1 -0
  1258. package/dist/server/handlers/workflow-steps-cron.d.ts +4 -0
  1259. package/dist/server/handlers/workflow-steps-cron.js +259 -0
  1260. package/dist/server/handlers/workflow-steps-cron.js.map +1 -0
  1261. package/dist/server/handlers/workflow-steps-engine-execute.d.ts +3 -0
  1262. package/dist/server/handlers/workflow-steps-engine-execute.js +388 -0
  1263. package/dist/server/handlers/workflow-steps-engine-execute.js.map +1 -0
  1264. package/dist/server/handlers/workflow-steps-engine-inline.d.ts +2 -0
  1265. package/dist/server/handlers/workflow-steps-engine-inline.js +91 -0
  1266. package/dist/server/handlers/workflow-steps-engine-inline.js.map +1 -0
  1267. package/dist/server/handlers/workflow-steps-engine-persist.d.ts +5 -0
  1268. package/dist/server/handlers/workflow-steps-engine-persist.js +192 -0
  1269. package/dist/server/handlers/workflow-steps-engine-persist.js.map +1 -0
  1270. package/dist/server/handlers/workflow-steps-engine-process.d.ts +7 -0
  1271. package/dist/server/handlers/workflow-steps-engine-process.js +290 -0
  1272. package/dist/server/handlers/workflow-steps-engine-process.js.map +1 -0
  1273. package/dist/server/handlers/workflow-steps-engine.d.ts +3 -0
  1274. package/dist/server/handlers/workflow-steps-engine.js +10 -0
  1275. package/dist/server/handlers/workflow-steps-engine.js.map +1 -0
  1276. package/dist/server/handlers/workflow-steps-executors-llm.d.ts +7 -0
  1277. package/dist/server/handlers/workflow-steps-executors-llm.js +265 -0
  1278. package/dist/server/handlers/workflow-steps-executors-llm.js.map +1 -0
  1279. package/dist/server/handlers/workflow-steps-executors.d.ts +9 -0
  1280. package/dist/server/handlers/workflow-steps-executors.js +188 -0
  1281. package/dist/server/handlers/workflow-steps-executors.js.map +1 -0
  1282. package/dist/server/handlers/workflow-steps-maintenance.d.ts +4 -0
  1283. package/dist/server/handlers/workflow-steps-maintenance.js +256 -0
  1284. package/dist/server/handlers/workflow-steps-maintenance.js.map +1 -0
  1285. package/dist/server/handlers/workflow-steps-types.d.ts +84 -0
  1286. package/dist/server/handlers/workflow-steps-types.js +179 -0
  1287. package/dist/server/handlers/workflow-steps-types.js.map +1 -0
  1288. package/dist/server/handlers/workflow-steps-webhook.d.ts +5 -0
  1289. package/dist/server/handlers/workflow-steps-webhook.js +179 -0
  1290. package/dist/server/handlers/workflow-steps-webhook.js.map +1 -0
  1291. package/dist/server/handlers/workflow-steps.js +2837 -2116
  1292. package/dist/server/handlers/workflow-steps.js.map +1 -0
  1293. package/dist/server/handlers/workflow-steps.test.js +330 -0
  1294. package/dist/server/handlers/workflows-extras.test.js +65 -0
  1295. package/dist/server/handlers/workflows.js +1630 -933
  1296. package/dist/server/handlers/workflows.js.map +1 -0
  1297. package/dist/server/handlers/workflows.part2.test.js +170 -0
  1298. package/dist/server/handlers/workflows.test.js +281 -0
  1299. package/dist/server/index.js +1702 -2596
  1300. package/dist/server/index.js.map +1 -0
  1301. package/dist/server/lib/__tests__/batch-client-conversion-jsonl.test.js +171 -0
  1302. package/dist/server/lib/__tests__/batch-client-polling.test.js +292 -0
  1303. package/dist/server/lib/__tests__/batch-client-queue.test.js +270 -0
  1304. package/dist/server/lib/__tests__/clickhouse-buffer.test.js +236 -0
  1305. package/dist/server/lib/__tests__/code-worker-edge-cases.test.js +118 -0
  1306. package/dist/server/lib/__tests__/code-worker-pool-execute.test.js +193 -0
  1307. package/dist/server/lib/__tests__/code-worker-pool-execution.test.js +165 -0
  1308. package/dist/server/lib/__tests__/code-worker-pool-init.test.js +131 -0
  1309. package/dist/server/lib/__tests__/code-worker-pool.test.js +194 -0
  1310. package/dist/server/lib/__tests__/code-worker-sandbox-ops.test.js +123 -0
  1311. package/dist/server/lib/__tests__/code-worker-sandbox.test.js +217 -0
  1312. package/dist/server/lib/__tests__/code-worker.test.js +179 -0
  1313. package/dist/server/lib/__tests__/compaction-service-generate.test.js +229 -0
  1314. package/dist/server/lib/__tests__/compaction-service.test.js +319 -0
  1315. package/dist/server/lib/__tests__/otel.test.js +146 -0
  1316. package/dist/server/lib/__tests__/prompt-sanitizer-validation.test.js +165 -0
  1317. package/dist/server/lib/__tests__/prompt-sanitizer.sanitize.test.js +343 -0
  1318. package/dist/server/lib/__tests__/prompt-sanitizer.test.js +328 -0
  1319. package/dist/server/lib/__tests__/prompt-sanitizer.validate-tool.test.js +145 -0
  1320. package/dist/server/lib/__tests__/provider-capabilities.test.js +263 -0
  1321. package/dist/server/lib/__tests__/provider-failover-routing.test.js +145 -0
  1322. package/dist/server/lib/__tests__/provider-failover-state.test.js +131 -0
  1323. package/dist/server/lib/__tests__/rate-limiter-budgets.test.js +216 -0
  1324. package/dist/server/lib/__tests__/rate-limiter.budgets-tools.test.js +113 -0
  1325. package/dist/server/lib/__tests__/rate-limiter.check-request.test.js +141 -0
  1326. package/dist/server/lib/__tests__/rate-limiter.stats-lifecycle.test.js +135 -0
  1327. package/dist/server/lib/__tests__/rate-limiter.test.js +207 -0
  1328. package/dist/server/lib/__tests__/server-agent-loop-abort-conditions.test.js +544 -0
  1329. package/dist/server/lib/__tests__/server-agent-loop-abort.part2.test.js +504 -0
  1330. package/dist/server/lib/__tests__/server-agent-loop-abort.test.js +396 -0
  1331. package/dist/server/lib/__tests__/server-agent-loop-compaction.test.js +397 -0
  1332. package/dist/server/lib/__tests__/server-agent-loop-failover.test.js +356 -0
  1333. package/dist/server/lib/__tests__/server-agent-loop-features-caching.test.js +519 -0
  1334. package/dist/server/lib/__tests__/server-agent-loop-features-edges.test.js +512 -0
  1335. package/dist/server/lib/__tests__/server-subagent-bailout.test.js +194 -0
  1336. package/dist/server/lib/__tests__/server-subagent-basics.test.js +348 -0
  1337. package/dist/server/lib/__tests__/server-subagent-errors-abort.test.js +319 -0
  1338. package/dist/server/lib/__tests__/server-subagent-errors-progress.test.js +253 -0
  1339. package/dist/server/lib/__tests__/server-subagent-errors.part2.test.js +253 -0
  1340. package/dist/server/lib/__tests__/server-subagent-errors.test.js +319 -0
  1341. package/dist/server/lib/__tests__/session-checkpoint-load.test.js +275 -0
  1342. package/dist/server/lib/__tests__/session-checkpoint-save.test.js +159 -0
  1343. package/dist/server/lib/__tests__/ssrf-guard.test.js +93 -0
  1344. package/dist/server/lib/__tests__/supabase-client.test.js +111 -0
  1345. package/dist/server/lib/__tests__/template-resolver.test.js +317 -0
  1346. package/dist/server/lib/__tests__/utils-timeout.test.js +49 -0
  1347. package/dist/server/lib/__tests__/utils.test.js +322 -0
  1348. package/dist/server/lib/agent-loop-executor.d.ts +7 -0
  1349. package/dist/server/lib/agent-loop-executor.js +224 -0
  1350. package/dist/server/lib/agent-loop-executor.js.map +1 -0
  1351. package/dist/server/lib/agent-loop-turn.d.ts +53 -0
  1352. package/dist/server/lib/agent-loop-turn.js +166 -0
  1353. package/dist/server/lib/agent-loop-turn.js.map +1 -0
  1354. package/dist/server/lib/agent-loop-types.d.ts +118 -0
  1355. package/dist/server/lib/agent-loop-types.js +53 -0
  1356. package/dist/server/lib/agent-loop-types.js.map +1 -0
  1357. package/dist/server/lib/batch-client-anthropic.d.ts +10 -0
  1358. package/dist/server/lib/batch-client-anthropic.js +144 -0
  1359. package/dist/server/lib/batch-client-anthropic.js.map +1 -0
  1360. package/dist/server/lib/batch-client-openai.d.ts +10 -0
  1361. package/dist/server/lib/batch-client-openai.js +172 -0
  1362. package/dist/server/lib/batch-client-openai.js.map +1 -0
  1363. package/dist/server/lib/batch-client-types.d.ts +54 -0
  1364. package/dist/server/lib/batch-client-types.js +27 -0
  1365. package/dist/server/lib/batch-client-types.js.map +1 -0
  1366. package/dist/server/lib/batch-client.js +471 -409
  1367. package/dist/server/lib/batch-client.js.map +1 -0
  1368. package/dist/server/lib/clickhouse-buffer.js +118 -104
  1369. package/dist/server/lib/clickhouse-buffer.js.map +1 -0
  1370. package/dist/server/lib/clickhouse-client.js +107 -107
  1371. package/dist/server/lib/clickhouse-client.js.map +1 -0
  1372. package/dist/server/lib/coa-renderer-components.d.ts +15 -0
  1373. package/dist/server/lib/coa-renderer-components.js +361 -0
  1374. package/dist/server/lib/coa-renderer-components.js.map +1 -0
  1375. package/dist/server/lib/coa-renderer-pages.d.ts +15 -0
  1376. package/dist/server/lib/coa-renderer-pages.js +467 -0
  1377. package/dist/server/lib/coa-renderer-pages.js.map +1 -0
  1378. package/dist/server/lib/coa-renderer-styles.d.ts +525 -0
  1379. package/dist/server/lib/coa-renderer-styles.js +540 -0
  1380. package/dist/server/lib/coa-renderer-styles.js.map +1 -0
  1381. package/dist/server/lib/coa-renderer-tokens.d.ts +107 -0
  1382. package/dist/server/lib/coa-renderer-tokens.js +46 -0
  1383. package/dist/server/lib/coa-renderer-tokens.js.map +1 -0
  1384. package/dist/server/lib/coa-renderer.js +1786 -356
  1385. package/dist/server/lib/coa-renderer.js.map +1 -0
  1386. package/dist/server/lib/code-worker-pool.js +227 -177
  1387. package/dist/server/lib/code-worker-pool.js.map +1 -0
  1388. package/dist/server/lib/code-worker.js +174 -164
  1389. package/dist/server/lib/code-worker.js.map +1 -0
  1390. package/dist/server/lib/compaction-service.d.ts +2 -12
  1391. package/dist/server/lib/compaction-service.js +74 -184
  1392. package/dist/server/lib/compaction-service.js.map +1 -0
  1393. package/dist/server/lib/logger.js +36 -24
  1394. package/dist/server/lib/logger.js.map +1 -0
  1395. package/dist/server/lib/otel.js +101 -80
  1396. package/dist/server/lib/otel.js.map +1 -0
  1397. package/dist/server/lib/pdf-renderer-calc.d.ts +7 -0
  1398. package/dist/server/lib/pdf-renderer-calc.js +272 -0
  1399. package/dist/server/lib/pdf-renderer-calc.js.map +1 -0
  1400. package/dist/server/lib/pdf-renderer-generation.d.ts +73 -0
  1401. package/dist/server/lib/pdf-renderer-generation.js +298 -0
  1402. package/dist/server/lib/pdf-renderer-generation.js.map +1 -0
  1403. package/dist/server/lib/pdf-renderer-layout.d.ts +2 -0
  1404. package/dist/server/lib/pdf-renderer-layout.js +144 -0
  1405. package/dist/server/lib/pdf-renderer-layout.js.map +1 -0
  1406. package/dist/server/lib/pdf-renderer-validation.d.ts +14 -0
  1407. package/dist/server/lib/pdf-renderer-validation.js +220 -0
  1408. package/dist/server/lib/pdf-renderer-validation.js.map +1 -0
  1409. package/dist/server/lib/pdf-renderer.js +952 -788
  1410. package/dist/server/lib/pdf-renderer.js.map +1 -0
  1411. package/dist/server/lib/prompt-sanitizer.js +188 -108
  1412. package/dist/server/lib/prompt-sanitizer.js.map +1 -0
  1413. package/dist/server/lib/provider-capabilities.js +136 -138
  1414. package/dist/server/lib/provider-capabilities.js.map +1 -0
  1415. package/dist/server/lib/provider-failover.js +190 -168
  1416. package/dist/server/lib/provider-failover.js.map +1 -0
  1417. package/dist/server/lib/rate-limiter.js +186 -117
  1418. package/dist/server/lib/rate-limiter.js.map +1 -0
  1419. package/dist/server/lib/react-pdf-layout-elements.d.ts +8 -0
  1420. package/dist/server/lib/react-pdf-layout-elements.js +366 -0
  1421. package/dist/server/lib/react-pdf-layout-elements.js.map +1 -0
  1422. package/dist/server/lib/react-pdf-layout-labels.d.ts +38 -0
  1423. package/dist/server/lib/react-pdf-layout-labels.js +217 -0
  1424. package/dist/server/lib/react-pdf-layout-labels.js.map +1 -0
  1425. package/dist/server/lib/react-pdf-layout.js +551 -382
  1426. package/dist/server/lib/react-pdf-layout.js.map +1 -0
  1427. package/dist/server/lib/server-agent-loop-init.d.ts +28 -0
  1428. package/dist/server/lib/server-agent-loop-init.js +138 -0
  1429. package/dist/server/lib/server-agent-loop-init.js.map +1 -0
  1430. package/dist/server/lib/server-agent-loop-v2.d.ts +110 -0
  1431. package/dist/server/lib/server-agent-loop-v2.js +340 -0
  1432. package/dist/server/lib/server-agent-loop-v2.js.map +1 -0
  1433. package/dist/server/lib/server-agent-loop.d.ts +4 -1
  1434. package/dist/server/lib/server-agent-loop.js +907 -634
  1435. package/dist/server/lib/server-agent-loop.js.map +1 -0
  1436. package/dist/server/lib/server-subagent-loop.d.ts +3 -0
  1437. package/dist/server/lib/server-subagent-loop.js +267 -0
  1438. package/dist/server/lib/server-subagent-loop.js.map +1 -0
  1439. package/dist/server/lib/server-subagent.js +260 -164
  1440. package/dist/server/lib/server-subagent.js.map +1 -0
  1441. package/dist/server/lib/session-checkpoint.js +105 -96
  1442. package/dist/server/lib/session-checkpoint.js.map +1 -0
  1443. package/dist/server/lib/session-types.d.ts +106 -0
  1444. package/dist/server/lib/session-types.js +2 -0
  1445. package/dist/server/lib/session-types.js.map +1 -0
  1446. package/dist/server/lib/ssrf-guard.js +193 -184
  1447. package/dist/server/lib/ssrf-guard.js.map +1 -0
  1448. package/dist/server/lib/supabase-client.js +94 -82
  1449. package/dist/server/lib/supabase-client.js.map +1 -0
  1450. package/dist/server/lib/template-resolver.js +154 -176
  1451. package/dist/server/lib/template-resolver.js.map +1 -0
  1452. package/dist/server/lib/utils.js +242 -133
  1453. package/dist/server/lib/utils.js.map +1 -0
  1454. package/dist/server/local-agent-gateway-api.d.ts +34 -0
  1455. package/dist/server/local-agent-gateway-api.js +156 -0
  1456. package/dist/server/local-agent-gateway-api.js.map +1 -0
  1457. package/dist/server/local-agent-gateway-handler.d.ts +3 -0
  1458. package/dist/server/local-agent-gateway-handler.js +292 -0
  1459. package/dist/server/local-agent-gateway-handler.js.map +1 -0
  1460. package/dist/server/local-agent-gateway-init.d.ts +21 -0
  1461. package/dist/server/local-agent-gateway-init.js +143 -0
  1462. package/dist/server/local-agent-gateway-init.js.map +1 -0
  1463. package/dist/server/local-agent-gateway-messages.d.ts +12 -0
  1464. package/dist/server/local-agent-gateway-messages.js +108 -0
  1465. package/dist/server/local-agent-gateway-messages.js.map +1 -0
  1466. package/dist/server/local-agent-gateway-stats.d.ts +53 -0
  1467. package/dist/server/local-agent-gateway-stats.js +129 -0
  1468. package/dist/server/local-agent-gateway-stats.js.map +1 -0
  1469. package/dist/server/local-agent-gateway-types.d.ts +94 -0
  1470. package/dist/server/local-agent-gateway-types.js +78 -0
  1471. package/dist/server/local-agent-gateway-types.js.map +1 -0
  1472. package/dist/server/local-agent-gateway.d.ts +8 -2
  1473. package/dist/server/local-agent-gateway.js +825 -627
  1474. package/dist/server/local-agent-gateway.js.map +1 -0
  1475. package/dist/server/providers/__tests__/anthropic-adapter.test.js +228 -0
  1476. package/dist/server/providers/__tests__/anthropic-betas-toolchoice.test.js +257 -0
  1477. package/dist/server/providers/__tests__/anthropic-errors.test.js +262 -0
  1478. package/dist/server/providers/__tests__/anthropic-stream-core.test.js +275 -0
  1479. package/dist/server/providers/__tests__/anthropic-streaming-betas.test.js +247 -0
  1480. package/dist/server/providers/__tests__/anthropic-streaming-core.test.js +275 -0
  1481. package/dist/server/providers/__tests__/bedrock-config.test.js +177 -0
  1482. package/dist/server/providers/__tests__/bedrock-stream-behavior-streaming.test.js +272 -0
  1483. package/dist/server/providers/__tests__/bedrock-stream-behavior-toolchoice.test.js +214 -0
  1484. package/dist/server/providers/__tests__/bedrock-stream-behavior.part2.test.js +165 -0
  1485. package/dist/server/providers/__tests__/bedrock-stream-behavior.test.js +309 -0
  1486. package/dist/server/providers/__tests__/bedrock-stream-body-credentials.test.js +170 -0
  1487. package/dist/server/providers/__tests__/bedrock-stream-body-extras.test.js +183 -0
  1488. package/dist/server/providers/__tests__/bedrock-stream-body-request.test.js +305 -0
  1489. package/dist/server/providers/__tests__/bedrock-stream-body.part2.test.js +305 -0
  1490. package/dist/server/providers/__tests__/bedrock-stream-body.test.js +175 -0
  1491. package/dist/server/providers/__tests__/bedrock-stream-errors.test.js +165 -0
  1492. package/dist/server/providers/__tests__/gemini-config-methods.test.js +182 -0
  1493. package/dist/server/providers/__tests__/gemini-config-streaming.test.js +257 -0
  1494. package/dist/server/providers/__tests__/gemini-conversion-messages.test.js +247 -0
  1495. package/dist/server/providers/__tests__/gemini-conversion-schema.test.js +365 -0
  1496. package/dist/server/providers/__tests__/gemini-tools-choice.test.js +221 -0
  1497. package/dist/server/providers/__tests__/gemini-tools-fn.test.js +252 -0
  1498. package/dist/server/providers/__tests__/openai-config.test.js +194 -0
  1499. package/dist/server/providers/__tests__/openai-conversion.test.js +276 -0
  1500. package/dist/server/providers/__tests__/openai-messages.test.js +261 -0
  1501. package/dist/server/providers/__tests__/openai-streaming.test.js +394 -0
  1502. package/dist/server/providers/__tests__/openai-tools-cache.test.js +227 -0
  1503. package/dist/server/providers/__tests__/registry.test.js +183 -0
  1504. package/dist/server/providers/__tests__/shared.test.js +297 -0
  1505. package/dist/server/providers/anthropic.js +250 -172
  1506. package/dist/server/providers/anthropic.js.map +1 -0
  1507. package/dist/server/providers/bedrock.js +217 -158
  1508. package/dist/server/providers/bedrock.js.map +1 -0
  1509. package/dist/server/providers/gemini-conversion.d.ts +17 -0
  1510. package/dist/server/providers/gemini-conversion.js +185 -0
  1511. package/dist/server/providers/gemini-conversion.js.map +1 -0
  1512. package/dist/server/providers/gemini-streaming.d.ts +18 -0
  1513. package/dist/server/providers/gemini-streaming.js +187 -0
  1514. package/dist/server/providers/gemini-streaming.js.map +1 -0
  1515. package/dist/server/providers/gemini.js +548 -418
  1516. package/dist/server/providers/gemini.js.map +1 -0
  1517. package/dist/server/providers/openai-adapter.d.ts +15 -0
  1518. package/dist/server/providers/openai-adapter.js +423 -0
  1519. package/dist/server/providers/openai-adapter.js.map +1 -0
  1520. package/dist/server/providers/openai-conversion.d.ts +21 -0
  1521. package/dist/server/providers/openai-conversion.js +191 -0
  1522. package/dist/server/providers/openai-conversion.js.map +1 -0
  1523. package/dist/server/providers/openai.js +571 -437
  1524. package/dist/server/providers/openai.js.map +1 -0
  1525. package/dist/server/providers/registry.js +23 -18
  1526. package/dist/server/providers/registry.js.map +1 -0
  1527. package/dist/server/providers/shared.js +123 -95
  1528. package/dist/server/providers/shared.js.map +1 -0
  1529. package/dist/server/providers/types.js +1 -11
  1530. package/dist/server/providers/types.js.map +1 -0
  1531. package/dist/server/proxy-handlers.js +209 -165
  1532. package/dist/server/proxy-handlers.js.map +1 -0
  1533. package/dist/server/server-agent.d.ts +21 -0
  1534. package/dist/server/server-agent.js +162 -0
  1535. package/dist/server/server-agent.js.map +1 -0
  1536. package/dist/server/server-chat.d.ts +6 -0
  1537. package/dist/server/server-chat.js +210 -0
  1538. package/dist/server/server-chat.js.map +1 -0
  1539. package/dist/server/server-cost-guard.d.ts +16 -0
  1540. package/dist/server/server-cost-guard.js +141 -0
  1541. package/dist/server/server-cost-guard.js.map +1 -0
  1542. package/dist/server/server-executors.d.ts +10 -0
  1543. package/dist/server/server-executors.js +110 -0
  1544. package/dist/server/server-executors.js.map +1 -0
  1545. package/dist/server/server-helpers.d.ts +49 -0
  1546. package/dist/server/server-helpers.js +210 -0
  1547. package/dist/server/server-helpers.js.map +1 -0
  1548. package/dist/server/server-persist.d.ts +43 -0
  1549. package/dist/server/server-persist.js +249 -0
  1550. package/dist/server/server-persist.js.map +1 -0
  1551. package/dist/server/server-rate-limit.d.ts +9 -0
  1552. package/dist/server/server-rate-limit.js +77 -0
  1553. package/dist/server/server-rate-limit.js.map +1 -0
  1554. package/dist/server/server-routes-approvals.d.ts +4 -0
  1555. package/dist/server/server-routes-approvals.js +238 -0
  1556. package/dist/server/server-routes-approvals.js.map +1 -0
  1557. package/dist/server/server-routes-auth.d.ts +7 -0
  1558. package/dist/server/server-routes-auth.js +532 -0
  1559. package/dist/server/server-routes-auth.js.map +1 -0
  1560. package/dist/server/server-routes-events.d.ts +4 -0
  1561. package/dist/server/server-routes-events.js +167 -0
  1562. package/dist/server/server-routes-events.js.map +1 -0
  1563. package/dist/server/server-routes-public.d.ts +24 -0
  1564. package/dist/server/server-routes-public.js +453 -0
  1565. package/dist/server/server-routes-public.js.map +1 -0
  1566. package/dist/server/server-routes-waitpoints.d.ts +4 -0
  1567. package/dist/server/server-routes-waitpoints.js +190 -0
  1568. package/dist/server/server-routes-waitpoints.js.map +1 -0
  1569. package/dist/server/server-routes-webchat.d.ts +14 -0
  1570. package/dist/server/server-routes-webchat.js +307 -0
  1571. package/dist/server/server-routes-webchat.js.map +1 -0
  1572. package/dist/server/server-routes-workflows.d.ts +5 -0
  1573. package/dist/server/server-routes-workflows.js +289 -0
  1574. package/dist/server/server-routes-workflows.js.map +1 -0
  1575. package/dist/server/server-sse.d.ts +13 -0
  1576. package/dist/server/server-sse.js +197 -0
  1577. package/dist/server/server-sse.js.map +1 -0
  1578. package/dist/server/server-store-circuit-breaker.d.ts +32 -0
  1579. package/dist/server/server-store-circuit-breaker.js +211 -0
  1580. package/dist/server/server-store-circuit-breaker.js.map +1 -0
  1581. package/dist/server/server-store.d.ts +5 -0
  1582. package/dist/server/server-store.js +71 -0
  1583. package/dist/server/server-store.js.map +1 -0
  1584. package/dist/server/server-trace.d.ts +41 -0
  1585. package/dist/server/server-trace.js +133 -0
  1586. package/dist/server/server-trace.js.map +1 -0
  1587. package/dist/server/server-worker.d.ts +4 -0
  1588. package/dist/server/server-worker.js +127 -0
  1589. package/dist/server/server-worker.js.map +1 -0
  1590. package/dist/server/session-events.d.ts +27 -0
  1591. package/dist/server/session-events.js +69 -0
  1592. package/dist/server/session-events.js.map +1 -0
  1593. package/dist/server/session-manager.d.ts +52 -0
  1594. package/dist/server/session-manager.js +502 -0
  1595. package/dist/server/session-manager.js.map +1 -0
  1596. package/dist/server/tool-router-discovery.d.ts +33 -0
  1597. package/dist/server/tool-router-discovery.js +218 -0
  1598. package/dist/server/tool-router-discovery.js.map +1 -0
  1599. package/dist/server/tool-router-types.d.ts +91 -0
  1600. package/dist/server/tool-router-types.js +336 -0
  1601. package/dist/server/tool-router-types.js.map +1 -0
  1602. package/dist/server/tool-router-user-tools.d.ts +16 -0
  1603. package/dist/server/tool-router-user-tools.js +269 -0
  1604. package/dist/server/tool-router-user-tools.js.map +1 -0
  1605. package/dist/server/tool-router.js +959 -599
  1606. package/dist/server/tool-router.js.map +1 -0
  1607. package/dist/server/validation-schemas.d.ts +12 -0
  1608. package/dist/server/validation-schemas.js +251 -0
  1609. package/dist/server/validation-schemas.js.map +1 -0
  1610. package/dist/server/validation.js +248 -188
  1611. package/dist/server/validation.js.map +1 -0
  1612. package/dist/server/worker.js +202 -133
  1613. package/dist/server/worker.js.map +1 -0
  1614. package/dist/setup.d.ts +2 -2
  1615. package/dist/setup.js +151 -147
  1616. package/dist/setup.js.map +1 -0
  1617. package/dist/shared/agent-core-config.d.ts +12 -0
  1618. package/dist/shared/agent-core-config.js +77 -0
  1619. package/dist/shared/agent-core-config.js.map +1 -0
  1620. package/dist/shared/agent-core-config.test.js +132 -0
  1621. package/dist/shared/agent-core-context-thinking.test.js +293 -0
  1622. package/dist/shared/agent-core-loop-calls.test.js +174 -0
  1623. package/dist/shared/agent-core-loop-detector-bail.test.js +201 -0
  1624. package/dist/shared/agent-core-loop-detector.test.js +195 -0
  1625. package/dist/shared/agent-core-loop-errors.test.js +258 -0
  1626. package/dist/shared/agent-core-loop.d.ts +53 -0
  1627. package/dist/shared/agent-core-loop.js +251 -0
  1628. package/dist/shared/agent-core-loop.js.map +1 -0
  1629. package/dist/shared/agent-core-pricing.test.js +191 -0
  1630. package/dist/shared/agent-core-sanitize-retry.test.js +129 -0
  1631. package/dist/shared/agent-core-tools.d.ts +32 -0
  1632. package/dist/shared/agent-core-tools.js +323 -0
  1633. package/dist/shared/agent-core-tools.js.map +1 -0
  1634. package/dist/shared/agent-core-types.d.ts +182 -0
  1635. package/dist/shared/agent-core-types.js +265 -0
  1636. package/dist/shared/agent-core-types.js.map +1 -0
  1637. package/dist/shared/agent-core.d.ts +115 -26
  1638. package/dist/shared/agent-core.js +956 -522
  1639. package/dist/shared/agent-core.js.map +1 -0
  1640. package/dist/shared/agent-loop-base.d.ts +130 -0
  1641. package/dist/shared/agent-loop-base.js +347 -0
  1642. package/dist/shared/agent-loop-base.js.map +1 -0
  1643. package/dist/shared/anthropic-types.js +1 -6
  1644. package/dist/shared/anthropic-types.js.map +1 -0
  1645. package/dist/shared/api-client-build-request.test.js +228 -0
  1646. package/dist/shared/api-client-build-system-caching.test.js +107 -0
  1647. package/dist/shared/api-client-build.test.js +223 -0
  1648. package/dist/shared/api-client-config.d.ts +21 -0
  1649. package/dist/shared/api-client-helpers.d.ts +57 -0
  1650. package/dist/shared/api-client-helpers.test.js +261 -0
  1651. package/dist/shared/api-client-proxy-happy.test.js +255 -0
  1652. package/dist/shared/api-client-proxy-retry.test.js +307 -0
  1653. package/dist/shared/api-client-proxy.d.ts +26 -0
  1654. package/dist/shared/api-client-proxy.test.js +255 -0
  1655. package/dist/shared/api-client-retry.test.js +307 -0
  1656. package/dist/shared/api-client-system-trimming.test.js +261 -0
  1657. package/dist/shared/api-client-trimming.d.ts +36 -0
  1658. package/dist/shared/api-client.d.ts +16 -9
  1659. package/dist/shared/api-client.js +419 -327
  1660. package/dist/shared/api-client.js.map +1 -0
  1661. package/dist/shared/api-client.test.js +228 -0
  1662. package/dist/shared/compaction-thinking.test.js +315 -0
  1663. package/dist/shared/compaction-trimming.test.js +223 -0
  1664. package/dist/shared/compaction.d.ts +36 -0
  1665. package/dist/shared/compaction.js +138 -0
  1666. package/dist/shared/compaction.js.map +1 -0
  1667. package/dist/shared/constants.js +67 -64
  1668. package/dist/shared/constants.js.map +1 -0
  1669. package/dist/shared/exec-validator.d.ts +29 -0
  1670. package/dist/shared/exec-validator.js +106 -0
  1671. package/dist/shared/exec-validator.js.map +1 -0
  1672. package/dist/shared/imsg-constants.d.ts +8 -0
  1673. package/dist/shared/imsg-constants.js +13 -0
  1674. package/dist/shared/imsg-constants.js.map +1 -0
  1675. package/dist/shared/sse-parser-callbacks.test.js +422 -0
  1676. package/dist/shared/sse-parser-collect.test.js +252 -0
  1677. package/dist/shared/sse-parser-e2e.test.js +558 -0
  1678. package/dist/shared/sse-parser-parse.test.js +253 -0
  1679. package/dist/shared/sse-parser.js +221 -219
  1680. package/dist/shared/sse-parser.js.map +1 -0
  1681. package/dist/shared/tool-dispatch-advanced-batch-build.test.js +405 -0
  1682. package/dist/shared/tool-dispatch-advanced.test.js +320 -0
  1683. package/dist/shared/tool-dispatch-basic.test.js +278 -0
  1684. package/dist/shared/tool-dispatch-content.d.ts +14 -0
  1685. package/dist/shared/tool-dispatch-parallel.test.js +378 -0
  1686. package/dist/shared/tool-dispatch.d.ts +4 -0
  1687. package/dist/shared/tool-dispatch.js +226 -165
  1688. package/dist/shared/tool-dispatch.js.map +1 -0
  1689. package/dist/shared/types.js +1 -6
  1690. package/dist/shared/types.js.map +1 -0
  1691. package/dist/types/cli-highlight.d.js +2 -0
  1692. package/dist/types/cli-highlight.d.js.map +1 -0
  1693. package/dist/types/diff.d.js +2 -0
  1694. package/dist/types/diff.d.js.map +1 -0
  1695. package/dist/types/pdf-parse.d.js +2 -0
  1696. package/dist/types/pdf-parse.d.js.map +1 -0
  1697. package/dist/updater.d.ts +1 -1
  1698. package/dist/updater.js +118 -92
  1699. package/dist/updater.js.map +1 -0
  1700. package/dist/webchat/__tests__/widget-messaging.test.js +323 -0
  1701. package/dist/webchat/__tests__/widget.test.js +273 -0
  1702. package/dist/webchat/widget-styles.d.ts +7 -0
  1703. package/dist/webchat/widget-styles.js +11 -0
  1704. package/dist/webchat/widget-styles.js.map +1 -0
  1705. package/dist/webchat/widget.js +227 -380
  1706. package/dist/webchat/widget.js.map +1 -0
  1707. package/package.json +24 -11
  1708. package/src/cli/services/builtin-skills/verify.md +72 -0
  1709. package/vendor/ink/build/ansi-tokenizer.d.ts +38 -0
  1710. package/vendor/ink/build/ansi-tokenizer.js +316 -0
  1711. package/vendor/ink/build/ansi-tokenizer.js.map +1 -0
  1712. package/vendor/ink/build/apply-styles.js +175 -0
  1713. package/vendor/ink/build/build-layout.js +77 -0
  1714. package/vendor/ink/build/calculate-wrapped-text.js +53 -0
  1715. package/vendor/ink/build/colorize.d.ts +3 -0
  1716. package/vendor/ink/build/colorize.js +48 -0
  1717. package/vendor/ink/build/colorize.js.map +1 -0
  1718. package/vendor/ink/build/components/AccessibilityContext.d.ts +3 -0
  1719. package/vendor/ink/build/components/AccessibilityContext.js +5 -0
  1720. package/vendor/ink/build/components/AccessibilityContext.js.map +1 -0
  1721. package/vendor/ink/build/components/App.d.ts +18 -0
  1722. package/vendor/ink/build/components/App.js +351 -0
  1723. package/vendor/ink/build/components/App.js.map +1 -0
  1724. package/vendor/ink/build/components/AppContext.d.ts +15 -0
  1725. package/vendor/ink/build/components/AppContext.js +11 -0
  1726. package/vendor/ink/build/components/AppContext.js.map +1 -0
  1727. package/vendor/ink/build/components/BackgroundContext.d.ts +4 -0
  1728. package/vendor/ink/build/components/BackgroundContext.js +3 -0
  1729. package/vendor/ink/build/components/BackgroundContext.js.map +1 -0
  1730. package/vendor/ink/build/components/Box.d.ts +117 -0
  1731. package/vendor/ink/build/components/Box.js +34 -0
  1732. package/vendor/ink/build/components/Box.js.map +1 -0
  1733. package/vendor/ink/build/components/Color.js +62 -0
  1734. package/vendor/ink/build/components/Cursor.d.ts +83 -0
  1735. package/vendor/ink/build/components/Cursor.js +53 -0
  1736. package/vendor/ink/build/components/Cursor.js.map +1 -0
  1737. package/vendor/ink/build/components/CursorContext.d.ts +11 -0
  1738. package/vendor/ink/build/components/CursorContext.js +8 -0
  1739. package/vendor/ink/build/components/CursorContext.js.map +1 -0
  1740. package/vendor/ink/build/components/ErrorBoundary.d.ts +18 -0
  1741. package/vendor/ink/build/components/ErrorBoundary.js +23 -0
  1742. package/vendor/ink/build/components/ErrorBoundary.js.map +1 -0
  1743. package/vendor/ink/build/components/ErrorOverview.d.ts +6 -0
  1744. package/vendor/ink/build/components/ErrorOverview.js +84 -0
  1745. package/vendor/ink/build/components/ErrorOverview.js.map +1 -0
  1746. package/vendor/ink/build/components/FocusContext.d.ts +16 -0
  1747. package/vendor/ink/build/components/FocusContext.js +17 -0
  1748. package/vendor/ink/build/components/FocusContext.js.map +1 -0
  1749. package/vendor/ink/build/components/Newline.d.ts +13 -0
  1750. package/vendor/ink/build/components/Newline.js +8 -0
  1751. package/vendor/ink/build/components/Newline.js.map +1 -0
  1752. package/vendor/ink/build/components/Spacer.d.ts +7 -0
  1753. package/vendor/ink/build/components/Spacer.js +11 -0
  1754. package/vendor/ink/build/components/Spacer.js.map +1 -0
  1755. package/vendor/ink/build/components/Static.d.ts +24 -0
  1756. package/vendor/ink/build/components/Static.js +28 -0
  1757. package/vendor/ink/build/components/Static.js.map +1 -0
  1758. package/vendor/ink/build/components/StderrContext.d.ts +15 -0
  1759. package/vendor/ink/build/components/StderrContext.js +13 -0
  1760. package/vendor/ink/build/components/StderrContext.js.map +1 -0
  1761. package/vendor/ink/build/components/StdinContext.d.ts +22 -0
  1762. package/vendor/ink/build/components/StdinContext.js +19 -0
  1763. package/vendor/ink/build/components/StdinContext.js.map +1 -0
  1764. package/vendor/ink/build/components/StdoutContext.d.ts +15 -0
  1765. package/vendor/ink/build/components/StdoutContext.js +13 -0
  1766. package/vendor/ink/build/components/StdoutContext.js.map +1 -0
  1767. package/vendor/ink/build/components/Text.d.ts +55 -0
  1768. package/vendor/ink/build/components/Text.js +50 -0
  1769. package/vendor/ink/build/components/Text.js.map +1 -0
  1770. package/vendor/ink/build/components/Transform.d.ts +16 -0
  1771. package/vendor/ink/build/components/Transform.js +15 -0
  1772. package/vendor/ink/build/components/Transform.js.map +1 -0
  1773. package/vendor/ink/build/cursor-helpers.d.ts +38 -0
  1774. package/vendor/ink/build/cursor-helpers.js +56 -0
  1775. package/vendor/ink/build/cursor-helpers.js.map +1 -0
  1776. package/vendor/ink/build/devtools-window-polyfill.d.ts +1 -0
  1777. package/vendor/ink/build/devtools-window-polyfill.js +65 -0
  1778. package/vendor/ink/build/devtools-window-polyfill.js.map +1 -0
  1779. package/vendor/ink/build/devtools.d.ts +1 -0
  1780. package/vendor/ink/build/devtools.js +11 -0
  1781. package/vendor/ink/build/devtools.js.map +1 -0
  1782. package/vendor/ink/build/dom.d.ts +56 -0
  1783. package/vendor/ink/build/dom.js +124 -0
  1784. package/vendor/ink/build/dom.js.map +1 -0
  1785. package/vendor/ink/build/experimental/apply-style.js +140 -0
  1786. package/vendor/ink/build/experimental/dom.js +123 -0
  1787. package/vendor/ink/build/experimental/output.js +91 -0
  1788. package/vendor/ink/build/experimental/reconciler.js +141 -0
  1789. package/vendor/ink/build/experimental/renderer.js +81 -0
  1790. package/vendor/ink/build/get-max-width.d.ts +3 -0
  1791. package/vendor/ink/build/get-max-width.js +10 -0
  1792. package/vendor/ink/build/get-max-width.js.map +1 -0
  1793. package/vendor/ink/build/hooks/use-app.d.ts +5 -0
  1794. package/vendor/ink/build/hooks/use-app.js +8 -0
  1795. package/vendor/ink/build/hooks/use-app.js.map +1 -0
  1796. package/vendor/ink/build/hooks/use-cursor.d.ts +12 -0
  1797. package/vendor/ink/build/hooks/use-cursor.js +29 -0
  1798. package/vendor/ink/build/hooks/use-cursor.js.map +1 -0
  1799. package/vendor/ink/build/hooks/use-focus-manager.d.ts +28 -0
  1800. package/vendor/ink/build/hooks/use-focus-manager.js +17 -0
  1801. package/vendor/ink/build/hooks/use-focus-manager.js.map +1 -0
  1802. package/vendor/ink/build/hooks/use-focus.d.ts +29 -0
  1803. package/vendor/ink/build/hooks/use-focus.js +42 -0
  1804. package/vendor/ink/build/hooks/use-focus.js.map +1 -0
  1805. package/vendor/ink/build/hooks/use-input.d.ts +131 -0
  1806. package/vendor/ink/build/hooks/use-input.js +124 -0
  1807. package/vendor/ink/build/hooks/use-input.js.map +1 -0
  1808. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.d.ts +5 -0
  1809. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js +11 -0
  1810. package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js.map +1 -0
  1811. package/vendor/ink/build/hooks/use-stderr.d.ts +5 -0
  1812. package/vendor/ink/build/hooks/use-stderr.js +8 -0
  1813. package/vendor/ink/build/hooks/use-stderr.js.map +1 -0
  1814. package/vendor/ink/build/hooks/use-stdin.d.ts +5 -0
  1815. package/vendor/ink/build/hooks/use-stdin.js +8 -0
  1816. package/vendor/ink/build/hooks/use-stdin.js.map +1 -0
  1817. package/vendor/ink/build/hooks/use-stdout.d.ts +5 -0
  1818. package/vendor/ink/build/hooks/use-stdout.js +8 -0
  1819. package/vendor/ink/build/hooks/use-stdout.js.map +1 -0
  1820. package/vendor/ink/build/hooks/useInput.js +38 -0
  1821. package/vendor/ink/build/index.d.ts +34 -0
  1822. package/vendor/ink/build/index.js +20 -0
  1823. package/vendor/ink/build/index.js.map +1 -0
  1824. package/vendor/ink/build/ink.d.ts +90 -0
  1825. package/vendor/ink/build/ink.js +677 -0
  1826. package/vendor/ink/build/ink.js.map +1 -0
  1827. package/vendor/ink/build/input-parser.d.ts +7 -0
  1828. package/vendor/ink/build/input-parser.js +154 -0
  1829. package/vendor/ink/build/input-parser.js.map +1 -0
  1830. package/vendor/ink/build/instance.js +205 -0
  1831. package/vendor/ink/build/instances.d.ts +3 -0
  1832. package/vendor/ink/build/instances.js +8 -0
  1833. package/vendor/ink/build/instances.js.map +1 -0
  1834. package/vendor/ink/build/kitty-keyboard.d.ts +23 -0
  1835. package/vendor/ink/build/kitty-keyboard.js +32 -0
  1836. package/vendor/ink/build/kitty-keyboard.js.map +1 -0
  1837. package/vendor/ink/build/layout.d.ts +7 -0
  1838. package/vendor/ink/build/layout.js +33 -0
  1839. package/vendor/ink/build/layout.js.map +1 -0
  1840. package/vendor/ink/build/log-update.d.ts +19 -0
  1841. package/vendor/ink/build/log-update.js +250 -0
  1842. package/vendor/ink/build/log-update.js.map +1 -0
  1843. package/vendor/ink/build/measure-element.d.ts +16 -0
  1844. package/vendor/ink/build/measure-element.js +9 -0
  1845. package/vendor/ink/build/measure-element.js.map +1 -0
  1846. package/vendor/ink/build/measure-text.d.ts +6 -0
  1847. package/vendor/ink/build/measure-text.js +21 -0
  1848. package/vendor/ink/build/measure-text.js.map +1 -0
  1849. package/vendor/ink/build/options.d.ts +52 -0
  1850. package/vendor/ink/build/options.js +2 -0
  1851. package/vendor/ink/build/options.js.map +1 -0
  1852. package/vendor/ink/build/output.d.ts +35 -0
  1853. package/vendor/ink/build/output.js +183 -0
  1854. package/vendor/ink/build/output.js.map +1 -0
  1855. package/vendor/ink/build/parse-keypress.d.ts +22 -0
  1856. package/vendor/ink/build/parse-keypress.js +493 -0
  1857. package/vendor/ink/build/parse-keypress.js.map +1 -0
  1858. package/vendor/ink/build/reconciler.d.ts +4 -0
  1859. package/vendor/ink/build/reconciler.js +274 -0
  1860. package/vendor/ink/build/reconciler.js.map +1 -0
  1861. package/vendor/ink/build/render-background.d.ts +4 -0
  1862. package/vendor/ink/build/render-background.js +25 -0
  1863. package/vendor/ink/build/render-background.js.map +1 -0
  1864. package/vendor/ink/build/render-border.d.ts +4 -0
  1865. package/vendor/ink/build/render-border.js +73 -0
  1866. package/vendor/ink/build/render-border.js.map +1 -0
  1867. package/vendor/ink/build/render-node-to-output.d.ts +14 -0
  1868. package/vendor/ink/build/render-node-to-output.js +147 -0
  1869. package/vendor/ink/build/render-node-to-output.js.map +1 -0
  1870. package/vendor/ink/build/render-to-string.d.ts +38 -0
  1871. package/vendor/ink/build/render-to-string.js +115 -0
  1872. package/vendor/ink/build/render-to-string.js.map +1 -0
  1873. package/vendor/ink/build/render.d.ts +121 -0
  1874. package/vendor/ink/build/render.js +55 -0
  1875. package/vendor/ink/build/render.js.map +1 -0
  1876. package/vendor/ink/build/renderer.d.ts +8 -0
  1877. package/vendor/ink/build/renderer.js +55 -0
  1878. package/vendor/ink/build/renderer.js.map +1 -0
  1879. package/vendor/ink/build/sanitize-ansi.d.ts +2 -0
  1880. package/vendor/ink/build/sanitize-ansi.js +27 -0
  1881. package/vendor/ink/build/sanitize-ansi.js.map +1 -0
  1882. package/vendor/ink/build/screen-reader-update.d.ts +13 -0
  1883. package/vendor/ink/build/screen-reader-update.js +38 -0
  1884. package/vendor/ink/build/screen-reader-update.js.map +1 -0
  1885. package/vendor/ink/build/squash-text-nodes.d.ts +3 -0
  1886. package/vendor/ink/build/squash-text-nodes.js +36 -0
  1887. package/vendor/ink/build/squash-text-nodes.js.map +1 -0
  1888. package/vendor/ink/build/styles.d.ts +240 -0
  1889. package/vendor/ink/build/styles.js +232 -0
  1890. package/vendor/ink/build/styles.js.map +1 -0
  1891. package/vendor/ink/build/utils.d.ts +2 -0
  1892. package/vendor/ink/build/utils.js +4 -0
  1893. package/vendor/ink/build/utils.js.map +1 -0
  1894. package/vendor/ink/build/wrap-text.d.ts +3 -0
  1895. package/vendor/ink/build/wrap-text.js +31 -0
  1896. package/vendor/ink/build/wrap-text.js.map +1 -0
  1897. package/vendor/ink/build/write-synchronized.d.ts +4 -0
  1898. package/vendor/ink/build/write-synchronized.js +7 -0
  1899. package/vendor/ink/build/write-synchronized.js.map +1 -0
  1900. package/vendor/ink/license +10 -0
  1901. package/vendor/ink/node_modules/@types/node/LICENSE +21 -0
  1902. package/vendor/ink/node_modules/@types/node/README.md +15 -0
  1903. package/vendor/ink/node_modules/@types/node/assert/strict.d.ts +105 -0
  1904. package/vendor/ink/node_modules/@types/node/assert.d.ts +955 -0
  1905. package/vendor/ink/node_modules/@types/node/async_hooks.d.ts +623 -0
  1906. package/vendor/ink/node_modules/@types/node/buffer.buffer.d.ts +466 -0
  1907. package/vendor/ink/node_modules/@types/node/buffer.d.ts +1810 -0
  1908. package/vendor/ink/node_modules/@types/node/child_process.d.ts +1428 -0
  1909. package/vendor/ink/node_modules/@types/node/cluster.d.ts +486 -0
  1910. package/vendor/ink/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
  1911. package/vendor/ink/node_modules/@types/node/console.d.ts +151 -0
  1912. package/vendor/ink/node_modules/@types/node/constants.d.ts +20 -0
  1913. package/vendor/ink/node_modules/@types/node/crypto.d.ts +4065 -0
  1914. package/vendor/ink/node_modules/@types/node/dgram.d.ts +564 -0
  1915. package/vendor/ink/node_modules/@types/node/diagnostics_channel.d.ts +576 -0
  1916. package/vendor/ink/node_modules/@types/node/dns/promises.d.ts +503 -0
  1917. package/vendor/ink/node_modules/@types/node/dns.d.ts +922 -0
  1918. package/vendor/ink/node_modules/@types/node/domain.d.ts +166 -0
  1919. package/vendor/ink/node_modules/@types/node/events.d.ts +1054 -0
  1920. package/vendor/ink/node_modules/@types/node/fs/promises.d.ts +1329 -0
  1921. package/vendor/ink/node_modules/@types/node/fs.d.ts +4676 -0
  1922. package/vendor/ink/node_modules/@types/node/globals.d.ts +150 -0
  1923. package/vendor/ink/node_modules/@types/node/globals.typedarray.d.ts +101 -0
  1924. package/vendor/ink/node_modules/@types/node/http.d.ts +2167 -0
  1925. package/vendor/ink/node_modules/@types/node/http2.d.ts +2480 -0
  1926. package/vendor/ink/node_modules/@types/node/https.d.ts +405 -0
  1927. package/vendor/ink/node_modules/@types/node/index.d.ts +115 -0
  1928. package/vendor/ink/node_modules/@types/node/inspector/promises.d.ts +41 -0
  1929. package/vendor/ink/node_modules/@types/node/inspector.d.ts +224 -0
  1930. package/vendor/ink/node_modules/@types/node/inspector.generated.d.ts +4226 -0
  1931. package/vendor/ink/node_modules/@types/node/module.d.ts +819 -0
  1932. package/vendor/ink/node_modules/@types/node/net.d.ts +933 -0
  1933. package/vendor/ink/node_modules/@types/node/os.d.ts +507 -0
  1934. package/vendor/ink/node_modules/@types/node/package.json +155 -0
  1935. package/vendor/ink/node_modules/@types/node/path/posix.d.ts +8 -0
  1936. package/vendor/ink/node_modules/@types/node/path/win32.d.ts +8 -0
  1937. package/vendor/ink/node_modules/@types/node/path.d.ts +187 -0
  1938. package/vendor/ink/node_modules/@types/node/perf_hooks.d.ts +643 -0
  1939. package/vendor/ink/node_modules/@types/node/process.d.ts +2156 -0
  1940. package/vendor/ink/node_modules/@types/node/punycode.d.ts +117 -0
  1941. package/vendor/ink/node_modules/@types/node/querystring.d.ts +152 -0
  1942. package/vendor/ink/node_modules/@types/node/quic.d.ts +910 -0
  1943. package/vendor/ink/node_modules/@types/node/readline/promises.d.ts +161 -0
  1944. package/vendor/ink/node_modules/@types/node/readline.d.ts +541 -0
  1945. package/vendor/ink/node_modules/@types/node/repl.d.ts +415 -0
  1946. package/vendor/ink/node_modules/@types/node/sea.d.ts +162 -0
  1947. package/vendor/ink/node_modules/@types/node/sqlite.d.ts +955 -0
  1948. package/vendor/ink/node_modules/@types/node/stream/consumers.d.ts +38 -0
  1949. package/vendor/ink/node_modules/@types/node/stream/promises.d.ts +211 -0
  1950. package/vendor/ink/node_modules/@types/node/stream/web.d.ts +296 -0
  1951. package/vendor/ink/node_modules/@types/node/stream.d.ts +1760 -0
  1952. package/vendor/ink/node_modules/@types/node/string_decoder.d.ts +67 -0
  1953. package/vendor/ink/node_modules/@types/node/test/reporters.d.ts +96 -0
  1954. package/vendor/ink/node_modules/@types/node/test.d.ts +2240 -0
  1955. package/vendor/ink/node_modules/@types/node/timers/promises.d.ts +108 -0
  1956. package/vendor/ink/node_modules/@types/node/timers.d.ts +159 -0
  1957. package/vendor/ink/node_modules/@types/node/tls.d.ts +1198 -0
  1958. package/vendor/ink/node_modules/@types/node/trace_events.d.ts +197 -0
  1959. package/vendor/ink/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +462 -0
  1960. package/vendor/ink/node_modules/@types/node/ts5.6/compatibility/float16array.d.ts +71 -0
  1961. package/vendor/ink/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +36 -0
  1962. package/vendor/ink/node_modules/@types/node/ts5.6/index.d.ts +117 -0
  1963. package/vendor/ink/node_modules/@types/node/ts5.7/compatibility/float16array.d.ts +72 -0
  1964. package/vendor/ink/node_modules/@types/node/ts5.7/index.d.ts +117 -0
  1965. package/vendor/ink/node_modules/@types/node/tty.d.ts +250 -0
  1966. package/vendor/ink/node_modules/@types/node/url.d.ts +519 -0
  1967. package/vendor/ink/node_modules/@types/node/util/types.d.ts +558 -0
  1968. package/vendor/ink/node_modules/@types/node/util.d.ts +1662 -0
  1969. package/vendor/ink/node_modules/@types/node/v8.d.ts +983 -0
  1970. package/vendor/ink/node_modules/@types/node/vm.d.ts +1208 -0
  1971. package/vendor/ink/node_modules/@types/node/wasi.d.ts +202 -0
  1972. package/vendor/ink/node_modules/@types/node/web-globals/abortcontroller.d.ts +59 -0
  1973. package/vendor/ink/node_modules/@types/node/web-globals/blob.d.ts +23 -0
  1974. package/vendor/ink/node_modules/@types/node/web-globals/console.d.ts +9 -0
  1975. package/vendor/ink/node_modules/@types/node/web-globals/crypto.d.ts +39 -0
  1976. package/vendor/ink/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  1977. package/vendor/ink/node_modules/@types/node/web-globals/encoding.d.ts +11 -0
  1978. package/vendor/ink/node_modules/@types/node/web-globals/events.d.ts +106 -0
  1979. package/vendor/ink/node_modules/@types/node/web-globals/fetch.d.ts +69 -0
  1980. package/vendor/ink/node_modules/@types/node/web-globals/importmeta.d.ts +13 -0
  1981. package/vendor/ink/node_modules/@types/node/web-globals/messaging.d.ts +23 -0
  1982. package/vendor/ink/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
  1983. package/vendor/ink/node_modules/@types/node/web-globals/performance.d.ts +45 -0
  1984. package/vendor/ink/node_modules/@types/node/web-globals/storage.d.ts +24 -0
  1985. package/vendor/ink/node_modules/@types/node/web-globals/streams.d.ts +115 -0
  1986. package/vendor/ink/node_modules/@types/node/web-globals/timers.d.ts +44 -0
  1987. package/vendor/ink/node_modules/@types/node/web-globals/url.d.ts +24 -0
  1988. package/vendor/ink/node_modules/@types/node/worker_threads.d.ts +717 -0
  1989. package/vendor/ink/node_modules/@types/node/zlib.d.ts +618 -0
  1990. package/vendor/ink/node_modules/node-pty/LICENSE +69 -0
  1991. package/vendor/ink/node_modules/node-pty/README.md +164 -0
  1992. package/vendor/ink/node_modules/node-pty/binding.gyp +150 -0
  1993. package/vendor/ink/node_modules/node-pty/lib/conpty_console_list_agent.js +25 -0
  1994. package/vendor/ink/node_modules/node-pty/lib/eventEmitter2.js +47 -0
  1995. package/vendor/ink/node_modules/node-pty/lib/index.js +52 -0
  1996. package/vendor/ink/node_modules/node-pty/lib/interfaces.js +7 -0
  1997. package/vendor/ink/node_modules/node-pty/lib/shared/conout.js +11 -0
  1998. package/vendor/ink/node_modules/node-pty/lib/terminal.js +190 -0
  1999. package/vendor/ink/node_modules/node-pty/lib/types.js +7 -0
  2000. package/vendor/ink/node_modules/node-pty/lib/unixTerminal.js +349 -0
  2001. package/vendor/ink/node_modules/node-pty/lib/utils.js +39 -0
  2002. package/vendor/ink/node_modules/node-pty/lib/windowsConoutConnection.js +125 -0
  2003. package/vendor/ink/node_modules/node-pty/lib/windowsPtyAgent.js +287 -0
  2004. package/vendor/ink/node_modules/node-pty/lib/windowsTerminal.js +201 -0
  2005. package/vendor/ink/node_modules/node-pty/lib/worker/conoutSocketWorker.js +22 -0
  2006. package/vendor/ink/node_modules/node-pty/package.json +65 -0
  2007. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/pty.node +0 -0
  2008. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/spawn-helper +0 -0
  2009. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/pty.node +0 -0
  2010. package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/spawn-helper +0 -0
  2011. package/vendor/ink/node_modules/node-pty/prebuilds/linux-arm64/pty.node +0 -0
  2012. package/vendor/ink/node_modules/node-pty/prebuilds/linux-x64/pty.node +0 -0
  2013. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/OpenConsole.exe +0 -0
  2014. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/conpty.dll +0 -0
  2015. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.node +0 -0
  2016. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.pdb +0 -0
  2017. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.node +0 -0
  2018. package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.pdb +0 -0
  2019. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/OpenConsole.exe +0 -0
  2020. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/conpty.dll +0 -0
  2021. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.node +0 -0
  2022. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.pdb +0 -0
  2023. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.node +0 -0
  2024. package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.pdb +0 -0
  2025. package/vendor/ink/node_modules/node-pty/scripts/post-install.js +76 -0
  2026. package/vendor/ink/node_modules/node-pty/scripts/prebuild.js +34 -0
  2027. package/vendor/ink/node_modules/node-pty/src/unix/pty.cc +875 -0
  2028. package/vendor/ink/node_modules/node-pty/src/unix/spawn-helper.cc +23 -0
  2029. package/vendor/ink/node_modules/node-pty/src/win/conpty.cc +582 -0
  2030. package/vendor/ink/node_modules/node-pty/src/win/conpty.h +41 -0
  2031. package/vendor/ink/node_modules/node-pty/src/win/conpty_console_list.cc +44 -0
  2032. package/vendor/ink/node_modules/node-pty/src/win/path_util.cc +95 -0
  2033. package/vendor/ink/node_modules/node-pty/src/win/path_util.h +26 -0
  2034. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/OpenConsole.exe +0 -0
  2035. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/conpty.dll +0 -0
  2036. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/OpenConsole.exe +0 -0
  2037. package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/conpty.dll +0 -0
  2038. package/vendor/ink/node_modules/node-pty/typings/node-pty.d.ts +215 -0
  2039. package/vendor/ink/node_modules/undici-types/LICENSE +21 -0
  2040. package/vendor/ink/node_modules/undici-types/README.md +6 -0
  2041. package/vendor/ink/node_modules/undici-types/agent.d.ts +32 -0
  2042. package/vendor/ink/node_modules/undici-types/api.d.ts +43 -0
  2043. package/vendor/ink/node_modules/undici-types/balanced-pool.d.ts +30 -0
  2044. package/vendor/ink/node_modules/undici-types/cache-interceptor.d.ts +173 -0
  2045. package/vendor/ink/node_modules/undici-types/cache.d.ts +36 -0
  2046. package/vendor/ink/node_modules/undici-types/client-stats.d.ts +15 -0
  2047. package/vendor/ink/node_modules/undici-types/client.d.ts +108 -0
  2048. package/vendor/ink/node_modules/undici-types/connector.d.ts +34 -0
  2049. package/vendor/ink/node_modules/undici-types/content-type.d.ts +21 -0
  2050. package/vendor/ink/node_modules/undici-types/cookies.d.ts +30 -0
  2051. package/vendor/ink/node_modules/undici-types/diagnostics-channel.d.ts +74 -0
  2052. package/vendor/ink/node_modules/undici-types/dispatcher.d.ts +276 -0
  2053. package/vendor/ink/node_modules/undici-types/env-http-proxy-agent.d.ts +22 -0
  2054. package/vendor/ink/node_modules/undici-types/errors.d.ts +161 -0
  2055. package/vendor/ink/node_modules/undici-types/eventsource.d.ts +66 -0
  2056. package/vendor/ink/node_modules/undici-types/fetch.d.ts +211 -0
  2057. package/vendor/ink/node_modules/undici-types/formdata.d.ts +108 -0
  2058. package/vendor/ink/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  2059. package/vendor/ink/node_modules/undici-types/global-origin.d.ts +7 -0
  2060. package/vendor/ink/node_modules/undici-types/h2c-client.d.ts +73 -0
  2061. package/vendor/ink/node_modules/undici-types/handlers.d.ts +15 -0
  2062. package/vendor/ink/node_modules/undici-types/header.d.ts +160 -0
  2063. package/vendor/ink/node_modules/undici-types/index.d.ts +88 -0
  2064. package/vendor/ink/node_modules/undici-types/interceptors.d.ts +73 -0
  2065. package/vendor/ink/node_modules/undici-types/mock-agent.d.ts +68 -0
  2066. package/vendor/ink/node_modules/undici-types/mock-call-history.d.ts +111 -0
  2067. package/vendor/ink/node_modules/undici-types/mock-client.d.ts +27 -0
  2068. package/vendor/ink/node_modules/undici-types/mock-errors.d.ts +12 -0
  2069. package/vendor/ink/node_modules/undici-types/mock-interceptor.d.ts +94 -0
  2070. package/vendor/ink/node_modules/undici-types/mock-pool.d.ts +27 -0
  2071. package/vendor/ink/node_modules/undici-types/package.json +55 -0
  2072. package/vendor/ink/node_modules/undici-types/patch.d.ts +29 -0
  2073. package/vendor/ink/node_modules/undici-types/pool-stats.d.ts +19 -0
  2074. package/vendor/ink/node_modules/undici-types/pool.d.ts +41 -0
  2075. package/vendor/ink/node_modules/undici-types/proxy-agent.d.ts +29 -0
  2076. package/vendor/ink/node_modules/undici-types/readable.d.ts +68 -0
  2077. package/vendor/ink/node_modules/undici-types/retry-agent.d.ts +8 -0
  2078. package/vendor/ink/node_modules/undici-types/retry-handler.d.ts +125 -0
  2079. package/vendor/ink/node_modules/undici-types/round-robin-pool.d.ts +41 -0
  2080. package/vendor/ink/node_modules/undici-types/snapshot-agent.d.ts +109 -0
  2081. package/vendor/ink/node_modules/undici-types/util.d.ts +18 -0
  2082. package/vendor/ink/node_modules/undici-types/utility.d.ts +7 -0
  2083. package/vendor/ink/node_modules/undici-types/webidl.d.ts +341 -0
  2084. package/vendor/ink/node_modules/undici-types/websocket.d.ts +186 -0
  2085. package/vendor/ink/package.json +201 -0
  2086. package/vendor/ink/readme.md +2636 -0
  2087. package/bin/swag-agent.js +0 -9
  2088. package/dist/server/lib/pg-rate-limiter.d.ts +0 -21
  2089. package/dist/server/lib/pg-rate-limiter.js +0 -86
@@ -1,823 +1,1114 @@
1
1
  import { sanitizeFilterValue } from "../lib/utils.js";
2
2
  import { handleEmail } from "./comms.js";
3
+
3
4
  /** Strip internal infrastructure fields that stores should never see */
4
5
  function stripInternal(row) {
5
- if (!row)
6
- return null;
7
- const { platform_user_id, store_id, password_hash, ...clean } = row;
8
- return clean;
6
+ if (!row) return null;
7
+ const {
8
+ platform_user_id,
9
+ store_id,
10
+ password_hash,
11
+ ...clean
12
+ } = row;
13
+ return clean;
9
14
  }
10
15
  function stripInternalArray(rows) {
11
- return (rows || []).map(r => stripInternal(r));
16
+ return (rows || []).map(r => stripInternal(r));
12
17
  }
13
18
  export async function handleCustomers(sb, args, storeId) {
14
- const sid = storeId;
15
- switch (args.action) {
16
- // ---- FIND: search customers via v_segment_customers view ----
17
- case "find": {
18
- const sortField = args.sort_by || "created_at";
19
- const sortAsc = args.sort_order === "asc";
20
- let q = sb.from("v_segment_customers")
21
- .select("id, first_name, last_name, email, phone, loyalty_points, loyalty_tier, total_spent, total_orders, lifetime_value, is_active, rfm_segment, is_vip_customer, is_at_risk, is_churned, reorder_due, ai_churn_risk, days_since_last_order, engagement_score, age_bracket, created_at")
22
- .eq("store_id", sid)
23
- .order(sortField, { ascending: sortAsc });
24
- if (args.limit)
25
- q = q.limit(args.limit);
26
- if (args.query) {
27
- const raw = sanitizeFilterValue(String(args.query).trim());
28
- const words = raw.split(/\s+/).filter(Boolean);
29
- if (words.length > 1) {
30
- const clauses = words.map(w => { const sw = sanitizeFilterValue(w); return `first_name.ilike.%${sw}%,last_name.ilike.%${sw}%`; }).join(",");
31
- q = q.or(`${clauses},email.ilike.%${raw}%,phone.ilike.%${raw}%`);
32
- }
33
- else {
34
- const term = `%${raw}%`;
35
- q = q.or(`first_name.ilike.${term},last_name.ilike.${term},email.ilike.${term},phone.ilike.${term}`);
36
- }
37
- }
38
- if (args.status === "active")
39
- q = q.eq("is_active", true);
40
- if (args.status === "inactive")
41
- q = q.eq("is_active", false);
42
- if (args.loyalty_tier)
43
- q = q.eq("loyalty_tier", args.loyalty_tier);
44
- if (args.rfm_segment)
45
- q = q.eq("rfm_segment", args.rfm_segment);
46
- if (args.is_vip !== undefined)
47
- q = q.eq("is_vip_customer", args.is_vip);
48
- if (args.is_at_risk !== undefined)
49
- q = q.eq("is_at_risk", args.is_at_risk);
50
- if (args.is_churned !== undefined)
51
- q = q.eq("is_churned", args.is_churned);
52
- if (args.reorder_due !== undefined)
53
- q = q.eq("reorder_due", args.reorder_due);
54
- if (args.age_bracket)
55
- q = q.eq("age_bracket", args.age_bracket);
56
- if (args.min_orders !== undefined)
57
- q = q.gte("total_orders", args.min_orders);
58
- if (args.max_orders !== undefined)
59
- q = q.lte("total_orders", args.max_orders);
60
- if (args.min_spent !== undefined)
61
- q = q.gte("total_spent", args.min_spent);
62
- if (args.max_spent !== undefined)
63
- q = q.lte("total_spent", args.max_spent);
64
- const { data, error } = await q;
65
- return error ? { success: false, error: error.message } : { success: true, count: data?.length, data };
19
+ const sid = storeId;
20
+ switch (args.action) {
21
+ // ---- FIND: search customers via v_segment_customers view ----
22
+ case "find":
23
+ {
24
+ const sortField = args.sort_by || "created_at";
25
+ const sortAsc = args.sort_order === "asc";
26
+ let q = sb.from("v_segment_customers").select("id, first_name, last_name, email, phone, loyalty_points, loyalty_tier, total_spent, total_orders, lifetime_value, is_active, rfm_segment, is_vip_customer, is_at_risk, is_churned, reorder_due, ai_churn_risk, days_since_last_order, engagement_score, age_bracket, created_at").eq("store_id", sid).order(sortField, {
27
+ ascending: sortAsc
28
+ });
29
+ if (args.limit) q = q.limit(args.limit);
30
+ if (args.query) {
31
+ const raw = sanitizeFilterValue(String(args.query).trim());
32
+ const words = raw.split(/\s+/).filter(Boolean);
33
+ if (words.length > 1) {
34
+ const clauses = words.map(w => {
35
+ const sw = sanitizeFilterValue(w);
36
+ return `first_name.ilike.%${sw}%,last_name.ilike.%${sw}%`;
37
+ }).join(",");
38
+ q = q.or(`${clauses},email.ilike.%${raw}%,phone.ilike.%${raw}%`);
39
+ } else {
40
+ const term = `%${raw}%`;
41
+ q = q.or(`first_name.ilike.${term},last_name.ilike.${term},email.ilike.${term},phone.ilike.${term}`);
42
+ }
66
43
  }
67
- // ---- GET: full 360° customer detail with orders, activity, notes, loyalty, segments ----
68
- case "get": {
69
- const custId = args.customer_id;
70
- const { data: customer, error: custErr } = await sb.from("v_segment_customers")
71
- .select("*").eq("id", custId).eq("store_id", sid).single();
72
- if (custErr)
73
- return { success: false, error: custErr.message };
74
- const [{ data: orders }, { data: notes }, { data: activity }, { data: profile }, { data: loyaltyHistory }, { data: segmentRows }] = await Promise.all([
75
- sb.from("orders")
76
- .select("id, order_number, status, total_amount, payment_status, fulfillment_status, created_at")
77
- .eq("customer_id", custId).eq("store_id", sid)
78
- .order("created_at", { ascending: false })
79
- .limit(args.orders_limit || 10),
80
- sb.from("customer_notes")
81
- .select("id, note, created_by, created_at")
82
- .eq("customer_id", custId)
83
- .order("created_at", { ascending: false }).limit(10),
84
- sb.from("customer_activity")
85
- .select("id, activity_type, description, created_at")
86
- .eq("customer_id", custId)
87
- .order("created_at", { ascending: false }).limit(10),
88
- sb.from("store_customer_profiles")
89
- .select("*").eq("relationship_id", custId).maybeSingle(),
90
- sb.from("loyalty_transactions")
91
- .select("id, points, transaction_type, reference_type, reference_id, description, balance_before, balance_after, expires_at, created_at")
92
- .eq("customer_id", custId)
93
- .order("created_at", { ascending: false }).limit(20),
94
- sb.from("customer_segment_memberships")
95
- .select("added_at, segment:customer_segments(id, name, type)")
96
- .eq("customer_id", custId),
97
- ]);
98
- // Flatten profile fields into customer object (skip sensitive + computed-only fields)
99
- const prof = profile;
100
- const profileFields = {};
101
- if (prof) {
102
- const skip = new Set([
103
- "id", "relationship_id", "created_at", "updated_at",
104
- "password_hash", // never expose
105
- // These are recomputed by refresh_metrics — read from the view instead
106
- "total_spent", "total_orders", "lifetime_value", "average_order_value",
107
- "first_order_at", "last_order_at",
108
- ]);
109
- for (const [k, v] of Object.entries(prof)) {
110
- if (!skip.has(k))
111
- profileFields[k] = v ?? null;
112
- }
113
- }
114
- // Flatten segment memberships
115
- const segments = (segmentRows || []).map((r) => ({
116
- segment_id: r.segment?.id, name: r.segment?.name, type: r.segment?.type, added_at: r.added_at,
117
- }));
118
- return { success: true, data: stripInternal({ ...customer, ...profileFields, orders, notes, activity, loyalty_history: loyaltyHistory || [], segments }) };
44
+ if (args.status === "active") q = q.eq("is_active", true);
45
+ if (args.status === "inactive") q = q.eq("is_active", false);
46
+ if (args.loyalty_tier) q = q.eq("loyalty_tier", args.loyalty_tier);
47
+ if (args.rfm_segment) q = q.eq("rfm_segment", args.rfm_segment);
48
+ if (args.is_vip !== undefined) q = q.eq("is_vip_customer", args.is_vip);
49
+ if (args.is_at_risk !== undefined) q = q.eq("is_at_risk", args.is_at_risk);
50
+ if (args.is_churned !== undefined) q = q.eq("is_churned", args.is_churned);
51
+ if (args.reorder_due !== undefined) q = q.eq("reorder_due", args.reorder_due);
52
+ if (args.age_bracket) q = q.eq("age_bracket", args.age_bracket);
53
+ if (args.min_orders !== undefined) q = q.gte("total_orders", args.min_orders);
54
+ if (args.max_orders !== undefined) q = q.lte("total_orders", args.max_orders);
55
+ if (args.min_spent !== undefined) q = q.gte("total_spent", args.min_spent);
56
+ if (args.max_spent !== undefined) q = q.lte("total_spent", args.max_spent);
57
+ const {
58
+ data,
59
+ error
60
+ } = await q;
61
+ return error ? {
62
+ success: false,
63
+ error: error.message
64
+ } : {
65
+ success: true,
66
+ count: data?.length,
67
+ data
68
+ };
69
+ }
70
+
71
+ // ---- GET: full 360° customer detail with orders, activity, notes, loyalty, segments ----
72
+ case "get":
73
+ {
74
+ const custId = args.customer_id;
75
+ const {
76
+ data: customer,
77
+ error: custErr
78
+ } = await sb.from("v_segment_customers").select("*").eq("id", custId).eq("store_id", sid).single();
79
+ if (custErr) return {
80
+ success: false,
81
+ error: custErr.message
82
+ };
83
+ const [{
84
+ data: orders
85
+ }, {
86
+ data: notes
87
+ }, {
88
+ data: activity
89
+ }, {
90
+ data: profile
91
+ }, {
92
+ data: loyaltyHistory
93
+ }, {
94
+ data: segmentRows
95
+ }] = await Promise.all([sb.from("orders").select("id, order_number, status, total_amount, payment_status, fulfillment_status, created_at").eq("customer_id", custId).eq("store_id", sid).order("created_at", {
96
+ ascending: false
97
+ }).limit(args.orders_limit || 10), sb.from("customer_notes").select("id, note, created_by, created_at").eq("customer_id", custId).order("created_at", {
98
+ ascending: false
99
+ }).limit(10), sb.from("customer_activity").select("id, activity_type, description, created_at").eq("customer_id", custId).order("created_at", {
100
+ ascending: false
101
+ }).limit(10), sb.from("store_customer_profiles").select("*").eq("relationship_id", custId).maybeSingle(), sb.from("loyalty_transactions").select("id, points, transaction_type, reference_type, reference_id, description, balance_before, balance_after, expires_at, created_at").eq("customer_id", custId).order("created_at", {
102
+ ascending: false
103
+ }).limit(20), sb.from("customer_segment_memberships").select("added_at, segment:customer_segments(id, name, type)").eq("customer_id", custId)]);
104
+
105
+ // Flatten profile fields into customer object (skip sensitive + computed-only fields)
106
+ const prof = profile;
107
+ const profileFields = {};
108
+ if (prof) {
109
+ const skip = new Set(["id", "relationship_id", "created_at", "updated_at", "password_hash",
110
+ // never expose
111
+ // These are recomputed by refresh_metrics — read from the view instead
112
+ "total_spent", "total_orders", "lifetime_value", "average_order_value", "first_order_at", "last_order_at"]);
113
+ for (const [k, v] of Object.entries(prof)) {
114
+ if (!skip.has(k)) profileFields[k] = v ?? null;
115
+ }
119
116
  }
120
- // ---- CREATE: new customer (platform_user + relationship + profile) ----
121
- // Matching priority: email → phone → drivers_license → name+DOB → create new
122
- case "create": {
123
- const email = args.email;
124
- const phone = args.phone;
125
- const firstName = args.first_name;
126
- const lastName = args.last_name;
127
- const dob = args.date_of_birth;
128
- const dl = args.drivers_license_number;
129
- if (!firstName && !lastName)
130
- return { success: false, error: "first_name or last_name is required" };
131
- // Multi-tier matching to find existing platform_user (mirrors POS verify flow)
132
- let platformUserId = null;
133
- let matchedVia = null;
134
- // Tier 1: email
135
- if (!platformUserId && email) {
136
- const { data: existing } = await sb.from("platform_users")
137
- .select("id").eq("email", email).maybeSingle();
138
- if (existing) {
139
- platformUserId = existing.id;
140
- matchedVia = "email";
141
- }
142
- }
143
- // Tier 2: phone
144
- if (!platformUserId && phone) {
145
- const { data: existing } = await sb.from("platform_users")
146
- .select("id").eq("phone", phone).maybeSingle();
147
- if (existing) {
148
- platformUserId = existing.id;
149
- matchedVia = "phone";
150
- }
151
- }
152
- // Tier 3: drivers license (look up via store_customer_profiles → relationship → platform_user)
153
- if (!platformUserId && dl) {
154
- const { data: profMatch } = await sb.from("store_customer_profiles")
155
- .select("relationship_id, relationship:user_creation_relationships!relationship_id(user_id, store_id)")
156
- .eq("drivers_license_number", dl).limit(1).maybeSingle();
157
- if (profMatch) {
158
- const rel = profMatch.relationship;
159
- if (rel?.user_id) {
160
- platformUserId = rel.user_id;
161
- matchedVia = "drivers_license";
162
- }
163
- }
164
- }
165
- // Tier 4: exact name + date of birth (only when all 3 are provided)
166
- if (!platformUserId && firstName && lastName && dob) {
167
- const { data: nameMatch } = await sb.from("platform_users")
168
- .select("id").ilike("first_name", firstName).ilike("last_name", lastName)
169
- .eq("date_of_birth", dob).limit(1).maybeSingle();
170
- if (nameMatch) {
171
- platformUserId = nameMatch.id;
172
- matchedVia = "name+dob";
173
- }
174
- }
175
- // Create platform_user if no match found
176
- const isNameOnly = !email && !phone;
177
- if (!platformUserId) {
178
- const puInsert = { first_name: firstName, last_name: lastName };
179
- if (email)
180
- puInsert.email = email;
181
- if (phone)
182
- puInsert.phone = phone;
183
- if (dob)
184
- puInsert.date_of_birth = dob;
185
- const { data: newPu, error: puErr } = await sb.from("platform_users")
186
- .insert(puInsert).select("id").single();
187
- if (puErr)
188
- return { success: false, error: `Failed to create platform user: ${puErr.message}` };
189
- platformUserId = newPu.id;
190
- }
191
- // Check if relationship already exists for this store
192
- const { data: existingRel } = await sb.from("user_creation_relationships")
193
- .select("id").eq("user_id", platformUserId).eq("store_id", sid).maybeSingle();
194
- if (existingRel) {
195
- const { data: existing } = await sb.from("v_store_customers")
196
- .select("*").eq("id", existingRel.id).single();
197
- return { success: true, data: stripInternal(existing), note: `Customer already exists (matched via ${matchedVia || "existing record"})` };
198
- }
199
- // Create relationship
200
- const { data: rel, error: relErr } = await sb.from("user_creation_relationships")
201
- .insert({
202
- user_id: platformUserId, creation_id: sid, creation_type: "store",
203
- store_id: sid, role: "user", status: "active",
204
- email_consent: args.email_consent ?? false,
205
- sms_consent: args.sms_consent ?? false,
206
- }).select("id").single();
207
- if (relErr)
208
- return { success: false, error: `Failed to create customer relationship: ${relErr.message}` };
209
- // Create store profile
210
- const profileInsert = { relationship_id: rel.id };
211
- if (args.street_address)
212
- profileInsert.street_address = args.street_address;
213
- if (args.city)
214
- profileInsert.city = args.city;
215
- if (args.state)
216
- profileInsert.state = args.state;
217
- if (args.postal_code)
218
- profileInsert.postal_code = args.postal_code;
219
- if (dl)
220
- profileInsert.drivers_license_number = dl;
221
- if (args.medical_card_number)
222
- profileInsert.medical_card_number = args.medical_card_number;
223
- if (args.medical_card_expiry)
224
- profileInsert.medical_card_expiry = args.medical_card_expiry;
225
- if (args.gender)
226
- profileInsert.gender = args.gender;
227
- if (args.eye_color)
228
- profileInsert.eye_color = args.eye_color;
229
- if (args.hair_color)
230
- profileInsert.hair_color = args.hair_color;
231
- if (args.height_raw)
232
- profileInsert.height_raw = args.height_raw;
233
- if (args.weight)
234
- profileInsert.weight = args.weight;
235
- if (args.suffix)
236
- profileInsert.suffix = args.suffix;
237
- if (args.is_staff !== undefined)
238
- profileInsert.is_staff = args.is_staff;
239
- await sb.from("store_customer_profiles").insert(profileInsert);
240
- const { data: created } = await sb.from("v_store_customers")
241
- .select("*").eq("id", rel.id).single();
242
- return {
243
- success: true,
244
- data: stripInternal(created),
245
- ...(matchedVia ? { note: `Linked to existing customer record (matched via ${matchedVia})` } : {}),
246
- ...(isNameOnly ? { warning: "Created with no email or phone — add contact info to prevent duplicates." } : {}),
247
- };
117
+
118
+ // Flatten segment memberships
119
+ const segments = (segmentRows || []).map(r => ({
120
+ segment_id: r.segment?.id,
121
+ name: r.segment?.name,
122
+ type: r.segment?.type,
123
+ added_at: r.added_at
124
+ }));
125
+ return {
126
+ success: true,
127
+ data: stripInternal({
128
+ ...customer,
129
+ ...profileFields,
130
+ orders,
131
+ notes,
132
+ activity,
133
+ loyalty_history: loyaltyHistory || [],
134
+ segments
135
+ })
136
+ };
137
+ }
138
+
139
+ // ---- CREATE: new customer (platform_user + relationship + profile) ----
140
+ // Matching priority: email → phone → drivers_license → name+DOB → create new
141
+ case "create":
142
+ {
143
+ const email = args.email;
144
+ const phone = args.phone;
145
+ const firstName = args.first_name;
146
+ const lastName = args.last_name;
147
+ const dob = args.date_of_birth;
148
+ const dl = args.drivers_license_number;
149
+ if (!firstName && !lastName) return {
150
+ success: false,
151
+ error: "first_name or last_name is required"
152
+ };
153
+
154
+ // Multi-tier matching to find existing platform_user (mirrors POS verify flow)
155
+ let platformUserId = null;
156
+ let matchedVia = null;
157
+
158
+ // Tier 1: email
159
+ if (!platformUserId && email) {
160
+ const {
161
+ data: existing
162
+ } = await sb.from("platform_users").select("id").eq("email", email).maybeSingle();
163
+ if (existing) {
164
+ platformUserId = existing.id;
165
+ matchedVia = "email";
166
+ }
248
167
  }
249
- // ---- UPDATE: modify any customer fields ----
250
- case "update": {
251
- const custId = args.customer_id;
252
- const { data: rel, error: relErr } = await sb.from("user_creation_relationships")
253
- .select("id, user_id").eq("id", custId).eq("store_id", sid).single();
254
- if (relErr)
255
- return { success: false, error: `Customer not found: ${relErr.message}` };
256
- // Customer identity (name, email, phone, DOB)
257
- const identityUpdates = {};
258
- if (args.first_name !== undefined)
259
- identityUpdates.first_name = args.first_name;
260
- if (args.last_name !== undefined)
261
- identityUpdates.last_name = args.last_name;
262
- if (args.email !== undefined)
263
- identityUpdates.email = args.email;
264
- if (args.phone !== undefined)
265
- identityUpdates.phone = args.phone;
266
- if (args.date_of_birth !== undefined)
267
- identityUpdates.date_of_birth = args.date_of_birth;
268
- if (Object.keys(identityUpdates).length > 0) {
269
- identityUpdates.updated_at = new Date().toISOString();
270
- const { error: puErr } = await sb.from("platform_users")
271
- .update(identityUpdates).eq("id", rel.user_id);
272
- if (puErr)
273
- return { success: false, error: `Failed to update customer: ${puErr.message}` };
274
- }
275
- // Consent & status
276
- const relUpdates = {};
277
- if (args.status !== undefined)
278
- relUpdates.status = args.status;
279
- if (args.email_consent !== undefined)
280
- relUpdates.email_consent = args.email_consent;
281
- if (args.sms_consent !== undefined)
282
- relUpdates.sms_consent = args.sms_consent;
283
- if (args.push_consent !== undefined)
284
- relUpdates.push_consent = args.push_consent;
285
- if (Object.keys(relUpdates).length > 0) {
286
- relUpdates.updated_at = new Date().toISOString();
287
- await sb.from("user_creation_relationships").update(relUpdates).eq("id", custId);
288
- }
289
- // Profile fields
290
- const profUpdates = {};
291
- if (args.loyalty_points !== undefined)
292
- profUpdates.loyalty_points = args.loyalty_points;
293
- if (args.loyalty_tier !== undefined)
294
- profUpdates.loyalty_tier = args.loyalty_tier;
295
- if (args.street_address !== undefined)
296
- profUpdates.street_address = args.street_address;
297
- if (args.city !== undefined)
298
- profUpdates.city = args.city;
299
- if (args.state !== undefined)
300
- profUpdates.state = args.state;
301
- if (args.postal_code !== undefined)
302
- profUpdates.postal_code = args.postal_code;
303
- if (args.billing_address !== undefined)
304
- profUpdates.billing_address = args.billing_address;
305
- if (args.shipping_addresses !== undefined)
306
- profUpdates.shipping_addresses = args.shipping_addresses;
307
- if (args.default_shipping_address_index !== undefined)
308
- profUpdates.default_shipping_address_index = args.default_shipping_address_index;
309
- if (args.drivers_license_number !== undefined)
310
- profUpdates.drivers_license_number = args.drivers_license_number;
311
- if (args.id_verified !== undefined) {
312
- profUpdates.id_verified = args.id_verified;
313
- if (args.id_verified === true)
314
- profUpdates.id_verified_at = new Date().toISOString();
315
- }
316
- if (args.license_expiration_date !== undefined)
317
- profUpdates.license_expiration_date = args.license_expiration_date;
318
- if (args.license_issue_date !== undefined)
319
- profUpdates.license_issue_date = args.license_issue_date;
320
- if (args.medical_card_number !== undefined)
321
- profUpdates.medical_card_number = args.medical_card_number;
322
- if (args.medical_card_expiry !== undefined)
323
- profUpdates.medical_card_expiry = args.medical_card_expiry;
324
- if (args.gender !== undefined)
325
- profUpdates.gender = args.gender;
326
- if (args.eye_color !== undefined)
327
- profUpdates.eye_color = args.eye_color;
328
- if (args.height_raw !== undefined)
329
- profUpdates.height_raw = args.height_raw;
330
- if (args.weight !== undefined)
331
- profUpdates.weight = args.weight;
332
- if (args.hair_color !== undefined)
333
- profUpdates.hair_color = args.hair_color;
334
- if (args.suffix !== undefined)
335
- profUpdates.suffix = args.suffix;
336
- if (args.is_staff !== undefined)
337
- profUpdates.is_staff = args.is_staff;
338
- if (args.has_wallet_pass !== undefined)
339
- profUpdates.has_wallet_pass = args.has_wallet_pass;
340
- if (args.is_wholesale_approved !== undefined)
341
- profUpdates.is_wholesale_approved = args.is_wholesale_approved;
342
- if (args.wholesale_tier !== undefined)
343
- profUpdates.wholesale_tier = args.wholesale_tier;
344
- if (args.wholesale_business_name !== undefined)
345
- profUpdates.wholesale_business_name = args.wholesale_business_name;
346
- if (args.wholesale_business_type !== undefined)
347
- profUpdates.wholesale_business_type = args.wholesale_business_type;
348
- if (args.wholesale_license_number !== undefined)
349
- profUpdates.wholesale_license_number = args.wholesale_license_number;
350
- if (args.wholesale_tax_id !== undefined)
351
- profUpdates.wholesale_tax_id = args.wholesale_tax_id;
352
- if (args.wholesale_discount_percent !== undefined)
353
- profUpdates.wholesale_discount_percent = args.wholesale_discount_percent;
354
- if (args.wholesale_payment_terms !== undefined)
355
- profUpdates.wholesale_payment_terms = args.wholesale_payment_terms;
356
- if (args.wholesale_credit_limit !== undefined)
357
- profUpdates.wholesale_credit_limit = args.wholesale_credit_limit;
358
- if (args.wholesale_resale_certificate !== undefined)
359
- profUpdates.wholesale_resale_certificate = args.wholesale_resale_certificate;
360
- if (args.wholesale_notes !== undefined)
361
- profUpdates.wholesale_notes = args.wholesale_notes;
362
- if (Object.keys(profUpdates).length > 0) {
363
- profUpdates.updated_at = new Date().toISOString();
364
- const { error: profErr } = await sb.from("store_customer_profiles")
365
- .update(profUpdates).eq("relationship_id", custId);
366
- if (profErr)
367
- return { success: false, error: `Failed to update profile: ${profErr.message}` };
368
- }
369
- const { data: updated } = await sb.from("v_segment_customers")
370
- .select("*").eq("id", custId).eq("store_id", sid).single();
371
- return { success: true, data: stripInternal(updated) };
168
+ // Tier 2: phone
169
+ if (!platformUserId && phone) {
170
+ const {
171
+ data: existing
172
+ } = await sb.from("platform_users").select("id").eq("phone", phone).maybeSingle();
173
+ if (existing) {
174
+ platformUserId = existing.id;
175
+ matchedVia = "phone";
176
+ }
372
177
  }
373
- // ---- FIND_DUPLICATES: identify potential duplicate customer accounts ----
374
- case "find_duplicates": {
375
- // Try RPC first (may not exist yet)
376
- const { data: dupes, error: dupeErr } = await sb.rpc("find_duplicate_customers", { p_store_id: sid });
377
- if (!dupeErr && dupes)
378
- return { success: true, data: dupes };
379
- // Fallback: manual duplicate detection by phone
380
- const { data: byPhone, error: phErr } = await sb.from("v_store_customers")
381
- .select("id, first_name, last_name, email, phone, total_spent, total_orders, created_at")
382
- .eq("store_id", sid).not("phone", "is", null).order("phone");
383
- if (phErr)
384
- return { success: false, error: phErr.message };
385
- const phoneMap = new Map();
386
- for (const c of byPhone || []) {
387
- if (!c.phone)
388
- continue;
389
- const normalized = c.phone.replace(/\D/g, "").slice(-10);
390
- if (!phoneMap.has(normalized))
391
- phoneMap.set(normalized, []);
392
- phoneMap.get(normalized).push(c);
393
- }
394
- const phoneDupes = Array.from(phoneMap.entries())
395
- .filter(([_, custs]) => custs.length > 1)
396
- .map(([phone, custs]) => ({ phone, count: custs.length, customers: custs }));
397
- // Also check by exact name match
398
- const { data: byName } = await sb.from("v_store_customers")
399
- .select("id, first_name, last_name, email, phone, total_spent, total_orders, created_at")
400
- .eq("store_id", sid).order("last_name").order("first_name");
401
- const nameMap = new Map();
402
- for (const c of byName || []) {
403
- const key = `${(c.first_name || "").toLowerCase().trim()} ${(c.last_name || "").toLowerCase().trim()}`;
404
- if (!key.trim())
405
- continue;
406
- if (!nameMap.has(key))
407
- nameMap.set(key, []);
408
- nameMap.get(key).push(c);
409
- }
410
- const nameDupes = Array.from(nameMap.entries())
411
- .filter(([_, custs]) => custs.length > 1)
412
- .map(([name, custs]) => ({ name, count: custs.length, customers: custs }));
413
- // Pre-format as markdown — formatter drops nested customer arrays
414
- const totalPhoneDupes = phoneDupes.reduce((s, d) => s + d.count, 0);
415
- const totalNameDupes = nameDupes.reduce((s, d) => s + d.count, 0);
416
- const lines = [
417
- `## Duplicate Customers`,
418
- `**By Phone**: ${phoneDupes.length} groups (${totalPhoneDupes} customers) | **By Name**: ${nameDupes.length} groups (${totalNameDupes} customers)\n`,
419
- ];
420
- if (phoneDupes.length > 0) {
421
- lines.push("### Phone Duplicates");
422
- for (const group of phoneDupes.slice(0, 20)) {
423
- lines.push(`\n**Phone ${group.phone}** (${group.count} customers):`);
424
- lines.push("| Name | Email | Phone | Orders | Spent | Created |");
425
- lines.push("| --- | --- | --- | ---: | ---: | --- |");
426
- for (const c of group.customers) {
427
- lines.push(`| ${c.first_name || ""} ${c.last_name || ""} | ${c.email || "—"} | ${c.phone || "—"} | ${c.total_orders ?? 0} | $${c.total_spent ?? 0} | ${c.created_at?.slice(0, 10) || "—"} |`);
428
- }
429
- }
430
- }
431
- if (nameDupes.length > 0) {
432
- lines.push("\n### Name Duplicates");
433
- for (const group of nameDupes.slice(0, 20)) {
434
- lines.push(`\n**"${group.name}"** (${group.count} customers):`);
435
- lines.push("| Name | Email | Phone | Orders | Spent | Created |");
436
- lines.push("| --- | --- | --- | ---: | ---: | --- |");
437
- for (const c of group.customers) {
438
- lines.push(`| ${c.first_name || ""} ${c.last_name || ""} | ${c.email || "—"} | ${c.phone || "—"} | ${c.total_orders ?? 0} | $${c.total_spent ?? 0} | ${c.created_at?.slice(0, 10) || "—"} |`);
439
- }
440
- }
178
+ // Tier 3: drivers license (look up via store_customer_profiles → relationship → platform_user)
179
+ if (!platformUserId && dl) {
180
+ const {
181
+ data: profMatch
182
+ } = await sb.from("store_customer_profiles").select("relationship_id, relationship:user_creation_relationships!relationship_id(user_id, store_id)").eq("drivers_license_number", dl).limit(1).maybeSingle();
183
+ if (profMatch) {
184
+ const rel = profMatch.relationship;
185
+ if (rel?.user_id) {
186
+ platformUserId = rel.user_id;
187
+ matchedVia = "drivers_license";
441
188
  }
442
- if (phoneDupes.length === 0 && nameDupes.length === 0) {
443
- lines.push("\nNo duplicates found.");
444
- }
445
- return { success: true, data: lines.join("\n") };
189
+ }
446
190
  }
447
- // ---- MERGE: merge two customer records into one ----
448
- case "merge": {
449
- const primaryId = args.primary_customer_id;
450
- const secondaryId = args.secondary_customer_id;
451
- if (!primaryId || !secondaryId)
452
- return { success: false, error: "primary_customer_id and secondary_customer_id required" };
453
- if (primaryId === secondaryId)
454
- return { success: false, error: "Cannot merge a customer with itself" };
455
- // Verify both exist and belong to this store
456
- const { data: primary } = await sb.from("v_store_customers").select("*").eq("id", primaryId).eq("store_id", sid).single();
457
- const { data: secondary } = await sb.from("v_store_customers").select("*").eq("id", secondaryId).eq("store_id", sid).single();
458
- if (!primary)
459
- return { success: false, error: `Primary customer ${primaryId} not found in this store` };
460
- if (!secondary)
461
- return { success: false, error: `Secondary customer ${secondaryId} not found in this store` };
462
- // Reassign all child records from secondary to primary
463
- // Tables with store_id column get scoped; tables without rely on customer ownership verification above
464
- const storeScoped = ["orders"];
465
- const customerOnly = ["customer_activity", "customer_notes", "customer_loyalty", "customer_sessions", "customer_segment_memberships"];
466
- const reassignResults = {};
467
- for (const table of storeScoped) {
468
- const { error, count } = await sb.from(table)
469
- .update({ customer_id: primaryId }).eq("customer_id", secondaryId).eq("store_id", sid);
470
- reassignResults[table] = error ? `error: ${error.message}` : `moved ${count ?? "?"} rows`;
471
- }
472
- for (const table of customerOnly) {
473
- const { error, count } = await sb.from(table)
474
- .update({ customer_id: primaryId }).eq("customer_id", secondaryId);
475
- reassignResults[table] = error ? `error: ${error.message}` : `moved ${count ?? "?"} rows`;
476
- }
477
- // Merge profile stats
478
- const { data: primaryProf } = await sb.from("store_customer_profiles")
479
- .select("*").eq("relationship_id", primaryId).maybeSingle();
480
- const { data: secondaryProf } = await sb.from("store_customer_profiles")
481
- .select("*").eq("relationship_id", secondaryId).maybeSingle();
482
- if (primaryProf && secondaryProf) {
483
- await sb.from("store_customer_profiles").update({
484
- total_spent: parseFloat(primaryProf.total_spent || 0) + parseFloat(secondaryProf.total_spent || 0),
485
- total_orders: (primaryProf.total_orders || 0) + (secondaryProf.total_orders || 0),
486
- loyalty_points: (primaryProf.loyalty_points || 0) + (secondaryProf.loyalty_points || 0),
487
- lifetime_points_earned: (primaryProf.lifetime_points_earned || 0) + (secondaryProf.lifetime_points_earned || 0),
488
- first_order_at: primaryProf.first_order_at && secondaryProf.first_order_at
489
- ? (primaryProf.first_order_at < secondaryProf.first_order_at ? primaryProf.first_order_at : secondaryProf.first_order_at)
490
- : primaryProf.first_order_at || secondaryProf.first_order_at,
491
- last_order_at: primaryProf.last_order_at && secondaryProf.last_order_at
492
- ? (primaryProf.last_order_at > secondaryProf.last_order_at ? primaryProf.last_order_at : secondaryProf.last_order_at)
493
- : primaryProf.last_order_at || secondaryProf.last_order_at,
494
- updated_at: new Date().toISOString(),
495
- }).eq("relationship_id", primaryId);
496
- await sb.from("store_customer_profiles").delete().eq("relationship_id", secondaryId);
497
- }
498
- // Mark secondary as merged
499
- await sb.from("user_creation_relationships").update({
500
- status: "merged",
501
- relationship_data: { merged_into: primaryId, merged_at: new Date().toISOString() },
502
- updated_at: new Date().toISOString(),
503
- }).eq("id", secondaryId).eq("store_id", sid);
504
- // Fill in missing identity fields from secondary
505
- const { data: primaryRel } = await sb.from("user_creation_relationships").select("user_id").eq("id", primaryId).eq("store_id", sid).single();
506
- const { data: secondaryRel } = await sb.from("user_creation_relationships").select("user_id").eq("id", secondaryId).eq("store_id", sid).single();
507
- if (primaryRel && secondaryRel) {
508
- const { data: pPu } = await sb.from("platform_users").select("*").eq("id", primaryRel.user_id).single();
509
- const { data: sPu } = await sb.from("platform_users").select("*").eq("id", secondaryRel.user_id).single();
510
- if (pPu && sPu) {
511
- const fills = {};
512
- if (!pPu.email && sPu.email && !sPu.email.startsWith("merged."))
513
- fills.email = sPu.email;
514
- if (!pPu.phone && sPu.phone && !sPu.phone.startsWith("merged_"))
515
- fills.phone = sPu.phone;
516
- if (!pPu.date_of_birth && sPu.date_of_birth)
517
- fills.date_of_birth = sPu.date_of_birth;
518
- if (Object.keys(fills).length > 0)
519
- await sb.from("platform_users").update(fills).eq("id", primaryRel.user_id);
520
- // Mark secondary identity as merged
521
- const marks = {};
522
- if (sPu.email && !sPu.email.startsWith("merged."))
523
- marks.email = `merged.${sPu.email}`;
524
- if (sPu.phone && !sPu.phone.startsWith("merged_"))
525
- marks.phone = `merged_${sPu.phone}`;
526
- if (Object.keys(marks).length > 0)
527
- await sb.from("platform_users").update(marks).eq("id", secondaryRel.user_id);
528
- }
529
- }
530
- const { data: merged } = await sb.from("v_store_customers").select("*").eq("id", primaryId).single();
531
- return { success: true, data: { merged_customer: stripInternal(merged), reassign_results: reassignResults } };
191
+ // Tier 4: exact name + date of birth (only when all 3 are provided)
192
+ if (!platformUserId && firstName && lastName && dob) {
193
+ const {
194
+ data: nameMatch
195
+ } = await sb.from("platform_users").select("id").ilike("first_name", firstName).ilike("last_name", lastName).eq("date_of_birth", dob).limit(1).maybeSingle();
196
+ if (nameMatch) {
197
+ platformUserId = nameMatch.id;
198
+ matchedVia = "name+dob";
199
+ }
532
200
  }
533
- // ---- ADD_NOTE ----
534
- case "add_note": {
535
- // Verify customer belongs to this store before adding note
536
- const { data: custCheck } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
537
- if (!custCheck)
538
- return { success: false, error: "Customer not found in this store" };
539
- const { data, error } = await sb.from("customer_notes")
540
- .insert({ customer_id: args.customer_id, note: args.note, created_by: args.created_by || "agent" })
541
- .select().single();
542
- return error ? { success: false, error: error.message } : { success: true, data };
201
+
202
+ // Create platform_user if no match found
203
+ const isNameOnly = !email && !phone;
204
+ if (!platformUserId) {
205
+ const puInsert = {
206
+ first_name: firstName,
207
+ last_name: lastName
208
+ };
209
+ if (email) puInsert.email = email;
210
+ if (phone) puInsert.phone = phone;
211
+ if (dob) puInsert.date_of_birth = dob;
212
+ const {
213
+ data: newPu,
214
+ error: puErr
215
+ } = await sb.from("platform_users").insert(puInsert).select("id").single();
216
+ if (puErr) return {
217
+ success: false,
218
+ error: `Failed to create platform user: ${puErr.message}`
219
+ };
220
+ platformUserId = newPu.id;
543
221
  }
544
- // ---- NOTES ----
545
- case "notes": {
546
- // Verify customer belongs to this store
547
- const { data: custCheck } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
548
- if (!custCheck)
549
- return { success: false, error: "Customer not found in this store" };
550
- const { data, error } = await sb.from("customer_notes")
551
- .select("id, note, created_by, created_at")
552
- .eq("customer_id", args.customer_id)
553
- .order("created_at", { ascending: false }).limit(args.limit || 25);
554
- return error ? { success: false, error: error.message } : { success: true, data };
222
+
223
+ // Check if relationship already exists for this store
224
+ const {
225
+ data: existingRel
226
+ } = await sb.from("user_creation_relationships").select("id").eq("user_id", platformUserId).eq("store_id", sid).maybeSingle();
227
+ if (existingRel) {
228
+ const {
229
+ data: existing
230
+ } = await sb.from("v_store_customers").select("*").eq("id", existingRel.id).single();
231
+ return {
232
+ success: true,
233
+ data: stripInternal(existing),
234
+ note: `Customer already exists (matched via ${matchedVia || "existing record"})`
235
+ };
555
236
  }
556
- // ---- ACTIVITY ----
557
- case "activity": {
558
- // Verify customer belongs to this store
559
- const { data: custCheck } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
560
- if (!custCheck)
561
- return { success: false, error: "Customer not found in this store" };
562
- const { data, error } = await sb.from("customer_activity")
563
- .select("id, activity_type, description, metadata, created_at")
564
- .eq("customer_id", args.customer_id)
565
- .order("created_at", { ascending: false }).limit(args.limit || 25);
566
- return error ? { success: false, error: error.message } : { success: true, data };
237
+
238
+ // Create relationship
239
+ const {
240
+ data: rel,
241
+ error: relErr
242
+ } = await sb.from("user_creation_relationships").insert({
243
+ user_id: platformUserId,
244
+ creation_id: sid,
245
+ creation_type: "store",
246
+ store_id: sid,
247
+ role: "user",
248
+ status: "active",
249
+ email_consent: args.email_consent ?? false,
250
+ sms_consent: args.sms_consent ?? false
251
+ }).select("id").single();
252
+ if (relErr) return {
253
+ success: false,
254
+ error: `Failed to create customer relationship: ${relErr.message}`
255
+ };
256
+
257
+ // Create store profile
258
+ const profileInsert = {
259
+ relationship_id: rel.id
260
+ };
261
+ if (args.street_address) profileInsert.street_address = args.street_address;
262
+ if (args.city) profileInsert.city = args.city;
263
+ if (args.state) profileInsert.state = args.state;
264
+ if (args.postal_code) profileInsert.postal_code = args.postal_code;
265
+ if (dl) profileInsert.drivers_license_number = dl;
266
+ if (args.medical_card_number) profileInsert.medical_card_number = args.medical_card_number;
267
+ if (args.medical_card_expiry) profileInsert.medical_card_expiry = args.medical_card_expiry;
268
+ if (args.gender) profileInsert.gender = args.gender;
269
+ if (args.eye_color) profileInsert.eye_color = args.eye_color;
270
+ if (args.hair_color) profileInsert.hair_color = args.hair_color;
271
+ if (args.height_raw) profileInsert.height_raw = args.height_raw;
272
+ if (args.weight) profileInsert.weight = args.weight;
273
+ if (args.suffix) profileInsert.suffix = args.suffix;
274
+ if (args.is_staff !== undefined) profileInsert.is_staff = args.is_staff;
275
+ await sb.from("store_customer_profiles").insert(profileInsert);
276
+ const {
277
+ data: created
278
+ } = await sb.from("v_store_customers").select("*").eq("id", rel.id).single();
279
+ return {
280
+ success: true,
281
+ data: stripInternal(created),
282
+ ...(matchedVia ? {
283
+ note: `Linked to existing customer record (matched via ${matchedVia})`
284
+ } : {}),
285
+ ...(isNameOnly ? {
286
+ warning: "Created with no email or phone — add contact info to prevent duplicates."
287
+ } : {})
288
+ };
289
+ }
290
+
291
+ // ---- UPDATE: modify any customer fields ----
292
+ case "update":
293
+ {
294
+ const custId = args.customer_id;
295
+ const {
296
+ data: rel,
297
+ error: relErr
298
+ } = await sb.from("user_creation_relationships").select("id, user_id").eq("id", custId).eq("store_id", sid).single();
299
+ if (relErr) return {
300
+ success: false,
301
+ error: `Customer not found: ${relErr.message}`
302
+ };
303
+
304
+ // Customer identity (name, email, phone, DOB)
305
+ const identityUpdates = {};
306
+ if (args.first_name !== undefined) identityUpdates.first_name = args.first_name;
307
+ if (args.last_name !== undefined) identityUpdates.last_name = args.last_name;
308
+ if (args.email !== undefined) identityUpdates.email = args.email;
309
+ if (args.phone !== undefined) identityUpdates.phone = args.phone;
310
+ if (args.date_of_birth !== undefined) identityUpdates.date_of_birth = args.date_of_birth;
311
+ if (Object.keys(identityUpdates).length > 0) {
312
+ identityUpdates.updated_at = new Date().toISOString();
313
+ const {
314
+ error: puErr
315
+ } = await sb.from("platform_users").update(identityUpdates).eq("id", rel.user_id);
316
+ if (puErr) return {
317
+ success: false,
318
+ error: `Failed to update customer: ${puErr.message}`
319
+ };
567
320
  }
568
- // ---- ORDERS: customer order history ----
569
- case "orders": {
570
- const { data, error } = await sb.from("orders")
571
- .select("id, order_number, status, total_amount, subtotal, tax_amount, payment_status, fulfillment_status, payment_method, created_at")
572
- .eq("customer_id", args.customer_id).eq("store_id", sid)
573
- .order("created_at", { ascending: false }).limit(args.limit || 25);
574
- return error ? { success: false, error: error.message } : { success: true, count: data?.length, data };
321
+
322
+ // Consent & status
323
+ const relUpdates = {};
324
+ if (args.status !== undefined) relUpdates.status = args.status;
325
+ if (args.email_consent !== undefined) relUpdates.email_consent = args.email_consent;
326
+ if (args.sms_consent !== undefined) relUpdates.sms_consent = args.sms_consent;
327
+ if (args.push_consent !== undefined) relUpdates.push_consent = args.push_consent;
328
+ if (Object.keys(relUpdates).length > 0) {
329
+ relUpdates.updated_at = new Date().toISOString();
330
+ await sb.from("user_creation_relationships").update(relUpdates).eq("id", custId);
575
331
  }
576
- // ---- LINK_CHANNEL_IDENTITY: connect a sender_id on any channel to a customer ----
577
- case "link_channel_identity": {
578
- const { customer_id, channel_type, sender_id, sender_name } = args;
579
- if (!customer_id || !channel_type || !sender_id) {
580
- return { success: false, error: "customer_id, channel_type, and sender_id are required" };
581
- }
582
- // Verify customer belongs to this store
583
- const { data: custCheck } = await sb.from("v_store_customers")
584
- .select("id").eq("id", customer_id).eq("store_id", sid).single();
585
- if (!custCheck)
586
- return { success: false, error: "Customer not found in this store" };
587
- const { error } = await sb.from("customer_channel_identities").upsert({
588
- store_id: sid,
589
- customer_id,
590
- channel_type,
591
- sender_id,
592
- sender_name: sender_name || null,
593
- verified: true,
594
- last_seen_at: new Date().toISOString(),
595
- }, { onConflict: "store_id,channel_type,sender_id" });
596
- return error
597
- ? { success: false, error: error.message }
598
- : { success: true, linked: { customer_id, channel_type, sender_id } };
332
+
333
+ // Profile fields
334
+ const profUpdates = {};
335
+ if (args.loyalty_points !== undefined) profUpdates.loyalty_points = args.loyalty_points;
336
+ if (args.loyalty_tier !== undefined) profUpdates.loyalty_tier = args.loyalty_tier;
337
+ if (args.street_address !== undefined) profUpdates.street_address = args.street_address;
338
+ if (args.city !== undefined) profUpdates.city = args.city;
339
+ if (args.state !== undefined) profUpdates.state = args.state;
340
+ if (args.postal_code !== undefined) profUpdates.postal_code = args.postal_code;
341
+ if (args.billing_address !== undefined) profUpdates.billing_address = args.billing_address;
342
+ if (args.shipping_addresses !== undefined) profUpdates.shipping_addresses = args.shipping_addresses;
343
+ if (args.default_shipping_address_index !== undefined) profUpdates.default_shipping_address_index = args.default_shipping_address_index;
344
+ if (args.drivers_license_number !== undefined) profUpdates.drivers_license_number = args.drivers_license_number;
345
+ if (args.id_verified !== undefined) {
346
+ profUpdates.id_verified = args.id_verified;
347
+ if (args.id_verified === true) profUpdates.id_verified_at = new Date().toISOString();
348
+ }
349
+ if (args.license_expiration_date !== undefined) profUpdates.license_expiration_date = args.license_expiration_date;
350
+ if (args.license_issue_date !== undefined) profUpdates.license_issue_date = args.license_issue_date;
351
+ if (args.medical_card_number !== undefined) profUpdates.medical_card_number = args.medical_card_number;
352
+ if (args.medical_card_expiry !== undefined) profUpdates.medical_card_expiry = args.medical_card_expiry;
353
+ if (args.gender !== undefined) profUpdates.gender = args.gender;
354
+ if (args.eye_color !== undefined) profUpdates.eye_color = args.eye_color;
355
+ if (args.height_raw !== undefined) profUpdates.height_raw = args.height_raw;
356
+ if (args.weight !== undefined) profUpdates.weight = args.weight;
357
+ if (args.hair_color !== undefined) profUpdates.hair_color = args.hair_color;
358
+ if (args.suffix !== undefined) profUpdates.suffix = args.suffix;
359
+ if (args.is_staff !== undefined) profUpdates.is_staff = args.is_staff;
360
+ if (args.has_wallet_pass !== undefined) profUpdates.has_wallet_pass = args.has_wallet_pass;
361
+ if (args.is_wholesale_approved !== undefined) profUpdates.is_wholesale_approved = args.is_wholesale_approved;
362
+ if (args.wholesale_tier !== undefined) profUpdates.wholesale_tier = args.wholesale_tier;
363
+ if (args.wholesale_business_name !== undefined) profUpdates.wholesale_business_name = args.wholesale_business_name;
364
+ if (args.wholesale_business_type !== undefined) profUpdates.wholesale_business_type = args.wholesale_business_type;
365
+ if (args.wholesale_license_number !== undefined) profUpdates.wholesale_license_number = args.wholesale_license_number;
366
+ if (args.wholesale_tax_id !== undefined) profUpdates.wholesale_tax_id = args.wholesale_tax_id;
367
+ if (args.wholesale_discount_percent !== undefined) profUpdates.wholesale_discount_percent = args.wholesale_discount_percent;
368
+ if (args.wholesale_payment_terms !== undefined) profUpdates.wholesale_payment_terms = args.wholesale_payment_terms;
369
+ if (args.wholesale_credit_limit !== undefined) profUpdates.wholesale_credit_limit = args.wholesale_credit_limit;
370
+ if (args.wholesale_resale_certificate !== undefined) profUpdates.wholesale_resale_certificate = args.wholesale_resale_certificate;
371
+ if (args.wholesale_notes !== undefined) profUpdates.wholesale_notes = args.wholesale_notes;
372
+ if (Object.keys(profUpdates).length > 0) {
373
+ profUpdates.updated_at = new Date().toISOString();
374
+ const {
375
+ error: profErr
376
+ } = await sb.from("store_customer_profiles").update(profUpdates).eq("relationship_id", custId);
377
+ if (profErr) return {
378
+ success: false,
379
+ error: `Failed to update profile: ${profErr.message}`
380
+ };
381
+ }
382
+ const {
383
+ data: updated
384
+ } = await sb.from("v_segment_customers").select("*").eq("id", custId).eq("store_id", sid).single();
385
+ return {
386
+ success: true,
387
+ data: stripInternal(updated)
388
+ };
389
+ }
390
+
391
+ // ---- FIND_DUPLICATES: identify potential duplicate customer accounts ----
392
+ case "find_duplicates":
393
+ {
394
+ // Try RPC first (may not exist yet)
395
+ const {
396
+ data: dupes,
397
+ error: dupeErr
398
+ } = await sb.rpc("find_duplicate_customers", {
399
+ p_store_id: sid
400
+ });
401
+ if (!dupeErr && dupes) return {
402
+ success: true,
403
+ data: dupes
404
+ };
405
+
406
+ // Fallback: manual duplicate detection by phone
407
+ const {
408
+ data: byPhone,
409
+ error: phErr
410
+ } = await sb.from("v_store_customers").select("id, first_name, last_name, email, phone, total_spent, total_orders, created_at").eq("store_id", sid).not("phone", "is", null).order("phone");
411
+ if (phErr) return {
412
+ success: false,
413
+ error: phErr.message
414
+ };
415
+ const phoneMap = new Map();
416
+ for (const c of byPhone || []) {
417
+ if (!c.phone) continue;
418
+ const normalized = c.phone.replace(/\D/g, "").slice(-10);
419
+ if (!phoneMap.has(normalized)) phoneMap.set(normalized, []);
420
+ phoneMap.get(normalized).push(c);
599
421
  }
600
- // ---- GET_CHANNEL_IDENTITIES: list all channel identities for a customer ----
601
- case "get_channel_identities": {
602
- const custId = args.customer_id;
603
- if (!custId)
604
- return { success: false, error: "customer_id is required" };
605
- const { data, error } = await sb.from("customer_channel_identities")
606
- .select("id, channel_type, sender_id, sender_name, verified, last_seen_at, created_at")
607
- .eq("store_id", sid).eq("customer_id", custId)
608
- .order("last_seen_at", { ascending: false });
609
- return error ? { success: false, error: error.message } : { success: true, data };
422
+ const phoneDupes = Array.from(phoneMap.entries()).filter(([_, custs]) => custs.length > 1).map(([phone, custs]) => ({
423
+ phone,
424
+ count: custs.length,
425
+ customers: custs
426
+ }));
427
+
428
+ // Also check by exact name match
429
+ const {
430
+ data: byName
431
+ } = await sb.from("v_store_customers").select("id, first_name, last_name, email, phone, total_spent, total_orders, created_at").eq("store_id", sid).order("last_name").order("first_name");
432
+ const nameMap = new Map();
433
+ for (const c of byName || []) {
434
+ const key = `${(c.first_name || "").toLowerCase().trim()} ${(c.last_name || "").toLowerCase().trim()}`;
435
+ if (!key.trim()) continue;
436
+ if (!nameMap.has(key)) nameMap.set(key, []);
437
+ nameMap.get(key).push(c);
610
438
  }
611
- // ---- INVITE: create auth account for customer and send branded invite email ----
612
- case "invite": {
613
- const custId = args.customer_id;
614
- if (!custId)
615
- return { success: false, error: "customer_id is required" };
616
- // Verify customer belongs to this store
617
- const { data: rel, error: relErr } = await sb.from("user_creation_relationships")
618
- .select("id, user_id, store_id")
619
- .eq("id", custId).eq("store_id", sid).single();
620
- if (relErr || !rel)
621
- return { success: false, error: "Customer not found for this store" };
622
- // Get platform user + store name in parallel
623
- const [{ data: pu }, { data: store }] = await Promise.all([
624
- sb.from("platform_users").select("id, auth_id, email, first_name, last_name").eq("id", rel.user_id).single(),
625
- sb.from("stores").select("store_name").eq("id", sid).single(),
626
- ]);
627
- if (!pu)
628
- return { success: false, error: "Platform user not found" };
629
- if (!pu.email)
630
- return { success: false, error: "Customer has no email address — add one first" };
631
- const storeName = store?.store_name || "our platform";
632
- const customerName = [pu.first_name, pu.last_name].filter(Boolean).join(" ") || "there";
633
- const portalUrl = args.portal_url || args.redirect_to || null;
634
- // If already has an auth account, just resend the email with a new magic link
635
- let authId = pu.auth_id;
636
- if (!authId) {
637
- // Create auth account silently (no Supabase built-in email)
638
- const { data: newUser, error: createErr } = await sb.auth.admin.createUser({
639
- email: pu.email,
640
- email_confirm: true, // skip verification — store is vouching for this email
641
- user_metadata: {
642
- first_name: pu.first_name,
643
- last_name: pu.last_name,
644
- invited_by_store: sid,
645
- },
646
- });
647
- if (createErr)
648
- return { success: false, error: `Account creation failed: ${createErr.message}` };
649
- authId = newUser.user.id;
650
- // Link auth account to platform user
651
- await sb.from("platform_users").update({ auth_id: authId }).eq("id", pu.id);
439
+ const nameDupes = Array.from(nameMap.entries()).filter(([_, custs]) => custs.length > 1).map(([name, custs]) => ({
440
+ name,
441
+ count: custs.length,
442
+ customers: custs
443
+ }));
444
+
445
+ // Pre-format as markdown formatter drops nested customer arrays
446
+ const totalPhoneDupes = phoneDupes.reduce((s, d) => s + d.count, 0);
447
+ const totalNameDupes = nameDupes.reduce((s, d) => s + d.count, 0);
448
+ const lines = [`## Duplicate Customers`, `**By Phone**: ${phoneDupes.length} groups (${totalPhoneDupes} customers) | **By Name**: ${nameDupes.length} groups (${totalNameDupes} customers)\n`];
449
+ if (phoneDupes.length > 0) {
450
+ lines.push("### Phone Duplicates");
451
+ for (const group of phoneDupes.slice(0, 20)) {
452
+ lines.push(`\n**Phone ${group.phone}** (${group.count} customers):`);
453
+ lines.push("| Name | Email | Phone | Orders | Spent | Created |");
454
+ lines.push("| --- | --- | --- | ---: | ---: | --- |");
455
+ for (const c of group.customers) {
456
+ lines.push(`| ${c.first_name || ""} ${c.last_name || ""} | ${c.email || "—"} | ${c.phone || "—"} | ${c.total_orders ?? 0} | $${c.total_spent ?? 0} | ${c.created_at?.slice(0, 10) || "—"} |`);
652
457
  }
653
- // Generate a magic link for the customer to set up / log in
654
- const { data: linkData, error: linkErr } = await sb.auth.admin.generateLink({
655
- type: "magiclink",
656
- email: pu.email,
657
- options: {
658
- ...(portalUrl ? { redirectTo: portalUrl } : {}),
659
- },
660
- });
661
- if (linkErr)
662
- return { success: false, error: `Link generation failed: ${linkErr.message}` };
663
- const magicLink = linkData?.properties?.action_link || "";
664
- // Send branded invite email through our email system
665
- const emailResult = await handleEmail(sb, {
666
- action: "send_template",
667
- to: pu.email,
668
- template: "customer-portal-invite",
669
- template_data: {
670
- customer_name: customerName,
671
- store_name: storeName,
672
- magic_link: magicLink,
673
- portal_url: portalUrl || magicLink,
674
- },
675
- }, sid);
676
- return {
677
- success: true,
678
- data: {
679
- email: pu.email,
680
- name: customerName,
681
- invited: true,
682
- email_sent: emailResult.success,
683
- ...(emailResult.success ? {} : { email_error: emailResult.error }),
684
- },
685
- };
458
+ }
686
459
  }
687
- // ---- LOYALTY_HISTORY: transaction history for a customer ----
688
- case "loyalty_history": {
689
- const custId = args.customer_id;
690
- if (!custId)
691
- return { success: false, error: "customer_id is required" };
692
- let q = sb.from("loyalty_transactions")
693
- .select("id, points, transaction_type, reference_type, reference_id, description, balance_before, balance_after, expires_at, created_at")
694
- .eq("customer_id", custId)
695
- .order("created_at", { ascending: false });
696
- if (args.transaction_type)
697
- q = q.eq("transaction_type", args.transaction_type);
698
- q = q.limit(args.limit || 50);
699
- const { data, error } = await q;
700
- return error ? { success: false, error: error.message } : { success: true, count: data?.length, data };
460
+ if (nameDupes.length > 0) {
461
+ lines.push("\n### Name Duplicates");
462
+ for (const group of nameDupes.slice(0, 20)) {
463
+ lines.push(`\n**"${group.name}"** (${group.count} customers):`);
464
+ lines.push("| Name | Email | Phone | Orders | Spent | Created |");
465
+ lines.push("| --- | --- | --- | ---: | ---: | --- |");
466
+ for (const c of group.customers) {
467
+ lines.push(`| ${c.first_name || ""} ${c.last_name || ""} | ${c.email || "—"} | ${c.phone || "—"} | ${c.total_orders ?? 0} | $${c.total_spent ?? 0} | ${c.created_at?.slice(0, 10) || "—"} |`);
468
+ }
469
+ }
701
470
  }
702
- // ---- ADJUST_LOYALTY: award or deduct loyalty points via RPC ----
703
- case "adjust_loyalty": {
704
- const custId = args.customer_id;
705
- const points = args.points;
706
- const reason = args.reason;
707
- if (!custId || points === undefined || !reason)
708
- return { success: false, error: "customer_id, points, and reason are required" };
709
- const { data, error } = await sb.rpc("adjust_customer_loyalty_points", {
710
- p_customer_id: custId,
711
- p_points_change: points,
712
- p_reason: reason,
713
- });
714
- if (error)
715
- return { success: false, error: error.message };
716
- const { data: updated } = await sb.from("store_customer_profiles")
717
- .select("loyalty_points, loyalty_tier, lifetime_points_earned")
718
- .eq("relationship_id", custId).maybeSingle();
719
- return { success: true, data: { rpc_result: data, ...updated } };
471
+ if (phoneDupes.length === 0 && nameDupes.length === 0) {
472
+ lines.push("\nNo duplicates found.");
720
473
  }
721
- // ---- SEGMENTS: list all customer segments for the store ----
722
- case "segments": {
723
- let q = sb.from("customer_segments")
724
- .select("id, name, ai_description, type, segment_rules, filter_criteria, customer_count, is_active, color, icon, targeting_tips, created_at")
725
- .eq("store_id", sid)
726
- .order("customer_count", { ascending: false });
727
- if (args.limit)
728
- q = q.limit(args.limit);
729
- const { data, error } = await q;
730
- return error ? { success: false, error: error.message } : { success: true, count: data?.length, data };
474
+ return {
475
+ success: true,
476
+ data: lines.join("\n")
477
+ };
478
+ }
479
+
480
+ // ---- MERGE: merge two customer records into one ----
481
+ case "merge":
482
+ {
483
+ const primaryId = args.primary_customer_id;
484
+ const secondaryId = args.secondary_customer_id;
485
+ if (!primaryId || !secondaryId) return {
486
+ success: false,
487
+ error: "primary_customer_id and secondary_customer_id required"
488
+ };
489
+ if (primaryId === secondaryId) return {
490
+ success: false,
491
+ error: "Cannot merge a customer with itself"
492
+ };
493
+
494
+ // Verify both exist and belong to this store
495
+ const {
496
+ data: primary
497
+ } = await sb.from("v_store_customers").select("*").eq("id", primaryId).eq("store_id", sid).single();
498
+ const {
499
+ data: secondary
500
+ } = await sb.from("v_store_customers").select("*").eq("id", secondaryId).eq("store_id", sid).single();
501
+ if (!primary) return {
502
+ success: false,
503
+ error: `Primary customer ${primaryId} not found in this store`
504
+ };
505
+ if (!secondary) return {
506
+ success: false,
507
+ error: `Secondary customer ${secondaryId} not found in this store`
508
+ };
509
+
510
+ // Reassign all child records from secondary to primary
511
+ // Tables with store_id column get scoped; tables without rely on customer ownership verification above
512
+ const storeScoped = ["orders"];
513
+ const customerOnly = ["customer_activity", "customer_notes", "customer_loyalty", "customer_sessions", "customer_segment_memberships"];
514
+ const reassignResults = {};
515
+ for (const table of storeScoped) {
516
+ const {
517
+ error,
518
+ count
519
+ } = await sb.from(table).update({
520
+ customer_id: primaryId
521
+ }).eq("customer_id", secondaryId).eq("store_id", sid);
522
+ reassignResults[table] = error ? `error: ${error.message}` : `moved ${count ?? "?"} rows`;
731
523
  }
732
- // ---- SEGMENT_MEMBERS: list customers in a specific segment ----
733
- case "segment_members": {
734
- const segId = args.segment_id;
735
- if (!segId)
736
- return { success: false, error: "segment_id is required" };
737
- const { data, error } = await sb.from("customer_segment_memberships")
738
- .select("added_at, customer:v_segment_customers!customer_id(*)")
739
- .eq("segment_id", segId)
740
- .order("added_at", { ascending: false })
741
- .limit(args.limit || 50);
742
- if (error)
743
- return { success: false, error: error.message };
744
- const members = (data || []).map((r) => ({ added_at: r.added_at, ...r.customer }))
745
- .filter((m) => m.store_id === sid);
746
- return { success: true, count: members.length, data: stripInternalArray(members) };
524
+ for (const table of customerOnly) {
525
+ const {
526
+ error,
527
+ count
528
+ } = await sb.from(table).update({
529
+ customer_id: primaryId
530
+ }).eq("customer_id", secondaryId);
531
+ reassignResults[table] = error ? `error: ${error.message}` : `moved ${count ?? "?"} rows`;
747
532
  }
748
- // ---- REFRESH_METRICS: recalculate all customer metrics for the store ----
749
- case "refresh_metrics": {
750
- const start = Date.now();
751
- const { data, error } = await sb.rpc("refresh_customer_metrics", { p_store_id: sid });
752
- const elapsed = Date.now() - start;
753
- if (error)
754
- return { success: false, error: error.message };
755
- return { success: true, data: { result: data, elapsed_ms: elapsed, message: `Customer metrics refreshed in ${elapsed}ms` } };
533
+
534
+ // Merge profile stats
535
+ const {
536
+ data: primaryProf
537
+ } = await sb.from("store_customer_profiles").select("*").eq("relationship_id", primaryId).maybeSingle();
538
+ const {
539
+ data: secondaryProf
540
+ } = await sb.from("store_customer_profiles").select("*").eq("relationship_id", secondaryId).maybeSingle();
541
+ if (primaryProf && secondaryProf) {
542
+ await sb.from("store_customer_profiles").update({
543
+ total_spent: parseFloat(primaryProf.total_spent || 0) + parseFloat(secondaryProf.total_spent || 0),
544
+ total_orders: (primaryProf.total_orders || 0) + (secondaryProf.total_orders || 0),
545
+ loyalty_points: (primaryProf.loyalty_points || 0) + (secondaryProf.loyalty_points || 0),
546
+ lifetime_points_earned: (primaryProf.lifetime_points_earned || 0) + (secondaryProf.lifetime_points_earned || 0),
547
+ first_order_at: primaryProf.first_order_at && secondaryProf.first_order_at ? primaryProf.first_order_at < secondaryProf.first_order_at ? primaryProf.first_order_at : secondaryProf.first_order_at : primaryProf.first_order_at || secondaryProf.first_order_at,
548
+ last_order_at: primaryProf.last_order_at && secondaryProf.last_order_at ? primaryProf.last_order_at > secondaryProf.last_order_at ? primaryProf.last_order_at : secondaryProf.last_order_at : primaryProf.last_order_at || secondaryProf.last_order_at,
549
+ updated_at: new Date().toISOString()
550
+ }).eq("relationship_id", primaryId);
551
+ await sb.from("store_customer_profiles").delete().eq("relationship_id", secondaryId);
756
552
  }
757
- default:
758
- return { success: false, error: `Unknown customers action: ${args.action}. Valid: find, get, create, update, invite, find_duplicates, merge, add_note, notes, activity, orders, loyalty_history, adjust_loyalty, segments, segment_members, refresh_metrics, link_channel_identity, get_channel_identities` };
759
- }
760
- }
761
- export async function handleOrders(sb, args, storeId) {
762
- const sid = storeId;
763
- switch (args.action) {
764
- case "find": {
765
- let q = sb.from("orders")
766
- .select("id, order_number, status, total_amount, subtotal, tax_amount, created_at, customer_id, customer:v_store_customers!customer_id(id, first_name, last_name, email, phone)")
767
- .eq("store_id", sid).order("created_at", { ascending: false });
768
- if (args.limit)
769
- q = q.limit(args.limit);
770
- if (args.status)
771
- q = q.eq("status", args.status);
772
- if (args.customer_id)
773
- q = q.eq("customer_id", args.customer_id);
774
- if (args.order_number)
775
- q = q.eq("order_number", args.order_number);
776
- if (args.query) {
777
- const sq = sanitizeFilterValue(String(args.query));
778
- q = q.or(`order_number.ilike.%${sq}%`);
553
+
554
+ // Mark secondary as merged
555
+ await sb.from("user_creation_relationships").update({
556
+ status: "merged",
557
+ relationship_data: {
558
+ merged_into: primaryId,
559
+ merged_at: new Date().toISOString()
560
+ },
561
+ updated_at: new Date().toISOString()
562
+ }).eq("id", secondaryId).eq("store_id", sid);
563
+
564
+ // Fill in missing identity fields from secondary
565
+ const {
566
+ data: primaryRel
567
+ } = await sb.from("user_creation_relationships").select("user_id").eq("id", primaryId).eq("store_id", sid).single();
568
+ const {
569
+ data: secondaryRel
570
+ } = await sb.from("user_creation_relationships").select("user_id").eq("id", secondaryId).eq("store_id", sid).single();
571
+ if (primaryRel && secondaryRel) {
572
+ const {
573
+ data: pPu
574
+ } = await sb.from("platform_users").select("*").eq("id", primaryRel.user_id).single();
575
+ const {
576
+ data: sPu
577
+ } = await sb.from("platform_users").select("*").eq("id", secondaryRel.user_id).single();
578
+ if (pPu && sPu) {
579
+ const fills = {};
580
+ if (!pPu.email && sPu.email && !sPu.email.startsWith("merged.")) fills.email = sPu.email;
581
+ if (!pPu.phone && sPu.phone && !sPu.phone.startsWith("merged_")) fills.phone = sPu.phone;
582
+ if (!pPu.date_of_birth && sPu.date_of_birth) fills.date_of_birth = sPu.date_of_birth;
583
+ if (Object.keys(fills).length > 0) await sb.from("platform_users").update(fills).eq("id", primaryRel.user_id);
584
+ // Mark secondary identity as merged
585
+ const marks = {};
586
+ if (sPu.email && !sPu.email.startsWith("merged.")) marks.email = `merged.${sPu.email}`;
587
+ if (sPu.phone && !sPu.phone.startsWith("merged_")) marks.phone = `merged_${sPu.phone}`;
588
+ if (Object.keys(marks).length > 0) await sb.from("platform_users").update(marks).eq("id", secondaryRel.user_id);
589
+ }
590
+ }
591
+ const {
592
+ data: merged
593
+ } = await sb.from("v_store_customers").select("*").eq("id", primaryId).single();
594
+ return {
595
+ success: true,
596
+ data: {
597
+ merged_customer: stripInternal(merged),
598
+ reassign_results: reassignResults
599
+ }
600
+ };
601
+ }
602
+
603
+ // ---- ADD_NOTE ----
604
+ case "add_note":
605
+ {
606
+ // Verify customer belongs to this store before adding note
607
+ const {
608
+ data: custCheck
609
+ } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
610
+ if (!custCheck) return {
611
+ success: false,
612
+ error: "Customer not found in this store"
613
+ };
614
+ const {
615
+ data,
616
+ error
617
+ } = await sb.from("customer_notes").insert({
618
+ customer_id: args.customer_id,
619
+ note: args.note,
620
+ created_by: args.created_by || "agent"
621
+ }).select().single();
622
+ return error ? {
623
+ success: false,
624
+ error: error.message
625
+ } : {
626
+ success: true,
627
+ data
628
+ };
629
+ }
630
+
631
+ // ---- NOTES ----
632
+ case "notes":
633
+ {
634
+ // Verify customer belongs to this store
635
+ const {
636
+ data: custCheck
637
+ } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
638
+ if (!custCheck) return {
639
+ success: false,
640
+ error: "Customer not found in this store"
641
+ };
642
+ const {
643
+ data,
644
+ error
645
+ } = await sb.from("customer_notes").select("id, note, created_by, created_at").eq("customer_id", args.customer_id).order("created_at", {
646
+ ascending: false
647
+ }).limit(args.limit || 25);
648
+ return error ? {
649
+ success: false,
650
+ error: error.message
651
+ } : {
652
+ success: true,
653
+ data
654
+ };
655
+ }
656
+
657
+ // ---- ACTIVITY ----
658
+ case "activity":
659
+ {
660
+ // Verify customer belongs to this store
661
+ const {
662
+ data: custCheck
663
+ } = await sb.from("v_store_customers").select("id").eq("id", args.customer_id).eq("store_id", sid).single();
664
+ if (!custCheck) return {
665
+ success: false,
666
+ error: "Customer not found in this store"
667
+ };
668
+ const {
669
+ data,
670
+ error
671
+ } = await sb.from("customer_activity").select("id, activity_type, description, metadata, created_at").eq("customer_id", args.customer_id).order("created_at", {
672
+ ascending: false
673
+ }).limit(args.limit || 25);
674
+ return error ? {
675
+ success: false,
676
+ error: error.message
677
+ } : {
678
+ success: true,
679
+ data
680
+ };
681
+ }
682
+
683
+ // ---- ORDERS: customer order history ----
684
+ case "orders":
685
+ {
686
+ const {
687
+ data,
688
+ error
689
+ } = await sb.from("orders").select("id, order_number, status, total_amount, subtotal, tax_amount, payment_status, fulfillment_status, payment_method, created_at").eq("customer_id", args.customer_id).eq("store_id", sid).order("created_at", {
690
+ ascending: false
691
+ }).limit(args.limit || 25);
692
+ return error ? {
693
+ success: false,
694
+ error: error.message
695
+ } : {
696
+ success: true,
697
+ count: data?.length,
698
+ data
699
+ };
700
+ }
701
+
702
+ // ---- LINK_CHANNEL_IDENTITY: connect a sender_id on any channel to a customer ----
703
+ case "link_channel_identity":
704
+ {
705
+ const {
706
+ customer_id,
707
+ channel_type,
708
+ sender_id,
709
+ sender_name
710
+ } = args;
711
+ if (!customer_id || !channel_type || !sender_id) {
712
+ return {
713
+ success: false,
714
+ error: "customer_id, channel_type, and sender_id are required"
715
+ };
716
+ }
717
+ // Verify customer belongs to this store
718
+ const {
719
+ data: custCheck
720
+ } = await sb.from("v_store_customers").select("id").eq("id", customer_id).eq("store_id", sid).single();
721
+ if (!custCheck) return {
722
+ success: false,
723
+ error: "Customer not found in this store"
724
+ };
725
+ const {
726
+ error
727
+ } = await sb.from("customer_channel_identities").upsert({
728
+ store_id: sid,
729
+ customer_id,
730
+ channel_type,
731
+ sender_id,
732
+ sender_name: sender_name || null,
733
+ verified: true,
734
+ last_seen_at: new Date().toISOString()
735
+ }, {
736
+ onConflict: "store_id,channel_type,sender_id"
737
+ });
738
+ return error ? {
739
+ success: false,
740
+ error: error.message
741
+ } : {
742
+ success: true,
743
+ linked: {
744
+ customer_id,
745
+ channel_type,
746
+ sender_id
747
+ }
748
+ };
749
+ }
750
+
751
+ // ---- GET_CHANNEL_IDENTITIES: list all channel identities for a customer ----
752
+ case "get_channel_identities":
753
+ {
754
+ const custId = args.customer_id;
755
+ if (!custId) return {
756
+ success: false,
757
+ error: "customer_id is required"
758
+ };
759
+ const {
760
+ data,
761
+ error
762
+ } = await sb.from("customer_channel_identities").select("id, channel_type, sender_id, sender_name, verified, last_seen_at, created_at").eq("store_id", sid).eq("customer_id", custId).order("last_seen_at", {
763
+ ascending: false
764
+ });
765
+ return error ? {
766
+ success: false,
767
+ error: error.message
768
+ } : {
769
+ success: true,
770
+ data
771
+ };
772
+ }
773
+
774
+ // ---- INVITE: create auth account for customer and send branded invite email ----
775
+ case "invite":
776
+ {
777
+ const custId = args.customer_id;
778
+ if (!custId) return {
779
+ success: false,
780
+ error: "customer_id is required"
781
+ };
782
+
783
+ // Verify customer belongs to this store
784
+ const {
785
+ data: rel,
786
+ error: relErr
787
+ } = await sb.from("user_creation_relationships").select("id, user_id, store_id").eq("id", custId).eq("store_id", sid).single();
788
+ if (relErr || !rel) return {
789
+ success: false,
790
+ error: "Customer not found for this store"
791
+ };
792
+
793
+ // Get platform user + store name in parallel
794
+ const [{
795
+ data: pu
796
+ }, {
797
+ data: store
798
+ }] = await Promise.all([sb.from("platform_users").select("id, auth_id, email, first_name, last_name").eq("id", rel.user_id).single(), sb.from("stores").select("store_name").eq("id", sid).single()]);
799
+ if (!pu) return {
800
+ success: false,
801
+ error: "Platform user not found"
802
+ };
803
+ if (!pu.email) return {
804
+ success: false,
805
+ error: "Customer has no email address — add one first"
806
+ };
807
+ const storeName = store?.store_name || "our platform";
808
+ const customerName = [pu.first_name, pu.last_name].filter(Boolean).join(" ") || "there";
809
+ const portalUrl = args.portal_url || args.redirect_to || null;
810
+
811
+ // If already has an auth account, just resend the email with a new magic link
812
+ let authId = pu.auth_id;
813
+ if (!authId) {
814
+ // Create auth account silently (no Supabase built-in email)
815
+ const {
816
+ data: newUser,
817
+ error: createErr
818
+ } = await sb.auth.admin.createUser({
819
+ email: pu.email,
820
+ email_confirm: true,
821
+ // skip verification — store is vouching for this email
822
+ user_metadata: {
823
+ first_name: pu.first_name,
824
+ last_name: pu.last_name,
825
+ invited_by_store: sid
779
826
  }
780
- const { data, error } = await q;
781
- if (error)
782
- return { success: false, error: error.message };
783
- // Flatten customer join so name/email appear as table columns
784
- const flattened = (data || []).map((row) => {
785
- const { customer, ...rest } = row;
786
- return {
787
- ...rest,
788
- customer_name: customer ? `${customer.first_name || ""} ${customer.last_name || ""}`.trim() : "—",
789
- customer_email: customer?.email || null,
790
- };
791
- });
792
- return { success: true, count: flattened.length, data: flattened };
827
+ });
828
+ if (createErr) return {
829
+ success: false,
830
+ error: `Account creation failed: ${createErr.message}`
831
+ };
832
+ authId = newUser.user.id;
833
+
834
+ // Link auth account to platform user
835
+ await sb.from("platform_users").update({
836
+ auth_id: authId
837
+ }).eq("id", pu.id);
793
838
  }
794
- case "get": {
795
- const { data, error } = await sb.from("orders")
796
- .select("*, customer:v_store_customers!customer_id(id, first_name, last_name, email, phone, loyalty_points, total_spent, total_orders), items:order_items(id, product_id, quantity, line_total, cost_per_unit, product_sku, product:products(id, name, sku))")
797
- .eq("id", args.order_id).eq("store_id", sid).single();
798
- if (error)
799
- return { success: false, error: error.message };
800
- // Flatten customer and item product joins for readable display
801
- const order = data;
802
- const { customer, items: rawItems, ...orderFields } = order;
803
- const flatItems = (rawItems || []).map((item) => ({
804
- id: item.id, product_id: item.product_id,
805
- product_name: item.product?.name || "—", product_sku: item.product_sku || item.product?.sku || "—",
806
- quantity: item.quantity, line_total: item.line_total, cost_per_unit: item.cost_per_unit,
807
- }));
808
- return {
809
- success: true,
810
- data: {
811
- ...orderFields,
812
- customer_name: customer ? `${customer.first_name || ""} ${customer.last_name || ""}`.trim() : "—",
813
- customer_email: customer?.email || null,
814
- customer_phone: customer?.phone || null,
815
- customer_id: customer?.id || orderFields.customer_id,
816
- items: flatItems,
817
- }
818
- };
839
+
840
+ // Generate a magic link for the customer to set up / log in
841
+ const {
842
+ data: linkData,
843
+ error: linkErr
844
+ } = await sb.auth.admin.generateLink({
845
+ type: "magiclink",
846
+ email: pu.email,
847
+ options: {
848
+ ...(portalUrl ? {
849
+ redirectTo: portalUrl
850
+ } : {})
851
+ }
852
+ });
853
+ if (linkErr) return {
854
+ success: false,
855
+ error: `Link generation failed: ${linkErr.message}`
856
+ };
857
+ const magicLink = linkData?.properties?.action_link || "";
858
+
859
+ // Send branded invite email through our email system
860
+ const emailResult = await handleEmail(sb, {
861
+ action: "send_template",
862
+ to: pu.email,
863
+ template: "customer-portal-invite",
864
+ template_data: {
865
+ customer_name: customerName,
866
+ store_name: storeName,
867
+ magic_link: magicLink,
868
+ portal_url: portalUrl || magicLink
869
+ }
870
+ }, sid);
871
+ return {
872
+ success: true,
873
+ data: {
874
+ email: pu.email,
875
+ name: customerName,
876
+ invited: true,
877
+ email_sent: emailResult.success,
878
+ ...(emailResult.success ? {} : {
879
+ email_error: emailResult.error
880
+ })
881
+ }
882
+ };
883
+ }
884
+
885
+ // ---- LOYALTY_HISTORY: transaction history for a customer ----
886
+ case "loyalty_history":
887
+ {
888
+ const custId = args.customer_id;
889
+ if (!custId) return {
890
+ success: false,
891
+ error: "customer_id is required"
892
+ };
893
+ let q = sb.from("loyalty_transactions").select("id, points, transaction_type, reference_type, reference_id, description, balance_before, balance_after, expires_at, created_at").eq("customer_id", custId).order("created_at", {
894
+ ascending: false
895
+ });
896
+ if (args.transaction_type) q = q.eq("transaction_type", args.transaction_type);
897
+ q = q.limit(args.limit || 50);
898
+ const {
899
+ data,
900
+ error
901
+ } = await q;
902
+ return error ? {
903
+ success: false,
904
+ error: error.message
905
+ } : {
906
+ success: true,
907
+ count: data?.length,
908
+ data
909
+ };
910
+ }
911
+
912
+ // ---- ADJUST_LOYALTY: award or deduct loyalty points via RPC ----
913
+ case "adjust_loyalty":
914
+ {
915
+ const custId = args.customer_id;
916
+ const points = args.points;
917
+ const reason = args.reason;
918
+ if (!custId || points === undefined || !reason) return {
919
+ success: false,
920
+ error: "customer_id, points, and reason are required"
921
+ };
922
+ const {
923
+ data,
924
+ error
925
+ } = await sb.rpc("adjust_customer_loyalty_points", {
926
+ p_customer_id: custId,
927
+ p_points_change: points,
928
+ p_reason: reason
929
+ });
930
+ if (error) return {
931
+ success: false,
932
+ error: error.message
933
+ };
934
+ const {
935
+ data: updated
936
+ } = await sb.from("store_customer_profiles").select("loyalty_points, loyalty_tier, lifetime_points_earned").eq("relationship_id", custId).maybeSingle();
937
+ return {
938
+ success: true,
939
+ data: {
940
+ rpc_result: data,
941
+ ...updated
942
+ }
943
+ };
944
+ }
945
+
946
+ // ---- SEGMENTS: list all customer segments for the store ----
947
+ case "segments":
948
+ {
949
+ let q = sb.from("customer_segments").select("id, name, ai_description, type, segment_rules, filter_criteria, customer_count, is_active, color, icon, targeting_tips, created_at").eq("store_id", sid).order("customer_count", {
950
+ ascending: false
951
+ });
952
+ if (args.limit) q = q.limit(args.limit);
953
+ const {
954
+ data,
955
+ error
956
+ } = await q;
957
+ return error ? {
958
+ success: false,
959
+ error: error.message
960
+ } : {
961
+ success: true,
962
+ count: data?.length,
963
+ data
964
+ };
965
+ }
966
+
967
+ // ---- SEGMENT_MEMBERS: list customers in a specific segment ----
968
+ case "segment_members":
969
+ {
970
+ const segId = args.segment_id;
971
+ if (!segId) return {
972
+ success: false,
973
+ error: "segment_id is required"
974
+ };
975
+ const {
976
+ data,
977
+ error
978
+ } = await sb.from("customer_segment_memberships").select("added_at, customer:v_segment_customers!customer_id(*)").eq("segment_id", segId).order("added_at", {
979
+ ascending: false
980
+ }).limit(args.limit || 50);
981
+ if (error) return {
982
+ success: false,
983
+ error: error.message
984
+ };
985
+ const members = (data || []).map(r => ({
986
+ added_at: r.added_at,
987
+ ...r.customer
988
+ })).filter(m => m.store_id === sid);
989
+ return {
990
+ success: true,
991
+ count: members.length,
992
+ data: stripInternalArray(members)
993
+ };
994
+ }
995
+
996
+ // ---- REFRESH_METRICS: recalculate all customer metrics for the store ----
997
+ case "refresh_metrics":
998
+ {
999
+ const start = Date.now();
1000
+ const {
1001
+ data,
1002
+ error
1003
+ } = await sb.rpc("refresh_customer_metrics", {
1004
+ p_store_id: sid
1005
+ });
1006
+ const elapsed = Date.now() - start;
1007
+ if (error) return {
1008
+ success: false,
1009
+ error: error.message
1010
+ };
1011
+ return {
1012
+ success: true,
1013
+ data: {
1014
+ result: data,
1015
+ elapsed_ms: elapsed,
1016
+ message: `Customer metrics refreshed in ${elapsed}ms`
1017
+ }
1018
+ };
1019
+ }
1020
+ default:
1021
+ return {
1022
+ success: false,
1023
+ error: `Unknown customers action: ${args.action}. Valid: find, get, create, update, invite, find_duplicates, merge, add_note, notes, activity, orders, loyalty_history, adjust_loyalty, segments, segment_members, refresh_metrics, link_channel_identity, get_channel_identities`
1024
+ };
1025
+ }
1026
+ }
1027
+ export async function handleOrders(sb, args, storeId) {
1028
+ const sid = storeId;
1029
+ switch (args.action) {
1030
+ case "find":
1031
+ {
1032
+ let q = sb.from("orders").select("id, order_number, status, total_amount, subtotal, tax_amount, created_at, customer_id, customer:v_store_customers!customer_id(id, first_name, last_name, email, phone)").eq("store_id", sid).order("created_at", {
1033
+ ascending: false
1034
+ });
1035
+ if (args.limit) q = q.limit(args.limit);
1036
+ if (args.status) q = q.eq("status", args.status);
1037
+ if (args.customer_id) q = q.eq("customer_id", args.customer_id);
1038
+ if (args.order_number) q = q.eq("order_number", args.order_number);
1039
+ if (args.query) {
1040
+ const sq = sanitizeFilterValue(String(args.query));
1041
+ q = q.or(`order_number.ilike.%${sq}%`);
819
1042
  }
820
- default:
821
- return { success: false, error: `Unknown orders action: ${args.action}` };
822
- }
1043
+ const {
1044
+ data,
1045
+ error
1046
+ } = await q;
1047
+ if (error) return {
1048
+ success: false,
1049
+ error: error.message
1050
+ };
1051
+ // Flatten customer join so name/email appear as table columns
1052
+ const flattened = (data || []).map(row => {
1053
+ const {
1054
+ customer,
1055
+ ...rest
1056
+ } = row;
1057
+ return {
1058
+ ...rest,
1059
+ customer_name: customer ? `${customer.first_name || ""} ${customer.last_name || ""}`.trim() : "—",
1060
+ customer_email: customer?.email || null
1061
+ };
1062
+ });
1063
+ return {
1064
+ success: true,
1065
+ count: flattened.length,
1066
+ data: flattened
1067
+ };
1068
+ }
1069
+ case "get":
1070
+ {
1071
+ const {
1072
+ data,
1073
+ error
1074
+ } = await sb.from("orders").select("*, customer:v_store_customers!customer_id(id, first_name, last_name, email, phone, loyalty_points, total_spent, total_orders), items:order_items(id, product_id, quantity, line_total, cost_per_unit, product_sku, product:products(id, name, sku))").eq("id", args.order_id).eq("store_id", sid).single();
1075
+ if (error) return {
1076
+ success: false,
1077
+ error: error.message
1078
+ };
1079
+ // Flatten customer and item product joins for readable display
1080
+ const order = data;
1081
+ const {
1082
+ customer,
1083
+ items: rawItems,
1084
+ ...orderFields
1085
+ } = order;
1086
+ const flatItems = (rawItems || []).map(item => ({
1087
+ id: item.id,
1088
+ product_id: item.product_id,
1089
+ product_name: item.product?.name || "—",
1090
+ product_sku: item.product_sku || item.product?.sku || "—",
1091
+ quantity: item.quantity,
1092
+ line_total: item.line_total,
1093
+ cost_per_unit: item.cost_per_unit
1094
+ }));
1095
+ return {
1096
+ success: true,
1097
+ data: {
1098
+ ...orderFields,
1099
+ customer_name: customer ? `${customer.first_name || ""} ${customer.last_name || ""}`.trim() : "—",
1100
+ customer_email: customer?.email || null,
1101
+ customer_phone: customer?.phone || null,
1102
+ customer_id: customer?.id || orderFields.customer_id,
1103
+ items: flatItems
1104
+ }
1105
+ };
1106
+ }
1107
+ default:
1108
+ return {
1109
+ success: false,
1110
+ error: `Unknown orders action: ${args.action}`
1111
+ };
1112
+ }
823
1113
  }
1114
+ //# sourceMappingURL=crm.js.map