spine-framework 0.2.1 → 1.0.0

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 (425) hide show
  1. package/LICENSE.md +213 -8
  2. package/README.md +327 -0
  3. package/package.json +107 -217
  4. package/src/cli/commands/init.ts +192 -0
  5. package/src/cli/commands/install.ts +25 -0
  6. package/src/cli/commands/list.ts +33 -0
  7. package/src/cli/commands/migrate.ts +24 -0
  8. package/src/cli/index.ts +46 -0
  9. package/src/components/AppLayout.tsx +21 -0
  10. package/src/components/AuthGuard.tsx +21 -0
  11. package/src/components/RoleGuard.tsx +23 -0
  12. package/src/components/index.ts +3 -0
  13. package/src/contexts/AppContext.tsx +122 -0
  14. package/src/contexts/AuthContext.tsx +87 -0
  15. package/src/contexts/SpineContext.tsx +46 -0
  16. package/src/contexts/index.ts +3 -0
  17. package/src/hooks/index.ts +4 -0
  18. package/src/hooks/useItems.ts +78 -0
  19. package/src/hooks/useThreads.ts +73 -0
  20. package/src/hooks/useWebSocket.ts +97 -0
  21. package/src/index.ts +22 -0
  22. package/src/types/index.ts +163 -0
  23. package/src/utils/api.ts +88 -0
  24. package/src/utils/client.ts +146 -0
  25. package/src/utils/config.ts +20 -0
  26. package/src/utils/index.ts +3 -0
  27. package/.framework/README.md +0 -129
  28. package/.framework/cli/bin.cjs +0 -14
  29. package/.framework/cli/commands/agents.ts +0 -153
  30. package/.framework/cli/commands/auth.ts +0 -94
  31. package/.framework/cli/commands/create-app.ts +0 -185
  32. package/.framework/cli/commands/dev.ts +0 -113
  33. package/.framework/cli/commands/doctor.ts +0 -442
  34. package/.framework/cli/commands/generate.ts +0 -332
  35. package/.framework/cli/commands/init.ts +0 -186
  36. package/.framework/cli/commands/install-app.ts +0 -565
  37. package/.framework/cli/commands/items.ts +0 -253
  38. package/.framework/cli/commands/migrate.ts +0 -139
  39. package/.framework/cli/commands/migrations.ts +0 -141
  40. package/.framework/cli/commands/pipelines.ts +0 -166
  41. package/.framework/cli/commands/status.ts +0 -197
  42. package/.framework/cli/commands/system.ts +0 -184
  43. package/.framework/cli/commands/test.ts +0 -227
  44. package/.framework/cli/commands/uninstall-app.ts +0 -166
  45. package/.framework/cli/context.ts +0 -268
  46. package/.framework/cli/env-loader.ts +0 -36
  47. package/.framework/cli/index.ts +0 -116
  48. package/.framework/cli/welcome.cjs +0 -45
  49. package/.framework/docs/API.md +0 -384
  50. package/.framework/docs/STABILITY.md +0 -52
  51. package/.framework/docs/admin-routes.md +0 -76
  52. package/.framework/docs/api-docs-progress.md +0 -38
  53. package/.framework/docs/api-governance.md +0 -146
  54. package/.framework/docs/api-testing-results.md +0 -212
  55. package/.framework/docs/apis/admin-configs.md +0 -567
  56. package/.framework/docs/apis/admin-data.md +0 -272
  57. package/.framework/docs/apis/index.md +0 -231
  58. package/.framework/docs/apis/internal.md +0 -295
  59. package/.framework/docs/apis/runtime.md +0 -537
  60. package/.framework/docs/assembly-launch-guide.md +0 -138
  61. package/.framework/docs/audit-results.md +0 -590
  62. package/.framework/docs/authorization-model.md +0 -170
  63. package/.framework/docs/db-api-inventory.md +0 -95
  64. package/.framework/docs/examples/custom-app/README.md +0 -77
  65. package/.framework/docs/examples/custom-function/README.md +0 -27
  66. package/.framework/docs/examples/custom-function/handler.ts +0 -48
  67. package/.framework/docs/examples/custom-webhook/README.md +0 -68
  68. package/.framework/docs/gap-remediation-backlog.md +0 -103
  69. package/.framework/docs/guides/cli-guide.md +0 -224
  70. package/.framework/docs/guides/getting-started.md +0 -103
  71. package/.framework/docs/guides/import-guide.md +0 -193
  72. package/.framework/docs/guides/testing-guide.md +0 -229
  73. package/.framework/docs/permission-examples.md +0 -326
  74. package/.framework/docs/ui-adoption-verification.md +0 -111
  75. package/.framework/docs/ui-api-coverage.md +0 -84
  76. package/.framework/docs/v2-compatibility-audit.md +0 -228
  77. package/.framework/functions/.gitkeep +0 -1
  78. package/.framework/functions/_shared/agent-runner.ts +0 -1097
  79. package/.framework/functions/_shared/app-manifest.ts +0 -184
  80. package/.framework/functions/_shared/audit.ts +0 -150
  81. package/.framework/functions/_shared/db.ts +0 -178
  82. package/.framework/functions/_shared/index.ts +0 -391
  83. package/.framework/functions/_shared/middleware.ts +0 -490
  84. package/.framework/functions/_shared/permissions.ts +0 -1325
  85. package/.framework/functions/_shared/pipeline-runner.ts +0 -731
  86. package/.framework/functions/_shared/principal.ts +0 -818
  87. package/.framework/functions/_shared/resolve-ids.ts +0 -106
  88. package/.framework/functions/_shared/schema-utils.ts +0 -967
  89. package/.framework/functions/_shared/testing.ts +0 -258
  90. package/.framework/functions/_shared/trigger-engine.ts +0 -425
  91. package/.framework/functions/_shared/webhook-registration.ts +0 -168
  92. package/.framework/functions/_shared/webhook-registry.ts +0 -129
  93. package/.framework/functions/account-nodes.ts +0 -111
  94. package/.framework/functions/admin-data.ts +0 -606
  95. package/.framework/functions/ai-agents.ts +0 -323
  96. package/.framework/functions/api-keys.ts +0 -376
  97. package/.framework/functions/apps.ts +0 -483
  98. package/.framework/functions/auth.ts +0 -196
  99. package/.framework/functions/debug-auth.ts +0 -107
  100. package/.framework/functions/embeddings.ts +0 -556
  101. package/.framework/functions/integration-routes.ts +0 -523
  102. package/.framework/functions/integrations.ts +0 -319
  103. package/.framework/functions/item-progress.ts +0 -272
  104. package/.framework/functions/logs.ts +0 -438
  105. package/.framework/functions/observability.ts +0 -275
  106. package/.framework/functions/pipeline-executions.ts +0 -494
  107. package/.framework/functions/pipelines.ts +0 -485
  108. package/.framework/functions/prompt-configs.ts +0 -339
  109. package/.framework/functions/roles.ts +0 -387
  110. package/.framework/functions/system-cron.ts +0 -742
  111. package/.framework/functions/system.ts +0 -323
  112. package/.framework/functions/tests.ts +0 -119
  113. package/.framework/functions/timers.ts +0 -357
  114. package/.framework/functions/triggers.ts +0 -563
  115. package/.framework/functions/types.ts +0 -604
  116. package/.framework/index.html +0 -16
  117. package/.framework/migrations/000_foundation.sql +0 -1266
  118. package/.framework/migrations/001_seed.sql +0 -163
  119. package/.framework/migrations/002_seed_constraints.sql +0 -19
  120. package/.framework/migrations/003_auth_user_trigger.sql +0 -67
  121. package/.framework/src/App.tsx +0 -133
  122. package/.framework/src/apps/admin/index.tsx +0 -173
  123. package/.framework/src/components/AppWrapper.tsx +0 -56
  124. package/.framework/src/components/CustomAppLoader.tsx +0 -116
  125. package/.framework/src/components/admin/AdminListPage.tsx +0 -151
  126. package/.framework/src/components/admin/AdminSidebar.tsx +0 -166
  127. package/.framework/src/components/admin/AdminStatsCard.tsx +0 -62
  128. package/.framework/src/components/admin/SortableTableHeader.tsx +0 -42
  129. package/.framework/src/components/app-shell/GenericAppShell.tsx +0 -181
  130. package/.framework/src/components/app-shell/GenericDetailPage.tsx +0 -200
  131. package/.framework/src/components/app-shell/GenericListPage.tsx +0 -116
  132. package/.framework/src/components/app-sidebar.tsx +0 -228
  133. package/.framework/src/components/auth/ProtectedRoute.tsx +0 -88
  134. package/.framework/src/components/layout/AppShell.tsx +0 -91
  135. package/.framework/src/components/layout/Header.tsx +0 -88
  136. package/.framework/src/components/layout/Layout.tsx +0 -95
  137. package/.framework/src/components/layout/Sidebar.tsx +0 -329
  138. package/.framework/src/components/runtime/DataDetailHeader.tsx +0 -77
  139. package/.framework/src/components/runtime/DataDetailPage.tsx +0 -171
  140. package/.framework/src/components/runtime/DataFilters.tsx +0 -91
  141. package/.framework/src/components/runtime/DataHeader.tsx +0 -68
  142. package/.framework/src/components/runtime/DataListPage.tsx +0 -124
  143. package/.framework/src/components/runtime/DataStats.tsx +0 -70
  144. package/.framework/src/components/runtime/DataTable.tsx +0 -174
  145. package/.framework/src/components/runtime/SchemaDetailForm.tsx +0 -134
  146. package/.framework/src/components/runtime/index.ts +0 -18
  147. package/.framework/src/components/search-form.tsx +0 -29
  148. package/.framework/src/components/shared/AgentView.tsx +0 -213
  149. package/.framework/src/components/shared/FieldRenderer.tsx +0 -478
  150. package/.framework/src/components/shared/SchemaFields.tsx +0 -226
  151. package/.framework/src/components/ui/DataTable.tsx +0 -343
  152. package/.framework/src/components/ui/Form.tsx +0 -281
  153. package/.framework/src/components/ui/ItemCard.tsx +0 -296
  154. package/.framework/src/components/ui/ItemListView.tsx +0 -308
  155. package/.framework/src/components/ui/LoadingSpinner.tsx +0 -52
  156. package/.framework/src/components/ui/Modal.tsx +0 -61
  157. package/.framework/src/components/ui/RichTextEditor.tsx +0 -210
  158. package/.framework/src/components/ui/accordion.tsx +0 -82
  159. package/.framework/src/components/ui/alert-dialog.tsx +0 -197
  160. package/.framework/src/components/ui/alert.tsx +0 -76
  161. package/.framework/src/components/ui/aspect-ratio.tsx +0 -11
  162. package/.framework/src/components/ui/avatar.tsx +0 -110
  163. package/.framework/src/components/ui/badge.tsx +0 -49
  164. package/.framework/src/components/ui/breadcrumb.tsx +0 -122
  165. package/.framework/src/components/ui/button-group.tsx +0 -83
  166. package/.framework/src/components/ui/button.tsx +0 -65
  167. package/.framework/src/components/ui/calendar.tsx +0 -222
  168. package/.framework/src/components/ui/card.tsx +0 -100
  169. package/.framework/src/components/ui/carousel.tsx +0 -240
  170. package/.framework/src/components/ui/chart.tsx +0 -368
  171. package/.framework/src/components/ui/checkbox.tsx +0 -31
  172. package/.framework/src/components/ui/collapsible.tsx +0 -33
  173. package/.framework/src/components/ui/combobox.tsx +0 -299
  174. package/.framework/src/components/ui/command.tsx +0 -193
  175. package/.framework/src/components/ui/context-menu.tsx +0 -261
  176. package/.framework/src/components/ui/dialog.tsx +0 -165
  177. package/.framework/src/components/ui/direction.tsx +0 -6
  178. package/.framework/src/components/ui/drawer.tsx +0 -132
  179. package/.framework/src/components/ui/dropdown-menu.tsx +0 -269
  180. package/.framework/src/components/ui/empty.tsx +0 -104
  181. package/.framework/src/components/ui/field.tsx +0 -238
  182. package/.framework/src/components/ui/hover-card.tsx +0 -42
  183. package/.framework/src/components/ui/input-group.tsx +0 -153
  184. package/.framework/src/components/ui/input-otp.tsx +0 -87
  185. package/.framework/src/components/ui/input.tsx +0 -19
  186. package/.framework/src/components/ui/item.tsx +0 -196
  187. package/.framework/src/components/ui/kbd.tsx +0 -26
  188. package/.framework/src/components/ui/label.tsx +0 -22
  189. package/.framework/src/components/ui/menubar.tsx +0 -277
  190. package/.framework/src/components/ui/native-select.tsx +0 -61
  191. package/.framework/src/components/ui/navigation-menu.tsx +0 -164
  192. package/.framework/src/components/ui/pagination.tsx +0 -129
  193. package/.framework/src/components/ui/popover.tsx +0 -87
  194. package/.framework/src/components/ui/progress.tsx +0 -31
  195. package/.framework/src/components/ui/radio-group.tsx +0 -42
  196. package/.framework/src/components/ui/resizable.tsx +0 -50
  197. package/.framework/src/components/ui/scroll-area.tsx +0 -53
  198. package/.framework/src/components/ui/select.tsx +0 -195
  199. package/.framework/src/components/ui/separator.tsx +0 -26
  200. package/.framework/src/components/ui/sheet.tsx +0 -145
  201. package/.framework/src/components/ui/sidebar.tsx +0 -706
  202. package/.framework/src/components/ui/skeleton.tsx +0 -13
  203. package/.framework/src/components/ui/slider.tsx +0 -59
  204. package/.framework/src/components/ui/sonner.tsx +0 -47
  205. package/.framework/src/components/ui/spinner.tsx +0 -10
  206. package/.framework/src/components/ui/switch.tsx +0 -33
  207. package/.framework/src/components/ui/table-primitives.tsx +0 -141
  208. package/.framework/src/components/ui/table.tsx +0 -114
  209. package/.framework/src/components/ui/tabs.tsx +0 -90
  210. package/.framework/src/components/ui/textarea.tsx +0 -18
  211. package/.framework/src/components/ui/toggle-group.tsx +0 -89
  212. package/.framework/src/components/ui/toggle.tsx +0 -45
  213. package/.framework/src/components/ui/tooltip.tsx +0 -57
  214. package/.framework/src/contexts/AppContext.tsx +0 -133
  215. package/.framework/src/contexts/AuthContext.tsx +0 -371
  216. package/.framework/src/hooks/use-mobile.ts +0 -19
  217. package/.framework/src/hooks/useApi.ts +0 -526
  218. package/.framework/src/hooks/useApps.ts +0 -114
  219. package/.framework/src/hooks/useEntityList.ts +0 -190
  220. package/.framework/src/hooks/useEntityRecord.ts +0 -308
  221. package/.framework/src/hooks/useForm.ts +0 -307
  222. package/.framework/src/hooks/useListSchema.ts +0 -264
  223. package/.framework/src/hooks/useSchemaRecord.ts +0 -223
  224. package/.framework/src/index.css +0 -128
  225. package/.framework/src/lib/api.ts +0 -156
  226. package/.framework/src/lib/supabase.ts +0 -94
  227. package/.framework/src/lib/utils.ts +0 -317
  228. package/.framework/src/main.tsx +0 -27
  229. package/.framework/src/pages/DashboardPage.tsx +0 -181
  230. package/.framework/src/pages/NotFoundPage.tsx +0 -39
  231. package/.framework/src/pages/admin/AIAgentDetailPage.tsx +0 -161
  232. package/.framework/src/pages/admin/AIAgentsPage.tsx +0 -318
  233. package/.framework/src/pages/admin/APIKeyDetailPage.tsx +0 -199
  234. package/.framework/src/pages/admin/APIKeysPage.tsx +0 -303
  235. package/.framework/src/pages/admin/AlertsConfigPage.tsx +0 -523
  236. package/.framework/src/pages/admin/AppDetailPage.tsx +0 -493
  237. package/.framework/src/pages/admin/AppsPage.tsx +0 -355
  238. package/.framework/src/pages/admin/DesignedPage.tsx +0 -491
  239. package/.framework/src/pages/admin/EmbeddingDetailPage.tsx +0 -534
  240. package/.framework/src/pages/admin/EmbeddingsPage.tsx +0 -424
  241. package/.framework/src/pages/admin/ExtendedShadcnTestPage.tsx +0 -176
  242. package/.framework/src/pages/admin/IncrementalShadcnTestPage.tsx +0 -109
  243. package/.framework/src/pages/admin/IntegratedDashboard.tsx +0 -402
  244. package/.framework/src/pages/admin/IntegrationDetailPage.tsx +0 -187
  245. package/.framework/src/pages/admin/IntegrationsPage.tsx +0 -301
  246. package/.framework/src/pages/admin/LogsPage.tsx +0 -283
  247. package/.framework/src/pages/admin/MinimalShadcnTestPage.tsx +0 -85
  248. package/.framework/src/pages/admin/ObservabilityDashboard.tsx +0 -470
  249. package/.framework/src/pages/admin/PipelineDetailPage.tsx +0 -183
  250. package/.framework/src/pages/admin/PipelineExecutionsPage.tsx +0 -279
  251. package/.framework/src/pages/admin/PipelinesPage.tsx +0 -390
  252. package/.framework/src/pages/admin/PromptConfigDetailPage.tsx +0 -299
  253. package/.framework/src/pages/admin/PromptConfigsPage.tsx +0 -292
  254. package/.framework/src/pages/admin/ProperlyDesignedPage.tsx +0 -434
  255. package/.framework/src/pages/admin/RoleDetailPage.tsx +0 -273
  256. package/.framework/src/pages/admin/RolesPage.tsx +0 -292
  257. package/.framework/src/pages/admin/SelectTestPage.tsx +0 -61
  258. package/.framework/src/pages/admin/ShadcnTestPage.tsx +0 -588
  259. package/.framework/src/pages/admin/SimpleDashboard.tsx +0 -387
  260. package/.framework/src/pages/admin/TestRunDetailPage.tsx +0 -172
  261. package/.framework/src/pages/admin/TestingDashboard.tsx +0 -257
  262. package/.framework/src/pages/admin/TimerDetailPage.tsx +0 -151
  263. package/.framework/src/pages/admin/TimersPage.tsx +0 -376
  264. package/.framework/src/pages/admin/TriggerDetailPage.tsx +0 -149
  265. package/.framework/src/pages/admin/TriggersPage.tsx +0 -381
  266. package/.framework/src/pages/admin/TypeDetailPage.tsx +0 -694
  267. package/.framework/src/pages/admin/TypesPage.tsx +0 -295
  268. package/.framework/src/pages/auth/LoginPage.tsx +0 -187
  269. package/.framework/src/pages/auth/RegisterPage.tsx +0 -163
  270. package/.framework/src/pages/spine-framework/APIPage.tsx +0 -17
  271. package/.framework/src/pages/spine-framework/CLIPage.tsx +0 -25
  272. package/.framework/src/types/auth.ts +0 -125
  273. package/.framework/src/types/types.ts +0 -407
  274. package/STRUCTURE.md +0 -150
  275. package/bin/spine-framework.cjs +0 -62
  276. package/bin/welcome.cjs +0 -45
  277. package/bin/ws-shim.cjs +0 -8
  278. package/bin/ws-shim.ts +0 -10
  279. package/config/components.json +0 -25
  280. package/config/deno.lock +0 -108
  281. package/config/package-lock.json +0 -17183
  282. package/config/postcss.config.cjs +0 -10
  283. package/config/tailwind.config.cjs +0 -78
  284. package/config/tsconfig.build.json +0 -32
  285. package/config/tsconfig.cli.json +0 -18
  286. package/config/tsconfig.json +0 -41
  287. package/config/tsconfig.node.json +0 -17
  288. package/config/tsconfig.node.tsbuildinfo +0 -1
  289. package/config/tsconfig.tsbuildinfo +0 -1
  290. package/config/typedoc.json +0 -16
  291. package/config/vite.config.d.ts +0 -2
  292. package/config/vite.config.ts +0 -71
  293. package/dist/cli/commands/agents.d.ts +0 -39
  294. package/dist/cli/commands/agents.d.ts.map +0 -1
  295. package/dist/cli/commands/auth.d.ts +0 -36
  296. package/dist/cli/commands/auth.d.ts.map +0 -1
  297. package/dist/cli/commands/create-app.d.ts +0 -23
  298. package/dist/cli/commands/create-app.d.ts.map +0 -1
  299. package/dist/cli/commands/dev.d.ts +0 -24
  300. package/dist/cli/commands/dev.d.ts.map +0 -1
  301. package/dist/cli/commands/doctor.d.ts +0 -42
  302. package/dist/cli/commands/doctor.d.ts.map +0 -1
  303. package/dist/cli/commands/generate.d.ts +0 -36
  304. package/dist/cli/commands/generate.d.ts.map +0 -1
  305. package/dist/cli/commands/init.d.ts +0 -20
  306. package/dist/cli/commands/init.d.ts.map +0 -1
  307. package/dist/cli/commands/install-app.d.ts +0 -30
  308. package/dist/cli/commands/install-app.d.ts.map +0 -1
  309. package/dist/cli/commands/items.d.ts +0 -45
  310. package/dist/cli/commands/items.d.ts.map +0 -1
  311. package/dist/cli/commands/migrate.d.ts +0 -21
  312. package/dist/cli/commands/migrate.d.ts.map +0 -1
  313. package/dist/cli/commands/migrations.d.ts +0 -41
  314. package/dist/cli/commands/migrations.d.ts.map +0 -1
  315. package/dist/cli/commands/pipelines.d.ts +0 -40
  316. package/dist/cli/commands/pipelines.d.ts.map +0 -1
  317. package/dist/cli/commands/status.d.ts +0 -23
  318. package/dist/cli/commands/status.d.ts.map +0 -1
  319. package/dist/cli/commands/system.d.ts +0 -29
  320. package/dist/cli/commands/system.d.ts.map +0 -1
  321. package/dist/cli/commands/test.d.ts +0 -46
  322. package/dist/cli/commands/test.d.ts.map +0 -1
  323. package/dist/cli/commands/uninstall-app.d.ts +0 -23
  324. package/dist/cli/commands/uninstall-app.d.ts.map +0 -1
  325. package/dist/cli/context.d.ts +0 -88
  326. package/dist/cli/context.d.ts.map +0 -1
  327. package/dist/cli/env-loader.d.ts +0 -14
  328. package/dist/cli/env-loader.d.ts.map +0 -1
  329. package/dist/cli/index.d.ts +0 -41
  330. package/dist/cli/index.d.ts.map +0 -1
  331. package/dist/functions/_shared/agent-runner.d.ts +0 -156
  332. package/dist/functions/_shared/agent-runner.d.ts.map +0 -1
  333. package/dist/functions/_shared/app-manifest.d.ts +0 -68
  334. package/dist/functions/_shared/app-manifest.d.ts.map +0 -1
  335. package/dist/functions/_shared/audit.d.ts +0 -91
  336. package/dist/functions/_shared/audit.d.ts.map +0 -1
  337. package/dist/functions/_shared/db.d.ts +0 -125
  338. package/dist/functions/_shared/db.d.ts.map +0 -1
  339. package/dist/functions/_shared/index.d.ts +0 -299
  340. package/dist/functions/_shared/index.d.ts.map +0 -1
  341. package/dist/functions/_shared/middleware.d.ts +0 -315
  342. package/dist/functions/_shared/middleware.d.ts.map +0 -1
  343. package/dist/functions/_shared/permissions.d.ts +0 -626
  344. package/dist/functions/_shared/permissions.d.ts.map +0 -1
  345. package/dist/functions/_shared/pipeline-runner.d.ts +0 -124
  346. package/dist/functions/_shared/pipeline-runner.d.ts.map +0 -1
  347. package/dist/functions/_shared/principal.d.ts +0 -284
  348. package/dist/functions/_shared/principal.d.ts.map +0 -1
  349. package/dist/functions/_shared/resolve-ids.d.ts +0 -10
  350. package/dist/functions/_shared/resolve-ids.d.ts.map +0 -1
  351. package/dist/functions/_shared/schema-utils.d.ts +0 -181
  352. package/dist/functions/_shared/schema-utils.d.ts.map +0 -1
  353. package/dist/functions/_shared/testing.d.ts +0 -172
  354. package/dist/functions/_shared/testing.d.ts.map +0 -1
  355. package/dist/functions/_shared/trigger-engine.d.ts +0 -140
  356. package/dist/functions/_shared/trigger-engine.d.ts.map +0 -1
  357. package/dist/functions/_shared/webhook-registration.d.ts +0 -81
  358. package/dist/functions/_shared/webhook-registration.d.ts.map +0 -1
  359. package/dist/functions/_shared/webhook-registry.d.ts +0 -57
  360. package/dist/functions/_shared/webhook-registry.d.ts.map +0 -1
  361. package/dist/functions/account-nodes.d.ts +0 -48
  362. package/dist/functions/account-nodes.d.ts.map +0 -1
  363. package/dist/functions/admin-data.d.ts +0 -178
  364. package/dist/functions/admin-data.d.ts.map +0 -1
  365. package/dist/functions/ai-agents.d.ts +0 -125
  366. package/dist/functions/ai-agents.d.ts.map +0 -1
  367. package/dist/functions/api-keys.d.ts +0 -140
  368. package/dist/functions/api-keys.d.ts.map +0 -1
  369. package/dist/functions/apps.d.ts +0 -163
  370. package/dist/functions/apps.d.ts.map +0 -1
  371. package/dist/functions/auth.d.ts +0 -74
  372. package/dist/functions/auth.d.ts.map +0 -1
  373. package/dist/functions/debug-auth.d.ts +0 -33
  374. package/dist/functions/debug-auth.d.ts.map +0 -1
  375. package/dist/functions/embeddings.d.ts +0 -205
  376. package/dist/functions/embeddings.d.ts.map +0 -1
  377. package/dist/functions/integration-routes.d.ts +0 -45
  378. package/dist/functions/integration-routes.d.ts.map +0 -1
  379. package/dist/functions/integrations.d.ts +0 -124
  380. package/dist/functions/integrations.d.ts.map +0 -1
  381. package/dist/functions/item-progress.d.ts +0 -41
  382. package/dist/functions/item-progress.d.ts.map +0 -1
  383. package/dist/functions/logs.d.ts +0 -162
  384. package/dist/functions/logs.d.ts.map +0 -1
  385. package/dist/functions/observability.d.ts +0 -123
  386. package/dist/functions/observability.d.ts.map +0 -1
  387. package/dist/functions/pipeline-executions.d.ts +0 -190
  388. package/dist/functions/pipeline-executions.d.ts.map +0 -1
  389. package/dist/functions/pipelines.d.ts +0 -171
  390. package/dist/functions/pipelines.d.ts.map +0 -1
  391. package/dist/functions/prompt-configs.d.ts +0 -125
  392. package/dist/functions/prompt-configs.d.ts.map +0 -1
  393. package/dist/functions/roles.d.ts +0 -118
  394. package/dist/functions/roles.d.ts.map +0 -1
  395. package/dist/functions/system-cron.d.ts +0 -65
  396. package/dist/functions/system-cron.d.ts.map +0 -1
  397. package/dist/functions/system.d.ts +0 -29
  398. package/dist/functions/system.d.ts.map +0 -1
  399. package/dist/functions/tests.d.ts +0 -28
  400. package/dist/functions/tests.d.ts.map +0 -1
  401. package/dist/functions/timers.d.ts +0 -139
  402. package/dist/functions/timers.d.ts.map +0 -1
  403. package/dist/functions/triggers.d.ts +0 -203
  404. package/dist/functions/triggers.d.ts.map +0 -1
  405. package/dist/functions/types.d.ts +0 -151
  406. package/dist/functions/types.d.ts.map +0 -1
  407. package/dist/src/types/types.d.ts +0 -364
  408. package/dist/src/types/types.d.ts.map +0 -1
  409. package/index.html +0 -13
  410. package/netlify.toml +0 -36
  411. package/package-project.json +0 -71
  412. package/scripts/app-install-cli.ts +0 -286
  413. package/scripts/assemble-frontend.sh +0 -76
  414. package/scripts/assemble-functions.sh +0 -62
  415. package/scripts/assemble.sh +0 -41
  416. package/scripts/boundary-check.sh +0 -106
  417. package/scripts/build-manifest.sh +0 -80
  418. package/scripts/check-core-integrity.sh +0 -82
  419. package/scripts/ingest-chunks.cjs +0 -202
  420. package/scripts/kb-chunk-parser.cjs +0 -312
  421. package/scripts/kb-chunk-parser.ts +0 -330
  422. package/scripts/load-test-app-install.ts +0 -484
  423. package/scripts/netlify-dev-wrapper.sh +0 -22
  424. package/scripts/verify-integrity.sh +0 -69
  425. package/vitest.config.ts +0 -45
