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,604 +0,0 @@
1
- /**
2
- * @module types
3
- * @audience core-contributor
4
- * @layer api-handler
5
- * @stability stable
6
- *
7
- * CRUD API for the `types` table. Types are the schema configuration objects
8
- * that define `design_schema`, `validation_schema`, field definitions, and
9
- * view configurations for runtime entities (`items`, `people`, `accounts`).
10
- *
11
- * **Routed by:** `GET/POST/PATCH/DELETE /.netlify/functions/types`
12
- *
13
- * **Authorization model:**
14
- * - All reads use `ctx.db` (RLS-scoped) and are sanitized via `sanitizeRecordData`.
15
- * - All writes (`create`, `update`, `remove`) require `isSystemAdmin` AND the
16
- * caller's account must be a master tenant (`accounts.parent_id IS NULL`).
17
- * - Unauthenticated `list` calls receive minimal fields only (id, slug, name, kind).
18
- *
19
- * **Design schema auto-sync:** `update` regenerates `validation_schema` automatically
20
- * via `generateValidationSchema` whenever `design_schema` changes.
21
- *
22
- * INVARIANT: type slugs must be unique per (kind, app_id) combination.
23
- * INVARIANT: `ownership` of system types cannot be changed (to prevent constraint violations).
24
- * INVARIANT: `app_id = null` for system types; must be provided for app/tenant types.
25
- *
26
- * @seeAlso middleware.ts (createHandler, CoreContext)
27
- * @seeAlso permissions.ts (PermissionEngine, sanitizeRecordData, validateUpdatePermissions)
28
- * @seeAlso schema-utils.ts (generateValidationSchema — auto-called on design_schema updates)
29
- * @seeAlso audit.ts (emitLog for type.created / type.updated / type.deleted)
30
- */
31
-
32
- import { createHandler } from './_shared/middleware'
33
- import { adminDb, joins } from './_shared/db'
34
- import { emitLog } from './_shared/audit'
35
- import { PermissionEngine, sanitizeRecordData } from './_shared/permissions'
36
- import { generateValidationSchema } from './_shared/schema-utils'
37
-
38
- const permissions = PermissionEngine as any
39
-
40
- // ─── HANDLERS ─────────────────────────────────────────────────────────────────
41
-
42
- // ─── CHUNK_START: TYPES_LIST ──────────────────────────────────────────────
43
- /**
44
- * @chunk-id TYPES_LIST_1_0_0
45
- * @version 1.0.0
46
- * @hash 0cfcf45a5a70d17002599b77e1c45bf7d3de456bc474e68a89ff44069d711b91
47
- * @macro Types List Handler
48
- * @micro Lists types with filtering, authentication-based response, and sanitization
49
- * @inputs ctx: CoreContext — Request context with principal and database
50
- * @inputs body: any — Request body (unused for GET)
51
- * @outputs Array of type records with app join, sanitized and schema-aware
52
- * @depends-on [createHandler, joins, sanitizeRecordData]
53
- * @depended-by [Netlify function routing]
54
- * @side-effects [DB queries, permission sanitization, schema preservation]
55
- * @tags types, list, crud, filtering, authentication
56
- */
57
- export const list = createHandler(async (ctx, body) => {
58
- const { kind, app_id, ownership, limit = '50', offset = '0', include_schema } = ctx.query || {}
59
-
60
- // RLS automatically filters to accessible accounts
61
- let query = ctx.db
62
- .from('types')
63
- .select(`*, ${joins.app}`)
64
- .eq('is_active', true)
65
- .order('kind')
66
- .order('name')
67
-
68
- if (kind) {
69
- query = query.eq('kind', kind)
70
- }
71
-
72
- if (app_id) {
73
- query = query.eq('app_id', app_id)
74
- } else if (app_id === 'null') {
75
- query = query.is('app_id', null)
76
- }
77
-
78
- if (ownership) {
79
- query = query.eq('ownership', ownership)
80
- }
81
-
82
- const { data, error: err } = await query
83
- .range(parseInt(offset), parseInt(offset) + parseInt(limit) - 1)
84
-
85
- if (err) throw err
86
-
87
- // For authenticated users, always include design_schema for schema-driven UI
88
- // System admin sees everything, others get sanitized data with design_schema preserved
89
- // When include_schema=true, preserve full design_schema for all accessible types
90
- const sanitized = []
91
- for (const type of data || []) {
92
- if (ctx.principal) {
93
- // Authenticated user - get sanitized data but preserve design_schema
94
- const sanitizedType = await sanitizeRecordData(ctx, type, 'type')
95
- // Ensure design_schema is preserved for schema-driven UI
96
- if (type.design_schema && !sanitizedType.design_schema) {
97
- sanitizedType.design_schema = type.design_schema
98
- }
99
- // When include_schema=true, also preserve validation_schema
100
- if (include_schema === 'true' && type.validation_schema) {
101
- sanitizedType.validation_schema = type.validation_schema
102
- }
103
- sanitized.push(sanitizedType)
104
- } else {
105
- // Unauthenticated user - return minimal data
106
- const minimal: any = {
107
- id: type.id,
108
- slug: type.slug,
109
- name: type.name,
110
- kind: type.kind
111
- }
112
- // When include_schema=true, unauthenticated users also get schema
113
- if (include_schema === 'true' && type.design_schema) {
114
- minimal.design_schema = type.design_schema
115
- }
116
- sanitized.push(minimal)
117
- }
118
- }
119
-
120
- return sanitized
121
- })
122
- // ─── CHUNK_END: TYPES_LIST ────────────────────────────────────────────────
123
-
124
- // ─── CHUNK_START: TYPES_GET ──────────────────────────────────────────────
125
- /**
126
- * @chunk-id TYPES_GET_1_0_0
127
- * @version 1.0.0
128
- * @hash 435ff5a93d05f74e0299b515d32f50ceb5c526b517a6972ef65c3bdaa75c218f
129
- * @macro Type Get Handler
130
- * @micro Returns single type record with joins and sanitization
131
- * @inputs ctx: CoreContext — Request context with principal and database
132
- * @inputs body: any — Request body (unused for GET)
133
- * @outputs Sanitized type record with app join
134
- * @depends-on [createHandler, joins, sanitizeRecordData]
135
- * @depended-by [Netlify function routing]
136
- * @side-effects [DB single row query, permission sanitization]
137
- * @tags types, get, crud, single-record
138
- */
139
- export const get = createHandler(async (ctx, body) => {
140
- const { id } = ctx.query || {}
141
-
142
- if (!id) {
143
- throw new Error('Type ID is required')
144
- }
145
-
146
- const { data, error: err } = await ctx.db
147
- .from('types')
148
- .select(`*, ${joins.app}`)
149
- .eq('id', id)
150
- .eq('is_active', true)
151
- .single()
152
-
153
- if (err) throw err
154
-
155
- // Sanitize based on role permissions
156
- return await sanitizeRecordData(ctx, data, 'type')
157
- })
158
- // ─── CHUNK_END: TYPES_GET ────────────────────────────────────────────────
159
-
160
- // ─── CHUNK_START: TYPES_GET_BY_SLUG ──────────────────────────────────────────────
161
- /**
162
- * @chunk-id TYPES_GET_BY_SLUG_1_0_0
163
- * @version 1.0.0
164
- * @hash 6585200f3ecdef92e2912849afd5d72a3968fe13b464cdf43f33a888edda4163
165
- * @macro Type Get By Slug Handler
166
- * @micro Returns single type record by slug with joins and sanitization
167
- * @inputs ctx: CoreContext — Request context with principal and database
168
- * @inputs body: any — Request body (unused for GET)
169
- * @outputs Sanitized type record with app join
170
- * @depends-on [createHandler, joins, sanitizeRecordData]
171
- * @depended-by [Netlify function routing]
172
- * @side-effects [DB single row query, permission sanitization]
173
- * @tags types, get, crud, single-record, slug
174
- */
175
- export const getBySlug = createHandler(async (ctx, body) => {
176
- const { slug } = ctx.query || {}
177
-
178
- if (!slug) {
179
- throw new Error('Type slug is required')
180
- }
181
-
182
- const { data, error: err } = await ctx.db
183
- .from('types')
184
- .select(`*, ${joins.app}`)
185
- .eq('slug', slug)
186
- .eq('is_active', true)
187
- .single()
188
-
189
- if (err) throw err
190
-
191
- // Sanitize based on role permissions
192
- return await sanitizeRecordData(ctx, data, 'type')
193
- })
194
- // ─── CHUNK_END: TYPES_GET_BY_SLUG ────────────────────────────────────────────────
195
-
196
- // ─── CHUNK_START: TYPES_GET_SCHEMA ──────────────────────────────────────────────
197
- /**
198
- * @chunk-id TYPES_GET_SCHEMA_1_0_0
199
- * @version 1.0.0
200
- * @hash 2cff73f363bb53c145d64b5b2fc788de592a94321000425f6b2ab82489c9a1e4
201
- * @macro Type Schema Handler
202
- * @micro Returns design_schema for a type via RPC
203
- * @inputs ctx: CoreContext — Request context with principal and database
204
- * @inputs body: any — Request body (unused for GET)
205
- * @outputs {design_schema: object} — Type design schema
206
- * @depends-on [createHandler]
207
- * @depended-by [Netlify function routing]
208
- * @side-effects [DB RPC call, RLS enforcement]
209
- * @tags types, schema, rpc, design-schema
210
- */
211
- export const getSchema = createHandler(async (ctx, body) => {
212
- const { kind, slug, app_id } = ctx.query || {}
213
-
214
- if (!kind || !slug) {
215
- throw new Error('kind and slug are required')
216
- }
217
-
218
- const { data, error: err } = await ctx.db
219
- .rpc('get_type_schema', {
220
- kind,
221
- slug,
222
- app_id: app_id || null
223
- })
224
-
225
- if (err) throw err
226
-
227
- return { design_schema: data }
228
- })
229
- // ─── CHUNK_END: TYPES_GET_SCHEMA ────────────────────────────────────────────────
230
-
231
- // ─── CHUNK_START: TYPES_CREATE ──────────────────────────────────────────────
232
- /**
233
- * @chunk-id TYPES_CREATE_1_0_0
234
- * @version 1.0.0
235
- * @hash c226d40910e332c0c89bfbb0d09f2b6a04b45a0a104c70d485ebd08c2c07cbe0
236
- * @macro Type Create Handler
237
- * @micro Creates type with system admin validation, schema generation, and audit logging
238
- * @inputs ctx: CoreContext — Request context with principal and database
239
- * @inputs body: object — Type data including kind, slug, name, and optional fields
240
- * @outputs Inserted type record
241
- * @depends-on [createHandler, adminDb, permissions, generateValidationSchema, emitLog]
242
- * @depended-by [Netlify function routing]
243
- * @side-effects [DB insert, master tenant validation, schema generation, audit logging]
244
- * @tags types, create, crud, system-admin, schema-generation, audit
245
- */
246
- export const create = createHandler(async (ctx, body) => {
247
- const { app_id, kind, slug, name, description, icon, color, design_schema: bodySchema = {}, ownership } = body
248
-
249
- if (!kind || !slug || !name) {
250
- throw new Error('kind, slug, and name are required')
251
- }
252
-
253
- if (!ctx.principal || ctx.principal.id === 'anonymous' || !ctx.accountId) {
254
- throw new Error('User context (person and account) required')
255
- }
256
-
257
- // Config mutations (types) are only allowed in master tenant by system admins
258
- if (!permissions.isSystemAdmin(ctx)) {
259
- throw new Error('Only system administrators can create type configurations')
260
- }
261
-
262
- // Verify the current account is a master tenant (parent_id IS NULL)
263
- // Use adminDb for this check since we're verifying account structure
264
- const { data: accountData } = await adminDb
265
- .from('accounts')
266
- .select('parent_id')
267
- .eq('id', ctx.accountId!)
268
- .single()
269
-
270
- if (!accountData || accountData.parent_id !== null) {
271
- throw new Error('Type configurations can only be created in master tenant accounts')
272
- }
273
-
274
- // Check if slug is unique within app/kind
275
- let query = adminDb
276
- .from('types')
277
- .select('id')
278
- .eq('kind', kind)
279
- .eq('slug', slug)
280
-
281
- if (app_id) {
282
- query = query.eq('app_id', app_id)
283
- } else {
284
- query = query.is('app_id', null)
285
- }
286
-
287
- const { data: existing } = await query.single()
288
-
289
- if (existing) {
290
- throw new Error('Type slug already exists for this kind and app')
291
- }
292
-
293
- // Basic schema validation
294
- if (bodySchema && typeof bodySchema === 'object') {
295
- if (bodySchema.fields && (typeof bodySchema.fields !== 'object' || bodySchema.fields === null)) {
296
- throw new Error('Schema fields must be an object')
297
- }
298
- }
299
-
300
- // For non-system ownership, we need an app_id to satisfy the constraint
301
- let finalAppId = app_id
302
- let finalOwnership = ownership
303
-
304
- if (!app_id && ownership !== 'system') {
305
- // Get the first available app for tenant/custom types
306
- const { data: apps } = await adminDb
307
- .from('apps')
308
- .select('id')
309
- .limit(1)
310
- .single()
311
-
312
- if (apps?.id) {
313
- finalAppId = apps.id
314
- finalOwnership = 'app' // Use 'app' ownership when associated with an app
315
- } else {
316
- throw new Error('Cannot create type without app_id for non-system ownership')
317
- }
318
- }
319
-
320
- // Generate validation schema from design schema
321
- const validationSchema = generateValidationSchema(bodySchema || {})
322
-
323
- const { data, error: err } = await adminDb
324
- .from('types')
325
- .insert({
326
- app_id: finalAppId,
327
- kind,
328
- slug,
329
- name,
330
- description,
331
- icon,
332
- color,
333
- design_schema: bodySchema || {},
334
- validation_schema: validationSchema,
335
- ownership: finalOwnership || 'system',
336
- is_active: true
337
- })
338
- .select()
339
- .single()
340
-
341
- if (err) throw err
342
-
343
- await emitLog(ctx, 'type.created', { type: 'type', id: data.id }, { after: data })
344
-
345
- return data
346
- })
347
- // ─── CHUNK_END: TYPES_CREATE ────────────────────────────────────────────────
348
-
349
- // ─── CHUNK_START: TYPES_UPDATE ──────────────────────────────────────────────
350
- /**
351
- * @chunk-id TYPES_UPDATE_1_0_0
352
- * @version 1.0.0
353
- * @hash 7778ce63ecc3dd50fe50680c4f1199a59db4c4dae734cf7a2d58cc2de76b9a6a
354
- * @macro Type Update Handler
355
- * @micro Updates type with validation, schema regeneration, and audit logging
356
- * @inputs ctx: CoreContext — Request context with principal and database
357
- * @inputs body: object — Type updates including id and updatable fields
358
- * @outputs Updated type record
359
- * @depends-on [createHandler, adminDb, permissions, generateValidationSchema, emitLog]
360
- * @depended-by [Netlify function routing]
361
- * @side-effects [DB update, field validation, schema regeneration, audit logging]
362
- * @tags types, update, crud, system-admin, schema-generation, audit
363
- */
364
- export const update = createHandler(async (ctx, body) => {
365
- const id = body?.id || ctx.query?.id
366
- const { id: _bodyId, ...updates } = body || {}
367
-
368
- if (!id) {
369
- throw new Error('Type ID is required')
370
- }
371
-
372
- if (!ctx.principal || ctx.principal.id === 'anonymous' || !ctx.accountId) {
373
- throw new Error('User context (person and account) required')
374
- }
375
-
376
- // Get current state for audit - RLS will filter to accessible types
377
- const { data: current } = await adminDb
378
- .from('types')
379
- .select('*')
380
- .eq('id', id)
381
- .single()
382
-
383
- if (!current) {
384
- throw new Error('Type not found')
385
- }
386
-
387
- // Config mutations (types) are only allowed in master tenant by system admins
388
- if (!permissions.isSystemAdmin(ctx)) {
389
- throw new Error('Only system administrators can update type configurations')
390
- }
391
-
392
- // System types can only be updated by system admins (already checked above)
393
- // App types require app ownership verification
394
- if (current.ownership === 'app' && current.app_id) {
395
- // Verify user has access to this app
396
- const { data: appAccess } = await adminDb
397
- .from('apps')
398
- .select('id')
399
- .eq('id', current.app_id)
400
- .eq('is_active', true)
401
- .single()
402
-
403
- if (!appAccess) {
404
- throw new Error('App not found or inactive')
405
- }
406
- }
407
-
408
- // Verify the current account is a master tenant (parent_id IS NULL)
409
- // Use adminDb for this check since we're verifying account structure
410
- const { data: accountData } = await adminDb
411
- .from('accounts')
412
- .select('parent_id')
413
- .eq('id', ctx.accountId!)
414
- .single()
415
-
416
- if (!accountData || accountData.parent_id !== null) {
417
- throw new Error('Type configurations can only be updated in master tenant accounts')
418
- }
419
-
420
- // Validate field-level permissions
421
- const fieldValidation = await permissions.validateUpdatePermissions(
422
- ctx,
423
- updates,
424
- current,
425
- 'type'
426
- )
427
-
428
- if (!fieldValidation.valid) {
429
- throw new Error(fieldValidation.error)
430
- }
431
-
432
- // Prevent ownership changes for system types to avoid constraint violations
433
- if (current.ownership === 'system' && updates.ownership && updates.ownership !== 'system') {
434
- // Remove ownership from updates to preserve system ownership
435
- delete updates.ownership
436
- }
437
-
438
- // Handle app_id null conversion for system types
439
- if (updates.app_id === '') {
440
- updates.app_id = null
441
- }
442
-
443
- // Validate design_schema if being updated
444
- if (updates.design_schema) {
445
- if (typeof updates.design_schema !== 'object' || updates.design_schema === null) {
446
- throw new Error('Design schema must be an object')
447
- }
448
- if (updates.design_schema.fields && (typeof updates.design_schema.fields !== 'object' || updates.design_schema.fields === null)) {
449
- throw new Error('Design schema fields must be an object')
450
- }
451
-
452
- // Auto-generate validation_schema when design_schema changes
453
- updates.validation_schema = generateValidationSchema(updates.design_schema)
454
- }
455
-
456
- const { data, error: err } = await ctx.db
457
- .from('types')
458
- .update({
459
- ...updates,
460
- updated_at: new Date().toISOString()
461
- })
462
- .eq('id', id)
463
- .select()
464
- .single()
465
-
466
- if (err) throw err
467
-
468
- await emitLog(ctx, 'type.updated', { type: 'type', id }, { before: current, after: data })
469
-
470
- return data
471
- })
472
- // ─── CHUNK_END: TYPES_UPDATE ────────────────────────────────────────────────
473
-
474
- // ─── CHUNK_START: TYPES_REMOVE ──────────────────────────────────────────────
475
- /**
476
- * @chunk-id TYPES_REMOVE_1_0_0
477
- * @version 1.0.0
478
- * @hash eef22a9e3f661c71c65ba5d69ce7e60c2c2bfccec986ad2309290217f5332455
479
- * @macro Type Remove Handler
480
- * @micro Soft-deletes type with system admin validation and audit logging
481
- * @inputs ctx: CoreContext — Request context with principal and database
482
- * @inputs body: object — Type id for deletion
483
- * @outputs Updated type record with is_active: false
484
- * @depends-on [createHandler, adminDb, permissions, emitLog]
485
- * @depended-by [Netlify function routing]
486
- * @side-effects [DB soft delete, master tenant validation, audit logging]
487
- * @tags types, remove, soft-delete, system-admin, audit
488
- */
489
- export const remove = createHandler(async (ctx, body) => {
490
- const id = body?.id || ctx.query?.id
491
-
492
- if (!id) {
493
- throw new Error('Type ID is required')
494
- }
495
-
496
- if (!ctx.principal || ctx.principal.id === 'anonymous' || !ctx.accountId) {
497
- throw new Error('User context (person and account) required')
498
- }
499
-
500
- // Get current state for audit - RLS will filter to accessible types
501
- const { data: current } = await ctx.db
502
- .from('types')
503
- .select('*')
504
- .eq('id', id)
505
- .single()
506
-
507
- if (!current) {
508
- throw new Error('Type not found')
509
- }
510
-
511
- // Config mutations (types) are only allowed in master tenant by system admins
512
- if (!permissions.isSystemAdmin(ctx)) {
513
- throw new Error('Only system administrators can delete type configurations')
514
- }
515
-
516
- // System types can only be deleted by system admins (already checked above)
517
- // App types require app ownership verification
518
- if (current.ownership === 'app' && current.app_id) {
519
- // Verify user has access to this app
520
- const { data: appAccess } = await ctx.db
521
- .from('apps')
522
- .select('id')
523
- .eq('id', current.app_id)
524
- .eq('is_active', true)
525
- .single()
526
-
527
- if (!appAccess) {
528
- throw new Error('App not found or inactive')
529
- }
530
- }
531
-
532
- // Verify the current account is a master tenant (parent_id IS NULL)
533
- // Use adminDb for this check since we're verifying account structure
534
- const { data: accountData } = await adminDb
535
- .from('accounts')
536
- .select('parent_id')
537
- .eq('id', ctx.accountId!)
538
- .single()
539
-
540
- if (!accountData || accountData.parent_id !== null) {
541
- throw new Error('Type configurations can only be deleted in master tenant accounts')
542
- }
543
-
544
- const { data, error: err } = await ctx.db
545
- .from('types')
546
- .update({
547
- is_active: false,
548
- updated_at: new Date().toISOString()
549
- })
550
- .eq('id', id)
551
- .select()
552
- .single()
553
-
554
- if (err) throw err
555
-
556
- await emitLog(ctx, 'type.deleted', { type: 'type', id }, { before: current })
557
-
558
- return data
559
- })
560
- // ─── CHUNK_END: TYPES_REMOVE ────────────────────────────────────────────────
561
-
562
- // ─── MAIN HANDLER ────────────────────────────────────────────────────────────
563
-
564
- // ─── CHUNK_START: TYPES_HANDLER ──────────────────────────────────────────────
565
- /**
566
- * @chunk-id TYPES_HANDLER_1_0_0
567
- * @version 1.0.0
568
- * @hash 70e9e120f669468bd7aa45d7a2b8b4cf9a13a2323f897a6fc2bd389d960f8adc
569
- * @macro Types Router
570
- * @micro Routes HTTP methods and actions to appropriate type handlers
571
- * @inputs ctx: CoreContext — Request context with principal and database
572
- * @inputs body: any — Request body for POST/PATCH/DELETE operations
573
- * @outputs Varies — Depends on routed handler (list/get/getBySlug/getSchema/create/update/remove)
574
- * @depends-on [createHandler, list, get, getBySlug, getSchema, create, update, remove]
575
- * @depended-by [Netlify function routing]
576
- * @side-effects [Delegates to appropriate handler]
577
- * @tags types, router, crud, netlify-function
578
- */
579
- export const handler = createHandler(async (ctx, body) => {
580
- const method = ctx.query?.method || 'GET'
581
- const action = ctx.query?.action
582
-
583
- switch (method) {
584
- case 'GET':
585
- if (action === 'get' && ctx.query?.slug) {
586
- return await getBySlug(ctx, body)
587
- } else if (ctx.query?.id) {
588
- return await get(ctx, body)
589
- } else if (action === 'schema') {
590
- return await getSchema(ctx, body)
591
- } else {
592
- return await list(ctx, body)
593
- }
594
- case 'POST':
595
- return await create(ctx, body)
596
- case 'PATCH':
597
- return await update(ctx, body)
598
- case 'DELETE':
599
- return await remove(ctx, body)
600
- default:
601
- throw new Error(`Unsupported method: ${method}`)
602
- }
603
- })
604
- // ─── CHUNK_END: TYPES_HANDLER ────────────────────────────────────────────────
@@ -1,16 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="UTF-8" />
5
- <link rel="icon" type="image/svg+xml" href="/spine-logo.svg" />
6
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
7
- <link rel="preconnect" href="https://fonts.googleapis.com">
8
- <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
9
- <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet">
10
- <title>Spine Framework</title>
11
- </head>
12
- <body>
13
- <div id="root"></div>
14
- <script type="module" src="/src/main.tsx"></script>
15
- </body>
16
- </html>