@agent-native/core 0.4.5 → 0.6.1

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 (1015) hide show
  1. package/README.md +15 -43
  2. package/dist/a2a/agent-card.d.ts.map +1 -1
  3. package/dist/a2a/agent-card.js +12 -1
  4. package/dist/a2a/agent-card.js.map +1 -1
  5. package/dist/a2a/client.d.ts +18 -0
  6. package/dist/a2a/client.d.ts.map +1 -1
  7. package/dist/a2a/client.js +62 -4
  8. package/dist/a2a/client.js.map +1 -1
  9. package/dist/a2a/handlers.d.ts +6 -3
  10. package/dist/a2a/handlers.d.ts.map +1 -1
  11. package/dist/a2a/handlers.js +45 -39
  12. package/dist/a2a/handlers.js.map +1 -1
  13. package/dist/a2a/index.d.ts +2 -2
  14. package/dist/a2a/index.d.ts.map +1 -1
  15. package/dist/a2a/index.js +3 -3
  16. package/dist/a2a/index.js.map +1 -1
  17. package/dist/a2a/server.d.ts +11 -2
  18. package/dist/a2a/server.d.ts.map +1 -1
  19. package/dist/a2a/server.js +99 -14
  20. package/dist/a2a/server.js.map +1 -1
  21. package/dist/a2a/task-store.d.ts +6 -6
  22. package/dist/a2a/task-store.d.ts.map +1 -1
  23. package/dist/a2a/task-store.js +102 -42
  24. package/dist/a2a/task-store.js.map +1 -1
  25. package/dist/a2a/types.d.ts +3 -0
  26. package/dist/a2a/types.d.ts.map +1 -1
  27. package/dist/action.d.ts +80 -0
  28. package/dist/action.d.ts.map +1 -0
  29. package/dist/action.js +232 -0
  30. package/dist/action.js.map +1 -0
  31. package/dist/agent/engine/ai-sdk-engine.d.ts +24 -0
  32. package/dist/agent/engine/ai-sdk-engine.d.ts.map +1 -0
  33. package/dist/agent/engine/ai-sdk-engine.js +302 -0
  34. package/dist/agent/engine/ai-sdk-engine.js.map +1 -0
  35. package/dist/agent/engine/anthropic-engine.d.ts +24 -0
  36. package/dist/agent/engine/anthropic-engine.d.ts.map +1 -0
  37. package/dist/agent/engine/anthropic-engine.js +169 -0
  38. package/dist/agent/engine/anthropic-engine.js.map +1 -0
  39. package/dist/agent/engine/builtin.d.ts +12 -0
  40. package/dist/agent/engine/builtin.d.ts.map +1 -0
  41. package/dist/agent/engine/builtin.js +72 -0
  42. package/dist/agent/engine/builtin.js.map +1 -0
  43. package/dist/agent/engine/index.d.ts +9 -0
  44. package/dist/agent/engine/index.d.ts.map +1 -0
  45. package/dist/agent/engine/index.js +8 -0
  46. package/dist/agent/engine/index.js.map +1 -0
  47. package/dist/agent/engine/registry.d.ts +61 -0
  48. package/dist/agent/engine/registry.d.ts.map +1 -0
  49. package/dist/agent/engine/registry.js +101 -0
  50. package/dist/agent/engine/registry.js.map +1 -0
  51. package/dist/agent/engine/translate-ai-sdk.d.ts +20 -0
  52. package/dist/agent/engine/translate-ai-sdk.d.ts.map +1 -0
  53. package/dist/agent/engine/translate-ai-sdk.js +174 -0
  54. package/dist/agent/engine/translate-ai-sdk.js.map +1 -0
  55. package/dist/agent/engine/translate-anthropic.d.ts +23 -0
  56. package/dist/agent/engine/translate-anthropic.d.ts.map +1 -0
  57. package/dist/agent/engine/translate-anthropic.js +140 -0
  58. package/dist/agent/engine/translate-anthropic.js.map +1 -0
  59. package/dist/agent/engine/types.d.ts +168 -0
  60. package/dist/agent/engine/types.d.ts.map +1 -0
  61. package/dist/agent/engine/types.js +13 -0
  62. package/dist/agent/engine/types.js.map +1 -0
  63. package/dist/agent/index.d.ts +2 -2
  64. package/dist/agent/index.d.ts.map +1 -1
  65. package/dist/agent/index.js.map +1 -1
  66. package/dist/agent/production-agent.d.ts +69 -7
  67. package/dist/agent/production-agent.d.ts.map +1 -1
  68. package/dist/agent/production-agent.js +480 -127
  69. package/dist/agent/production-agent.js.map +1 -1
  70. package/dist/agent/run-manager.d.ts +43 -0
  71. package/dist/agent/run-manager.d.ts.map +1 -0
  72. package/dist/agent/run-manager.js +364 -0
  73. package/dist/agent/run-manager.js.map +1 -0
  74. package/dist/agent/run-store.d.ts +26 -0
  75. package/dist/agent/run-store.d.ts.map +1 -0
  76. package/dist/agent/run-store.js +145 -0
  77. package/dist/agent/run-store.js.map +1 -0
  78. package/dist/agent/thread-data-builder.d.ts +31 -0
  79. package/dist/agent/thread-data-builder.d.ts.map +1 -0
  80. package/dist/agent/thread-data-builder.js +91 -0
  81. package/dist/agent/thread-data-builder.js.map +1 -0
  82. package/dist/agent/types.d.ts +73 -1
  83. package/dist/agent/types.d.ts.map +1 -1
  84. package/dist/application-state/emitter.d.ts +3 -2
  85. package/dist/application-state/emitter.d.ts.map +1 -1
  86. package/dist/application-state/emitter.js +14 -4
  87. package/dist/application-state/emitter.js.map +1 -1
  88. package/dist/application-state/handlers.d.ts +8 -8
  89. package/dist/application-state/handlers.d.ts.map +1 -1
  90. package/dist/application-state/handlers.js +15 -17
  91. package/dist/application-state/handlers.js.map +1 -1
  92. package/dist/application-state/script-helpers.d.ts +1 -1
  93. package/dist/application-state/script-helpers.d.ts.map +1 -1
  94. package/dist/application-state/script-helpers.js +56 -8
  95. package/dist/application-state/script-helpers.js.map +1 -1
  96. package/dist/application-state/store.d.ts +4 -3
  97. package/dist/application-state/store.d.ts.map +1 -1
  98. package/dist/application-state/store.js +31 -59
  99. package/dist/application-state/store.js.map +1 -1
  100. package/dist/chat-threads/emitter.d.ts +9 -0
  101. package/dist/chat-threads/emitter.d.ts.map +1 -0
  102. package/dist/chat-threads/emitter.js +14 -0
  103. package/dist/chat-threads/emitter.js.map +1 -0
  104. package/dist/chat-threads/store.d.ts +42 -0
  105. package/dist/chat-threads/store.d.ts.map +1 -0
  106. package/dist/chat-threads/store.js +156 -0
  107. package/dist/chat-threads/store.js.map +1 -0
  108. package/dist/cli/create.d.ts +8 -2
  109. package/dist/cli/create.d.ts.map +1 -1
  110. package/dist/cli/create.js +288 -47
  111. package/dist/cli/create.js.map +1 -1
  112. package/dist/cli/index.js +49 -9
  113. package/dist/cli/index.js.map +1 -1
  114. package/dist/cli/setup-agents.d.ts +11 -0
  115. package/dist/cli/setup-agents.d.ts.map +1 -0
  116. package/dist/cli/setup-agents.js +123 -0
  117. package/dist/cli/setup-agents.js.map +1 -0
  118. package/dist/client/AgentPanel.d.ts +13 -2
  119. package/dist/client/AgentPanel.d.ts.map +1 -1
  120. package/dist/client/AgentPanel.js +771 -38
  121. package/dist/client/AgentPanel.js.map +1 -1
  122. package/dist/client/AgentTaskCard.d.ts +12 -0
  123. package/dist/client/AgentTaskCard.d.ts.map +1 -0
  124. package/dist/client/AgentTaskCard.js +146 -0
  125. package/dist/client/AgentTaskCard.js.map +1 -0
  126. package/dist/client/AssistantChat.d.ts +36 -3
  127. package/dist/client/AssistantChat.d.ts.map +1 -1
  128. package/dist/client/AssistantChat.js +838 -86
  129. package/dist/client/AssistantChat.js.map +1 -1
  130. package/dist/client/ClientOnly.d.ts +14 -0
  131. package/dist/client/ClientOnly.d.ts.map +1 -0
  132. package/dist/client/ClientOnly.js +17 -0
  133. package/dist/client/ClientOnly.js.map +1 -0
  134. package/dist/client/CommandMenu.d.ts +71 -0
  135. package/dist/client/CommandMenu.d.ts.map +1 -0
  136. package/dist/client/CommandMenu.js +257 -0
  137. package/dist/client/CommandMenu.js.map +1 -0
  138. package/dist/client/DefaultSpinner.d.ts +7 -0
  139. package/dist/client/DefaultSpinner.d.ts.map +1 -0
  140. package/dist/client/DefaultSpinner.js +28 -0
  141. package/dist/client/DefaultSpinner.js.map +1 -0
  142. package/dist/client/MultiTabAssistantChat.d.ts +40 -2
  143. package/dist/client/MultiTabAssistantChat.d.ts.map +1 -1
  144. package/dist/client/MultiTabAssistantChat.js +630 -59
  145. package/dist/client/MultiTabAssistantChat.js.map +1 -1
  146. package/dist/client/PoweredByBadge.d.ts.map +1 -1
  147. package/dist/client/PoweredByBadge.js +4 -3
  148. package/dist/client/PoweredByBadge.js.map +1 -1
  149. package/dist/client/Turnstile.d.ts.map +1 -1
  150. package/dist/client/Turnstile.js +2 -3
  151. package/dist/client/Turnstile.js.map +1 -1
  152. package/dist/client/active-run-state.d.ts +10 -0
  153. package/dist/client/active-run-state.d.ts.map +1 -0
  154. package/dist/client/active-run-state.js +32 -0
  155. package/dist/client/active-run-state.js.map +1 -0
  156. package/dist/client/agent-chat-adapter.d.ts +2 -1
  157. package/dist/client/agent-chat-adapter.d.ts.map +1 -1
  158. package/dist/client/agent-chat-adapter.js +145 -130
  159. package/dist/client/agent-chat-adapter.js.map +1 -1
  160. package/dist/client/agent-chat.d.ts +14 -1
  161. package/dist/client/agent-chat.d.ts.map +1 -1
  162. package/dist/client/agent-chat.js +6 -4
  163. package/dist/client/agent-chat.js.map +1 -1
  164. package/dist/client/components/ApiKeySettings.d.ts +2 -2
  165. package/dist/client/components/ApiKeySettings.js +4 -4
  166. package/dist/client/components/ApiKeySettings.js.map +1 -1
  167. package/dist/client/components/CodeAgentIndicator.d.ts +14 -0
  168. package/dist/client/components/CodeAgentIndicator.d.ts.map +1 -0
  169. package/dist/client/components/CodeAgentIndicator.js +29 -0
  170. package/dist/client/components/CodeAgentIndicator.js.map +1 -0
  171. package/dist/client/components/CodeRequiredDialog.d.ts.map +1 -1
  172. package/dist/client/components/CodeRequiredDialog.js +4 -3
  173. package/dist/client/components/CodeRequiredDialog.js.map +1 -1
  174. package/dist/client/composer/MentionPopover.d.ts +29 -0
  175. package/dist/client/composer/MentionPopover.d.ts.map +1 -0
  176. package/dist/client/composer/MentionPopover.js +160 -0
  177. package/dist/client/composer/MentionPopover.js.map +1 -0
  178. package/dist/client/composer/TiptapComposer.d.ts +26 -0
  179. package/dist/client/composer/TiptapComposer.d.ts.map +1 -0
  180. package/dist/client/composer/TiptapComposer.js +545 -0
  181. package/dist/client/composer/TiptapComposer.js.map +1 -0
  182. package/dist/client/composer/extensions/FileReference.d.ts +3 -0
  183. package/dist/client/composer/extensions/FileReference.d.ts.map +1 -0
  184. package/dist/client/composer/extensions/FileReference.js +36 -0
  185. package/dist/client/composer/extensions/FileReference.js.map +1 -0
  186. package/dist/client/composer/extensions/MentionReference.d.ts +3 -0
  187. package/dist/client/composer/extensions/MentionReference.d.ts.map +1 -0
  188. package/dist/client/composer/extensions/MentionReference.js +63 -0
  189. package/dist/client/composer/extensions/MentionReference.js.map +1 -0
  190. package/dist/client/composer/extensions/SkillReference.d.ts +3 -0
  191. package/dist/client/composer/extensions/SkillReference.d.ts.map +1 -0
  192. package/dist/client/composer/extensions/SkillReference.js +40 -0
  193. package/dist/client/composer/extensions/SkillReference.js.map +1 -0
  194. package/dist/client/composer/index.d.ts +8 -0
  195. package/dist/client/composer/index.d.ts.map +1 -0
  196. package/dist/client/composer/index.js +7 -0
  197. package/dist/client/composer/index.js.map +1 -0
  198. package/dist/client/composer/types.d.ts +37 -0
  199. package/dist/client/composer/types.d.ts.map +1 -0
  200. package/dist/client/composer/types.js +2 -0
  201. package/dist/client/composer/types.js.map +1 -0
  202. package/dist/client/composer/use-file-search.d.ts +6 -0
  203. package/dist/client/composer/use-file-search.d.ts.map +1 -0
  204. package/dist/client/composer/use-file-search.js +40 -0
  205. package/dist/client/composer/use-file-search.js.map +1 -0
  206. package/dist/client/composer/use-mention-search.d.ts +6 -0
  207. package/dist/client/composer/use-mention-search.d.ts.map +1 -0
  208. package/dist/client/composer/use-mention-search.js +72 -0
  209. package/dist/client/composer/use-mention-search.js.map +1 -0
  210. package/dist/client/composer/use-skills.d.ts +7 -0
  211. package/dist/client/composer/use-skills.d.ts.map +1 -0
  212. package/dist/client/composer/use-skills.js +38 -0
  213. package/dist/client/composer/use-skills.js.map +1 -0
  214. package/dist/client/frame-protocol.d.ts +54 -0
  215. package/dist/client/frame-protocol.d.ts.map +1 -0
  216. package/dist/client/frame-protocol.js +9 -0
  217. package/dist/client/frame-protocol.js.map +1 -0
  218. package/dist/client/frame.d.ts +56 -0
  219. package/dist/client/frame.d.ts.map +1 -0
  220. package/dist/client/{harness.js → frame.js} +49 -26
  221. package/dist/client/frame.js.map +1 -0
  222. package/dist/client/index.d.ts +15 -6
  223. package/dist/client/index.d.ts.map +1 -1
  224. package/dist/client/index.js +13 -5
  225. package/dist/client/index.js.map +1 -1
  226. package/dist/client/integrations/IntegrationCard.d.ts +6 -0
  227. package/dist/client/integrations/IntegrationCard.d.ts.map +1 -0
  228. package/dist/client/integrations/IntegrationCard.js +45 -0
  229. package/dist/client/integrations/IntegrationCard.js.map +1 -0
  230. package/dist/client/integrations/IntegrationsPanel.d.ts +2 -0
  231. package/dist/client/integrations/IntegrationsPanel.d.ts.map +1 -0
  232. package/dist/client/integrations/IntegrationsPanel.js +149 -0
  233. package/dist/client/integrations/IntegrationsPanel.js.map +1 -0
  234. package/dist/client/integrations/index.d.ts +4 -0
  235. package/dist/client/integrations/index.d.ts.map +1 -0
  236. package/dist/client/integrations/index.js +3 -0
  237. package/dist/client/integrations/index.js.map +1 -0
  238. package/dist/client/integrations/useIntegrationStatus.d.ts +15 -0
  239. package/dist/client/integrations/useIntegrationStatus.d.ts.map +1 -0
  240. package/dist/client/integrations/useIntegrationStatus.js +37 -0
  241. package/dist/client/integrations/useIntegrationStatus.js.map +1 -0
  242. package/dist/client/org/InvitationBanner.d.ts +9 -0
  243. package/dist/client/org/InvitationBanner.d.ts.map +1 -0
  244. package/dist/client/org/InvitationBanner.js +17 -0
  245. package/dist/client/org/InvitationBanner.js.map +1 -0
  246. package/dist/client/org/OrgSwitcher.d.ts +14 -0
  247. package/dist/client/org/OrgSwitcher.d.ts.map +1 -0
  248. package/dist/client/org/OrgSwitcher.js +51 -0
  249. package/dist/client/org/OrgSwitcher.js.map +1 -0
  250. package/dist/client/org/TeamPage.d.ts +23 -0
  251. package/dist/client/org/TeamPage.d.ts.map +1 -0
  252. package/dist/client/org/TeamPage.js +145 -0
  253. package/dist/client/org/TeamPage.js.map +1 -0
  254. package/dist/client/org/hooks.d.ts +14 -0
  255. package/dist/client/org/hooks.d.ts.map +1 -0
  256. package/dist/client/org/hooks.js +101 -0
  257. package/dist/client/org/hooks.js.map +1 -0
  258. package/dist/client/org/index.d.ts +6 -0
  259. package/dist/client/org/index.d.ts.map +1 -0
  260. package/dist/client/org/index.js +6 -0
  261. package/dist/client/org/index.js.map +1 -0
  262. package/dist/client/resources/ResourceEditor.d.ts +14 -0
  263. package/dist/client/resources/ResourceEditor.d.ts.map +1 -0
  264. package/dist/client/resources/ResourceEditor.js +932 -0
  265. package/dist/client/resources/ResourceEditor.js.map +1 -0
  266. package/dist/client/resources/ResourceTree.d.ts +17 -0
  267. package/dist/client/resources/ResourceTree.d.ts.map +1 -0
  268. package/dist/client/resources/ResourceTree.js +137 -0
  269. package/dist/client/resources/ResourceTree.js.map +1 -0
  270. package/dist/client/resources/ResourcesPanel.d.ts +2 -0
  271. package/dist/client/resources/ResourcesPanel.d.ts.map +1 -0
  272. package/dist/client/resources/ResourcesPanel.js +366 -0
  273. package/dist/client/resources/ResourcesPanel.js.map +1 -0
  274. package/dist/client/resources/index.d.ts +5 -0
  275. package/dist/client/resources/index.d.ts.map +1 -0
  276. package/dist/client/resources/index.js +5 -0
  277. package/dist/client/resources/index.js.map +1 -0
  278. package/dist/client/resources/use-resources.d.ts +55 -0
  279. package/dist/client/resources/use-resources.d.ts.map +1 -0
  280. package/dist/client/resources/use-resources.js +102 -0
  281. package/dist/client/resources/use-resources.js.map +1 -0
  282. package/dist/client/sse-event-processor.d.ts +58 -0
  283. package/dist/client/sse-event-processor.d.ts.map +1 -0
  284. package/dist/client/sse-event-processor.js +300 -0
  285. package/dist/client/sse-event-processor.js.map +1 -0
  286. package/dist/client/terminal/AgentTerminal.d.ts +5 -5
  287. package/dist/client/terminal/AgentTerminal.d.ts.map +1 -1
  288. package/dist/client/terminal/AgentTerminal.js +25 -20
  289. package/dist/client/terminal/AgentTerminal.js.map +1 -1
  290. package/dist/client/use-action.d.ts +51 -0
  291. package/dist/client/use-action.d.ts.map +1 -0
  292. package/dist/client/use-action.js +102 -0
  293. package/dist/client/use-action.js.map +1 -0
  294. package/dist/client/use-agent-chat.d.ts +1 -1
  295. package/dist/client/use-agent-chat.d.ts.map +1 -1
  296. package/dist/client/use-agent-chat.js +3 -3
  297. package/dist/client/use-agent-chat.js.map +1 -1
  298. package/dist/client/use-avatar.d.ts +15 -0
  299. package/dist/client/use-avatar.d.ts.map +1 -0
  300. package/dist/client/use-avatar.js +116 -0
  301. package/dist/client/use-avatar.js.map +1 -0
  302. package/dist/client/use-chat-threads.d.ts +36 -0
  303. package/dist/client/use-chat-threads.d.ts.map +1 -0
  304. package/dist/client/use-chat-threads.js +191 -0
  305. package/dist/client/use-chat-threads.js.map +1 -0
  306. package/dist/client/use-db-sync.d.ts +35 -0
  307. package/dist/client/use-db-sync.d.ts.map +1 -0
  308. package/dist/client/use-db-sync.js +74 -0
  309. package/dist/client/use-db-sync.js.map +1 -0
  310. package/dist/client/use-dev-mode.d.ts +4 -2
  311. package/dist/client/use-dev-mode.d.ts.map +1 -1
  312. package/dist/client/use-dev-mode.js +41 -12
  313. package/dist/client/use-dev-mode.js.map +1 -1
  314. package/dist/client/use-send-to-agent-chat.d.ts +7 -4
  315. package/dist/client/use-send-to-agent-chat.d.ts.map +1 -1
  316. package/dist/client/use-send-to-agent-chat.js +31 -10
  317. package/dist/client/use-send-to-agent-chat.js.map +1 -1
  318. package/dist/client/use-session.d.ts +1 -1
  319. package/dist/client/use-session.js +2 -2
  320. package/dist/client/use-session.js.map +1 -1
  321. package/dist/client/useProductionAgent.d.ts +1 -1
  322. package/dist/client/useProductionAgent.d.ts.map +1 -1
  323. package/dist/client/useProductionAgent.js +38 -3
  324. package/dist/client/useProductionAgent.js.map +1 -1
  325. package/dist/collab/awareness.d.ts +41 -0
  326. package/dist/collab/awareness.d.ts.map +1 -0
  327. package/dist/collab/awareness.js +82 -0
  328. package/dist/collab/awareness.js.map +1 -0
  329. package/dist/collab/client.d.ts +49 -0
  330. package/dist/collab/client.d.ts.map +1 -0
  331. package/dist/collab/client.js +250 -0
  332. package/dist/collab/client.js.map +1 -0
  333. package/dist/collab/emitter.d.ts +12 -0
  334. package/dist/collab/emitter.d.ts.map +1 -0
  335. package/dist/collab/emitter.js +16 -0
  336. package/dist/collab/emitter.js.map +1 -0
  337. package/dist/collab/index.d.ts +7 -0
  338. package/dist/collab/index.d.ts.map +1 -0
  339. package/dist/collab/index.js +14 -0
  340. package/dist/collab/index.js.map +1 -0
  341. package/dist/collab/routes.d.ts +69 -0
  342. package/dist/collab/routes.d.ts.map +1 -0
  343. package/dist/collab/routes.js +98 -0
  344. package/dist/collab/routes.js.map +1 -0
  345. package/dist/collab/storage.d.ts +18 -0
  346. package/dist/collab/storage.d.ts.map +1 -0
  347. package/dist/collab/storage.js +94 -0
  348. package/dist/collab/storage.js.map +1 -0
  349. package/dist/collab/text-to-yjs.d.ts +23 -0
  350. package/dist/collab/text-to-yjs.d.ts.map +1 -0
  351. package/dist/collab/text-to-yjs.js +63 -0
  352. package/dist/collab/text-to-yjs.js.map +1 -0
  353. package/dist/collab/xml-ops.d.ts +20 -0
  354. package/dist/collab/xml-ops.d.ts.map +1 -0
  355. package/dist/collab/xml-ops.js +59 -0
  356. package/dist/collab/xml-ops.js.map +1 -0
  357. package/dist/collab/ydoc-manager.d.ts +52 -0
  358. package/dist/collab/ydoc-manager.d.ts.map +1 -0
  359. package/dist/collab/ydoc-manager.js +154 -0
  360. package/dist/collab/ydoc-manager.js.map +1 -0
  361. package/dist/credentials/index.d.ts +18 -0
  362. package/dist/credentials/index.d.ts.map +1 -0
  363. package/dist/credentials/index.js +32 -0
  364. package/dist/credentials/index.js.map +1 -0
  365. package/dist/db/client.d.ts +45 -0
  366. package/dist/db/client.d.ts.map +1 -0
  367. package/dist/db/client.js +289 -0
  368. package/dist/db/client.js.map +1 -0
  369. package/dist/db/create-get-db.d.ts.map +1 -1
  370. package/dist/db/create-get-db.js +103 -16
  371. package/dist/db/create-get-db.js.map +1 -1
  372. package/dist/db/index.d.ts +10 -6
  373. package/dist/db/index.d.ts.map +1 -1
  374. package/dist/db/index.js +10 -4
  375. package/dist/db/index.js.map +1 -1
  376. package/dist/db/migrations.d.ts +9 -1
  377. package/dist/db/migrations.d.ts.map +1 -1
  378. package/dist/db/migrations.js +67 -41
  379. package/dist/db/migrations.js.map +1 -1
  380. package/dist/db/schema.d.ts +52 -0
  381. package/dist/db/schema.d.ts.map +1 -0
  382. package/dist/db/schema.js +72 -0
  383. package/dist/db/schema.js.map +1 -0
  384. package/dist/deploy/build.js +636 -42
  385. package/dist/deploy/build.js.map +1 -1
  386. package/dist/deploy/route-discovery.d.ts +25 -3
  387. package/dist/deploy/route-discovery.d.ts.map +1 -1
  388. package/dist/deploy/route-discovery.js +135 -24
  389. package/dist/deploy/route-discovery.js.map +1 -1
  390. package/dist/index.browser.d.ts +3 -1
  391. package/dist/index.browser.d.ts.map +1 -1
  392. package/dist/index.browser.js +5 -1
  393. package/dist/index.browser.js.map +1 -1
  394. package/dist/index.d.ts +4 -3
  395. package/dist/index.d.ts.map +1 -1
  396. package/dist/index.js +3 -2
  397. package/dist/index.js.map +1 -1
  398. package/dist/integrations/adapters/slack.d.ts +10 -0
  399. package/dist/integrations/adapters/slack.d.ts.map +1 -0
  400. package/dist/integrations/adapters/slack.js +215 -0
  401. package/dist/integrations/adapters/slack.js.map +1 -0
  402. package/dist/integrations/adapters/telegram.d.ts +12 -0
  403. package/dist/integrations/adapters/telegram.d.ts.map +1 -0
  404. package/dist/integrations/adapters/telegram.js +184 -0
  405. package/dist/integrations/adapters/telegram.js.map +1 -0
  406. package/dist/integrations/adapters/whatsapp.d.ts +14 -0
  407. package/dist/integrations/adapters/whatsapp.d.ts.map +1 -0
  408. package/dist/integrations/adapters/whatsapp.js +205 -0
  409. package/dist/integrations/adapters/whatsapp.js.map +1 -0
  410. package/dist/integrations/config-store.d.ts +24 -0
  411. package/dist/integrations/config-store.d.ts.map +1 -0
  412. package/dist/integrations/config-store.js +92 -0
  413. package/dist/integrations/config-store.js.map +1 -0
  414. package/dist/integrations/index.d.ts +8 -0
  415. package/dist/integrations/index.d.ts.map +1 -0
  416. package/dist/integrations/index.js +10 -0
  417. package/dist/integrations/index.js.map +1 -0
  418. package/dist/integrations/plugin.d.ts +20 -0
  419. package/dist/integrations/plugin.d.ts.map +1 -0
  420. package/dist/integrations/plugin.js +213 -0
  421. package/dist/integrations/plugin.js.map +1 -0
  422. package/dist/integrations/thread-mapping-store.d.ts +25 -0
  423. package/dist/integrations/thread-mapping-store.d.ts.map +1 -0
  424. package/dist/integrations/thread-mapping-store.js +95 -0
  425. package/dist/integrations/thread-mapping-store.js.map +1 -0
  426. package/dist/integrations/types.d.ts +111 -0
  427. package/dist/integrations/types.d.ts.map +1 -0
  428. package/dist/integrations/types.js +2 -0
  429. package/dist/integrations/types.js.map +1 -0
  430. package/dist/integrations/webhook-handler.d.ts +31 -0
  431. package/dist/integrations/webhook-handler.d.ts.map +1 -0
  432. package/dist/integrations/webhook-handler.js +210 -0
  433. package/dist/integrations/webhook-handler.js.map +1 -0
  434. package/dist/jobs/cron.d.ts +14 -0
  435. package/dist/jobs/cron.d.ts.map +1 -0
  436. package/dist/jobs/cron.js +100 -0
  437. package/dist/jobs/cron.js.map +1 -0
  438. package/dist/jobs/index.d.ts +4 -0
  439. package/dist/jobs/index.d.ts.map +1 -0
  440. package/dist/jobs/index.js +4 -0
  441. package/dist/jobs/index.js.map +1 -0
  442. package/dist/jobs/scheduler.d.ts +29 -0
  443. package/dist/jobs/scheduler.d.ts.map +1 -0
  444. package/dist/jobs/scheduler.js +205 -0
  445. package/dist/jobs/scheduler.js.map +1 -0
  446. package/dist/jobs/tools.d.ts +3 -0
  447. package/dist/jobs/tools.d.ts.map +1 -0
  448. package/dist/jobs/tools.js +192 -0
  449. package/dist/jobs/tools.js.map +1 -0
  450. package/dist/mcp/index.d.ts +3 -0
  451. package/dist/mcp/index.d.ts.map +1 -0
  452. package/dist/mcp/index.js +2 -0
  453. package/dist/mcp/index.js.map +1 -0
  454. package/dist/mcp/server.d.ts +26 -0
  455. package/dist/mcp/server.d.ts.map +1 -0
  456. package/dist/mcp/server.js +182 -0
  457. package/dist/mcp/server.js.map +1 -0
  458. package/dist/oauth-tokens/index.d.ts +1 -1
  459. package/dist/oauth-tokens/index.d.ts.map +1 -1
  460. package/dist/oauth-tokens/index.js +1 -1
  461. package/dist/oauth-tokens/index.js.map +1 -1
  462. package/dist/oauth-tokens/store.d.ts +5 -0
  463. package/dist/oauth-tokens/store.d.ts.map +1 -1
  464. package/dist/oauth-tokens/store.js +67 -82
  465. package/dist/oauth-tokens/store.js.map +1 -1
  466. package/dist/org/context.d.ts +11 -0
  467. package/dist/org/context.d.ts.map +1 -0
  468. package/dist/org/context.js +61 -0
  469. package/dist/org/context.js.map +1 -0
  470. package/dist/org/handlers.d.ts +66 -0
  471. package/dist/org/handlers.d.ts.map +1 -0
  472. package/dist/org/handlers.js +306 -0
  473. package/dist/org/handlers.js.map +1 -0
  474. package/dist/org/index.d.ts +7 -0
  475. package/dist/org/index.d.ts.map +1 -0
  476. package/dist/org/index.js +11 -0
  477. package/dist/org/index.js.map +1 -0
  478. package/dist/org/migrations.d.ts +10 -0
  479. package/dist/org/migrations.d.ts.map +1 -0
  480. package/dist/org/migrations.js +39 -0
  481. package/dist/org/migrations.js.map +1 -0
  482. package/dist/org/plugin.d.ts +26 -0
  483. package/dist/org/plugin.d.ts.map +1 -0
  484. package/dist/org/plugin.js +94 -0
  485. package/dist/org/plugin.js.map +1 -0
  486. package/dist/org/schema.d.ts +301 -0
  487. package/dist/org/schema.d.ts.map +1 -0
  488. package/dist/org/schema.js +23 -0
  489. package/dist/org/schema.js.map +1 -0
  490. package/dist/org/types.d.ts +42 -0
  491. package/dist/org/types.d.ts.map +1 -0
  492. package/dist/org/types.js +5 -0
  493. package/dist/org/types.js.map +1 -0
  494. package/dist/resources/emitter.d.ts +13 -0
  495. package/dist/resources/emitter.d.ts.map +1 -0
  496. package/dist/resources/emitter.js +32 -0
  497. package/dist/resources/emitter.js.map +1 -0
  498. package/dist/resources/handlers.d.ts +54 -0
  499. package/dist/resources/handlers.d.ts.map +1 -0
  500. package/dist/resources/handlers.js +292 -0
  501. package/dist/resources/handlers.js.map +1 -0
  502. package/dist/resources/index.d.ts +5 -0
  503. package/dist/resources/index.d.ts.map +1 -0
  504. package/dist/resources/index.js +5 -0
  505. package/dist/resources/index.js.map +1 -0
  506. package/dist/resources/script-helpers.d.ts +24 -0
  507. package/dist/resources/script-helpers.d.ts.map +1 -0
  508. package/dist/resources/script-helpers.js +36 -0
  509. package/dist/resources/script-helpers.js.map +1 -0
  510. package/dist/resources/store.d.ts +40 -0
  511. package/dist/resources/store.d.ts.map +1 -0
  512. package/dist/resources/store.js +497 -0
  513. package/dist/resources/store.js.map +1 -0
  514. package/dist/scripts/agent-engines/list-agent-engines.d.ts +7 -0
  515. package/dist/scripts/agent-engines/list-agent-engines.d.ts.map +1 -0
  516. package/dist/scripts/agent-engines/list-agent-engines.js +42 -0
  517. package/dist/scripts/agent-engines/list-agent-engines.js.map +1 -0
  518. package/dist/scripts/agent-engines/set-agent-engine.d.ts +7 -0
  519. package/dist/scripts/agent-engines/set-agent-engine.d.ts.map +1 -0
  520. package/dist/scripts/agent-engines/set-agent-engine.js +57 -0
  521. package/dist/scripts/agent-engines/set-agent-engine.js.map +1 -0
  522. package/dist/scripts/agent-engines/test-agent-engine.d.ts +7 -0
  523. package/dist/scripts/agent-engines/test-agent-engine.d.ts.map +1 -0
  524. package/dist/scripts/agent-engines/test-agent-engine.js +102 -0
  525. package/dist/scripts/agent-engines/test-agent-engine.js.map +1 -0
  526. package/dist/scripts/call-agent.d.ts +5 -0
  527. package/dist/scripts/call-agent.d.ts.map +1 -0
  528. package/dist/scripts/call-agent.js +111 -0
  529. package/dist/scripts/call-agent.js.map +1 -0
  530. package/dist/scripts/chat/index.d.ts +2 -0
  531. package/dist/scripts/chat/index.d.ts.map +1 -0
  532. package/dist/scripts/chat/index.js +5 -0
  533. package/dist/scripts/chat/index.js.map +1 -0
  534. package/dist/scripts/chat/open-chat.d.ts +11 -0
  535. package/dist/scripts/chat/open-chat.d.ts.map +1 -0
  536. package/dist/scripts/chat/open-chat.js +48 -0
  537. package/dist/scripts/chat/open-chat.js.map +1 -0
  538. package/dist/scripts/chat/search-chats.d.ts +10 -0
  539. package/dist/scripts/chat/search-chats.d.ts.map +1 -0
  540. package/dist/scripts/chat/search-chats.js +89 -0
  541. package/dist/scripts/chat/search-chats.js.map +1 -0
  542. package/dist/scripts/core-scripts.d.ts.map +1 -1
  543. package/dist/scripts/core-scripts.js +4 -0
  544. package/dist/scripts/core-scripts.js.map +1 -1
  545. package/dist/scripts/db/check-scoping.d.ts +14 -0
  546. package/dist/scripts/db/check-scoping.d.ts.map +1 -0
  547. package/dist/scripts/db/check-scoping.js +174 -0
  548. package/dist/scripts/db/check-scoping.js.map +1 -0
  549. package/dist/scripts/db/exec.d.ts +7 -2
  550. package/dist/scripts/db/exec.d.ts.map +1 -1
  551. package/dist/scripts/db/exec.js +143 -36
  552. package/dist/scripts/db/exec.js.map +1 -1
  553. package/dist/scripts/db/index.d.ts.map +1 -1
  554. package/dist/scripts/db/index.js +2 -0
  555. package/dist/scripts/db/index.js.map +1 -1
  556. package/dist/scripts/db/patch.d.ts +50 -0
  557. package/dist/scripts/db/patch.d.ts.map +1 -0
  558. package/dist/scripts/db/patch.js +392 -0
  559. package/dist/scripts/db/patch.js.map +1 -0
  560. package/dist/scripts/db/query.d.ts +7 -2
  561. package/dist/scripts/db/query.d.ts.map +1 -1
  562. package/dist/scripts/db/query.js +89 -45
  563. package/dist/scripts/db/query.js.map +1 -1
  564. package/dist/scripts/db/schema.d.ts +2 -2
  565. package/dist/scripts/db/schema.d.ts.map +1 -1
  566. package/dist/scripts/db/schema.js +145 -6
  567. package/dist/scripts/db/schema.js.map +1 -1
  568. package/dist/scripts/db/scoping.d.ts +42 -0
  569. package/dist/scripts/db/scoping.d.ts.map +1 -0
  570. package/dist/scripts/db/scoping.js +216 -0
  571. package/dist/scripts/db/scoping.js.map +1 -0
  572. package/dist/scripts/dev/index.d.ts +2 -2
  573. package/dist/scripts/dev/index.d.ts.map +1 -1
  574. package/dist/scripts/dev/index.js +65 -2
  575. package/dist/scripts/dev/index.js.map +1 -1
  576. package/dist/scripts/dev/list-files.d.ts +2 -2
  577. package/dist/scripts/dev/read-file.d.ts +2 -2
  578. package/dist/scripts/dev/read-file.js +1 -1
  579. package/dist/scripts/dev/read-file.js.map +1 -1
  580. package/dist/scripts/dev/search-files.d.ts +2 -2
  581. package/dist/scripts/dev/search-files.js +1 -1
  582. package/dist/scripts/dev/search-files.js.map +1 -1
  583. package/dist/scripts/dev/shell.d.ts +2 -2
  584. package/dist/scripts/dev/shell.js +1 -1
  585. package/dist/scripts/dev/shell.js.map +1 -1
  586. package/dist/scripts/dev/write-file.d.ts +2 -2
  587. package/dist/scripts/dev/write-file.js +1 -1
  588. package/dist/scripts/dev/write-file.js.map +1 -1
  589. package/dist/scripts/parse-args.d.ts +14 -0
  590. package/dist/scripts/parse-args.d.ts.map +1 -0
  591. package/dist/scripts/parse-args.js +45 -0
  592. package/dist/scripts/parse-args.js.map +1 -0
  593. package/dist/scripts/resources/delete.d.ts +10 -0
  594. package/dist/scripts/resources/delete.d.ts.map +1 -0
  595. package/dist/scripts/resources/delete.js +38 -0
  596. package/dist/scripts/resources/delete.js.map +1 -0
  597. package/dist/scripts/resources/index.d.ts +2 -0
  598. package/dist/scripts/resources/index.d.ts.map +1 -0
  599. package/dist/scripts/resources/index.js +8 -0
  600. package/dist/scripts/resources/index.js.map +1 -0
  601. package/dist/scripts/resources/list.d.ts +10 -0
  602. package/dist/scripts/resources/list.d.ts.map +1 -0
  603. package/dist/scripts/resources/list.js +57 -0
  604. package/dist/scripts/resources/list.js.map +1 -0
  605. package/dist/scripts/resources/migrate-learnings.d.ts +10 -0
  606. package/dist/scripts/resources/migrate-learnings.d.ts.map +1 -0
  607. package/dist/scripts/resources/migrate-learnings.js +23 -0
  608. package/dist/scripts/resources/migrate-learnings.js.map +1 -0
  609. package/dist/scripts/resources/read.d.ts +10 -0
  610. package/dist/scripts/resources/read.d.ts.map +1 -0
  611. package/dist/scripts/resources/read.js +59 -0
  612. package/dist/scripts/resources/read.js.map +1 -0
  613. package/dist/scripts/resources/write.d.ts +10 -0
  614. package/dist/scripts/resources/write.d.ts.map +1 -0
  615. package/dist/scripts/resources/write.js +67 -0
  616. package/dist/scripts/resources/write.js.map +1 -0
  617. package/dist/scripts/runner.d.ts +7 -7
  618. package/dist/scripts/runner.d.ts.map +1 -1
  619. package/dist/scripts/runner.js +78 -29
  620. package/dist/scripts/runner.js.map +1 -1
  621. package/dist/scripts/utils.d.ts +5 -10
  622. package/dist/scripts/utils.d.ts.map +1 -1
  623. package/dist/scripts/utils.js +7 -43
  624. package/dist/scripts/utils.js.map +1 -1
  625. package/dist/server/action-discovery.d.ts +40 -0
  626. package/dist/server/action-discovery.d.ts.map +1 -0
  627. package/dist/server/action-discovery.js +257 -0
  628. package/dist/server/action-discovery.js.map +1 -0
  629. package/dist/server/action-routes.d.ts +15 -0
  630. package/dist/server/action-routes.d.ts.map +1 -0
  631. package/dist/server/action-routes.js +105 -0
  632. package/dist/server/action-routes.js.map +1 -0
  633. package/dist/server/agent-chat-plugin.d.ts +32 -23
  634. package/dist/server/agent-chat-plugin.d.ts.map +1 -1
  635. package/dist/server/agent-chat-plugin.js +1983 -39
  636. package/dist/server/agent-chat-plugin.js.map +1 -1
  637. package/dist/server/agent-discovery.d.ts +21 -0
  638. package/dist/server/agent-discovery.d.ts.map +1 -0
  639. package/dist/server/agent-discovery.js +197 -0
  640. package/dist/server/agent-discovery.js.map +1 -0
  641. package/dist/server/agent-teams.d.ts +70 -0
  642. package/dist/server/agent-teams.d.ts.map +1 -0
  643. package/dist/server/agent-teams.js +367 -0
  644. package/dist/server/agent-teams.js.map +1 -0
  645. package/dist/server/agents-bundle.d.ts +87 -0
  646. package/dist/server/agents-bundle.d.ts.map +1 -0
  647. package/dist/server/agents-bundle.js +231 -0
  648. package/dist/server/agents-bundle.js.map +1 -0
  649. package/dist/server/auth-plugin.d.ts +5 -0
  650. package/dist/server/auth-plugin.d.ts.map +1 -1
  651. package/dist/server/auth-plugin.js +13 -3
  652. package/dist/server/auth-plugin.js.map +1 -1
  653. package/dist/server/auth.d.ts +54 -31
  654. package/dist/server/auth.d.ts.map +1 -1
  655. package/dist/server/auth.js +671 -294
  656. package/dist/server/auth.js.map +1 -1
  657. package/dist/server/better-auth-instance.d.ts +72 -0
  658. package/dist/server/better-auth-instance.d.ts.map +1 -0
  659. package/dist/server/better-auth-instance.js +144 -0
  660. package/dist/server/better-auth-instance.js.map +1 -0
  661. package/dist/server/collab-plugin.d.ts +29 -0
  662. package/dist/server/collab-plugin.d.ts.map +1 -0
  663. package/dist/server/collab-plugin.js +85 -0
  664. package/dist/server/collab-plugin.js.map +1 -0
  665. package/dist/server/core-routes-plugin.d.ts +54 -0
  666. package/dist/server/core-routes-plugin.d.ts.map +1 -0
  667. package/dist/server/core-routes-plugin.js +195 -0
  668. package/dist/server/core-routes-plugin.js.map +1 -0
  669. package/dist/server/create-server.d.ts +5 -5
  670. package/dist/server/create-server.d.ts.map +1 -1
  671. package/dist/server/create-server.js +44 -21
  672. package/dist/server/create-server.js.map +1 -1
  673. package/dist/server/framework-request-handler.d.ts +47 -0
  674. package/dist/server/framework-request-handler.d.ts.map +1 -0
  675. package/dist/server/framework-request-handler.js +168 -0
  676. package/dist/server/framework-request-handler.js.map +1 -0
  677. package/dist/server/google-auth-plugin.d.ts +4 -0
  678. package/dist/server/google-auth-plugin.d.ts.map +1 -1
  679. package/dist/server/google-auth-plugin.js +16 -15
  680. package/dist/server/google-auth-plugin.js.map +1 -1
  681. package/dist/server/google-oauth.d.ts +72 -0
  682. package/dist/server/google-oauth.d.ts.map +1 -0
  683. package/dist/server/google-oauth.js +209 -0
  684. package/dist/server/google-oauth.js.map +1 -0
  685. package/dist/server/h3-helpers.d.ts +23 -0
  686. package/dist/server/h3-helpers.d.ts.map +1 -0
  687. package/dist/server/h3-helpers.js +37 -0
  688. package/dist/server/h3-helpers.js.map +1 -0
  689. package/dist/server/index.d.ts +17 -5
  690. package/dist/server/index.d.ts.map +1 -1
  691. package/dist/server/index.js +19 -4
  692. package/dist/server/index.js.map +1 -1
  693. package/dist/server/local-migration.d.ts +32 -0
  694. package/dist/server/local-migration.d.ts.map +1 -0
  695. package/dist/server/local-migration.js +205 -0
  696. package/dist/server/local-migration.js.map +1 -0
  697. package/dist/server/oauth-helpers.d.ts +14 -0
  698. package/dist/server/oauth-helpers.d.ts.map +1 -0
  699. package/dist/server/oauth-helpers.js +23 -0
  700. package/dist/server/oauth-helpers.js.map +1 -0
  701. package/dist/server/onboarding-html.d.ts +24 -0
  702. package/dist/server/onboarding-html.d.ts.map +1 -0
  703. package/dist/server/onboarding-html.js +347 -0
  704. package/dist/server/onboarding-html.js.map +1 -0
  705. package/dist/server/poll.d.ts +45 -0
  706. package/dist/server/poll.d.ts.map +1 -0
  707. package/dist/server/poll.js +96 -0
  708. package/dist/server/poll.js.map +1 -0
  709. package/dist/server/resources-plugin.d.ts +27 -0
  710. package/dist/server/resources-plugin.d.ts.map +1 -0
  711. package/dist/server/resources-plugin.js +75 -0
  712. package/dist/server/resources-plugin.js.map +1 -0
  713. package/dist/server/schema-prompt.d.ts +16 -0
  714. package/dist/server/schema-prompt.d.ts.map +1 -0
  715. package/dist/server/schema-prompt.js +275 -0
  716. package/dist/server/schema-prompt.js.map +1 -0
  717. package/dist/server/script-discovery.d.ts +6 -0
  718. package/dist/server/script-discovery.d.ts.map +1 -0
  719. package/dist/server/script-discovery.js +6 -0
  720. package/dist/server/script-discovery.js.map +1 -0
  721. package/dist/server/sse.d.ts +4 -21
  722. package/dist/server/sse.d.ts.map +1 -1
  723. package/dist/server/sse.js +2 -30
  724. package/dist/server/sse.js.map +1 -1
  725. package/dist/server/ssr-handler.d.ts +6 -0
  726. package/dist/server/ssr-handler.d.ts.map +1 -0
  727. package/dist/server/ssr-handler.js +55 -0
  728. package/dist/server/ssr-handler.js.map +1 -0
  729. package/dist/settings/handlers.d.ts +6 -6
  730. package/dist/settings/handlers.d.ts.map +1 -1
  731. package/dist/settings/handlers.js +9 -6
  732. package/dist/settings/handlers.js.map +1 -1
  733. package/dist/settings/index.d.ts +2 -1
  734. package/dist/settings/index.d.ts.map +1 -1
  735. package/dist/settings/index.js +2 -0
  736. package/dist/settings/index.js.map +1 -1
  737. package/dist/settings/org-settings.d.ts +22 -0
  738. package/dist/settings/org-settings.d.ts.map +1 -0
  739. package/dist/settings/org-settings.js +45 -0
  740. package/dist/settings/org-settings.js.map +1 -0
  741. package/dist/settings/store.d.ts +6 -2
  742. package/dist/settings/store.d.ts.map +1 -1
  743. package/dist/settings/store.js +26 -63
  744. package/dist/settings/store.js.map +1 -1
  745. package/dist/settings/user-settings.d.ts +3 -2
  746. package/dist/settings/user-settings.d.ts.map +1 -1
  747. package/dist/settings/user-settings.js +5 -5
  748. package/dist/settings/user-settings.js.map +1 -1
  749. package/dist/shared/agent-chat.d.ts +5 -5
  750. package/dist/shared/agent-chat.d.ts.map +1 -1
  751. package/dist/shared/agent-chat.js +8 -8
  752. package/dist/shared/agent-chat.js.map +1 -1
  753. package/dist/shared/agent-env.d.ts +1 -1
  754. package/dist/shared/agent-env.js +1 -1
  755. package/dist/shared/runtime.d.ts +14 -0
  756. package/dist/shared/runtime.d.ts.map +1 -0
  757. package/dist/shared/runtime.js +25 -0
  758. package/dist/shared/runtime.js.map +1 -0
  759. package/dist/tailwind.preset.d.ts +7 -6
  760. package/dist/tailwind.preset.d.ts.map +1 -1
  761. package/dist/tailwind.preset.js +18 -1
  762. package/dist/tailwind.preset.js.map +1 -1
  763. package/dist/templates/default/.agents/skills/actions/SKILL.md +142 -0
  764. package/dist/templates/default/.agents/skills/agent-engines/SKILL.md +127 -0
  765. package/dist/templates/default/.agents/skills/capture-learnings/SKILL.md +50 -0
  766. package/dist/templates/default/.agents/skills/create-skill/SKILL.md +167 -0
  767. package/dist/templates/default/.agents/skills/delegate-to-agent/SKILL.md +90 -0
  768. package/dist/templates/default/.agents/skills/frontend-design/SKILL.md +69 -0
  769. package/dist/templates/default/.agents/skills/real-time-collab/SKILL.md +183 -0
  770. package/dist/templates/default/.agents/skills/real-time-sync/SKILL.md +112 -0
  771. package/dist/templates/default/.agents/skills/security/SKILL.md +108 -0
  772. package/dist/templates/default/.agents/skills/self-modifying-code/SKILL.md +79 -0
  773. package/{src/templates/default/.agents/skills/files-as-database → dist/templates/default/.agents/skills/storing-data}/SKILL.md +2 -2
  774. package/dist/templates/default/.claude/settings.json +100 -0
  775. package/dist/templates/default/.env.example +5 -0
  776. package/dist/templates/default/.prettierrc +5 -0
  777. package/dist/templates/default/AGENTS.md +110 -0
  778. package/dist/templates/default/DEVELOPING.md +117 -0
  779. package/dist/templates/default/_gitignore +37 -0
  780. package/{src/templates/default/scripts → dist/templates/default/actions}/hello.ts +1 -1
  781. package/dist/templates/default/actions/navigate.ts +53 -0
  782. package/dist/templates/default/actions/view-screen.ts +39 -0
  783. package/dist/templates/default/app/entry.client.tsx +4 -0
  784. package/dist/templates/default/app/entry.server.tsx +56 -0
  785. package/dist/templates/default/app/global.css +95 -0
  786. package/dist/templates/default/app/lib/utils.ts +1 -0
  787. package/dist/templates/default/app/root.tsx +107 -0
  788. package/dist/templates/default/app/routes/_index.tsx +62 -0
  789. package/dist/templates/default/app/routes.ts +4 -0
  790. package/dist/templates/default/app/vite-env.d.ts +6 -0
  791. package/dist/templates/default/components.json +20 -0
  792. package/dist/templates/default/data/.gitkeep +0 -0
  793. package/dist/templates/default/data/sync-config.json +1 -0
  794. package/dist/templates/default/learnings.defaults.md +5 -0
  795. package/dist/templates/default/learnings.md +0 -0
  796. package/dist/templates/default/package.json +46 -0
  797. package/dist/templates/default/postcss.config.js +6 -0
  798. package/dist/templates/default/public/icon-180.svg +4 -0
  799. package/dist/templates/default/public/icon-192.svg +4 -0
  800. package/dist/templates/default/public/icon-512.svg +4 -0
  801. package/dist/templates/default/public/manifest.json +13 -0
  802. package/dist/templates/default/react-router.config.ts +6 -0
  803. package/dist/templates/default/server/middleware/auth.ts +15 -0
  804. package/dist/templates/default/server/plugins/.gitkeep +0 -0
  805. package/dist/templates/default/server/routes/[...page].get.ts +5 -0
  806. package/dist/templates/default/server/routes/api/hello.get.ts +5 -0
  807. package/dist/templates/default/shared/api.ts +6 -0
  808. package/dist/templates/default/ssr-entry.ts +20 -0
  809. package/dist/templates/default/tailwind.config.ts +7 -0
  810. package/dist/templates/default/tsconfig.json +11 -0
  811. package/dist/templates/default/vite.config.ts +6 -0
  812. package/dist/templates/templates/default/.agents/skills/actions/SKILL.md +142 -0
  813. package/dist/templates/templates/default/.agents/skills/agent-engines/SKILL.md +127 -0
  814. package/dist/templates/templates/default/.agents/skills/capture-learnings/SKILL.md +50 -0
  815. package/dist/templates/templates/default/.agents/skills/create-skill/SKILL.md +167 -0
  816. package/dist/templates/templates/default/.agents/skills/delegate-to-agent/SKILL.md +90 -0
  817. package/dist/templates/templates/default/.agents/skills/frontend-design/SKILL.md +69 -0
  818. package/dist/templates/templates/default/.agents/skills/real-time-collab/SKILL.md +183 -0
  819. package/dist/templates/templates/default/.agents/skills/real-time-sync/SKILL.md +112 -0
  820. package/dist/templates/templates/default/.agents/skills/security/SKILL.md +108 -0
  821. package/dist/templates/templates/default/.agents/skills/self-modifying-code/SKILL.md +79 -0
  822. package/dist/templates/templates/default/.agents/skills/storing-data/SKILL.md +110 -0
  823. package/dist/templates/templates/default/.claude/settings.json +100 -0
  824. package/dist/templates/templates/default/.env.example +5 -0
  825. package/dist/templates/templates/default/.ignore +0 -0
  826. package/dist/templates/templates/default/.prettierrc +5 -0
  827. package/dist/templates/templates/default/AGENTS.md +110 -0
  828. package/dist/templates/templates/default/DEVELOPING.md +117 -0
  829. package/dist/templates/templates/default/_gitignore +37 -0
  830. package/dist/templates/templates/default/actions/hello.ts +20 -0
  831. package/dist/templates/templates/default/actions/navigate.ts +53 -0
  832. package/dist/templates/templates/default/actions/run.ts +2 -0
  833. package/dist/templates/templates/default/actions/view-screen.ts +39 -0
  834. package/dist/templates/templates/default/app/entry.client.tsx +4 -0
  835. package/dist/templates/templates/default/app/entry.server.tsx +56 -0
  836. package/dist/templates/templates/default/app/global.css +95 -0
  837. package/dist/templates/templates/default/app/lib/utils.ts +1 -0
  838. package/dist/templates/templates/default/app/root.tsx +107 -0
  839. package/dist/templates/templates/default/app/routes/_index.tsx +62 -0
  840. package/dist/templates/templates/default/app/routes.ts +4 -0
  841. package/dist/templates/templates/default/app/vite-env.d.ts +6 -0
  842. package/dist/templates/templates/default/components.json +20 -0
  843. package/dist/templates/templates/default/data/.gitkeep +0 -0
  844. package/dist/templates/templates/default/data/sync-config.json +1 -0
  845. package/dist/templates/templates/default/learnings.defaults.md +5 -0
  846. package/dist/templates/templates/default/learnings.md +0 -0
  847. package/dist/templates/templates/default/package.json +46 -0
  848. package/dist/templates/templates/default/postcss.config.js +6 -0
  849. package/dist/templates/templates/default/public/icon-180.svg +4 -0
  850. package/dist/templates/templates/default/public/icon-192.svg +4 -0
  851. package/dist/templates/templates/default/public/icon-512.svg +4 -0
  852. package/dist/templates/templates/default/public/manifest.json +13 -0
  853. package/dist/templates/templates/default/react-router.config.ts +6 -0
  854. package/dist/templates/templates/default/server/middleware/auth.ts +15 -0
  855. package/dist/templates/templates/default/server/plugins/.gitkeep +0 -0
  856. package/dist/templates/templates/default/server/routes/[...page].get.ts +5 -0
  857. package/dist/templates/templates/default/server/routes/api/hello.get.ts +5 -0
  858. package/dist/templates/templates/default/shared/api.ts +6 -0
  859. package/dist/templates/templates/default/ssr-entry.ts +20 -0
  860. package/dist/templates/templates/default/tailwind.config.ts +7 -0
  861. package/dist/templates/templates/default/tsconfig.json +11 -0
  862. package/dist/templates/templates/default/vite.config.ts +6 -0
  863. package/dist/terminal/cli-registry.d.ts +2 -2
  864. package/dist/terminal/cli-registry.d.ts.map +1 -1
  865. package/dist/terminal/cli-registry.js +8 -8
  866. package/dist/terminal/cli-registry.js.map +1 -1
  867. package/dist/terminal/pty-server.d.ts +1 -1
  868. package/dist/terminal/pty-server.d.ts.map +1 -1
  869. package/dist/terminal/pty-server.js +94 -18
  870. package/dist/terminal/pty-server.js.map +1 -1
  871. package/dist/terminal/terminal-plugin.d.ts +1 -10
  872. package/dist/terminal/terminal-plugin.d.ts.map +1 -1
  873. package/dist/terminal/terminal-plugin.js +77 -28
  874. package/dist/terminal/terminal-plugin.js.map +1 -1
  875. package/dist/usage/store.d.ts +29 -0
  876. package/dist/usage/store.d.ts.map +1 -0
  877. package/dist/usage/store.js +102 -0
  878. package/dist/usage/store.js.map +1 -0
  879. package/dist/vite/action-types-plugin.d.ts +13 -0
  880. package/dist/vite/action-types-plugin.d.ts.map +1 -0
  881. package/dist/vite/action-types-plugin.js +132 -0
  882. package/dist/vite/action-types-plugin.js.map +1 -0
  883. package/dist/vite/agents-bundle-plugin.d.ts +3 -0
  884. package/dist/vite/agents-bundle-plugin.d.ts.map +1 -0
  885. package/dist/vite/agents-bundle-plugin.js +87 -0
  886. package/dist/vite/agents-bundle-plugin.js.map +1 -0
  887. package/dist/vite/client.d.ts +5 -0
  888. package/dist/vite/client.d.ts.map +1 -1
  889. package/dist/vite/client.js +310 -19
  890. package/dist/vite/client.js.map +1 -1
  891. package/dist/vite/index.d.ts +2 -1
  892. package/dist/vite/index.d.ts.map +1 -1
  893. package/dist/vite/index.js +2 -1
  894. package/dist/vite/index.js.map +1 -1
  895. package/package.json +78 -14
  896. package/src/templates/default/.agents/skills/actions/SKILL.md +142 -0
  897. package/src/templates/default/.agents/skills/agent-engines/SKILL.md +127 -0
  898. package/src/templates/default/.agents/skills/create-skill/SKILL.md +1 -1
  899. package/src/templates/default/.agents/skills/delegate-to-agent/SKILL.md +1 -1
  900. package/src/templates/default/.agents/skills/real-time-collab/SKILL.md +183 -0
  901. package/src/templates/default/.agents/skills/real-time-sync/SKILL.md +112 -0
  902. package/src/templates/default/.agents/skills/security/SKILL.md +108 -0
  903. package/src/templates/default/.agents/skills/storing-data/SKILL.md +110 -0
  904. package/src/templates/default/.claude/settings.json +13 -0
  905. package/src/templates/default/AGENTS.md +72 -164
  906. package/src/templates/default/DEVELOPING.md +117 -0
  907. package/src/templates/default/actions/hello.ts +20 -0
  908. package/src/templates/default/actions/navigate.ts +53 -0
  909. package/src/templates/default/actions/run.ts +2 -0
  910. package/src/templates/default/actions/view-screen.ts +39 -0
  911. package/src/templates/default/app/global.css +2 -2
  912. package/src/templates/default/app/root.tsx +19 -16
  913. package/src/templates/default/app/routes/_index.tsx +1 -1
  914. package/src/templates/default/package.json +6 -2
  915. package/src/templates/default/server/middleware/auth.ts +15 -0
  916. package/src/templates/default/server/plugins/.gitkeep +0 -0
  917. package/src/templates/default/server/routes/[...page].get.ts +2 -9
  918. package/src/templates/default/ssr-entry.ts +20 -0
  919. package/dist/a2a/middleware.d.ts +0 -3
  920. package/dist/a2a/middleware.d.ts.map +0 -1
  921. package/dist/a2a/middleware.js +0 -36
  922. package/dist/a2a/middleware.js.map +0 -1
  923. package/dist/adapters/convex/adapter.d.ts +0 -24
  924. package/dist/adapters/convex/adapter.d.ts.map +0 -1
  925. package/dist/adapters/convex/adapter.js +0 -125
  926. package/dist/adapters/convex/adapter.js.map +0 -1
  927. package/dist/adapters/convex/index.d.ts +0 -4
  928. package/dist/adapters/convex/index.d.ts.map +0 -1
  929. package/dist/adapters/convex/index.js +0 -3
  930. package/dist/adapters/convex/index.js.map +0 -1
  931. package/dist/adapters/drizzle/adapter.d.ts +0 -36
  932. package/dist/adapters/drizzle/adapter.d.ts.map +0 -1
  933. package/dist/adapters/drizzle/adapter.js +0 -210
  934. package/dist/adapters/drizzle/adapter.js.map +0 -1
  935. package/dist/adapters/drizzle/index.d.ts +0 -3
  936. package/dist/adapters/drizzle/index.d.ts.map +0 -1
  937. package/dist/adapters/drizzle/index.js +0 -3
  938. package/dist/adapters/drizzle/index.js.map +0 -1
  939. package/dist/adapters/drizzle/schema.d.ts +0 -146
  940. package/dist/adapters/drizzle/schema.d.ts.map +0 -1
  941. package/dist/adapters/drizzle/schema.js +0 -20
  942. package/dist/adapters/drizzle/schema.js.map +0 -1
  943. package/dist/adapters/firestore/adapter.d.ts +0 -48
  944. package/dist/adapters/firestore/adapter.d.ts.map +0 -1
  945. package/dist/adapters/firestore/adapter.js +0 -62
  946. package/dist/adapters/firestore/adapter.js.map +0 -1
  947. package/dist/adapters/firestore/index.d.ts +0 -4
  948. package/dist/adapters/firestore/index.d.ts.map +0 -1
  949. package/dist/adapters/firestore/index.js +0 -3
  950. package/dist/adapters/firestore/index.js.map +0 -1
  951. package/dist/adapters/supabase/adapter.d.ts +0 -43
  952. package/dist/adapters/supabase/adapter.d.ts.map +0 -1
  953. package/dist/adapters/supabase/adapter.js +0 -137
  954. package/dist/adapters/supabase/adapter.js.map +0 -1
  955. package/dist/adapters/supabase/index.d.ts +0 -3
  956. package/dist/adapters/supabase/index.d.ts.map +0 -1
  957. package/dist/adapters/supabase/index.js +0 -3
  958. package/dist/adapters/supabase/index.js.map +0 -1
  959. package/dist/adapters/sync/config.d.ts +0 -40
  960. package/dist/adapters/sync/config.d.ts.map +0 -1
  961. package/dist/adapters/sync/config.js +0 -209
  962. package/dist/adapters/sync/config.js.map +0 -1
  963. package/dist/adapters/sync/create-file-sync.d.ts +0 -32
  964. package/dist/adapters/sync/create-file-sync.d.ts.map +0 -1
  965. package/dist/adapters/sync/create-file-sync.js +0 -218
  966. package/dist/adapters/sync/create-file-sync.js.map +0 -1
  967. package/dist/adapters/sync/file-sync.d.ts +0 -94
  968. package/dist/adapters/sync/file-sync.d.ts.map +0 -1
  969. package/dist/adapters/sync/file-sync.js +0 -671
  970. package/dist/adapters/sync/file-sync.js.map +0 -1
  971. package/dist/adapters/sync/index.d.ts +0 -6
  972. package/dist/adapters/sync/index.d.ts.map +0 -1
  973. package/dist/adapters/sync/index.js +0 -6
  974. package/dist/adapters/sync/index.js.map +0 -1
  975. package/dist/adapters/sync/merge.d.ts +0 -21
  976. package/dist/adapters/sync/merge.d.ts.map +0 -1
  977. package/dist/adapters/sync/merge.js +0 -132
  978. package/dist/adapters/sync/merge.js.map +0 -1
  979. package/dist/adapters/sync/types.d.ts +0 -62
  980. package/dist/adapters/sync/types.d.ts.map +0 -1
  981. package/dist/adapters/sync/types.js +0 -23
  982. package/dist/adapters/sync/types.js.map +0 -1
  983. package/dist/client/harness.d.ts +0 -48
  984. package/dist/client/harness.d.ts.map +0 -1
  985. package/dist/client/harness.js.map +0 -1
  986. package/dist/client/use-file-sync-status.d.ts +0 -21
  987. package/dist/client/use-file-sync-status.d.ts.map +0 -1
  988. package/dist/client/use-file-sync-status.js +0 -65
  989. package/dist/client/use-file-sync-status.js.map +0 -1
  990. package/dist/client/use-file-watcher.d.ts +0 -23
  991. package/dist/client/use-file-watcher.d.ts.map +0 -1
  992. package/dist/client/use-file-watcher.js +0 -50
  993. package/dist/client/use-file-watcher.js.map +0 -1
  994. package/dist/server/default-watcher.d.ts +0 -17
  995. package/dist/server/default-watcher.d.ts.map +0 -1
  996. package/dist/server/default-watcher.js +0 -37
  997. package/dist/server/default-watcher.js.map +0 -1
  998. package/dist/server/file-sync-plugin.d.ts +0 -7
  999. package/dist/server/file-sync-plugin.d.ts.map +0 -1
  1000. package/dist/server/file-sync-plugin.js +0 -38
  1001. package/dist/server/file-sync-plugin.js.map +0 -1
  1002. package/dist/vite/dev-api-server.d.ts +0 -10
  1003. package/dist/vite/dev-api-server.d.ts.map +0 -1
  1004. package/dist/vite/dev-api-server.js +0 -160
  1005. package/dist/vite/dev-api-server.js.map +0 -1
  1006. package/src/templates/default/.agents/skills/scripts/SKILL.md +0 -121
  1007. package/src/templates/default/.agents/skills/sse-file-watcher/SKILL.md +0 -80
  1008. package/src/templates/default/server/plugins/agent-chat.ts +0 -1
  1009. package/src/templates/default/server/plugins/auth.ts +0 -1
  1010. package/src/templates/default/server/plugins/file-sync.ts +0 -1
  1011. package/src/templates/default/server/plugins/terminal.ts +0 -1
  1012. package/src/templates/default/server/routes/api/events.get.ts +0 -3
  1013. package/src/templates/default/server/routes/api/file-sync/status.get.ts +0 -4
  1014. /package/{src/templates/default/application-state/.gitkeep → dist/templates/default/.ignore} +0 -0
  1015. /package/{src/templates/default/scripts → dist/templates/default/actions}/run.ts +0 -0
