spine-framework 0.1.61 → 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 +223 -0
  2. package/README.md +327 -0
  3. package/package.json +107 -216
  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 -126
  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 -72
  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 -64
  412. package/scripts/app-install-cli.ts +0 -286
  413. package/scripts/assemble-frontend.sh +0 -79
  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,299 +0,0 @@
1
- /**
2
- * @module index
3
- * @audience installer
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * Spine v2 Core — Public Import Surface
8
- *
9
- * This is the **single, stable entry point** for all custom code importing
10
- * Spine core functionality. Everything exported here is a committed contract.
11
- * Internal helpers not listed here are free to change without notice.
12
- *
13
- * ## Usage
14
- *
15
- * ### In custom functions (v2-custom/functions/)
16
- * ```ts
17
- * import { runPipeline, adminDb, SYSTEM_PRINCIPAL, CoreContext } from '../_shared'
18
- *
19
- * const ctx: CoreContext = {
20
- * principal: SYSTEM_PRINCIPAL,
21
- * accountId: myAccountId,
22
- * db: adminDb,
23
- * requestId: crypto.randomUUID()
24
- * }
25
- * const result = await runPipeline(pipelineId, triggerData, ctx)
26
- * ```
27
- *
28
- * ### In CLI commands
29
- * ```ts
30
- * import { runPipeline, adminDb, resolvePrincipal, CoreContext } from '../functions/_shared'
31
- * ```
32
- *
33
- * ### Stability contract
34
- * - All exports in this file are stable across patch and minor versions
35
- * - Breaking changes require a major version bump and migration guide
36
- * - Do NOT import from individual `_shared/*.ts` files directly — use this index
37
- *
38
- * @seeAlso middleware.ts (CoreContext, createHandler, HTTP helpers)
39
- * @seeAlso principal.ts (Principal interface, SYSTEM_PRINCIPAL, resolvePrincipal)
40
- * @seeAlso db.ts (adminDb, getUserDb, joins)
41
- * @seeAlso pipeline-runner.ts (runPipeline, ExecutionResult)
42
- * @seeAlso trigger-engine.ts (fire*Triggers, EventType)
43
- * @seeAlso agent-runner.ts (runAgent, AgentConfig, InferenceResult)
44
- * @seeAlso permissions.ts (PermissionEngine, sanitizeRecordData)
45
- * @seeAlso schema-utils.ts (generateValidationSchema, ValidationSchema)
46
- * @seeAlso audit.ts (emitAudit)
47
- */
48
- /**
49
- * CoreContext — the minimal execution context accepted by all Spine core functions.
50
- * Construct one directly for import/CLI usage; API handlers get it from createHandler().
51
- *
52
- * @example
53
- * ```ts
54
- * const ctx: CoreContext = {
55
- * principal: SYSTEM_PRINCIPAL,
56
- * accountId: 'uuid-here',
57
- * db: adminDb,
58
- * requestId: crypto.randomUUID()
59
- * }
60
- * ```
61
- */
62
- export type { CoreContext } from './middleware';
63
- /**
64
- * RequestContext — CoreContext extended with HTTP-specific fields.
65
- * Only needed if you are writing an API handler function.
66
- */
67
- export type { RequestContext, HandlerFunction, HandlerResult } from './middleware';
68
- /**
69
- * createHandler — wraps a handler function with auth, principal resolution, and audit.
70
- * Use this when writing Netlify function handlers.
71
- */
72
- export { createHandler, requireUserContext, requireSystemContextWithAudit, json, error as errorResponse, cors } from './middleware';
73
- /**
74
- * Principal — unified identity for all actors (humans, machines, cron, triggers).
75
- */
76
- export type { Principal } from './principal';
77
- /**
78
- * resolvePrincipal — resolves a Principal from an incoming HTTP event.
79
- * Used in custom handler wrappers.
80
- */
81
- export { resolvePrincipal } from './principal';
82
- /**
83
- * isSystemAdmin — returns true if principal has the system_admin role.
84
- */
85
- export { isSystemAdmin } from './principal';
86
- /**
87
- * machineHasScope — checks whether a machine principal has a given scope.
88
- * Supports wildcards: "items:*", "*:*".
89
- */
90
- export { machineHasScope, humanHasRole } from './principal';
91
- /**
92
- * getPrincipalDb — returns the appropriate DB client for a principal.
93
- * Humans get RLS-scoped client; machines get adminDb.
94
- */
95
- export { getPrincipalDb } from './principal';
96
- /**
97
- * formatPrincipalForAudit — structures a principal for audit log metadata.
98
- */
99
- export { formatPrincipalForAudit } from './principal';
100
- /**
101
- * ANONYMOUS_PRINCIPAL — static principal for unauthenticated requests.
102
- */
103
- export { ANONYMOUS_PRINCIPAL } from './principal';
104
- /**
105
- * SYSTEM_PRINCIPAL — static principal for internal system operations.
106
- * Use this when constructing a CoreContext for CLI or import usage without
107
- * a real authenticated user.
108
- */
109
- export { SYSTEM_PRINCIPAL } from './principal';
110
- /**
111
- * adminDb — Supabase service_role client. Bypasses RLS.
112
- * Use for system operations, migrations, machine principal actions.
113
- */
114
- export { adminDb } from './db';
115
- /**
116
- * getUserDb — Returns a JWT-scoped Supabase client with RLS enforced.
117
- * Use for human-principal requests.
118
- */
119
- export { getUserDb } from './db';
120
- /**
121
- * joins — PostgREST relationship hint strings for common FK relationships.
122
- * @example `.select(\`*, \${joins.type}, \${joins.app}\`)`
123
- */
124
- export { joins } from './db';
125
- export type { DbResult } from './db';
126
- /**
127
- * runPipeline — execute a pipeline by ID with trigger data.
128
- *
129
- * @param pipelineId - UUID of the pipeline to run
130
- * @param triggerData - Arbitrary data passed to all pipeline stages
131
- * @param ctx - CoreContext (principal + accountId + db + requestId)
132
- * @returns ExecutionResult with per-stage output and final status
133
- * @throws If pipeline not found or inactive
134
- *
135
- * @example API handler
136
- * ```ts
137
- * const result = await runPipeline(body.pipeline_id, body.data, ctx)
138
- * ```
139
- *
140
- * @example Custom import
141
- * ```ts
142
- * import { runPipeline, adminDb, SYSTEM_PRINCIPAL } from '../_shared'
143
- * const ctx = { principal: SYSTEM_PRINCIPAL, accountId, db: adminDb, requestId: crypto.randomUUID() }
144
- * const result = await runPipeline('uuid', { item_id: '...' }, ctx)
145
- * ```
146
- *
147
- * @example CLI
148
- * ```bash
149
- * spine pipelines run <pipeline-id> --data '{"item_id":"..."}'
150
- * ```
151
- */
152
- export { runPipeline } from './pipeline-runner';
153
- export type { ExecutionResult, StageResult } from './pipeline-runner';
154
- /**
155
- * checkAndFireTriggers — evaluate and fire all active triggers matching an event.
156
- *
157
- * @param eventType - e.g. 'item_created', 'account_updated'
158
- * @param entityType - table name string
159
- * @param entityId - UUID of the affected entity
160
- * @param entityData - full entity data for condition evaluation
161
- * @param ctx - CoreContext
162
- *
163
- * @example
164
- * ```ts
165
- * await checkAndFireTriggers('item_created', 'items', item.id, item, ctx)
166
- * ```
167
- */
168
- export { checkAndFireTriggers, fireCreateTriggers, fireUpdateTriggers, fireDeleteTriggers } from './trigger-engine';
169
- export type { EventType } from './trigger-engine';
170
- /**
171
- * runAgent — run AI agent inference for a user message in a thread.
172
- *
173
- * Resolves agent config from thread → agent → prompt_config chain,
174
- * assembles RAG context, calls LLM, handles tool dispatch and escalation.
175
- *
176
- * @param threadId - UUID of the thread
177
- * @param userMessage - The user's message text
178
- * @param ctx - CoreContext
179
- * @returns Saved agent message record
180
- *
181
- * @example
182
- * ```ts
183
- * const msg = await runAgent(threadId, 'How do I reset my password?', ctx)
184
- * ```
185
- */
186
- export { runAgent, resolveAgentConfig } from './agent-runner';
187
- export type { AgentConfig, InferenceResult, ToolCall, ToolResult } from './agent-runner';
188
- /**
189
- * PermissionEngine — the single source of truth for all authorization.
190
- *
191
- * @example
192
- * ```ts
193
- * const canRead = await PermissionEngine.canAccessRecord(ctx, record, 'read')
194
- * const sanitized = await PermissionEngine.sanitizeRecordData(ctx, record, 'support_ticket')
195
- * ```
196
- */
197
- export { PermissionEngine } from './permissions';
198
- export type { PermissionResult } from './permissions';
199
- export { sanitizeRecordData, validateUpdatePermissions, canAccessRecord } from './permissions';
200
- /**
201
- * generateValidationSchema — derive a structural validation schema from a design schema.
202
- * Called automatically on type create/update; also useful in custom code.
203
- */
204
- export { generateValidationSchema } from './schema-utils';
205
- export type { ValidationSchema } from './schema-utils';
206
- /**
207
- * emitAudit — emit a structured audit log entry with full principal provenance.
208
- *
209
- * @param ctx - CoreContext
210
- * @param action - e.g. 'items.create', 'pipeline.completed'
211
- * @param target - { type, id, account_id }
212
- * @param metadata - additional structured context
213
- *
214
- * @example
215
- * ```ts
216
- * await emitAudit(ctx, 'deal.stage_changed', { type: 'items', id: deal.id }, {
217
- * before: { stage: 'prospect' },
218
- * after: { stage: 'qualified' }
219
- * })
220
- * ```
221
- */
222
- export { emitAudit } from './audit';
223
- /**
224
- * resolveHandler — dynamically load a webhook handler by name.
225
- *
226
- * Used by integration-routes.ts to resolve handlers at runtime
227
- * without static imports, enabling custom handlers to self-register.
228
- *
229
- * @param handlerName — The handler identifier from webhook_handlers table
230
- * @returns Handler function or null if not found
231
- *
232
- * @example
233
- * ```ts
234
- * const handler = await resolveHandler('cortex-webhook')
235
- * if (handler) await handler(event, context)
236
- * ```
237
- */
238
- export { resolveHandler, lookupHandler, loadHandler } from './webhook-registry';
239
- /**
240
- * registerWebhookHandler — self-register a custom webhook handler.
241
- *
242
- * Use in custom Netlify functions to register as webhook handlers
243
- * without modifying core code.
244
- *
245
- * @param config — Handler registration details
246
- *
247
- * @example
248
- * ```ts
249
- * import { registerWebhookHandler } from '@core/_shared'
250
- * import { adminDb } from '@core/_shared'
251
- *
252
- * registerWebhookHandler({
253
- * name: 'my-handler',
254
- * functionName: 'custom_my-handler',
255
- * events: ['item.created']
256
- * }, adminDb)
257
- * ```
258
- */
259
- export { registerWebhookHandler, deregisterWebhookHandler, isHandlerRegistered } from './webhook-registration';
260
- export type { WebhookHandlerRegistration } from './webhook-registration';
261
- /**
262
- * loadManifest — load and parse an app manifest.json file.
263
- *
264
- * Used by apps.ts to merge database records with file-based
265
- * app configuration (name, routes, nav_items, required_roles).
266
- *
267
- * @param manifestPath — Path to manifest.json relative to project root
268
- * @returns Parsed AppManifest or null if not found/invalid
269
- *
270
- * @example
271
- * ```ts
272
- * const manifest = loadManifest('custom/apps/cortex/manifest.json')
273
- * console.log(manifest.required_roles) // ['member']
274
- * ```
275
- */
276
- export { loadManifest, mergeWithManifest, clearManifestCache, discoverManifests } from './app-manifest';
277
- export type { AppManifest, NavItem } from './app-manifest';
278
- /**
279
- * Testing utilities for custom code developers.
280
- *
281
- * Use these helpers to test your custom functions without
282
- * full deployment. Includes mock contexts, principals, and
283
- * assertion helpers.
284
- *
285
- * @example
286
- * ```ts
287
- * import { makeTestContext, mockPrincipal, cleanup } from '@core/testing'
288
- *
289
- * describe('My Handler', () => {
290
- * const ctx = makeTestContext({
291
- * principal: mockPrincipal({ roles: ['member'] })
292
- * })
293
- * })
294
- * ```
295
- */
296
- export { makeTestContext, mockPrincipal, mockLogger, mockEvent, mockNetlifyContext, cleanup, setupTests, expectSuccessResponse, expectErrorResponse } from './testing';
297
- export type { TestContext, TestPrincipal, TestLogger } from './testing';
298
- export { resolveTypeIds, resolveTypeId, resolveLinkTypeIds, resolveAccountId, resolveAgentId, resolvePromptConfigId } from './resolve-ids';
299
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/index.ts"],"names":[],"mappings":"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"}
@@ -1,315 +0,0 @@
1
- /**
2
- * @module middleware
3
- * @audience both
4
- * @layer shared-core
5
- * @stability stable
6
- *
7
- * HTTP handler factory and request context types for all Spine Netlify functions.
8
- * This module owns the boundary between raw HTTP events and the typed execution
9
- * context (`RequestContext`) used by every handler. It also provides guard
10
- * utilities (`requireUserContext`, `requireSystemContextWithAudit`) used to
11
- * enforce authentication at the top of handlers.
12
- *
13
- * The key invariant: `createHandler` always resolves a `Principal` via
14
- * `resolvePrincipal` before calling the inner handler. Handlers never receive
15
- * an unauthenticated context — anonymous requests are rejected at the wrapper.
16
- *
17
- * IMPORTANT: `result.data` is never unwrapped in `createHandler`. Handlers
18
- * return records directly. Unwrapping would collide with records that have a
19
- * `.data` JSONB column.
20
- *
21
- * @seeAlso principal.ts (resolvePrincipal, getPrincipalDb, isSystemAdmin)
22
- * @seeAlso audit.ts (emitAudit — called after every successful handler)
23
- * @seeAlso db.ts (adminDb, getUserDb — selected by getPrincipalDb)
24
- * @seeAlso index.ts (re-exports CoreContext, createHandler, requireUserContext)
25
- */
26
- import { Principal } from './principal';
27
- /**
28
- * Minimal execution context passed to all Spine core functions.
29
- *
30
- * This is the canonical context for `pipeline-runner`, `trigger-engine`,
31
- * `agent-runner`, `audit`, and any custom code in `v2-custom/`. It contains
32
- * only what core logic needs: identity, account scope, and a DB client.
33
- *
34
- * `RequestContext` (used inside HTTP handlers) extends this with HTTP-specific
35
- * fields (`appId`, `query`). Direct importers and CLI callers construct
36
- * `CoreContext` directly without going through `createHandler`.
37
- *
38
- * @inputSpec principal: Principal — must be a resolved principal (not null)
39
- * @inputSpec accountId: string | null — null is allowed for system-level ops only
40
- * @inputSpec db: SupabaseClient — use adminDb for system ops, getUserDb for RLS
41
- * @inputSpec requestId: string — UUID; ties execution to audit log entries
42
- * @calledBy pipeline-runner.ts, trigger-engine.ts, agent-runner.ts, audit.ts,
43
- * tests/integration/helpers.ts (makeTestCtx), cli/context.ts
44
- *
45
- * @example Import usage (v2-custom/)
46
- * ```ts
47
- * import { CoreContext, adminDb, SYSTEM_PRINCIPAL } from '../_shared/index'
48
- * const ctx: CoreContext = {
49
- * principal: SYSTEM_PRINCIPAL,
50
- * accountId: 'uuid-of-account',
51
- * db: adminDb,
52
- * requestId: crypto.randomUUID()
53
- * }
54
- * await runPipeline(pipelineId, data, ctx)
55
- * ```
56
- *
57
- * @example CLI usage
58
- * ```bash
59
- * # CLI constructs CoreContext from .xenv credentials automatically
60
- * spine pipelines run <pipeline-id>
61
- * ```
62
- */
63
- export interface CoreContext {
64
- /** Resolved principal for this execution */
65
- principal: Principal;
66
- /** Primary account scope — null for system-level operations */
67
- accountId: string | null;
68
- /** Database client — use adminDb for system ops, getUserDb for RLS-scoped */
69
- db: any;
70
- /** Unique ID for this execution (used in audit logs) */
71
- requestId: string;
72
- }
73
- /**
74
- * HTTP-layer execution context — extends `CoreContext` with request-specific fields.
75
- *
76
- * Constructed inside `createHandler` after principal resolution. Not used by
77
- * core logic directly — core functions accept `CoreContext`. The extra fields
78
- * are available to handlers that need them (e.g., `query.action`, `appId`).
79
- *
80
- * @inputSpec appId: string | null — from `x-app-id` header; null if absent
81
- * @inputSpec query: Record<string, string> — parsed queryStringParameters from event
82
- * @calledBy All 19 API handler functions (as the first argument)
83
- * @seeAlso CoreContext (parent interface)
84
- */
85
- export interface RequestContext extends CoreContext {
86
- /** App ID from `x-app-id` header — used for app-scoped operations */
87
- appId: string | null;
88
- /** Parsed query string parameters from the Netlify event */
89
- query: Record<string, string>;
90
- /** Request path from the Netlify event */
91
- requestPath: string;
92
- }
93
- /**
94
- * Signature for all Spine HTTP handler functions.
95
- *
96
- * Every handler file exports a default that calls `createHandler(myHandler)`.
97
- * The `body` parameter is the parsed JSON body, or null for GET requests.
98
- *
99
- * @inputSpec ctx: RequestContext — fully resolved context; never null
100
- * @inputSpec body: any — parsed JSON body or null; undefined for GET requests
101
- * @outputSpec Promise<any> — return value is wrapped in `{ data: result }` by createHandler
102
- */
103
- export type HandlerFunction = (ctx: RequestContext, body?: any) => Promise<any>;
104
- /**
105
- * Standard envelope shape returned by `createHandler` to the HTTP client.
106
- *
107
- * On success: `{ data: <handler result>, error: null, meta: { requestId, duration } }`
108
- * On error: `{ data: null, error: <message> }` with appropriate HTTP status code.
109
- *
110
- * @outputSpec data: any — handler return value, never unwrapped
111
- * @outputSpec error: string | undefined — error message; present only on failure
112
- * @outputSpec meta: object | undefined — requestId + duration on success
113
- */
114
- export interface HandlerResult {
115
- data?: any;
116
- error?: string;
117
- meta?: any;
118
- }
119
- /**
120
- * Wraps a handler function with principal resolution, request parsing, audit
121
- * logging, and error handling. This is the entry point for every Netlify function.
122
- *
123
- * Execution flow:
124
- * 1. Detect nested calls (event already has requestId + principal) → pass through
125
- * 2. Generate `requestId`, parse headers, query params
126
- * 3. Call `resolvePrincipal(event)` → reject anonymous with 401
127
- * 4. Call `getPrincipalDb(principal)` → select correct DB client
128
- * 5. Build `RequestContext`, parse + merge body
129
- * 6. Call inner handler, measure duration
130
- * 7. Emit `request.<method>` audit log (account-scoped requests only)
131
- * 8. Return `json({ data: result, error: null, meta })` envelope
132
- * 9. On any thrown error → return `error(message, 500)`
133
- *
134
- * @param handler - The inner handler function implementing the route logic
135
- * @returns Netlify-compatible async function `(event, context) => Response`
136
- * @throws never — all errors are caught and returned as HTTP 500
137
- * @inputSpec handler: HandlerFunction — must return a Promise
138
- * @outputSpec Netlify Lambda response object with statusCode, headers, body
139
- * @sideEffects DB read: principal resolution (people, api_keys tables)
140
- * @sideEffects DB write: emitAudit to logs table (account-scoped requests only)
141
- * @calledBy Every function in functions/*.ts as the default export wrapper
142
- * @calls resolvePrincipal, getPrincipalDb, emitAudit, json, error
143
- * @testIntegration tests/integration/admin-data-accounts.test.ts
144
- *
145
- * @example API handler file pattern
146
- * ```ts
147
- * import { createHandler, RequestContext } from './_shared/middleware'
148
- * export const handler = createHandler(async (ctx: RequestContext, body) => {
149
- * const action = ctx.query.action || 'list'
150
- * if (action === 'list') return listItems(ctx)
151
- * throw new Error(`Unknown action: ${action}`)
152
- * })
153
- * ```
154
- */
155
- export declare function createHandler(handler: HandlerFunction): (event: any, context: any) => Promise<any>;
156
- /**
157
- * Builds a JSON HTTP response object compatible with Netlify Functions.
158
- *
159
- * Always includes CORS headers permitting requests from any origin. Used
160
- * internally by `createHandler` and directly by handlers that need a custom
161
- * status code (e.g., 201 Created).
162
- *
163
- * @param data - Any JSON-serializable value to include as the response body
164
- * @param status - HTTP status code (default: 200)
165
- * @returns Netlify Lambda response object
166
- * @throws never
167
- * @inputSpec data: any — must be JSON-serializable; circular refs will throw at stringify
168
- * @inputSpec status: number — valid HTTP status code (default 200)
169
- * @outputSpec { statusCode, headers, body: string } — body is JSON.stringify(data)
170
- * @sideEffects none
171
- * @calledBy createHandler, error, cors, and directly by some handlers
172
- * @testUnit none — trivial; verified by integration tests on every request
173
- */
174
- export declare function json(data: any, status?: number): {
175
- statusCode: number;
176
- headers: {
177
- 'Content-Type': string;
178
- 'Access-Control-Allow-Origin': string;
179
- 'Access-Control-Allow-Headers': string;
180
- 'Access-Control-Allow-Methods': string;
181
- };
182
- body: string;
183
- };
184
- /**
185
- * Builds a JSON error response with `{ data: null, error: message }` shape.
186
- *
187
- * Use this to return structured error responses from handlers. The message
188
- * is safe to surface to clients — do not pass internal error details.
189
- *
190
- * @param message - Human-readable error message safe to return to client
191
- * @param status - HTTP status code (default: 400)
192
- * @returns Netlify Lambda response object
193
- * @throws never
194
- * @inputSpec message: string — client-safe error description
195
- * @inputSpec status: number — HTTP status code (400, 401, 403, 404, 500)
196
- * @outputSpec { statusCode: status, body: '{"data":null,"error":"<message>"}' }
197
- * @sideEffects none
198
- * @calledBy createHandler (on caught errors), requireUserContext,
199
- * requireSystemContextWithAudit, and many individual handlers
200
- */
201
- export declare function error(message: string, status?: number): {
202
- statusCode: number;
203
- headers: {
204
- 'Content-Type': string;
205
- 'Access-Control-Allow-Origin': string;
206
- 'Access-Control-Allow-Headers': string;
207
- 'Access-Control-Allow-Methods': string;
208
- };
209
- body: string;
210
- };
211
- /**
212
- * Parses the JSON body from a Netlify event object.
213
- *
214
- * Returns `null` if there is no body. Throws a descriptive error on malformed
215
- * JSON so the error surfaces cleanly from `createHandler`'s catch block.
216
- *
217
- * @param event - Raw Netlify event object
218
- * @returns Parsed body object or null
219
- * @throws Error('Invalid JSON in request body') — when body is present but not valid JSON
220
- * @inputSpec event.body: string | null | undefined — raw JSON string from HTTP request
221
- * @outputSpec any — parsed JSON object, or null if no body
222
- * @sideEffects none
223
- * @calledBy Handlers that need body outside of createHandler's automatic parsing
224
- */
225
- export declare function parseBody(event: any): any;
226
- /**
227
- * Overloaded guard that requires a resolved human principal with an account scope.
228
- *
229
- * **Overload 1 — wrapper:** wrap a handler to enforce auth before it runs.
230
- * **Overload 2 — inline:** call with `ctx` directly; returns an error response
231
- * object if auth is missing, or `null` if auth is present (allowing the
232
- * caller to do `const authErr = requireUserContext(ctx); if (authErr) return authErr`).
233
- *
234
- * Rejects requests where:
235
- * - `ctx.principal` is absent
236
- * - `ctx.principal.id === 'anonymous'`
237
- * - `ctx.accountId` is null or empty (machine principals without an account)
238
- *
239
- * @inputSpec ctx or handler: RequestContext or HandlerFunction
240
- * @outputSpec HandlerFunction (overload 1) or HandlerResult | null (overload 2)
241
- * @throws Error('User context required') — in wrapper mode if not authenticated
242
- * @sideEffects none
243
- * @calledBy API handlers that require an authenticated human with account scope
244
- * @testIntegration tests/integration/isolation.test.ts
245
- *
246
- * @example Inline guard pattern (preferred)
247
- * ```ts
248
- * const authErr = requireUserContext(ctx)
249
- * if (authErr) return authErr
250
- * // ctx.principal and ctx.accountId are guaranteed non-null below here
251
- * ```
252
- *
253
- * @example Wrapper pattern
254
- * ```ts
255
- * export const handler = createHandler(requireUserContext(async (ctx, body) => {
256
- * return listItems(ctx)
257
- * }))
258
- * ```
259
- */
260
- export declare function requireUserContext(handler: HandlerFunction): HandlerFunction;
261
- export declare function requireUserContext(ctx: RequestContext): HandlerResult | null;
262
- /**
263
- * Overloaded guard that requires a `system_admin` principal.
264
- *
265
- * **Overload 1 — wrapper:** wrap a handler; throws if not system_admin.
266
- * **Overload 2 — inline:** call with `ctx`; returns error response or null.
267
- * Also accepts an optional `triggeredBy` string to set on the context for
268
- * audit trail chaining (e.g. pipeline execution ID).
269
- *
270
- * Rejects requests where:
271
- * - `ctx.principal` is absent or anonymous
272
- * - `ctx.principal` does not have the `system_admin` role
273
- *
274
- * @param arg - Handler to wrap, or RequestContext to validate inline
275
- * @param triggeredBy - Optional: ID of the triggering entity (set on ctx)
276
- * @returns HandlerFunction (overload 1) or HandlerResult | null (overload 2)
277
- * @throws Error('System context required') — in wrapper mode if not system_admin
278
- * @inputSpec ctx.principal.roles: string[] — must include 'system_admin'
279
- * @outputSpec HandlerFunction | HandlerResult | null
280
- * @sideEffects sets `ctx.triggeredBy` when validation passes (inline mode)
281
- * @calledBy system-cron.ts, pipeline-executions.ts, and admin-only handlers
282
- * @testIntegration tests/integration/isolation.test.ts
283
- *
284
- * @example Inline guard pattern
285
- * ```ts
286
- * const authErr = requireSystemContextWithAudit(ctx, 'cron-job-id')
287
- * if (authErr) return authErr
288
- * ```
289
- */
290
- export declare function requireSystemContextWithAudit(handler: HandlerFunction): HandlerFunction;
291
- export declare function requireSystemContextWithAudit(ctx: RequestContext, triggeredBy?: string): HandlerResult | null;
292
- /**
293
- * Returns a 200 JSON response for CORS preflight requests.
294
- *
295
- * Netlify automatically handles OPTIONS at the CDN level for most routes, but
296
- * handlers that need to explicitly handle OPTIONS can call this.
297
- *
298
- * @returns json({ message: 'CORS enabled' }, 200) with CORS headers
299
- * @throws never
300
- * @inputSpec none
301
- * @outputSpec Netlify Lambda response with CORS headers
302
- * @sideEffects none
303
- * @calledBy Handler files that explicitly handle OPTIONS method
304
- */
305
- export declare function cors(): {
306
- statusCode: number;
307
- headers: {
308
- 'Content-Type': string;
309
- 'Access-Control-Allow-Origin': string;
310
- 'Access-Control-Allow-Headers': string;
311
- 'Access-Control-Allow-Methods': string;
312
- };
313
- body: string;
314
- };
315
- //# sourceMappingURL=middleware.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/middleware.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAEH,OAAO,EACL,SAAS,EAIV,MAAM,aAAa,CAAA;AAKpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,MAAM,WAAW,WAAW;IAC1B,4CAA4C;IAC5C,SAAS,EAAE,SAAS,CAAA;IACpB,+DAA+D;IAC/D,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,6EAA6E;IAC7E,EAAE,EAAE,GAAG,CAAA;IACP,wDAAwD;IACxD,SAAS,EAAE,MAAM,CAAA;CAClB;AAED;;;;;;;;;;;GAWG;AACH,MAAM,WAAW,cAAe,SAAQ,WAAW;IACjD,qEAAqE;IACrE,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,4DAA4D;IAC5D,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC7B,0CAA0C;IAC1C,WAAW,EAAE,MAAM,CAAA;CACpB;AAED;;;;;;;;;GASG;AACH,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,cAAc,EAAE,IAAI,CAAC,EAAE,GAAG,KAAK,OAAO,CAAC,GAAG,CAAC,CAAA;AAE/E;;;;;;;;;GASG;AACH,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,EAAE,GAAG,CAAA;IACV,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,GAAG,CAAA;CACX;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,eAAe,WAC/B,GAAG,WAAW,GAAG,kBAuGvC;AAID;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,GAAE,MAAY;;;;;;;;;EAWnD;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,GAAE,MAAY;;;;;;;;;EAK1D;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,GAAG,GAAG,GAAG,CAQzC;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,CAAA;AAC7E,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,cAAc,GAAG,aAAa,GAAG,IAAI,CAAA;AAmB7E;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,wBAAgB,6BAA6B,CAAC,OAAO,EAAE,eAAe,GAAG,eAAe,CAAA;AACxF,wBAAgB,6BAA6B,CAAC,GAAG,EAAE,cAAc,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI,CAAA;AAgC9G;;;;;;;;;;;;GAYG;AACH,wBAAgB,IAAI;;;;;;;;;EAEnB"}