@agent-native/core 0.4.5 → 0.5.0-dev.b51eaae

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 (479) hide show
  1. package/dist/a2a/client.d.ts +7 -0
  2. package/dist/a2a/client.d.ts.map +1 -1
  3. package/dist/a2a/client.js +24 -3
  4. package/dist/a2a/client.js.map +1 -1
  5. package/dist/a2a/handlers.d.ts +6 -3
  6. package/dist/a2a/handlers.d.ts.map +1 -1
  7. package/dist/a2a/handlers.js +45 -39
  8. package/dist/a2a/handlers.js.map +1 -1
  9. package/dist/a2a/index.d.ts +1 -1
  10. package/dist/a2a/index.d.ts.map +1 -1
  11. package/dist/a2a/index.js +2 -2
  12. package/dist/a2a/index.js.map +1 -1
  13. package/dist/a2a/server.d.ts +7 -2
  14. package/dist/a2a/server.d.ts.map +1 -1
  15. package/dist/a2a/server.js +54 -14
  16. package/dist/a2a/server.js.map +1 -1
  17. package/dist/a2a/task-store.d.ts +6 -6
  18. package/dist/a2a/task-store.d.ts.map +1 -1
  19. package/dist/a2a/task-store.js +102 -42
  20. package/dist/a2a/task-store.js.map +1 -1
  21. package/dist/a2a/types.d.ts +2 -0
  22. package/dist/a2a/types.d.ts.map +1 -1
  23. package/dist/action.d.ts +46 -0
  24. package/dist/action.d.ts.map +1 -0
  25. package/dist/action.js +35 -0
  26. package/dist/action.js.map +1 -0
  27. package/dist/adapters/sync/file-sync.js +1 -1
  28. package/dist/agent/index.d.ts +2 -2
  29. package/dist/agent/index.d.ts.map +1 -1
  30. package/dist/agent/index.js.map +1 -1
  31. package/dist/agent/production-agent.d.ts +22 -6
  32. package/dist/agent/production-agent.d.ts.map +1 -1
  33. package/dist/agent/production-agent.js +336 -123
  34. package/dist/agent/production-agent.js.map +1 -1
  35. package/dist/agent/run-manager.d.ts +43 -0
  36. package/dist/agent/run-manager.d.ts.map +1 -0
  37. package/dist/agent/run-manager.js +358 -0
  38. package/dist/agent/run-manager.js.map +1 -0
  39. package/dist/agent/run-store.d.ts +26 -0
  40. package/dist/agent/run-store.d.ts.map +1 -0
  41. package/dist/agent/run-store.js +145 -0
  42. package/dist/agent/run-store.js.map +1 -0
  43. package/dist/agent/thread-data-builder.d.ts +30 -0
  44. package/dist/agent/thread-data-builder.d.ts.map +1 -0
  45. package/dist/agent/thread-data-builder.js +88 -0
  46. package/dist/agent/thread-data-builder.js.map +1 -0
  47. package/dist/agent/types.d.ts +52 -1
  48. package/dist/agent/types.d.ts.map +1 -1
  49. package/dist/application-state/emitter.d.ts +3 -2
  50. package/dist/application-state/emitter.d.ts.map +1 -1
  51. package/dist/application-state/emitter.js +14 -4
  52. package/dist/application-state/emitter.js.map +1 -1
  53. package/dist/application-state/handlers.d.ts.map +1 -1
  54. package/dist/application-state/handlers.js +13 -16
  55. package/dist/application-state/handlers.js.map +1 -1
  56. package/dist/application-state/script-helpers.d.ts +1 -1
  57. package/dist/application-state/script-helpers.d.ts.map +1 -1
  58. package/dist/application-state/script-helpers.js +15 -5
  59. package/dist/application-state/script-helpers.js.map +1 -1
  60. package/dist/application-state/store.d.ts +4 -3
  61. package/dist/application-state/store.d.ts.map +1 -1
  62. package/dist/application-state/store.js +31 -59
  63. package/dist/application-state/store.js.map +1 -1
  64. package/dist/chat-threads/emitter.d.ts +9 -0
  65. package/dist/chat-threads/emitter.d.ts.map +1 -0
  66. package/dist/chat-threads/emitter.js +14 -0
  67. package/dist/chat-threads/emitter.js.map +1 -0
  68. package/dist/chat-threads/store.d.ts +28 -0
  69. package/dist/chat-threads/store.d.ts.map +1 -0
  70. package/dist/chat-threads/store.js +124 -0
  71. package/dist/chat-threads/store.js.map +1 -0
  72. package/dist/cli/create.d.ts.map +1 -1
  73. package/dist/cli/create.js +4 -18
  74. package/dist/cli/create.js.map +1 -1
  75. package/dist/cli/index.js +30 -3
  76. package/dist/cli/index.js.map +1 -1
  77. package/dist/cli/setup-agents.d.ts +11 -0
  78. package/dist/cli/setup-agents.d.ts.map +1 -0
  79. package/dist/cli/setup-agents.js +123 -0
  80. package/dist/cli/setup-agents.js.map +1 -0
  81. package/dist/client/AgentPanel.d.ts +9 -2
  82. package/dist/client/AgentPanel.d.ts.map +1 -1
  83. package/dist/client/AgentPanel.js +466 -29
  84. package/dist/client/AgentPanel.js.map +1 -1
  85. package/dist/client/AssistantChat.d.ts +25 -3
  86. package/dist/client/AssistantChat.d.ts.map +1 -1
  87. package/dist/client/AssistantChat.js +613 -83
  88. package/dist/client/AssistantChat.js.map +1 -1
  89. package/dist/client/ClientOnly.d.ts +14 -0
  90. package/dist/client/ClientOnly.d.ts.map +1 -0
  91. package/dist/client/ClientOnly.js +17 -0
  92. package/dist/client/ClientOnly.js.map +1 -0
  93. package/dist/client/CommandMenu.d.ts +71 -0
  94. package/dist/client/CommandMenu.d.ts.map +1 -0
  95. package/dist/client/CommandMenu.js +257 -0
  96. package/dist/client/CommandMenu.js.map +1 -0
  97. package/dist/client/DefaultSpinner.d.ts +7 -0
  98. package/dist/client/DefaultSpinner.d.ts.map +1 -0
  99. package/dist/client/DefaultSpinner.js +28 -0
  100. package/dist/client/DefaultSpinner.js.map +1 -0
  101. package/dist/client/MultiTabAssistantChat.d.ts +34 -2
  102. package/dist/client/MultiTabAssistantChat.d.ts.map +1 -1
  103. package/dist/client/MultiTabAssistantChat.js +346 -57
  104. package/dist/client/MultiTabAssistantChat.js.map +1 -1
  105. package/dist/client/PoweredByBadge.d.ts.map +1 -1
  106. package/dist/client/PoweredByBadge.js +2 -1
  107. package/dist/client/PoweredByBadge.js.map +1 -1
  108. package/dist/client/active-run-state.d.ts +10 -0
  109. package/dist/client/active-run-state.d.ts.map +1 -0
  110. package/dist/client/active-run-state.js +32 -0
  111. package/dist/client/active-run-state.js.map +1 -0
  112. package/dist/client/agent-chat-adapter.d.ts +2 -1
  113. package/dist/client/agent-chat-adapter.d.ts.map +1 -1
  114. package/dist/client/agent-chat-adapter.js +83 -129
  115. package/dist/client/agent-chat-adapter.js.map +1 -1
  116. package/dist/client/agent-chat.js +2 -2
  117. package/dist/client/agent-chat.js.map +1 -1
  118. package/dist/client/components/ApiKeySettings.d.ts +2 -2
  119. package/dist/client/components/ApiKeySettings.js +4 -4
  120. package/dist/client/components/ApiKeySettings.js.map +1 -1
  121. package/dist/client/components/CodeRequiredDialog.d.ts.map +1 -1
  122. package/dist/client/components/CodeRequiredDialog.js +4 -3
  123. package/dist/client/components/CodeRequiredDialog.js.map +1 -1
  124. package/dist/client/composer/MentionPopover.d.ts +26 -0
  125. package/dist/client/composer/MentionPopover.d.ts.map +1 -0
  126. package/dist/client/composer/MentionPopover.js +130 -0
  127. package/dist/client/composer/MentionPopover.js.map +1 -0
  128. package/dist/client/composer/TiptapComposer.d.ts +19 -0
  129. package/dist/client/composer/TiptapComposer.d.ts.map +1 -0
  130. package/dist/client/composer/TiptapComposer.js +415 -0
  131. package/dist/client/composer/TiptapComposer.js.map +1 -0
  132. package/dist/client/composer/extensions/FileReference.d.ts +3 -0
  133. package/dist/client/composer/extensions/FileReference.d.ts.map +1 -0
  134. package/dist/client/composer/extensions/FileReference.js +36 -0
  135. package/dist/client/composer/extensions/FileReference.js.map +1 -0
  136. package/dist/client/composer/extensions/MentionReference.d.ts +3 -0
  137. package/dist/client/composer/extensions/MentionReference.d.ts.map +1 -0
  138. package/dist/client/composer/extensions/MentionReference.js +63 -0
  139. package/dist/client/composer/extensions/MentionReference.js.map +1 -0
  140. package/dist/client/composer/extensions/SkillReference.d.ts +3 -0
  141. package/dist/client/composer/extensions/SkillReference.d.ts.map +1 -0
  142. package/dist/client/composer/extensions/SkillReference.js +40 -0
  143. package/dist/client/composer/extensions/SkillReference.js.map +1 -0
  144. package/dist/client/composer/index.d.ts +8 -0
  145. package/dist/client/composer/index.d.ts.map +1 -0
  146. package/dist/client/composer/index.js +7 -0
  147. package/dist/client/composer/index.js.map +1 -0
  148. package/dist/client/composer/types.d.ts +32 -0
  149. package/dist/client/composer/types.d.ts.map +1 -0
  150. package/dist/client/composer/types.js +2 -0
  151. package/dist/client/composer/types.js.map +1 -0
  152. package/dist/client/composer/use-file-search.d.ts +6 -0
  153. package/dist/client/composer/use-file-search.d.ts.map +1 -0
  154. package/dist/client/composer/use-file-search.js +40 -0
  155. package/dist/client/composer/use-file-search.js.map +1 -0
  156. package/dist/client/composer/use-mention-search.d.ts +6 -0
  157. package/dist/client/composer/use-mention-search.d.ts.map +1 -0
  158. package/dist/client/composer/use-mention-search.js +39 -0
  159. package/dist/client/composer/use-mention-search.js.map +1 -0
  160. package/dist/client/composer/use-skills.d.ts +7 -0
  161. package/dist/client/composer/use-skills.d.ts.map +1 -0
  162. package/dist/client/composer/use-skills.js +38 -0
  163. package/dist/client/composer/use-skills.js.map +1 -0
  164. package/dist/client/index.d.ts +9 -4
  165. package/dist/client/index.d.ts.map +1 -1
  166. package/dist/client/index.js +8 -3
  167. package/dist/client/index.js.map +1 -1
  168. package/dist/client/resources/ResourceEditor.d.ts +7 -0
  169. package/dist/client/resources/ResourceEditor.d.ts.map +1 -0
  170. package/dist/client/resources/ResourceEditor.js +851 -0
  171. package/dist/client/resources/ResourceEditor.js.map +1 -0
  172. package/dist/client/resources/ResourceTree.d.ts +13 -0
  173. package/dist/client/resources/ResourceTree.d.ts.map +1 -0
  174. package/dist/client/resources/ResourceTree.js +122 -0
  175. package/dist/client/resources/ResourceTree.js.map +1 -0
  176. package/dist/client/resources/ResourcesPanel.d.ts +2 -0
  177. package/dist/client/resources/ResourcesPanel.d.ts.map +1 -0
  178. package/dist/client/resources/ResourcesPanel.js +341 -0
  179. package/dist/client/resources/ResourcesPanel.js.map +1 -0
  180. package/dist/client/resources/index.d.ts +5 -0
  181. package/dist/client/resources/index.d.ts.map +1 -0
  182. package/dist/client/resources/index.js +5 -0
  183. package/dist/client/resources/index.js.map +1 -0
  184. package/dist/client/resources/use-resources.d.ts +45 -0
  185. package/dist/client/resources/use-resources.d.ts.map +1 -0
  186. package/dist/client/resources/use-resources.js +102 -0
  187. package/dist/client/resources/use-resources.js.map +1 -0
  188. package/dist/client/sse-event-processor.d.ts +50 -0
  189. package/dist/client/sse-event-processor.d.ts.map +1 -0
  190. package/dist/client/sse-event-processor.js +267 -0
  191. package/dist/client/sse-event-processor.js.map +1 -0
  192. package/dist/client/terminal/AgentTerminal.d.ts +1 -1
  193. package/dist/client/terminal/AgentTerminal.d.ts.map +1 -1
  194. package/dist/client/terminal/AgentTerminal.js +11 -6
  195. package/dist/client/terminal/AgentTerminal.js.map +1 -1
  196. package/dist/client/use-agent-chat.d.ts +1 -1
  197. package/dist/client/use-agent-chat.d.ts.map +1 -1
  198. package/dist/client/use-agent-chat.js +3 -3
  199. package/dist/client/use-agent-chat.js.map +1 -1
  200. package/dist/client/use-chat-threads.d.ts +36 -0
  201. package/dist/client/use-chat-threads.d.ts.map +1 -0
  202. package/dist/client/use-chat-threads.js +175 -0
  203. package/dist/client/use-chat-threads.js.map +1 -0
  204. package/dist/client/use-db-sync.d.ts +35 -0
  205. package/dist/client/use-db-sync.d.ts.map +1 -0
  206. package/dist/client/use-db-sync.js +74 -0
  207. package/dist/client/use-db-sync.js.map +1 -0
  208. package/dist/client/use-dev-mode.d.ts +4 -2
  209. package/dist/client/use-dev-mode.d.ts.map +1 -1
  210. package/dist/client/use-dev-mode.js +39 -12
  211. package/dist/client/use-dev-mode.js.map +1 -1
  212. package/dist/client/use-file-sync-status.d.ts +1 -1
  213. package/dist/client/use-file-sync-status.js +3 -3
  214. package/dist/client/use-file-sync-status.js.map +1 -1
  215. package/dist/client/use-session.d.ts +1 -1
  216. package/dist/client/use-session.js +2 -2
  217. package/dist/client/use-session.js.map +1 -1
  218. package/dist/client/useProductionAgent.d.ts +1 -1
  219. package/dist/client/useProductionAgent.d.ts.map +1 -1
  220. package/dist/client/useProductionAgent.js +38 -3
  221. package/dist/client/useProductionAgent.js.map +1 -1
  222. package/dist/credentials/index.d.ts +18 -0
  223. package/dist/credentials/index.d.ts.map +1 -0
  224. package/dist/credentials/index.js +32 -0
  225. package/dist/credentials/index.js.map +1 -0
  226. package/dist/db/client.d.ts +35 -0
  227. package/dist/db/client.d.ts.map +1 -0
  228. package/dist/db/client.js +248 -0
  229. package/dist/db/client.js.map +1 -0
  230. package/dist/db/create-get-db.d.ts.map +1 -1
  231. package/dist/db/create-get-db.js +103 -16
  232. package/dist/db/create-get-db.js.map +1 -1
  233. package/dist/db/index.d.ts +10 -6
  234. package/dist/db/index.d.ts.map +1 -1
  235. package/dist/db/index.js +10 -4
  236. package/dist/db/index.js.map +1 -1
  237. package/dist/db/migrations.d.ts.map +1 -1
  238. package/dist/db/migrations.js +31 -30
  239. package/dist/db/migrations.js.map +1 -1
  240. package/dist/db/schema.d.ts +45 -0
  241. package/dist/db/schema.d.ts.map +1 -0
  242. package/dist/db/schema.js +61 -0
  243. package/dist/db/schema.js.map +1 -0
  244. package/dist/deploy/build.js +35 -6
  245. package/dist/deploy/build.js.map +1 -1
  246. package/dist/deploy/route-discovery.d.ts +9 -0
  247. package/dist/deploy/route-discovery.d.ts.map +1 -1
  248. package/dist/deploy/route-discovery.js +30 -1
  249. package/dist/deploy/route-discovery.js.map +1 -1
  250. package/dist/index.browser.d.ts +1 -1
  251. package/dist/index.browser.d.ts.map +1 -1
  252. package/dist/index.browser.js +1 -1
  253. package/dist/index.browser.js.map +1 -1
  254. package/dist/index.d.ts +3 -2
  255. package/dist/index.d.ts.map +1 -1
  256. package/dist/index.js +2 -1
  257. package/dist/index.js.map +1 -1
  258. package/dist/oauth-tokens/store.d.ts.map +1 -1
  259. package/dist/oauth-tokens/store.js +43 -81
  260. package/dist/oauth-tokens/store.js.map +1 -1
  261. package/dist/resources/emitter.d.ts +13 -0
  262. package/dist/resources/emitter.d.ts.map +1 -0
  263. package/dist/resources/emitter.js +32 -0
  264. package/dist/resources/emitter.js.map +1 -0
  265. package/dist/resources/handlers.d.ts +45 -0
  266. package/dist/resources/handlers.d.ts.map +1 -0
  267. package/dist/resources/handlers.js +219 -0
  268. package/dist/resources/handlers.js.map +1 -0
  269. package/dist/resources/index.d.ts +5 -0
  270. package/dist/resources/index.d.ts.map +1 -0
  271. package/dist/resources/index.js +5 -0
  272. package/dist/resources/index.js.map +1 -0
  273. package/dist/resources/script-helpers.d.ts +24 -0
  274. package/dist/resources/script-helpers.d.ts.map +1 -0
  275. package/dist/resources/script-helpers.js +36 -0
  276. package/dist/resources/script-helpers.js.map +1 -0
  277. package/dist/resources/store.d.ts +35 -0
  278. package/dist/resources/store.d.ts.map +1 -0
  279. package/dist/resources/store.js +453 -0
  280. package/dist/resources/store.js.map +1 -0
  281. package/dist/scripts/call-agent.d.ts +5 -0
  282. package/dist/scripts/call-agent.d.ts.map +1 -0
  283. package/dist/scripts/call-agent.js +107 -0
  284. package/dist/scripts/call-agent.js.map +1 -0
  285. package/dist/scripts/core-scripts.d.ts.map +1 -1
  286. package/dist/scripts/core-scripts.js +2 -0
  287. package/dist/scripts/core-scripts.js.map +1 -1
  288. package/dist/scripts/db/exec.d.ts +6 -2
  289. package/dist/scripts/db/exec.d.ts.map +1 -1
  290. package/dist/scripts/db/exec.js +127 -36
  291. package/dist/scripts/db/exec.js.map +1 -1
  292. package/dist/scripts/db/query.d.ts +7 -2
  293. package/dist/scripts/db/query.d.ts.map +1 -1
  294. package/dist/scripts/db/query.js +89 -45
  295. package/dist/scripts/db/query.js.map +1 -1
  296. package/dist/scripts/db/schema.d.ts +2 -2
  297. package/dist/scripts/db/schema.d.ts.map +1 -1
  298. package/dist/scripts/db/schema.js +145 -6
  299. package/dist/scripts/db/schema.js.map +1 -1
  300. package/dist/scripts/db/scoping.d.ts +36 -0
  301. package/dist/scripts/db/scoping.d.ts.map +1 -0
  302. package/dist/scripts/db/scoping.js +198 -0
  303. package/dist/scripts/db/scoping.js.map +1 -0
  304. package/dist/scripts/dev/index.d.ts +2 -2
  305. package/dist/scripts/dev/index.js +1 -1
  306. package/dist/scripts/dev/list-files.d.ts +2 -2
  307. package/dist/scripts/dev/read-file.d.ts +2 -2
  308. package/dist/scripts/dev/read-file.js +1 -1
  309. package/dist/scripts/dev/read-file.js.map +1 -1
  310. package/dist/scripts/dev/search-files.d.ts +2 -2
  311. package/dist/scripts/dev/search-files.js +1 -1
  312. package/dist/scripts/dev/search-files.js.map +1 -1
  313. package/dist/scripts/dev/shell.d.ts +2 -2
  314. package/dist/scripts/dev/shell.js +1 -1
  315. package/dist/scripts/dev/shell.js.map +1 -1
  316. package/dist/scripts/dev/write-file.d.ts +2 -2
  317. package/dist/scripts/dev/write-file.js +1 -1
  318. package/dist/scripts/dev/write-file.js.map +1 -1
  319. package/dist/scripts/resources/delete.d.ts +10 -0
  320. package/dist/scripts/resources/delete.d.ts.map +1 -0
  321. package/dist/scripts/resources/delete.js +38 -0
  322. package/dist/scripts/resources/delete.js.map +1 -0
  323. package/dist/scripts/resources/index.d.ts +2 -0
  324. package/dist/scripts/resources/index.d.ts.map +1 -0
  325. package/dist/scripts/resources/index.js +8 -0
  326. package/dist/scripts/resources/index.js.map +1 -0
  327. package/dist/scripts/resources/list.d.ts +10 -0
  328. package/dist/scripts/resources/list.d.ts.map +1 -0
  329. package/dist/scripts/resources/list.js +57 -0
  330. package/dist/scripts/resources/list.js.map +1 -0
  331. package/dist/scripts/resources/migrate-learnings.d.ts +10 -0
  332. package/dist/scripts/resources/migrate-learnings.d.ts.map +1 -0
  333. package/dist/scripts/resources/migrate-learnings.js +23 -0
  334. package/dist/scripts/resources/migrate-learnings.js.map +1 -0
  335. package/dist/scripts/resources/read.d.ts +10 -0
  336. package/dist/scripts/resources/read.d.ts.map +1 -0
  337. package/dist/scripts/resources/read.js +59 -0
  338. package/dist/scripts/resources/read.js.map +1 -0
  339. package/dist/scripts/resources/write.d.ts +10 -0
  340. package/dist/scripts/resources/write.d.ts.map +1 -0
  341. package/dist/scripts/resources/write.js +67 -0
  342. package/dist/scripts/resources/write.js.map +1 -0
  343. package/dist/scripts/runner.d.ts +7 -7
  344. package/dist/scripts/runner.d.ts.map +1 -1
  345. package/dist/scripts/runner.js +68 -27
  346. package/dist/scripts/runner.js.map +1 -1
  347. package/dist/scripts/utils.d.ts +4 -1
  348. package/dist/scripts/utils.d.ts.map +1 -1
  349. package/dist/scripts/utils.js +5 -3
  350. package/dist/scripts/utils.js.map +1 -1
  351. package/dist/server/action-discovery.d.ts +40 -0
  352. package/dist/server/action-discovery.d.ts.map +1 -0
  353. package/dist/server/action-discovery.js +189 -0
  354. package/dist/server/action-discovery.js.map +1 -0
  355. package/dist/server/agent-chat-plugin.d.ts +12 -23
  356. package/dist/server/agent-chat-plugin.d.ts.map +1 -1
  357. package/dist/server/agent-chat-plugin.js +1087 -36
  358. package/dist/server/agent-chat-plugin.js.map +1 -1
  359. package/dist/server/agent-discovery.d.ts +16 -0
  360. package/dist/server/agent-discovery.d.ts.map +1 -0
  361. package/dist/server/agent-discovery.js +136 -0
  362. package/dist/server/agent-discovery.js.map +1 -0
  363. package/dist/server/auth-plugin.d.ts +5 -0
  364. package/dist/server/auth-plugin.d.ts.map +1 -1
  365. package/dist/server/auth-plugin.js +12 -1
  366. package/dist/server/auth-plugin.js.map +1 -1
  367. package/dist/server/auth.d.ts +3 -1
  368. package/dist/server/auth.d.ts.map +1 -1
  369. package/dist/server/auth.js +576 -117
  370. package/dist/server/auth.js.map +1 -1
  371. package/dist/server/core-routes-plugin.d.ts +57 -0
  372. package/dist/server/core-routes-plugin.d.ts.map +1 -0
  373. package/dist/server/core-routes-plugin.js +125 -0
  374. package/dist/server/core-routes-plugin.js.map +1 -0
  375. package/dist/server/create-server.d.ts +4 -4
  376. package/dist/server/create-server.d.ts.map +1 -1
  377. package/dist/server/create-server.js +5 -5
  378. package/dist/server/create-server.js.map +1 -1
  379. package/dist/server/default-watcher.d.ts +9 -3
  380. package/dist/server/default-watcher.d.ts.map +1 -1
  381. package/dist/server/default-watcher.js +26 -6
  382. package/dist/server/default-watcher.js.map +1 -1
  383. package/dist/server/google-auth-plugin.js +3 -3
  384. package/dist/server/google-auth-plugin.js.map +1 -1
  385. package/dist/server/google-oauth.d.ts +72 -0
  386. package/dist/server/google-oauth.d.ts.map +1 -0
  387. package/dist/server/google-oauth.js +187 -0
  388. package/dist/server/google-oauth.js.map +1 -0
  389. package/dist/server/index.d.ts +9 -2
  390. package/dist/server/index.d.ts.map +1 -1
  391. package/dist/server/index.js +8 -1
  392. package/dist/server/index.js.map +1 -1
  393. package/dist/server/oauth-helpers.d.ts +16 -0
  394. package/dist/server/oauth-helpers.d.ts.map +1 -0
  395. package/dist/server/oauth-helpers.js +25 -0
  396. package/dist/server/oauth-helpers.js.map +1 -0
  397. package/dist/server/poll.d.ts +40 -0
  398. package/dist/server/poll.d.ts.map +1 -0
  399. package/dist/server/poll.js +49 -0
  400. package/dist/server/poll.js.map +1 -0
  401. package/dist/server/resources-plugin.d.ts +27 -0
  402. package/dist/server/resources-plugin.d.ts.map +1 -0
  403. package/dist/server/resources-plugin.js +74 -0
  404. package/dist/server/resources-plugin.js.map +1 -0
  405. package/dist/server/script-discovery.d.ts +6 -0
  406. package/dist/server/script-discovery.d.ts.map +1 -0
  407. package/dist/server/script-discovery.js +6 -0
  408. package/dist/server/script-discovery.js.map +1 -0
  409. package/dist/server/sse.d.ts +1 -1
  410. package/dist/server/sse.js +1 -1
  411. package/dist/settings/handlers.d.ts +3 -3
  412. package/dist/settings/handlers.d.ts.map +1 -1
  413. package/dist/settings/handlers.js +8 -6
  414. package/dist/settings/handlers.js.map +1 -1
  415. package/dist/settings/index.d.ts +1 -1
  416. package/dist/settings/index.d.ts.map +1 -1
  417. package/dist/settings/index.js.map +1 -1
  418. package/dist/settings/store.d.ts +6 -2
  419. package/dist/settings/store.d.ts.map +1 -1
  420. package/dist/settings/store.js +26 -63
  421. package/dist/settings/store.js.map +1 -1
  422. package/dist/settings/user-settings.d.ts +3 -2
  423. package/dist/settings/user-settings.d.ts.map +1 -1
  424. package/dist/settings/user-settings.js +5 -5
  425. package/dist/settings/user-settings.js.map +1 -1
  426. package/dist/tailwind.preset.d.ts +7 -6
  427. package/dist/tailwind.preset.d.ts.map +1 -1
  428. package/dist/tailwind.preset.js +18 -1
  429. package/dist/tailwind.preset.js.map +1 -1
  430. package/dist/terminal/cli-registry.d.ts +1 -1
  431. package/dist/terminal/cli-registry.js +3 -3
  432. package/dist/terminal/cli-registry.js.map +1 -1
  433. package/dist/terminal/pty-server.d.ts.map +1 -1
  434. package/dist/terminal/pty-server.js +65 -11
  435. package/dist/terminal/pty-server.js.map +1 -1
  436. package/dist/terminal/terminal-plugin.d.ts +2 -2
  437. package/dist/terminal/terminal-plugin.d.ts.map +1 -1
  438. package/dist/terminal/terminal-plugin.js +27 -21
  439. package/dist/terminal/terminal-plugin.js.map +1 -1
  440. package/dist/vite/client.d.ts.map +1 -1
  441. package/dist/vite/client.js +114 -8
  442. package/dist/vite/client.js.map +1 -1
  443. package/dist/vite/dev-api-server.d.ts +1 -1
  444. package/dist/vite/dev-api-server.d.ts.map +1 -1
  445. package/dist/vite/dev-api-server.js +105 -22
  446. package/dist/vite/dev-api-server.js.map +1 -1
  447. package/package.json +22 -6
  448. package/src/templates/default/.agents/skills/actions/SKILL.md +136 -0
  449. package/src/templates/default/.agents/skills/create-skill/SKILL.md +1 -1
  450. package/src/templates/default/.agents/skills/delegate-to-agent/SKILL.md +1 -1
  451. package/src/templates/default/.agents/skills/files-as-database/SKILL.md +2 -2
  452. package/src/templates/default/.agents/skills/real-time-sync/SKILL.md +112 -0
  453. package/src/templates/default/AGENTS.md +56 -164
  454. package/src/templates/default/DEVELOPING.md +117 -0
  455. package/src/templates/default/{scripts → actions}/hello.ts +1 -1
  456. package/src/templates/default/actions/navigate.ts +53 -0
  457. package/src/templates/default/actions/view-screen.ts +39 -0
  458. package/src/templates/default/app/global.css +2 -2
  459. package/src/templates/default/app/root.tsx +19 -16
  460. package/src/templates/default/app/routes/_index.tsx +1 -1
  461. package/src/templates/default/package.json +4 -0
  462. package/src/templates/default/server/plugins/.gitkeep +0 -0
  463. package/dist/a2a/middleware.d.ts +0 -3
  464. package/dist/a2a/middleware.d.ts.map +0 -1
  465. package/dist/a2a/middleware.js +0 -36
  466. package/dist/a2a/middleware.js.map +0 -1
  467. package/dist/client/use-file-watcher.d.ts +0 -23
  468. package/dist/client/use-file-watcher.d.ts.map +0 -1
  469. package/dist/client/use-file-watcher.js +0 -50
  470. package/dist/client/use-file-watcher.js.map +0 -1
  471. package/src/templates/default/.agents/skills/scripts/SKILL.md +0 -121
  472. package/src/templates/default/.agents/skills/sse-file-watcher/SKILL.md +0 -80
  473. package/src/templates/default/server/plugins/agent-chat.ts +0 -1
  474. package/src/templates/default/server/plugins/auth.ts +0 -1
  475. package/src/templates/default/server/plugins/file-sync.ts +0 -1
  476. package/src/templates/default/server/plugins/terminal.ts +0 -1
  477. package/src/templates/default/server/routes/api/events.get.ts +0 -3
  478. package/src/templates/default/server/routes/api/file-sync/status.get.ts +0 -4
  479. /package/src/templates/default/{scripts → actions}/run.ts +0 -0