@@ -0,0 +1,392 @@
1
+ /**
2
+ * Core script: db-patch
3
+ *
4
+ * Surgical search-and-replace on a text column in any SQL table. Instead of
5
+ * re-sending the full column value (as `db-exec UPDATE` would require), the
6
+ * agent sends one or more `{find, replace}` pairs. The script reads the row,
7
+ * applies the edits in memory, and writes the result back in a single UPDATE.
8
+ *
9
+ * ## When to use which tool
10
+ *
11
+ * Large text field, small slice to change → db-patch (this)
12
+ * e.g. fix one paragraph in a 50KB document, tweak one key in a dashboard
13
+ * JSON blob, rename a label in a slide HTML string.
14
+ *
15
+ * Short field, set outright → db-exec UPDATE
16
+ * e.g. `UPDATE forms SET status = 'published' WHERE id = '...'`.
17
+ *
18
+ * Multiple columns / computed values → db-exec UPDATE
19
+ * e.g. `UPDATE meals SET calories = calories + 50, ...`.
20
+ *
21
+ * Domain-specific action exists → use that action
22
+ * e.g. `edit-document` or `update-slide` — they also push live Yjs
23
+ * updates to any open collaborative editor. db-patch is the generic
24
+ * fallback for tables without a bespoke action.
25
+ *
26
+ * ## Why it's faster
27
+ *
28
+ * The agent only has to transmit the diff (the `find` + `replace`
29
+ * strings), not the full new value. For large text fields — multi-kilobyte
30
+ * markdown documents, slide HTML, dashboard/form JSON — this dramatically
31
+ * reduces tokens per edit and keeps concurrent edits composable.
32
+ *
33
+ * ## Security
34
+ *
35
+ * In production mode, the same per-user / per-org temp view scoping that
36
+ * `db-exec` uses applies here: the SELECT and UPDATE both go through the
37
+ * scoped view, so you can never read or write rows outside the current
38
+ * user's data. The WHERE clause is validated against a keyword denylist
39
+ * (no ;, no chained statements, no DDL).
40
+ *
41
+ * ## Usage
42
+ *
43
+ * pnpm action db-patch --table <t> --column <c> --where "<clause>" \
44
+ * --find "old" --replace "new"
45
+ *
46
+ * pnpm action db-patch --table decks --column data --where "id='d1'" \
47
+ * --edits '[{"find":"Q3","replace":"Q4"},{"find":"$1M","replace":"$1.2M"}]'
48
+ */
49
+ import path from "path";
50
+ import { createClient } from "@libsql/client";
51
+ import { getDatabaseUrl, getDatabaseAuthToken } from "../../db/client.js";
52
+ import { parseArgs, fail } from "../utils.js";
53
+ import { buildScopingPostgres, buildScopingSqlite } from "./scoping.js";
54
+ function isPostgresUrl(url) {
55
+ return url.startsWith("postgres://") || url.startsWith("postgresql://");
56
+ }
57
+ /** Only unquoted [A-Za-z_][A-Za-z0-9_]* identifiers are allowed — no spaces,
58
+ * no quoting, no dotted names. This is deliberately strict: it stops the
59
+ * agent from sneaking SQL into the table/column slots. */
60
+ function isValidIdentifier(s) {
61
+ return /^[A-Za-z_][A-Za-z0-9_]*$/.test(s);
62
+ }
63
+ /** Reject WHERE clauses that could chain statements or hide DDL. This isn't
64
+ * a full SQL parser — just a keyword/character denylist to keep the surface
65
+ * area equivalent to what db-exec already allows. */
66
+ function validateWhere(where) {
67
+ if (where.includes(";")) {
68
+ fail("--where must not contain ';' (no statement chaining)");
69
+ }
70
+ // Strip inline strings before keyword scanning so "WHERE name = 'DROP TABLE'"
71
+ // doesn't trip the denylist.
72
+ const stripped = where
73
+ .replace(/'(?:''|[^'])*'/g, "''")
74
+ .replace(/"(?:""|[^"])*"/g, '""')
75
+ .toUpperCase();
76
+ const blocked = [
77
+ " INSERT ",
78
+ " UPDATE ",
79
+ " DELETE ",
80
+ " DROP ",
81
+ " ALTER ",
82
+ " CREATE ",
83
+ " ATTACH ",
84
+ " DETACH ",
85
+ " PRAGMA ",
86
+ " VACUUM ",
87
+ "--",
88
+ "/*",
89
+ ];
90
+ const padded = " " + stripped + " ";
91
+ for (const kw of blocked) {
92
+ if (padded.includes(kw)) {
93
+ fail(`--where must not contain "${kw.trim()}"`);
94
+ }
95
+ }
96
+ }
97
+ function parseEdits(parsed) {
98
+ let edits;
99
+ if (parsed.edits) {
100
+ let parsedJson;
101
+ try {
102
+ parsedJson = JSON.parse(parsed.edits);
103
+ }
104
+ catch (e) {
105
+ fail(`Invalid --edits JSON: ${e.message}`);
106
+ }
107
+ if (!Array.isArray(parsedJson) || parsedJson.length === 0) {
108
+ fail("--edits must be a non-empty JSON array of {find, replace} objects");
109
+ }
110
+ edits = parsedJson;
111
+ }
112
+ else if (parsed.find !== undefined) {
113
+ if (parsed.find === "")
114
+ fail("--find cannot be empty");
115
+ edits = [{ find: parsed.find, replace: parsed.replace ?? "" }];
116
+ }
117
+ else {
118
+ fail("Either --find/--replace or --edits is required");
119
+ }
120
+ for (const edit of edits) {
121
+ if (typeof edit.find !== "string" || edit.find === "") {
122
+ fail("Each edit must have a non-empty 'find' string");
123
+ }
124
+ if (edit.replace === undefined || edit.replace === null) {
125
+ edit.replace = "";
126
+ }
127
+ if (typeof edit.replace !== "string") {
128
+ fail("Each edit's 'replace' field must be a string");
129
+ }
130
+ }
131
+ return edits;
132
+ }
133
+ function preview(s) {
134
+ const max = 60;
135
+ const trimmed = s.replace(/\s+/g, " ");
136
+ return trimmed.length > max ? trimmed.slice(0, max) + "..." : trimmed;
137
+ }
138
+ function countOccurrences(haystack, needle) {
139
+ if (!needle)
140
+ return 0;
141
+ let count = 0;
142
+ let idx = 0;
143
+ while ((idx = haystack.indexOf(needle, idx)) !== -1) {
144
+ count++;
145
+ idx += needle.length;
146
+ }
147
+ return count;
148
+ }
149
+ /** Apply edits sequentially. By default replaces only the first occurrence
150
+ * of each `find` (matching the behavior of the template-specific
151
+ * `edit-document` action). `--all` switches to replace-every-occurrence. */
152
+ function applyEdits(content, edits, replaceAll) {
153
+ let out = content;
154
+ const results = [];
155
+ let applied = 0;
156
+ for (let i = 0; i < edits.length; i++) {
157
+ const edit = edits[i];
158
+ const idx = out.indexOf(edit.find);
159
+ if (idx === -1) {
160
+ results.push({
161
+ index: i,
162
+ status: "not-found",
163
+ detail: `NOT FOUND: "${preview(edit.find)}"`,
164
+ occurrences: 0,
165
+ });
166
+ continue;
167
+ }
168
+ if (replaceAll) {
169
+ const occurrences = countOccurrences(out, edit.find);
170
+ // Literal replaceAll via split/join — no regex, no special chars.
171
+ out = out.split(edit.find).join(edit.replace);
172
+ applied++;
173
+ results.push({
174
+ index: i,
175
+ status: edit.replace === "" ? "deleted" : "replaced",
176
+ detail: `${edit.replace === "" ? "deleted" : "replaced"} ${occurrences}×: "${preview(edit.find)}"`,
177
+ occurrences,
178
+ });
179
+ }
180
+ else {
181
+ out =
182
+ out.slice(0, idx) + edit.replace + out.slice(idx + edit.find.length);
183
+ applied++;
184
+ results.push({
185
+ index: i,
186
+ status: edit.replace === "" ? "deleted" : "replaced",
187
+ detail: `${edit.replace === "" ? "deleted" : "replaced"}: "${preview(edit.find)}"`,
188
+ occurrences: 1,
189
+ });
190
+ }
191
+ }
192
+ return { content: out, results, applied };
193
+ }
194
+ function printResult(out, format) {
195
+ if (format === "json") {
196
+ console.log(JSON.stringify(out, null, 2));
197
+ return;
198
+ }
199
+ console.log(`db-patch: ${out.table}.${out.column}`);
200
+ console.log(` Applied: ${out.applied}/${out.total}`);
201
+ console.log(` Bytes: ${out.bytesBefore} → ${out.bytesAfter}`);
202
+ for (const r of out.results) {
203
+ console.log(` - ${r.detail}`);
204
+ }
205
+ }
206
+ // ─── Postgres path ──────────────────────────────────────────────────────────
207
+ async function runPostgres(opts) {
208
+ const { default: pg } = await import("postgres");
209
+ const pgSql = pg(opts.url);
210
+ try {
211
+ // Same temp-view scoping db-exec uses — SELECT and UPDATE both go through
212
+ // the scoped view, so cross-user access is impossible even if --where is
213
+ // permissive.
214
+ const scoping = await buildScopingPostgres(pgSql);
215
+ for (const stmt of scoping.setup) {
216
+ await pgSql.unsafe(stmt);
217
+ }
218
+ const selectSql = `SELECT "${opts.column}" AS __val FROM "${opts.table}" WHERE ${opts.where}`;
219
+ const selected = Array.from(await pgSql.unsafe(selectSql));
220
+ if (selected.length === 0) {
221
+ fail(`No rows matched: ${opts.table} WHERE ${opts.where}. ` +
222
+ `(In production, data scoping filters results to the current user — the row may exist but be owned by someone else.)`);
223
+ }
224
+ if (selected.length > 1) {
225
+ fail(`WHERE matched ${selected.length} rows in ${opts.table}. db-patch expects exactly one row — narrow the WHERE clause (usually by primary key).`);
226
+ }
227
+ const original = (selected[0].__val ?? "");
228
+ if (typeof original !== "string") {
229
+ fail(`Column ${opts.table}.${opts.column} is not a text column (got ${typeof original}).`);
230
+ }
231
+ const { content, results, applied } = applyEdits(original, opts.edits, opts.replaceAll);
232
+ if (applied > 0) {
233
+ await pgSql.unsafe(`UPDATE "${opts.table}" SET "${opts.column}" = $1 WHERE ${opts.where}`, [content]);
234
+ }
235
+ printResult({
236
+ table: opts.table,
237
+ column: opts.column,
238
+ applied,
239
+ total: opts.edits.length,
240
+ bytesBefore: original.length,
241
+ bytesAfter: content.length,
242
+ results,
243
+ }, opts.format);
244
+ for (const stmt of scoping.teardown) {
245
+ await pgSql.unsafe(stmt).catch(() => { });
246
+ }
247
+ }
248
+ finally {
249
+ await pgSql.end();
250
+ }
251
+ }
252
+ // ─── SQLite / libSQL path ───────────────────────────────────────────────────
253
+ async function runSqlite(opts) {
254
+ const client = createClient({
255
+ url: opts.url,
256
+ authToken: getDatabaseAuthToken(),
257
+ });
258
+ try {
259
+ const scoping = await buildScopingSqlite(client);
260
+ for (const stmt of scoping.setup) {
261
+ await client.execute(stmt);
262
+ }
263
+ const selectSql = `SELECT "${opts.column}" AS __val FROM "${opts.table}" WHERE ${opts.where}`;
264
+ const selectRes = await client.execute(selectSql);
265
+ if (selectRes.rows.length === 0) {
266
+ fail(`No rows matched: ${opts.table} WHERE ${opts.where}. ` +
267
+ `(In production, data scoping filters results to the current user — the row may exist but be owned by someone else.)`);
268
+ }
269
+ if (selectRes.rows.length > 1) {
270
+ fail(`WHERE matched ${selectRes.rows.length} rows in ${opts.table}. db-patch expects exactly one row — narrow the WHERE clause (usually by primary key).`);
271
+ }
272
+ const row = selectRes.rows[0];
273
+ const original = (row.__val ?? row[0] ?? "");
274
+ if (typeof original !== "string") {
275
+ fail(`Column ${opts.table}.${opts.column} is not a text column (got ${typeof original}).`);
276
+ }
277
+ const { content, results, applied } = applyEdits(original, opts.edits, opts.replaceAll);
278
+ if (applied > 0) {
279
+ await client.execute({
280
+ sql: `UPDATE "${opts.table}" SET "${opts.column}" = ? WHERE ${opts.where}`,
281
+ args: [content],
282
+ });
283
+ }
284
+ printResult({
285
+ table: opts.table,
286
+ column: opts.column,
287
+ applied,
288
+ total: opts.edits.length,
289
+ bytesBefore: original.length,
290
+ bytesAfter: content.length,
291
+ results,
292
+ }, opts.format);
293
+ for (const stmt of scoping.teardown) {
294
+ await client.execute(stmt).catch(() => { });
295
+ }
296
+ }
297
+ finally {
298
+ client.close();
299
+ }
300
+ }
301
+ // ─── Entry point ────────────────────────────────────────────────────────────
302
+ export default async function dbPatch(args) {
303
+ const parsed = parseArgs(args);
304
+ if (parsed.help === "true") {
305
+ console.log(`Usage: pnpm action db-patch --table <t> --column <c> --where "<clause>" [edit flags]
306
+
307
+ Surgical search-and-replace on a text column. Avoids re-sending the full
308
+ column value — ideal for large strings (documents, slides, dashboards, JSON).
309
+
310
+ Required:
311
+ --table <name> Target table (identifier; no quoting)
312
+ --column <name> Target text column (identifier; no quoting)
313
+ --where "<clause>" SQL WHERE clause that matches exactly one row
314
+
315
+ Edit mode (pick one):
316
+ --find <text> Text to find (single edit; default replace = "")
317
+ --replace <text> Replacement text (used with --find)
318
+ --edits <json> Batch: JSON array of {find, replace} objects
319
+
320
+ Options:
321
+ --all Replace every occurrence of each 'find' (default: first only)
322
+ --format json Output as JSON
323
+ --help Show this help
324
+
325
+ Examples:
326
+ # Fix a typo in one document
327
+ pnpm action db-patch --table documents --column content \\
328
+ --where "id='abc'" --find "teh" --replace "the"
329
+
330
+ # Batch edits on a deck's JSON blob
331
+ pnpm action db-patch --table decks --column data --where "id='d1'" \\
332
+ --edits '[{"find":"\\"Q3\\"","replace":"\\"Q4\\""},{"find":"$1M","replace":"$1.2M"}]'
333
+
334
+ When to use db-patch vs other tools:
335
+ Large text field, small edit → db-patch (this)
336
+ Short field or multi-column set → db-exec UPDATE
337
+ Domain action exists (edit-document, ...) → use that action (syncs live
338
+ to open collaborative editors)
339
+ `);
340
+ return;
341
+ }
342
+ const table = parsed.table;
343
+ const column = parsed.column;
344
+ const where = parsed.where;
345
+ if (!table)
346
+ fail("--table is required");
347
+ if (!column)
348
+ fail("--column is required");
349
+ if (!where)
350
+ fail("--where is required");
351
+ if (!isValidIdentifier(table))
352
+ fail(`Invalid --table: "${table}". Must be a plain identifier (letters, digits, underscore).`);
353
+ if (!isValidIdentifier(column))
354
+ fail(`Invalid --column: "${column}". Must be a plain identifier (letters, digits, underscore).`);
355
+ validateWhere(where);
356
+ const edits = parseEdits(parsed);
357
+ const replaceAll = parsed.all === "true";
358
+ // Resolve database URL: --db flag → DATABASE_URL env → default file path
359
+ let url;
360
+ if (parsed.db) {
361
+ url = "file:" + path.resolve(parsed.db);
362
+ }
363
+ else if (getDatabaseUrl()) {
364
+ url = getDatabaseUrl();
365
+ }
366
+ else {
367
+ url = "file:" + path.resolve(process.cwd(), "data", "app.db");
368
+ }
369
+ if (isPostgresUrl(url)) {
370
+ await runPostgres({
371
+ url,
372
+ table,
373
+ column,
374
+ where,
375
+ edits,
376
+ replaceAll,
377
+ format: parsed.format,
378
+ });
379
+ }
380
+ else {
381
+ await runSqlite({
382
+ url,
383
+ table,
384
+ column,
385
+ where,
386
+ edits,
387
+ replaceAll,
388
+ format: parsed.format,
389
+ });
390
+ }
391
+ }
392
+ //# sourceMappingURL=patch.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patch.js","sourceRoot":"","sources":["../../../src/scripts/db/patch.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,15 @@
1
1
  /**
2
2
  * Core script: db-query
3
3
  *
4
- * Run a read-only SQL query against a SQLite database.
4
+ * Run a read-only SQL query against a SQLite or Postgres database.
5
+ *
6
+ * In production mode, temporary views are created to scope data to the
7
+ * current user (AGENT_USER_EMAIL). Tables with an `owner_email` column
8
+ * and core tables (settings, application_state, etc.) are automatically
9
+ * filtered so queries only return the current user's data.
5
10
  *
6
11
  * Usage:
7
- * pnpm script db-query --sql "SELECT * FROM forms" [--db path] [--format json] [--limit N]
12
+ * pnpm action db-query --sql "SELECT * FROM forms" [--db path] [--format json] [--limit N]
8
13
  */