@@ -1,156 +0,0 @@
1
- /**
2
- * @module agent-runner
3
- * @audience both
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * AI agent inference orchestrator with RAG, tool dispatch, and confidence-based
8
- * escalation. All agent behavior is defined via JSONB configuration stored in
9
- * existing schema tables — no dedicated migrations are needed.
10
- *
11
- * Configuration resolution chain (highest to lowest priority):
12
- * 1. `thread.data.agent_id` → `thread.type.design_schema.default_agent_id`
13
- * 2. `thread.data.prompt_config_id` → `agent.metadata.default_prompt_config_id`
14
- *
15
- * Inference loop (per `runAgent` call):
16
- * 1. `resolveAgentConfig` — resolve agent + prompt_config from thread
17
- * 2. Save user message to `messages` table
18
- * 3. `executeAgentInference` — iterative tool-call loop (max 5 iterations):
19
- * a. `buildContext` — assemble system prompt + RAG + history + tools
20
- * b. `callInference` — call OpenAI-compatible API (or return mock)
21
- * c. `dispatchTools` — execute any tool_calls via actions table
22
- * d. Rebuild context with tool results and repeat
23
- * 4. Confidence check — if below threshold, `handleEscalation`
24
- * 5. Save agent response to `messages` table
25
- * 6. Emit `agent.inference.completed` audit log
26
- *
27
- * Environment variables used by `callInference`:
28
- * - `OPENAI_API_KEY` / `ANTHROPIC_API_KEY` / `LLM_API_KEY` — LLM auth
29
- * - `OPENAI_BASE_URL` / `LLM_BASE_URL` — API base URL (default: OpenAI)
30
- * - `LLM_DEFAULT_MODEL` — model name fallback (default: 'gpt-4o')
31
- *
32
- * INVARIANT: if no API key is set, `callInference` returns a mock response
33
- * instead of throwing — safe for local development without credentials.
34
- * INVARIANT: `runAgent` throws on critical failures (config missing, inference
35
- * error) — callers must handle the rejection.
36
- * INVARIANT: `resolveAgentConfig` returns null (not throws) on missing config;
37
- * `runAgent` converts this to a throw.
38
- *
39
- * @seeAlso pipeline-runner.ts (tool dispatch calls runPipeline for run_pipeline tool)
40
- * @seeAlso audit.ts (emitAudit for agent.inference.* events)
41
- * @seeAlso index.ts (runAgent, resolveAgentConfig re-exported)
42
- */
43
- import { CoreContext } from './middleware';
44
- /**
45
- * Resolved agent configuration bundle. Output of `resolveAgentConfig`.
46
- * Passed to `executeAgentInference` and `buildContext`.
47
- *
48
- * @outputSpec agent: ai_agents row (system_prompt, model_config, metadata)
49
- * @outputSpec promptConfig: prompt_configs row (context_template,
50
- * knowledge_sources, available_tools, confidence_threshold, escalation_*)
51
- * @outputSpec thread: threads row with joined type record
52
- * @outputSpec threadType: types row (design_schema.default_agent_id)
53
- */
54
- export interface AgentConfig {
55
- agent: any;
56
- promptConfig: any;
57
- thread: any;
58
- threadType: any;
59
- }
60
- /**
61
- * Structured result from a single LLM inference call.
62
- *
63
- * @outputSpec content: string — agent response text
64
- * @outputSpec confidence: number — 0-1 score; derived from logprobs or 0.85 default
65
- * @outputSpec tool_calls: ToolCall[] | undefined — tools the model wants to call
66
- * @outputSpec metadata: { model, usage, finish_reason } | undefined
67
- */
68
- export interface InferenceResult {
69
- content: string;
70
- confidence: number;
71
- tool_calls?: ToolCall[];
72
- metadata?: Record<string, any>;
73
- }
74
- /**
75
- * A single tool invocation requested by the LLM in an `InferenceResult`.
76
- *
77
- * @inputSpec tool: string — action.slug to look up in the actions table
78
- * @inputSpec params: Record<string, any> — parsed from OpenAI function call arguments
79
- * @inputSpec id: string — opaque tool_call ID from the LLM response
80
- */
81
- export interface ToolCall {
82
- tool: string;
83
- params: Record<string, any>;
84
- id: string;
85
- }
86
- /**
87
- * Result of executing a single `ToolCall`.
88
- *
89
- * @outputSpec tool: string — mirrors ToolCall.tool
90
- * @outputSpec result: any — handler return value on success; null on error
91
- * @outputSpec error: string | undefined — error message if execution failed
92
- * @outputSpec id: string — mirrors ToolCall.id for correlation
93
- */
94
- export interface ToolResult {
95
- tool: string;
96
- result: any;
97
- error?: string;
98
- id: string;
99
- }
100
- /**
101
- * Main entry point: run a full agent inference cycle for a user message.
102
- *
103
- * Saves the user message, runs the inference loop (with tool calls), checks
104
- * confidence, saves the agent response, and emits audit logs.
105
- *
106
- * @param threadId - UUID of the thread to run inference on
107
- * @param userMessage - Raw message text from the user
108
- * @param ctx - CoreContext with accountId, principal, requestId
109
- * @returns Promise<any> — the saved agent message record from the `messages` table
110
- * @throws Error — if agent config cannot be resolved, or LLM inference fails
111
- * @inputSpec threadId: string — valid UUID in threads table
112
- * @inputSpec userMessage: string — non-empty message text
113
- * @inputSpec ctx.accountId: string | null — used to scope DB lookups
114
- * @outputSpec messages row — the inserted agent reply with content and metadata
115
- * @sideEffects DB write: inserts 2 messages rows (user + agent)
116
- * @sideEffects DB write: emitAudit (agent.inference.completed or agent.inference.failed)
117
- * @sideEffects HTTP call: callInference (LLM API)
118
- * @sideEffects DB write (conditional): handleEscalation if confidence < threshold
119
- * @calledBy functions/ai-agents.ts handler for POST ?action=run
120
- * @calledBy v2-custom/ import callers
121
- * @calls resolveAgentConfig, saveMessage, executeAgentInference,
122
- * handleEscalation, emitAudit
123
- * @testUnit tests/unit/agent-runner.test.ts
124
- * @testIntegration tests/integration/agent-runner.test.ts
125
- *
126
- * @example API handler usage
127
- * ```ts
128
- * import { runAgent } from './_shared/index'
129
- * const agentMsg = await runAgent(body.thread_id, body.message, ctx)
130
- * return agentMsg
131
- * ```
132
- */
133
- export declare function runAgent(threadId: string, userMessage: string, ctx: CoreContext): Promise<any>;
134
- /**
135
- * Resolves the agent, prompt config, thread, and thread type for a given thread.
136
- *
137
- * Resolution priority:
138
- * - `agent_id`: `thread.data.agent_id` → `thread.type.design_schema.default_agent_id`
139
- * - `prompt_config_id`: `thread.data.prompt_config_id` →
140
- * `agent.metadata.default_prompt_config_id`
141
- *
142
- * Returns `null` (does not throw) when any required record is missing. `runAgent`
143
- * converts a null return to a thrown Error.
144
- *
145
- * @param threadId - UUID of the thread
146
- * @param ctx - CoreContext (requestId used for error logging)
147
- * @returns Promise<AgentConfig | null> — null if config cannot be resolved
148
- * @throws never — errors logged to console, returns null
149
- * @inputSpec threadId: string — valid UUID in threads table
150
- * @outputSpec AgentConfig | null
151
- * @sideEffects DB reads: threads (with type join), ai_agents, prompt_configs
152
- * @calledBy runAgent
153
- * @testUnit tests/unit/agent-runner.test.ts — 'resolveAgentConfig'
154
- */
155
- export declare function resolveAgentConfig(threadId: string, ctx: CoreContext): Promise<AgentConfig | null>;
156
- //# sourceMappingURL=agent-runner.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"agent-runner.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/agent-runner.ts"],"names":[],"mappings":"AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAM1C;;;;;;;;;GASG;AACH,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,GAAG,CAAA;IACV,YAAY,EAAE,GAAG,CAAA;IACjB,MAAM,EAAE,GAAG,CAAA;IACX,UAAU,EAAE,GAAG,CAAA;CAChB;AAED;;;;;;;GAOG;AACH,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAA;IACf,UAAU,EAAE,MAAM,CAAA;IAClB,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAA;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAC/B;AAED;;;;;;GAMG;AACH,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC3B,EAAE,EAAE,MAAM,CAAA;CACX;AAED;;;;;;;GAOG;AACH,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,GAAG,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,EAAE,EAAE,MAAM,CAAA;CACX;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,WAAW,GACf,OAAO,CAAC,GAAG,CAAC,CA0Ed;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,WAAW,GACf,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAmE7B"}
@@ -1,68 +0,0 @@
1
- /**
2
- * @module app-manifest
3
- * @audience core-contributor
4
- * @layer shared-util
5
- * @stability evolving
6
- *
7
- * Utility for loading and merging app manifests with database records.
8
- * Enables file-first app configuration with database tracking installations.
9
- *
10
- * **Pattern:**
11
- * 1. Manifest files in custom/apps/{slug}/manifest.json are source of truth
12
- * 2. Database tracks which tenant has which app installed/enabled
13
- * 3. This utility merges both sources for the API response
14
- *
15
- * @seeAlso apps.ts (uses this for manifest-driven responses)
16
- * @seeAlso 015_simplify_apps_table.sql (database structure)
17
- */
18
- export interface AppManifest {
19
- name: string;
20
- slug: string;
21
- description?: string;
22
- version?: string;
23
- required_roles: string[];
24
- routes: string[];
25
- nav_items: NavItem[];
26
- features?: string[];
27
- dependencies?: string[];
28
- entry_point: string;
29
- is_public?: boolean;
30
- auth_required?: boolean;
31
- }
32
- export interface NavItem {
33
- title: string;
34
- path: string;
35
- icon?: string;
36
- order?: number;
37
- children?: NavItem[];
38
- }
39
- /**
40
- * Loads a manifest.json file from the filesystem.
41
- *
42
- * @param manifestPath - Relative path to manifest (e.g., 'custom/apps/cortex/manifest.json')
43
- * @returns Parsed manifest or null if not found
44
- */
45
- export declare function loadManifest(manifestPath: string): AppManifest | null;
46
- /**
47
- * Clears the manifest cache. Useful for testing.
48
- */
49
- export declare function clearManifestCache(): void;
50
- /**
51
- * Merges database app record with manifest data.
52
- * Manifest takes precedence for metadata fields.
53
- *
54
- * @param dbRecord - App record from app_definitions table
55
- * @returns Merged app data for API response
56
- */
57
- export declare function mergeWithManifest(dbRecord: any): any;
58
- /**
59
- * Lists all available manifests from filesystem.
60
- * Used for initial discovery before database tracking.
61
- *
62
- * @returns Array of discovered app slugs and their paths
63
- */
64
- export declare function discoverManifests(): Array<{
65
- slug: string;
66
- path: string;
67
- }>;
68
- //# sourceMappingURL=app-manifest.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"app-manifest.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/app-manifest.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAKH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,EAAE,CAAA;IACxB,MAAM,EAAE,MAAM,EAAE,CAAA;IAChB,SAAS,EAAE,OAAO,EAAE,CAAA;IACpB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAA;CACrB;AAKD;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,YAAY,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,CAiCrE;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC;AAED;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,GAAG,GAAG,GAAG,CA2DpD;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,IAAI,KAAK,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAC,CAAC,CAcvE"}
@@ -1,91 +0,0 @@
1
- /**
2
- * @module audit
3
- * @audience both
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * Unified audit logging for all operations in Spine. Every state-changing
8
- * operation should call `emitAudit` to write a structured row to the `logs`
9
- * table with full principal provenance. Audit failures never throw — a failed
10
- * log write must never break the operation that triggered it.
11
- *
12
- * INVARIANT: always call `emitAudit` after a successful write, not before.
13
- * Pass `result: 'failure'` only when the operation itself failed.
14
- * INVARIANT: never pass sensitive secrets (API keys, tokens) in metadata.
15
- *
16
- * @seeAlso principal.ts (formatPrincipalForAudit — shapes the principal field)
17
- * @seeAlso middleware.ts (CoreContext — ctx.requestId ties logs to HTTP requests)
18
- * @seeAlso logs.ts (API handler that queries the logs table)
19
- * @seeAlso permissions.ts (getPrincipalPermissionSummary — used in metadata)
20
- */
21
- import { CoreContext } from './middleware';
22
- /**
23
- * @chunk-id SHARED_AUDIT_EMIT_1_0_0
24
- * @version 1.0.0
25
- * @hash d9c3dbc103f5f2f0543dc4c154bbad256e59c885643a20bc20ca07198eabd67c
26
- * @macro Audit Log Emitter
27
- * @micro Writes structured audit logs to logs table with principal provenance
28
- * @inputs ctx: CoreContext — Request context with principal and database
29
- * @inputs action: string — Dot-namespaced action (e.g. 'items.create')
30
- * @inputs target: {type, id?, account_id?} — Resource being acted upon
31
- * @inputs metadata: {changes?, result?, error?, ...} — Optional context
32
- * @outputs void — Always resolves, never rejects
33
- * @depends-on [adminDb, formatPrincipalForAudit]
34
- * @depended-by [All state-changing API functions, pipeline-runner, trigger-engine]
35
- * @side-effects [DB insert to logs table, console.error on failure]
36
- * @tags audit, logging, security, compliance
37
- */
38
- export declare function emitAudit(ctx: CoreContext, action: string, target: {
39
- type: string;
40
- id?: string;
41
- account_id?: string;
42
- }, metadata?: {
43
- changes?: {
44
- before?: any;
45
- after?: any;
46
- };
47
- result?: 'success' | 'failure' | 'denied';
48
- error?: string;
49
- [key: string]: any;
50
- }): Promise<void>;
51
- /**
52
- * @chunk-id SHARED_AUDIT_EMIT_LOG_1_0_0
53
- * @version 1.0.0
54
- * @hash 148fb1ce7badf1d3df08e2daa38bac4c084c94ba2f262c782c9df092a22890dd
55
- * @macro Legacy Audit Log Wrapper
56
- * @micro Backward compatibility wrapper around emitAudit
57
- * @inputs ctx: CoreContext — Request context
58
- * @inputs eventType: string — Action string (maps to emitAudit's action)
59
- * @inputs target: {type, id} | undefined — Resource target
60
- * @inputs changes: {before?, after?} | undefined — Change data
61
- * @inputs metadata: Record<string, any> — Additional context
62
- * @outputs void — Always resolves
63
- * @depends-on [emitAudit]
64
- * @depended-by [Legacy code, should not be used in new code]
65
- * @side-effects [DB insert via emitAudit, console.error on failure]
66
- * @tags audit, logging, legacy, wrapper, deprecated
67
- */
68
- export declare function emitLog(ctx: CoreContext, eventType: string, target?: {
69
- type: string;
70
- id: string;
71
- }, changes?: {
72
- before?: any;
73
- after?: any;
74
- }, metadata?: Record<string, any>): Promise<void>;
75
- /**
76
- * @chunk-id SHARED_AUDIT_EMIT_ACTIVITY_1_0_0
77
- * @version 1.0.0
78
- * @hash 58e532a743fdae480ca24d311be66e82612477309270ec7462fd7dfd695d5282
79
- * @macro Legacy Activity Logger
80
- * @micro Wraps emitLog with activity. prefix for backward compatibility
81
- * @inputs ctx: CoreContext — Request context
82
- * @inputs type: string — Activity type (prefixed with 'activity.')
83
- * @inputs details: Record<string, any> — Metadata context
84
- * @outputs void — Always resolves
85
- * @depends-on [emitLog]
86
- * @depended-by [Legacy code, should not be used in new code]
87
- * @side-effects [DB insert via emitLog → emitAudit, console.error on failure]
88
- * @tags audit, logging, legacy, activity, deprecated
89
- */
90
- export declare function emitActivity(ctx: CoreContext, type: string, details?: Record<string, any>): Promise<void>;
91
- //# sourceMappingURL=audit.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/audit.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAO1C;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,SAAS,CAC7B,GAAG,EAAE,WAAW,EAChB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,EAAE,CAAC,EAAE,MAAM,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,CAAA;CAAE,EAC1D,QAAQ,CAAC,EAAE;IACT,OAAO,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,GAAG,CAAC;QAAC,KAAK,CAAC,EAAE,GAAG,CAAA;KAAE,CAAA;IACvC,MAAM,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAA;IACzC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB,GACA,OAAO,CAAC,IAAI,CAAC,CA0Bf;AAMD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,OAAO,CAC3B,GAAG,EAAE,WAAW,EAChB,SAAS,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,EAAE,EAAE,MAAM,CAAA;CAAE,EACrC,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,GAAG,CAAC;IAAC,KAAK,CAAC,EAAE,GAAG,CAAA;CAAE,EACvC,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GACjC,OAAO,CAAC,IAAI,CAAC,CAcf;AAID;;;;;;;;;;;;;;GAcG;AACH,wBAAsB,YAAY,CAChC,GAAG,EAAE,WAAW,EAChB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GAChC,OAAO,CAAC,IAAI,CAAC,CAEf"}
@@ -1,125 +0,0 @@
1
- /**
2
- * @module db
3
- * @audience both
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * Supabase client factory and PostgREST join helpers. This module owns the
8
- * two-client pattern that is central to Spine's security model: `adminDb`
9
- * bypasses RLS for system operations; `getUserDb` enforces RLS for all
10
- * human-principal requests. Never use `adminDb` for user-scoped queries —
11
- * doing so silently bypasses account isolation.
12
- *
13
- * @seeAlso principal.ts (getPrincipalDb selects between these two clients)
14
- * @seeAlso middleware.ts (ctx.db is set from getPrincipalDb at request time)
15
- */
16
- /**
17
- * Service-role Supabase client. Bypasses Row Level Security.
18
- *
19
- * Use this ONLY for:
20
- * - System/cron operations that must cross account boundaries (`system-cron.ts`)
21
- * - Principal resolution lookups (`principal.ts` — resolving auth_uid to person)
22
- * - Machine principal validation RPCs
23
- * - Test helpers that need to seed/clean data across accounts
24
- *
25
- * Do NOT use this in request handlers for user-scoped data reads or writes.
26
- * Always prefer `ctx.db` (set by `getPrincipalDb` in middleware) for those.
27
- *
28
- * @inputSpec SUPABASE_URL: string — valid Supabase project URL, required
29
- * @inputSpec SUPABASE_SERVICE_ROLE_KEY: string — service role JWT, required
30
- * @outputSpec SupabaseClient — PostgREST client scoped to `dbSchema`, RLS disabled
31
- * @sideEffects none (client construction only)
32
- * @calledBy principal.ts, middleware.ts, system-cron.ts, permissions.ts,
33
- * tests/integration/helpers.ts
34
- * @calls createClient (supabase-js)
35
- * @testUnit tests/unit/pipeline-runner.test.ts — mocked via vi.mock
36
- * @testIntegration tests/integration/helpers.ts — used directly as adminDb
37
- *
38
- * @example API handler (system operation)
39
- * ```ts
40
- * import { adminDb } from './_shared/db'
41
- * const { data } = await adminDb.from('types').select('*').eq('slug', 'item')
42
- * ```
43
- *
44
- * @example Import usage (v2-custom/ — system-level only)
45
- * ```ts
46
- * import { adminDb } from '../_shared/index'
47
- * // Only use adminDb if your custom code runs as a system/cron principal
48
- * ```
49
- */
50
- export declare const adminDb: import("@supabase/supabase-js").SupabaseClient<any, "public", string, any, any>;
51
- /**
52
- * @chunk-id SHARED_DB_GET_USER_DB_1_0_0
53
- * @version 1.0.0
54
- * @hash af3c792634c60ced1c1c4184cfc6c20add90ab97eb62f7e46bdf40ae2899a0f8
55
- * @macro User Database Client Factory
56
- * @micro Creates RLS-enforced Supabase client for specific user JWT
57
- * @inputs jwt: string — Valid Supabase JWT from Authorization header
58
- * @outputs SupabaseClient — PostgREST client with RLS enforced
59
- * @depends-on [createClient, supabaseUrl, supabaseAnonKey, dbSchema]
60
- * @depended-by [principal.ts, middleware.ts]
61
- * @side-effects [Client construction with Authorization header]
62
- * @tags database, supabase, rls, authentication, user-scoped
63
- */
64
- export declare function getUserDb(jwt: string): import("@supabase/supabase-js").SupabaseClient<any, "public", string, any, any>;
65
- /**
66
- * Standard shape returned by all Supabase PostgREST queries.
67
- *
68
- * Both `data` and `error` follow the Supabase JS client convention: on success,
69
- * `error` is null; on failure, `data` is null and `error` contains the Postgres
70
- * error details. Always check `error` before using `data`.
71
- *
72
- * @inputSpec T — the expected shape of a successful result row
73
- * @outputSpec data: T | null — the query result, null on error
74
- * @outputSpec error: any — null on success, Postgres/PostgREST error object on failure
75
- * @calledBy used as return type annotation across all functions/*.ts handlers
76
- *
77
- * @example
78
- * ```ts
79
- * const result: DbResult<Item> = await adminDb.from('items').select('*').single()
80
- * if (result.error) throw result.error
81
- * return result.data!
82
- * ```
83
- */
84
- export type DbResult<T> = {
85
- data: T | null;
86
- error: any;
87
- };
88
- /**
89
- * PostgREST relationship hint strings for all foreign keys in the public schema.
90
- *
91
- * These strings are interpolated into `.select()` calls to eager-load related
92
- * records in a single query. They use explicit `!fk_column` hints to resolve
93
- * ambiguous relationships — required when a table has multiple FKs to the same
94
- * target table, or when the FK column name doesn't follow PostgREST's default
95
- * `tablename_id` inference convention (e.g. `created_by` → `people.id`).
96
- *
97
- * Only add a join here when it is used in two or more handlers. One-off joins
98
- * should be written inline.
99
- *
100
- * @inputSpec none — these are static string constants
101
- * @outputSpec string — valid PostgREST embed expression for use in .select()
102
- * @sideEffects none
103
- * @calledBy types.ts, apps.ts, pipelines.ts, triggers.ts, admin-data.ts, and others
104
- * @testUnit none — these are string constants; incorrect joins fail at runtime
105
- * @testIntegration tests/integration/admin-data-accounts.test.ts — exercises joins.type
106
- *
107
- * @example
108
- * ```ts
109
- * import { joins } from './_shared/db'
110
- * const { data } = await ctx.db
111
- * .from('items')
112
- * .select(`*, ${joins.type}, ${joins.app}`)
113
- * // Returns items with nested type and app objects
114
- * ```
115
- */
116
- export declare const joins: {
117
- type: string;
118
- app: string;
119
- ownerAccount: string;
120
- createdBy: string;
121
- parentAccount: string;
122
- role: string;
123
- pipeline: string;
124
- };
125
- //# sourceMappingURL=db.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/db.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AA+BH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,eAAO,MAAM,OAAO,iFAIlB,CAAA;AAGF;;;;;;;;;;;;GAYG;AACH,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,mFAWpC;AAKD;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;IACxB,IAAI,EAAE,CAAC,GAAG,IAAI,CAAA;IACd,KAAK,EAAE,GAAG,CAAA;CACX,CAAA;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,eAAO,MAAM,KAAK;;;;;;;;CAQjB,CAAA"}