@@ -2,10 +2,14 @@
2
2
  * Core script: db-exec
3
3
  *
4
4
  * Execute a write SQL statement (INSERT, UPDATE, DELETE, etc.)
5
- * against a SQLite database.
5
+ * against a SQLite or Postgres database.
6
+ *
7
+ * In production mode, temporary views scope UPDATE/DELETE to the current
8
+ * user's data (AGENT_USER_EMAIL). For INSERT, the `owner_email` column
9
+ * is auto-injected if the target table uses the ownership convention.
6
10
  *
7
11
  * Usage:
8
- * pnpm script db-exec --sql "UPDATE forms SET status='published' WHERE id='abc'" [--db path]
12
+ * pnpm action db-exec --sql "UPDATE forms SET status='published' WHERE id='abc'" [--db path]
9
13
  */
10
14
  export default function dbExec(args: string[]): Promise<void>;
11
15
  //# sourceMappingURL=exec.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"exec.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/exec.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAMH,wBAA8B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAyGlE"}
1
+ {"version":3,"file":"exec.d.ts","sourceRoot":"","sources":["../../../src/scripts/db/exec.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AA4GH,wBAA8B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAwIlE"}
@@ -2,18 +2,93 @@
2
2
  * Core script: db-exec
3
3
  *
4
4
  * Execute a write SQL statement (INSERT, UPDATE, DELETE, etc.)
5
- * against a SQLite database.
5
+ * against a SQLite or Postgres database.
6
+ *
7
+ * In production mode, temporary views scope UPDATE/DELETE to the current
8
+ * user's data (AGENT_USER_EMAIL). For INSERT, the `owner_email` column
9
+ * is auto-injected if the target table uses the ownership convention.
6
10
  *
7
11
  * Usage:
8
- * pnpm script db-exec --sql "UPDATE forms SET status='published' WHERE id='abc'" [--db path]
12
+ * pnpm action db-exec --sql "UPDATE forms SET status='published' WHERE id='abc'" [--db path]
9
13
  */
10
14
  import path from "path";
11
15
  import { createClient } from "@libsql/client";
16
+ import { getDatabaseUrl, getDatabaseAuthToken } from "../../db/client.js";
12
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
+ /**
23
+ * For INSERT statements targeting a table with an owner_email column,
24
+ * auto-inject the current user's email if not already present.
25
+ *
26
+ * Handles both forms:
27
+ * INSERT INTO table (col1, col2) VALUES (?, ?)
28
+ * INSERT INTO table VALUES (...)
29
+ */
30
+ function injectOwnerEmail(sql, scoping) {
31
+ if (!scoping.active || !scoping.userEmail)
32
+ return sql;
33
+ const upper = sql
34
+ .replace(/^\s*--[^\n]*\n/gm, "")
35
+ .replace(/\/\*[\s\S]*?\*\//g, "")
36
+ .trim()
37
+ .toUpperCase();
38
+ if (!upper.startsWith("INSERT"))
39
+ return sql;
40
+ // Extract table name: INSERT INTO <table> ...
41
+ const match = sql.match(/INSERT\s+INTO\s+["']?(\w+)["']?/i);
42
+ if (!match)
43
+ return sql;
44
+ const tableName = match[1];
45
+ if (!scoping.ownerEmailTables.has(tableName))
46
+ return sql;
47
+ // Check if owner_email is already in the column list
48
+ if (/owner_email/i.test(sql))
49
+ return sql;
50
+ // Try to inject into explicit column list: INSERT INTO t (cols) VALUES (vals)
51
+ const colListMatch = sql.match(/(INSERT\s+INTO\s+["']?\w+["']?\s*)\(([^)]+)\)(\s*VALUES\s*)\(([^)]+)\)/i);
52
+ if (colListMatch) {
53
+ const [, prefix, cols, valueKeyword, vals] = colListMatch;
54
+ const escaped = scoping.userEmail.replace(/'/g, "''");
55
+ return `${prefix}(${cols}, owner_email)${valueKeyword}(${vals}, '${escaped}')`;
56
+ }
57
+ return sql;
58
+ }
59
+ function printResult(sql, result, hasReturning, format) {
60
+ if (hasReturning && result.rows && result.rows.length > 0) {
61
+ if (format === "json") {
62
+ console.log(JSON.stringify({ sql, rows: result.rows, count: result.rows.length }, null, 2));
63
+ return;
64
+ }
65
+ console.log(`Executed: ${sql}`);
66
+ console.log(`Returned ${result.rows.length} row(s):`);
67
+ console.log(JSON.stringify(result.rows, null, 2));
68
+ }
69
+ else {
70
+ const changes = result.count ?? result.rowsAffected ?? 0;
71
+ if (format === "json") {
72
+ console.log(JSON.stringify({
73
+ sql,
74
+ changes,
75
+ ...(result.lastInsertRowid && changes > 0
76
+ ? { lastInsertRowid: Number(result.lastInsertRowid) }
77
+ : {}),
78
+ }, null, 2));
79
+ return;
80
+ }
81
+ console.log(`Executed: ${sql}`);
82
+ console.log(`Changes: ${changes}`);
83
+ if (result.lastInsertRowid && changes > 0) {
84
+ console.log(`Last Insert Row ID: ${result.lastInsertRowid}`);
85
+ }
86
+ }
87
+ }
13
88
  export default async function dbExec(args) {
14
89
  const parsed = parseArgs(args);
15
90
  if (parsed.help === "true") {
16
- console.log(`Usage: pnpm script db-exec --sql "<statement>" [options]
91
+ console.log(`Usage: pnpm action db-exec --sql "<statement>" [options]
17
92
 
18
93
  Options:
19
94
  --sql <stmt> SQL statement to execute (required)
@@ -46,52 +121,68 @@ Options:
46
121
  if (parsed.db) {
47
122
  url = "file:" + path.resolve(parsed.db);
48
123
  }
49
- else if (process.env.DATABASE_URL) {
50
- url = process.env.DATABASE_URL;
124
+ else if (getDatabaseUrl()) {
125
+ url = getDatabaseUrl();
51
126
  }
52
127
  else {
53
128
  url = "file:" + path.resolve(process.cwd(), "data", "app.db");
54
129
  }
130
+ const hasReturning = /\bRETURNING\b/i.test(stripped);
131
+ // Postgres path
132
+ if (isPostgresUrl(url)) {
133
+ const { default: pg } = await import("postgres");
134
+ const pgSql = pg(url);
135
+ try {
136
+ // Set up user-scoped temp views in production
137
+ const scoping = await buildScopingPostgres(pgSql);
138
+ // For UPDATE/DELETE: temp views scope to current user's rows
139
+ for (const stmt of scoping.setup) {
140
+ await pgSql.unsafe(stmt);
141
+ }
142
+ // For INSERT: auto-inject owner_email
143
+ const finalSql = injectOwnerEmail(sql, scoping);
144
+ const result = await pgSql.unsafe(finalSql);
145
+ const rows = hasReturning && result.length > 0 ? Array.from(result) : [];
146
+ printResult(finalSql, { count: result.count ?? 0, rows }, hasReturning, parsed.format);
147
+ for (const stmt of scoping.teardown) {
148
+ await pgSql.unsafe(stmt).catch(() => { });
149
+ }
150
+ }
151
+ finally {
152
+ await pgSql.end();
153
+ }
154
+ return;
155
+ }
156
+ // libsql / SQLite path
55
157
  const client = createClient({
56
158
  url,
57
- authToken: process.env.DATABASE_AUTH_TOKEN,
159
+ authToken: getDatabaseAuthToken(),
58
160
  });
59
161
  try {
60
- // Detect if the SQL has a RETURNING clause — those produce rows
61
- const hasReturning = /\bRETURNING\b/i.test(stripped);
62
- const result = await client.execute(sql);
63
- if (hasReturning && result.rows.length > 0) {
64
- const rows = result.rows.map((row) => {
162
+ // Set up user-scoped temp views in production
163
+ const scoping = await buildScopingSqlite(client);
164
+ for (const stmt of scoping.setup) {
165
+ await client.execute(stmt);
166
+ }
167
+ // For INSERT: auto-inject owner_email
168
+ const finalSql = injectOwnerEmail(sql, scoping);
169
+ const result = await client.execute(finalSql);
170
+ const rows = hasReturning && result.rows.length > 0
171
+ ? result.rows.map((row) => {
65
172
  const obj = {};
66
173
  for (let i = 0; i < result.columns.length; i++) {
67
174
  obj[result.columns[i]] = row[i];
68
175
  }
69
176
  return obj;
70
- });
71
- if (parsed.format === "json") {
72
- console.log(JSON.stringify({ sql, rows, count: rows.length }, null, 2));
73
- return;
74
- }
75
- console.log(`Executed: ${sql}`);
76
- console.log(`Returned ${rows.length} row(s):`);
77
- if (rows.length > 0) {
78
- console.log(JSON.stringify(rows, null, 2));
79
- }
80
- }
81
- else {
82
- if (parsed.format === "json") {
83
- console.log(JSON.stringify({
84
- sql,
85
- changes: result.rowsAffected,
86
- lastInsertRowid: Number(result.lastInsertRowid ?? 0),
87
- }, null, 2));
88
- return;
89
- }
90
- console.log(`Executed: ${sql}`);
91
- console.log(`Changes: ${result.rowsAffected}`);
92
- if (result.lastInsertRowid && result.rowsAffected > 0) {
93
- console.log(`Last Insert Row ID: ${result.lastInsertRowid}`);
94
- }
177
+ })
178
+ : [];
179
+ printResult(finalSql, {
180
+ rowsAffected: result.rowsAffected,
181
+ lastInsertRowid: result.lastInsertRowid,
182
+ rows,
183
+ }, hasReturning, parsed.format);
184
+ for (const stmt of scoping.teardown) {
185
+ await client.execute(stmt).catch(() => { });
95
186
  }
96
187
  }
97
188
  finally {
@@ -1 +1 @@
1
- {"version":3,"file":"exec.js","sourceRoot":"","sources":["../../../src/scripts/db/exec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"exec.js","sourceRoot":"","sources":["../../../src/scripts/db/exec.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"}