9
14
  export default function dbQuery(args: string[]): Promise<void>;
10
15
  //# sourceMappingURL=query.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/query.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAMH,wBAA8B,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAuHnE"}
1
+ {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/query.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAuDH,wBAA8B,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA0HnE"}
@@ -1,18 +1,59 @@
1
1
  /**
2
2
  * Core script: db-query
3
3
  *
4
- * Run a read-only SQL query against a SQLite database.
4
+ * Run a read-only SQL query against a SQLite or Postgres database.
5
+ *
6
+ * In production mode, temporary views are created to scope data to the
7
+ * current user (AGENT_USER_EMAIL). Tables with an `owner_email` column
8
+ * and core tables (settings, application_state, etc.) are automatically
9
+ * filtered so queries only return the current user's data.
5
10
  *
6
11
  * Usage:
7
- * pnpm script db-query --sql "SELECT * FROM forms" [--db path] [--format json] [--limit N]
12
+ * pnpm action db-query --sql "SELECT * FROM forms" [--db path] [--format json] [--limit N]
8
13
  */
9
14
  import path from "path";
10
15
  import { createClient } from "@libsql/client";
16
+ import { getDatabaseUrl, getDatabaseAuthToken } from "../../db/client.js";
11
17
  import { parseArgs, fail } from "../utils.js";
18
+ import { buildScopingPostgres, buildScopingSqlite } from "./scoping.js";
19
+ function isPostgresUrl(url) {
20
+ return url.startsWith("postgres://") || url.startsWith("postgresql://");
21
+ }
22
+ function printTable(rows, finalSql, format) {
23
+ if (format === "json") {
24
+ console.log(JSON.stringify({ query: finalSql, rows, count: rows.length }, null, 2));
25
+ return;
26
+ }
27
+ console.log(`Query: ${finalSql}`);
28
+ console.log(`Rows: ${rows.length}\n`);
29
+ if (rows.length === 0) {
30
+ console.log("(no results)");
31
+ return;
32
+ }
33
+ const keys = Object.keys(rows[0]);
34
+ const widths = keys.map((k) => {
35
+ const maxVal = Math.max(...rows.map((r) => String(r[k] ?? "NULL").length));
36
+ return Math.max(k.length, Math.min(maxVal, 60));
37
+ });
38
+ const header = keys.map((k, i) => k.padEnd(widths[i])).join(" | ");
39
+ console.log(header);
40
+ console.log(widths.map((w) => "-".repeat(w)).join("-+-"));
41
+ for (const row of rows) {
42
+ const line = keys
43
+ .map((k, i) => {
44
+ const val = String(row[k] ?? "NULL");
45
+ return val.length > 60
46
+ ? val.slice(0, 57) + "..."
47
+ : val.padEnd(widths[i]);
48
+ })
49
+ .join(" | ");
50
+ console.log(line);
51
+ }
52
+ }
12
53
  export default async function dbQuery(args) {
13
54
  const parsed = parseArgs(args);
14
55
  if (parsed.help === "true") {
15
- console.log(`Usage: pnpm script db-query --sql "<query>" [options]
56
+ console.log(`Usage: pnpm action db-query --sql "<query>" [options]
16
57
 
17
58
  Options:
18
59
  --sql <query> SQL SELECT query to run (required)
@@ -44,25 +85,55 @@ Options:
44
85
  if (parsed.db) {
45
86
  url = "file:" + path.resolve(parsed.db);
46
87
  }
47
- else if (process.env.DATABASE_URL) {
48
- url = process.env.DATABASE_URL;
88
+ else if (getDatabaseUrl()) {
89
+ url = getDatabaseUrl();
49
90
  }
50
91
  else {
51
92
  url = "file:" + path.resolve(process.cwd(), "data", "app.db");
52
93
  }
94
+ let finalSql = sql;
95
+ if (parsed.limit &&
96
+ (upper.startsWith("SELECT") || upper.startsWith("WITH")) &&
97
+ !/\bLIMIT\b/i.test(stripped)) {
98
+ const limitVal = parseInt(parsed.limit, 10);
99
+ if (isNaN(limitVal) || limitVal < 1)
100
+ fail("--limit must be a positive integer");
101
+ finalSql = `${sql} LIMIT ${limitVal}`;
102
+ }
103
+ // Postgres path
104
+ if (isPostgresUrl(url)) {
105
+ const { default: pg } = await import("postgres");
106
+ const pgSql = pg(url);
107
+ try {
108
+ // Set up user-scoped temp views in production
109
+ const scoping = await buildScopingPostgres(pgSql);
110
+ for (const stmt of scoping.setup) {
111
+ await pgSql.unsafe(stmt);
112
+ }
113
+ const result = await pgSql.unsafe(finalSql);
114
+ const rows = Array.from(result);
115
+ const keys = rows.length > 0 ? Object.keys(rows[0]) : [];
116
+ printTable(rows.length > 0 ? rows : keys.length > 0 ? rows : [], finalSql, parsed.format);
117
+ // Tear down temp views
118
+ for (const stmt of scoping.teardown) {
119
+ await pgSql.unsafe(stmt).catch(() => { });
120
+ }
121
+ }
122
+ finally {
123
+ await pgSql.end();
124
+ }
125
+ return;
126
+ }
127
+ // libsql / SQLite path
53
128
  const client = createClient({
54
129
  url,
55
- authToken: process.env.DATABASE_AUTH_TOKEN,
130
+ authToken: getDatabaseAuthToken(),
56
131
  });
57
132
  try {
58
- let finalSql = sql;
59
- if (parsed.limit &&
60
- (upper.startsWith("SELECT") || upper.startsWith("WITH")) &&
61
- !/\bLIMIT\b/i.test(stripped)) {
62
- const limitVal = parseInt(parsed.limit, 10);
63
- if (isNaN(limitVal) || limitVal < 1)
64
- fail("--limit must be a positive integer");
65
- finalSql = `${sql} LIMIT ${limitVal}`;
133
+ // Set up user-scoped temp views in production
134
+ const scoping = await buildScopingSqlite(client);
135
+ for (const stmt of scoping.setup) {
136
+ await client.execute(stmt);
66
137
  }
67
138
  const result = await client.execute(finalSql);
68
139
  const rows = result.rows.map((row) => {
@@ -72,37 +143,10 @@ Options:
72
143
  }
73
144
  return obj;
74
145
  });
75
- if (parsed.format === "json") {
76
- console.log(JSON.stringify({ query: finalSql, rows, count: rows.length }, null, 2));
77
- return;
78
- }
79
- // Human-readable table output
80
- console.log(`Query: ${finalSql}`);
81
- console.log(`Rows: ${rows.length}\n`);
82
- if (rows.length === 0) {
83
- console.log("(no results)");
84
- return;
85
- }
86
- const keys = Object.keys(rows[0]);
87
- const widths = keys.map((k) => {
88
- const maxVal = Math.max(...rows.map((r) => String(r[k] ?? "NULL").length));
89
- return Math.max(k.length, Math.min(maxVal, 60));
90
- });
91
- // Header
92
- const header = keys.map((k, i) => k.padEnd(widths[i])).join(" | ");
93
- console.log(header);
94
- console.log(widths.map((w) => "-".repeat(w)).join("-+-"));
95
- // Rows
96
- for (const row of rows) {
97
- const line = keys
98
- .map((k, i) => {
99
- const val = String(row[k] ?? "NULL");
100
- return val.length > 60
101
- ? val.slice(0, 57) + "..."
102
- : val.padEnd(widths[i]);
103
- })
104
- .join(" | ");
105
- console.log(line);
146
+ printTable(rows, finalSql, parsed.format);
147
+ // Tear down temp views
148
+ for (const stmt of scoping.teardown) {
149
+ await client.execute(stmt).catch(() => { });
106
150
  }
107
151
  }
108
152
  finally {
@@ -1 +1 @@
1
- {"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/scripts/db/query.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/scripts/db/query.ts"],"names":[],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  /**
2
2
  * Core script: db-schema
3
3
  *
4
- * Inspects a SQLite database and prints all tables, columns, types,
4
+ * Inspects a SQLite or Postgres database and prints all tables, columns, types,
5
5
  * constraints, and foreign keys. Gives the agent full visibility
6
6
  * into the app's data model.
7
7
  *
8
8
  * Usage:
9
- * pnpm script db-schema [--db path] [--format json]
9
+ * pnpm action db-schema [--db path] [--format json]
10
10
  */
11
11
  export default function dbSchema(args: string[]): Promise<void>;
12
12
  //# sourceMappingURL=schema.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/schema.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AA4CH,wBAA8B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAoIpE"}
1
+ {"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/schema.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAwMH,wBAA8B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA0IpE"}