spine-framework 0.1.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 (385) hide show
  1. package/.framework/README.md +129 -0
  2. package/.framework/cli/bin.cjs +14 -0
  3. package/.framework/cli/commands/agents.ts +153 -0
  4. package/.framework/cli/commands/auth.ts +94 -0
  5. package/.framework/cli/commands/create-app.ts +185 -0
  6. package/.framework/cli/commands/dev.ts +295 -0
  7. package/.framework/cli/commands/doctor.ts +442 -0
  8. package/.framework/cli/commands/generate.ts +332 -0
  9. package/.framework/cli/commands/init.ts +272 -0
  10. package/.framework/cli/commands/install-app.ts +391 -0
  11. package/.framework/cli/commands/items.ts +253 -0
  12. package/.framework/cli/commands/migrations.ts +141 -0
  13. package/.framework/cli/commands/pipelines.ts +166 -0
  14. package/.framework/cli/commands/status.ts +197 -0
  15. package/.framework/cli/commands/system.ts +184 -0
  16. package/.framework/cli/commands/test.ts +227 -0
  17. package/.framework/cli/commands/uninstall-app.ts +166 -0
  18. package/.framework/cli/context.ts +268 -0
  19. package/.framework/cli/env-loader.ts +36 -0
  20. package/.framework/cli/index.ts +106 -0
  21. package/.framework/cli/welcome.cjs +45 -0
  22. package/.framework/docs/API.md +384 -0
  23. package/.framework/docs/STABILITY.md +52 -0
  24. package/.framework/docs/admin-routes.md +76 -0
  25. package/.framework/docs/api-docs-progress.md +38 -0
  26. package/.framework/docs/api-governance.md +146 -0
  27. package/.framework/docs/api-testing-results.md +212 -0
  28. package/.framework/docs/apis/admin-configs.md +567 -0
  29. package/.framework/docs/apis/admin-data.md +272 -0
  30. package/.framework/docs/apis/index.md +231 -0
  31. package/.framework/docs/apis/internal.md +295 -0
  32. package/.framework/docs/apis/runtime.md +537 -0
  33. package/.framework/docs/assembly-launch-guide.md +138 -0
  34. package/.framework/docs/audit-results.md +590 -0
  35. package/.framework/docs/authorization-model.md +170 -0
  36. package/.framework/docs/db-api-inventory.md +95 -0
  37. package/.framework/docs/examples/custom-app/README.md +77 -0
  38. package/.framework/docs/examples/custom-function/README.md +27 -0
  39. package/.framework/docs/examples/custom-function/handler.ts +48 -0
  40. package/.framework/docs/examples/custom-webhook/README.md +68 -0
  41. package/.framework/docs/gap-remediation-backlog.md +103 -0
  42. package/.framework/docs/guides/cli-guide.md +224 -0
  43. package/.framework/docs/guides/getting-started.md +103 -0
  44. package/.framework/docs/guides/import-guide.md +193 -0
  45. package/.framework/docs/guides/testing-guide.md +229 -0
  46. package/.framework/docs/permission-examples.md +326 -0
  47. package/.framework/docs/ui-adoption-verification.md +111 -0
  48. package/.framework/docs/ui-api-coverage.md +84 -0
  49. package/.framework/docs/v2-compatibility-audit.md +228 -0
  50. package/.framework/functions/.gitkeep +1 -0
  51. package/.framework/functions/_shared/agent-runner.ts +1097 -0
  52. package/.framework/functions/_shared/app-manifest.ts +184 -0
  53. package/.framework/functions/_shared/audit.ts +150 -0
  54. package/.framework/functions/_shared/db.ts +174 -0
  55. package/.framework/functions/_shared/index.ts +382 -0
  56. package/.framework/functions/_shared/middleware.ts +490 -0
  57. package/.framework/functions/_shared/permissions.ts +1325 -0
  58. package/.framework/functions/_shared/pipeline-runner.ts +731 -0
  59. package/.framework/functions/_shared/principal.ts +760 -0
  60. package/.framework/functions/_shared/schema-utils.ts +967 -0
  61. package/.framework/functions/_shared/testing.ts +258 -0
  62. package/.framework/functions/_shared/trigger-engine.ts +425 -0
  63. package/.framework/functions/_shared/webhook-registration.ts +168 -0
  64. package/.framework/functions/_shared/webhook-registry.ts +129 -0
  65. package/.framework/functions/account-nodes.ts +111 -0
  66. package/.framework/functions/admin-data.ts +606 -0
  67. package/.framework/functions/ai-agents.ts +323 -0
  68. package/.framework/functions/api-keys.ts +376 -0
  69. package/.framework/functions/apps.ts +483 -0
  70. package/.framework/functions/auth.ts +196 -0
  71. package/.framework/functions/debug-auth.ts +107 -0
  72. package/.framework/functions/embeddings.ts +556 -0
  73. package/.framework/functions/integration-routes.ts +523 -0
  74. package/.framework/functions/integrations.ts +319 -0
  75. package/.framework/functions/item-progress.ts +272 -0
  76. package/.framework/functions/logs.ts +438 -0
  77. package/.framework/functions/observability.ts +275 -0
  78. package/.framework/functions/pipeline-executions.ts +494 -0
  79. package/.framework/functions/pipelines.ts +485 -0
  80. package/.framework/functions/prompt-configs.ts +339 -0
  81. package/.framework/functions/roles.ts +387 -0
  82. package/.framework/functions/system-cron.ts +742 -0
  83. package/.framework/functions/system.ts +323 -0
  84. package/.framework/functions/tests.ts +119 -0
  85. package/.framework/functions/timers.ts +357 -0
  86. package/.framework/functions/triggers.ts +563 -0
  87. package/.framework/functions/types.ts +604 -0
  88. package/.framework/migrations/000_foundation.sql +1256 -0
  89. package/.framework/migrations/001_seed.sql +92 -0
  90. package/.framework/migrations/002_seed_constraints.sql +13 -0
  91. package/.framework/migrations/003_auth_user_trigger.sql +59 -0
  92. package/.framework/src/App.tsx +126 -0
  93. package/.framework/src/apps/admin/index.tsx +173 -0
  94. package/.framework/src/components/AppWrapper.tsx +56 -0
  95. package/.framework/src/components/CustomAppLoader.tsx +116 -0
  96. package/.framework/src/components/admin/AdminListPage.tsx +151 -0
  97. package/.framework/src/components/admin/AdminSidebar.tsx +166 -0
  98. package/.framework/src/components/admin/AdminStatsCard.tsx +62 -0
  99. package/.framework/src/components/admin/SortableTableHeader.tsx +42 -0
  100. package/.framework/src/components/app-shell/GenericAppShell.tsx +181 -0
  101. package/.framework/src/components/app-shell/GenericDetailPage.tsx +200 -0
  102. package/.framework/src/components/app-shell/GenericListPage.tsx +116 -0
  103. package/.framework/src/components/app-sidebar.tsx +228 -0
  104. package/.framework/src/components/auth/ProtectedRoute.tsx +88 -0
  105. package/.framework/src/components/layout/AppShell.tsx +91 -0
  106. package/.framework/src/components/layout/Header.tsx +88 -0
  107. package/.framework/src/components/layout/Layout.tsx +95 -0
  108. package/.framework/src/components/layout/Sidebar.tsx +329 -0
  109. package/.framework/src/components/runtime/DataDetailHeader.tsx +77 -0
  110. package/.framework/src/components/runtime/DataDetailPage.tsx +171 -0
  111. package/.framework/src/components/runtime/DataFilters.tsx +91 -0
  112. package/.framework/src/components/runtime/DataHeader.tsx +68 -0
  113. package/.framework/src/components/runtime/DataListPage.tsx +124 -0
  114. package/.framework/src/components/runtime/DataStats.tsx +70 -0
  115. package/.framework/src/components/runtime/DataTable.tsx +174 -0
  116. package/.framework/src/components/runtime/SchemaDetailForm.tsx +134 -0
  117. package/.framework/src/components/runtime/index.ts +18 -0
  118. package/.framework/src/components/search-form.tsx +29 -0
  119. package/.framework/src/components/shared/AgentView.tsx +213 -0
  120. package/.framework/src/components/shared/FieldRenderer.tsx +478 -0
  121. package/.framework/src/components/shared/SchemaFields.tsx +226 -0
  122. package/.framework/src/components/ui/DataTable.tsx +343 -0
  123. package/.framework/src/components/ui/Form.tsx +281 -0
  124. package/.framework/src/components/ui/ItemCard.tsx +296 -0
  125. package/.framework/src/components/ui/ItemListView.tsx +308 -0
  126. package/.framework/src/components/ui/LoadingSpinner.tsx +52 -0
  127. package/.framework/src/components/ui/Modal.tsx +61 -0
  128. package/.framework/src/components/ui/RichTextEditor.tsx +210 -0
  129. package/.framework/src/components/ui/accordion.tsx +82 -0
  130. package/.framework/src/components/ui/alert-dialog.tsx +197 -0
  131. package/.framework/src/components/ui/alert.tsx +76 -0
  132. package/.framework/src/components/ui/aspect-ratio.tsx +11 -0
  133. package/.framework/src/components/ui/avatar.tsx +110 -0
  134. package/.framework/src/components/ui/badge.tsx +49 -0
  135. package/.framework/src/components/ui/breadcrumb.tsx +122 -0
  136. package/.framework/src/components/ui/button-group.tsx +83 -0
  137. package/.framework/src/components/ui/button.tsx +65 -0
  138. package/.framework/src/components/ui/calendar.tsx +222 -0
  139. package/.framework/src/components/ui/card.tsx +100 -0
  140. package/.framework/src/components/ui/carousel.tsx +240 -0
  141. package/.framework/src/components/ui/chart.tsx +373 -0
  142. package/.framework/src/components/ui/checkbox.tsx +31 -0
  143. package/.framework/src/components/ui/collapsible.tsx +33 -0
  144. package/.framework/src/components/ui/combobox.tsx +299 -0
  145. package/.framework/src/components/ui/command.tsx +193 -0
  146. package/.framework/src/components/ui/context-menu.tsx +261 -0
  147. package/.framework/src/components/ui/dialog.tsx +165 -0
  148. package/.framework/src/components/ui/direction.tsx +22 -0
  149. package/.framework/src/components/ui/drawer.tsx +132 -0
  150. package/.framework/src/components/ui/dropdown-menu.tsx +269 -0
  151. package/.framework/src/components/ui/empty.tsx +104 -0
  152. package/.framework/src/components/ui/field.tsx +238 -0
  153. package/.framework/src/components/ui/hover-card.tsx +42 -0
  154. package/.framework/src/components/ui/input-group.tsx +153 -0
  155. package/.framework/src/components/ui/input-otp.tsx +87 -0
  156. package/.framework/src/components/ui/input.tsx +19 -0
  157. package/.framework/src/components/ui/item.tsx +196 -0
  158. package/.framework/src/components/ui/kbd.tsx +26 -0
  159. package/.framework/src/components/ui/label.tsx +22 -0
  160. package/.framework/src/components/ui/menubar.tsx +277 -0
  161. package/.framework/src/components/ui/native-select.tsx +61 -0
  162. package/.framework/src/components/ui/navigation-menu.tsx +164 -0
  163. package/.framework/src/components/ui/pagination.tsx +129 -0
  164. package/.framework/src/components/ui/popover.tsx +87 -0
  165. package/.framework/src/components/ui/progress.tsx +31 -0
  166. package/.framework/src/components/ui/radio-group.tsx +42 -0
  167. package/.framework/src/components/ui/resizable.tsx +50 -0
  168. package/.framework/src/components/ui/scroll-area.tsx +53 -0
  169. package/.framework/src/components/ui/select.tsx +195 -0
  170. package/.framework/src/components/ui/separator.tsx +26 -0
  171. package/.framework/src/components/ui/sheet.tsx +145 -0
  172. package/.framework/src/components/ui/sidebar.tsx +706 -0
  173. package/.framework/src/components/ui/skeleton.tsx +13 -0
  174. package/.framework/src/components/ui/slider.tsx +59 -0
  175. package/.framework/src/components/ui/sonner.tsx +47 -0
  176. package/.framework/src/components/ui/spinner.tsx +10 -0
  177. package/.framework/src/components/ui/switch.tsx +33 -0
  178. package/.framework/src/components/ui/table-primitives.tsx +141 -0
  179. package/.framework/src/components/ui/table.tsx +114 -0
  180. package/.framework/src/components/ui/tabs.tsx +90 -0
  181. package/.framework/src/components/ui/textarea.tsx +18 -0
  182. package/.framework/src/components/ui/toggle-group.tsx +89 -0
  183. package/.framework/src/components/ui/toggle.tsx +45 -0
  184. package/.framework/src/components/ui/tooltip.tsx +57 -0
  185. package/.framework/src/contexts/AppContext.tsx +133 -0
  186. package/.framework/src/contexts/AuthContext.tsx +371 -0
  187. package/.framework/src/hooks/use-mobile.ts +19 -0
  188. package/.framework/src/hooks/useApi.ts +526 -0
  189. package/.framework/src/hooks/useApps.ts +114 -0
  190. package/.framework/src/hooks/useEntityList.ts +190 -0
  191. package/.framework/src/hooks/useEntityRecord.ts +308 -0
  192. package/.framework/src/hooks/useForm.ts +307 -0
  193. package/.framework/src/hooks/useListSchema.ts +264 -0
  194. package/.framework/src/hooks/useSchemaRecord.ts +223 -0
  195. package/.framework/src/index.css +128 -0
  196. package/.framework/src/lib/api.ts +156 -0
  197. package/.framework/src/lib/supabase.ts +94 -0
  198. package/.framework/src/lib/utils.ts +317 -0
  199. package/.framework/src/main.tsx +27 -0
  200. package/.framework/src/pages/DashboardPage.tsx +181 -0
  201. package/.framework/src/pages/NotFoundPage.tsx +39 -0
  202. package/.framework/src/pages/admin/AIAgentDetailPage.tsx +161 -0
  203. package/.framework/src/pages/admin/AIAgentsPage.tsx +318 -0
  204. package/.framework/src/pages/admin/APIKeyDetailPage.tsx +199 -0
  205. package/.framework/src/pages/admin/APIKeysPage.tsx +303 -0
  206. package/.framework/src/pages/admin/AlertsConfigPage.tsx +523 -0
  207. package/.framework/src/pages/admin/AppDetailPage.tsx +493 -0
  208. package/.framework/src/pages/admin/AppsPage.tsx +355 -0
  209. package/.framework/src/pages/admin/DesignedPage.tsx +491 -0
  210. package/.framework/src/pages/admin/EmbeddingDetailPage.tsx +534 -0
  211. package/.framework/src/pages/admin/EmbeddingsPage.tsx +424 -0
  212. package/.framework/src/pages/admin/ExtendedShadcnTestPage.tsx +176 -0
  213. package/.framework/src/pages/admin/IncrementalShadcnTestPage.tsx +109 -0
  214. package/.framework/src/pages/admin/IntegratedDashboard.tsx +402 -0
  215. package/.framework/src/pages/admin/IntegrationDetailPage.tsx +187 -0
  216. package/.framework/src/pages/admin/IntegrationsPage.tsx +301 -0
  217. package/.framework/src/pages/admin/LogsPage.tsx +283 -0
  218. package/.framework/src/pages/admin/MinimalShadcnTestPage.tsx +85 -0
  219. package/.framework/src/pages/admin/ObservabilityDashboard.tsx +470 -0
  220. package/.framework/src/pages/admin/PipelineDetailPage.tsx +183 -0
  221. package/.framework/src/pages/admin/PipelineExecutionsPage.tsx +279 -0
  222. package/.framework/src/pages/admin/PipelinesPage.tsx +390 -0
  223. package/.framework/src/pages/admin/PromptConfigDetailPage.tsx +299 -0
  224. package/.framework/src/pages/admin/PromptConfigsPage.tsx +292 -0
  225. package/.framework/src/pages/admin/ProperlyDesignedPage.tsx +434 -0
  226. package/.framework/src/pages/admin/RoleDetailPage.tsx +273 -0
  227. package/.framework/src/pages/admin/RolesPage.tsx +292 -0
  228. package/.framework/src/pages/admin/SelectTestPage.tsx +61 -0
  229. package/.framework/src/pages/admin/ShadcnTestPage.tsx +588 -0
  230. package/.framework/src/pages/admin/SimpleDashboard.tsx +387 -0
  231. package/.framework/src/pages/admin/TestRunDetailPage.tsx +172 -0
  232. package/.framework/src/pages/admin/TestingDashboard.tsx +257 -0
  233. package/.framework/src/pages/admin/TimerDetailPage.tsx +151 -0
  234. package/.framework/src/pages/admin/TimersPage.tsx +376 -0
  235. package/.framework/src/pages/admin/TriggerDetailPage.tsx +149 -0
  236. package/.framework/src/pages/admin/TriggersPage.tsx +381 -0
  237. package/.framework/src/pages/admin/TypeDetailPage.tsx +694 -0
  238. package/.framework/src/pages/admin/TypesPage.tsx +295 -0
  239. package/.framework/src/pages/auth/LoginPage.tsx +188 -0
  240. package/.framework/src/pages/auth/RegisterPage.tsx +163 -0
  241. package/.framework/src/pages/spine-framework/APIPage.tsx +17 -0
  242. package/.framework/src/pages/spine-framework/CLIPage.tsx +25 -0
  243. package/.framework/src/types/auth.ts +125 -0
  244. package/.framework/src/types/types.ts +407 -0
  245. package/STRUCTURE.md +150 -0
  246. package/config/components.json +25 -0
  247. package/config/deno.lock +108 -0
  248. package/config/package-lock.json +17183 -0
  249. package/config/postcss.config.cjs +10 -0
  250. package/config/tailwind.config.cjs +78 -0
  251. package/config/tsconfig.build.json +32 -0
  252. package/config/tsconfig.cli.json +18 -0
  253. package/config/tsconfig.json +41 -0
  254. package/config/tsconfig.node.json +17 -0
  255. package/config/tsconfig.node.tsbuildinfo +1 -0
  256. package/config/tsconfig.tsbuildinfo +1 -0
  257. package/config/typedoc.json +16 -0
  258. package/config/vite.config.d.ts +2 -0
  259. package/config/vite.config.ts +72 -0
  260. package/dist/cli/commands/agents.d.ts +39 -0
  261. package/dist/cli/commands/agents.d.ts.map +1 -0
  262. package/dist/cli/commands/auth.d.ts +36 -0
  263. package/dist/cli/commands/auth.d.ts.map +1 -0
  264. package/dist/cli/commands/create-app.d.ts +23 -0
  265. package/dist/cli/commands/create-app.d.ts.map +1 -0
  266. package/dist/cli/commands/dev.d.ts +39 -0
  267. package/dist/cli/commands/dev.d.ts.map +1 -0
  268. package/dist/cli/commands/doctor.d.ts +42 -0
  269. package/dist/cli/commands/doctor.d.ts.map +1 -0
  270. package/dist/cli/commands/generate.d.ts +36 -0
  271. package/dist/cli/commands/generate.d.ts.map +1 -0
  272. package/dist/cli/commands/init.d.ts +30 -0
  273. package/dist/cli/commands/init.d.ts.map +1 -0
  274. package/dist/cli/commands/install-app.d.ts +30 -0
  275. package/dist/cli/commands/install-app.d.ts.map +1 -0
  276. package/dist/cli/commands/items.d.ts +45 -0
  277. package/dist/cli/commands/items.d.ts.map +1 -0
  278. package/dist/cli/commands/migrations.d.ts +41 -0
  279. package/dist/cli/commands/migrations.d.ts.map +1 -0
  280. package/dist/cli/commands/pipelines.d.ts +40 -0
  281. package/dist/cli/commands/pipelines.d.ts.map +1 -0
  282. package/dist/cli/commands/status.d.ts +23 -0
  283. package/dist/cli/commands/status.d.ts.map +1 -0
  284. package/dist/cli/commands/system.d.ts +29 -0
  285. package/dist/cli/commands/system.d.ts.map +1 -0
  286. package/dist/cli/commands/test.d.ts +46 -0
  287. package/dist/cli/commands/test.d.ts.map +1 -0
  288. package/dist/cli/commands/uninstall-app.d.ts +23 -0
  289. package/dist/cli/commands/uninstall-app.d.ts.map +1 -0
  290. package/dist/cli/context.d.ts +88 -0
  291. package/dist/cli/context.d.ts.map +1 -0
  292. package/dist/cli/env-loader.d.ts +14 -0
  293. package/dist/cli/env-loader.d.ts.map +1 -0
  294. package/dist/cli/index.d.ts +41 -0
  295. package/dist/cli/index.d.ts.map +1 -0
  296. package/dist/functions/_shared/agent-runner.d.ts +156 -0
  297. package/dist/functions/_shared/agent-runner.d.ts.map +1 -0
  298. package/dist/functions/_shared/app-manifest.d.ts +68 -0
  299. package/dist/functions/_shared/app-manifest.d.ts.map +1 -0
  300. package/dist/functions/_shared/audit.d.ts +91 -0
  301. package/dist/functions/_shared/audit.d.ts.map +1 -0
  302. package/dist/functions/_shared/db.d.ts +125 -0
  303. package/dist/functions/_shared/db.d.ts.map +1 -0
  304. package/dist/functions/_shared/index.d.ts +298 -0
  305. package/dist/functions/_shared/index.d.ts.map +1 -0
  306. package/dist/functions/_shared/middleware.d.ts +315 -0
  307. package/dist/functions/_shared/middleware.d.ts.map +1 -0
  308. package/dist/functions/_shared/permissions.d.ts +626 -0
  309. package/dist/functions/_shared/permissions.d.ts.map +1 -0
  310. package/dist/functions/_shared/pipeline-runner.d.ts +124 -0
  311. package/dist/functions/_shared/pipeline-runner.d.ts.map +1 -0
  312. package/dist/functions/_shared/principal.d.ts +284 -0
  313. package/dist/functions/_shared/principal.d.ts.map +1 -0
  314. package/dist/functions/_shared/schema-utils.d.ts +181 -0
  315. package/dist/functions/_shared/schema-utils.d.ts.map +1 -0
  316. package/dist/functions/_shared/testing.d.ts +172 -0
  317. package/dist/functions/_shared/testing.d.ts.map +1 -0
  318. package/dist/functions/_shared/trigger-engine.d.ts +140 -0
  319. package/dist/functions/_shared/trigger-engine.d.ts.map +1 -0
  320. package/dist/functions/_shared/webhook-registration.d.ts +81 -0
  321. package/dist/functions/_shared/webhook-registration.d.ts.map +1 -0
  322. package/dist/functions/_shared/webhook-registry.d.ts +57 -0
  323. package/dist/functions/_shared/webhook-registry.d.ts.map +1 -0
  324. package/dist/functions/account-nodes.d.ts +48 -0
  325. package/dist/functions/account-nodes.d.ts.map +1 -0
  326. package/dist/functions/admin-data.d.ts +178 -0
  327. package/dist/functions/admin-data.d.ts.map +1 -0
  328. package/dist/functions/ai-agents.d.ts +125 -0
  329. package/dist/functions/ai-agents.d.ts.map +1 -0
  330. package/dist/functions/api-keys.d.ts +140 -0
  331. package/dist/functions/api-keys.d.ts.map +1 -0
  332. package/dist/functions/apps.d.ts +163 -0
  333. package/dist/functions/apps.d.ts.map +1 -0
  334. package/dist/functions/auth.d.ts +74 -0
  335. package/dist/functions/auth.d.ts.map +1 -0
  336. package/dist/functions/debug-auth.d.ts +33 -0
  337. package/dist/functions/debug-auth.d.ts.map +1 -0
  338. package/dist/functions/embeddings.d.ts +205 -0
  339. package/dist/functions/embeddings.d.ts.map +1 -0
  340. package/dist/functions/integration-routes.d.ts +45 -0
  341. package/dist/functions/integration-routes.d.ts.map +1 -0
  342. package/dist/functions/integrations.d.ts +124 -0
  343. package/dist/functions/integrations.d.ts.map +1 -0
  344. package/dist/functions/item-progress.d.ts +41 -0
  345. package/dist/functions/item-progress.d.ts.map +1 -0
  346. package/dist/functions/logs.d.ts +162 -0
  347. package/dist/functions/logs.d.ts.map +1 -0
  348. package/dist/functions/observability.d.ts +123 -0
  349. package/dist/functions/observability.d.ts.map +1 -0
  350. package/dist/functions/pipeline-executions.d.ts +190 -0
  351. package/dist/functions/pipeline-executions.d.ts.map +1 -0
  352. package/dist/functions/pipelines.d.ts +171 -0
  353. package/dist/functions/pipelines.d.ts.map +1 -0
  354. package/dist/functions/prompt-configs.d.ts +125 -0
  355. package/dist/functions/prompt-configs.d.ts.map +1 -0
  356. package/dist/functions/roles.d.ts +118 -0
  357. package/dist/functions/roles.d.ts.map +1 -0
  358. package/dist/functions/system-cron.d.ts +65 -0
  359. package/dist/functions/system-cron.d.ts.map +1 -0
  360. package/dist/functions/system.d.ts +29 -0
  361. package/dist/functions/system.d.ts.map +1 -0
  362. package/dist/functions/tests.d.ts +28 -0
  363. package/dist/functions/tests.d.ts.map +1 -0
  364. package/dist/functions/timers.d.ts +139 -0
  365. package/dist/functions/timers.d.ts.map +1 -0
  366. package/dist/functions/triggers.d.ts +203 -0
  367. package/dist/functions/triggers.d.ts.map +1 -0
  368. package/dist/functions/types.d.ts +151 -0
  369. package/dist/functions/types.d.ts.map +1 -0
  370. package/dist/src/types/types.d.ts +364 -0
  371. package/dist/src/types/types.d.ts.map +1 -0
  372. package/package.json +192 -0
  373. package/scripts/app-install-cli.ts +286 -0
  374. package/scripts/assemble-frontend.sh +79 -0
  375. package/scripts/assemble-functions.sh +62 -0
  376. package/scripts/assemble.sh +35 -0
  377. package/scripts/boundary-check.sh +106 -0
  378. package/scripts/build-manifest.sh +80 -0
  379. package/scripts/check-core-integrity.sh +82 -0
  380. package/scripts/ingest-chunks.cjs +202 -0
  381. package/scripts/kb-chunk-parser.cjs +312 -0
  382. package/scripts/kb-chunk-parser.ts +330 -0
  383. package/scripts/load-test-app-install.ts +484 -0
  384. package/scripts/netlify-dev-wrapper.sh +22 -0
  385. package/scripts/verify-integrity.sh +69 -0
@@ -0,0 +1,184 @@
1
+ /**
2
+ * @module app-manifest
3
+ * @audience core-contributor
4
+ * @layer shared-util
5
+ * @stability evolving
6
+ *
7
+ * Utility for loading and merging app manifests with database records.
8
+ * Enables file-first app configuration with database tracking installations.
9
+ *
10
+ * **Pattern:**
11
+ * 1. Manifest files in custom/apps/{slug}/manifest.json are source of truth
12
+ * 2. Database tracks which tenant has which app installed/enabled
13
+ * 3. This utility merges both sources for the API response
14
+ *
15
+ * @seeAlso apps.ts (uses this for manifest-driven responses)
16
+ * @seeAlso 015_simplify_apps_table.sql (database structure)
17
+ */
18
+
19
+ import { readFileSync, readdirSync, existsSync } from 'fs'
20
+ import { resolve, join } from 'path'
21
+
22
+ export interface AppManifest {
23
+ name: string
24
+ slug: string
25
+ description?: string
26
+ version?: string
27
+ required_roles: string[] // Migrated from min_role (string) to array
28
+ routes: string[]
29
+ nav_items: NavItem[]
30
+ features?: string[]
31
+ dependencies?: string[]
32
+ entry_point: string
33
+ is_public?: boolean
34
+ auth_required?: boolean
35
+ }
36
+
37
+ export interface NavItem {
38
+ title: string
39
+ path: string
40
+ icon?: string
41
+ order?: number
42
+ children?: NavItem[]
43
+ }
44
+
45
+ // Cache for manifest content (development mode - no caching in production)
46
+ const manifestCache = new Map<string, AppManifest>()
47
+
48
+ /**
49
+ * Loads a manifest.json file from the filesystem.
50
+ *
51
+ * @param manifestPath - Relative path to manifest (e.g., 'custom/apps/cortex/manifest.json')
52
+ * @returns Parsed manifest or null if not found
53
+ */
54
+ export function loadManifest(manifestPath: string): AppManifest | null {
55
+ // Check cache first (dev only)
56
+ if (manifestCache.has(manifestPath)) {
57
+ return manifestCache.get(manifestPath)!
58
+ }
59
+
60
+ try {
61
+ // Resolve from project root (functions are at .assembled/netlify/functions/)
62
+ const projectRoot = resolve(__dirname, '../../../..')
63
+ const fullPath = resolve(projectRoot, manifestPath)
64
+
65
+ const content = readFileSync(fullPath, 'utf-8')
66
+ const manifest: AppManifest = JSON.parse(content)
67
+
68
+ // Validate required fields
69
+ if (!manifest.slug || !manifest.name) {
70
+ console.error(`[app-manifest] Invalid manifest at ${manifestPath}: missing slug or name`)
71
+ return null
72
+ }
73
+
74
+ // Ensure required_roles is array (backward compat)
75
+ if (!manifest.required_roles) {
76
+ manifest.required_roles = []
77
+ }
78
+
79
+ // Cache for development (dev server restarts clear cache)
80
+ manifestCache.set(manifestPath, manifest)
81
+
82
+ return manifest
83
+ } catch (err) {
84
+ console.error(`[app-manifest] Failed to load ${manifestPath}:`, err)
85
+ return null
86
+ }
87
+ }
88
+
89
+ /**
90
+ * Clears the manifest cache. Useful for testing.
91
+ */
92
+ export function clearManifestCache(): void {
93
+ manifestCache.clear()
94
+ }
95
+
96
+ /**
97
+ * Merges database app record with manifest data.
98
+ * Manifest takes precedence for metadata fields.
99
+ *
100
+ * @param dbRecord - App record from app_definitions table
101
+ * @returns Merged app data for API response
102
+ */
103
+ export function mergeWithManifest(dbRecord: any): any {
104
+ if (!dbRecord) return null
105
+
106
+ // If no manifest path, return DB record as-is (legacy mode)
107
+ if (!dbRecord.manifest_path || dbRecord.config_source !== 'manifest') {
108
+ // Convert legacy min_role to required_roles for frontend compatibility
109
+ return {
110
+ ...dbRecord,
111
+ required_roles: dbRecord.min_role ? [dbRecord.min_role] : [],
112
+ _source: 'database'
113
+ }
114
+ }
115
+
116
+ // Load manifest and merge
117
+ const manifest = loadManifest(dbRecord.manifest_path)
118
+ if (!manifest) {
119
+ console.warn(`[app-manifest] Could not load manifest for ${dbRecord.slug}, falling back to DB`)
120
+ return {
121
+ ...dbRecord,
122
+ required_roles: dbRecord.min_role ? [dbRecord.min_role] : [],
123
+ _source: 'database (manifest missing)'
124
+ }
125
+ }
126
+
127
+ // Merge: Manifest metadata + DB state fields
128
+ return {
129
+ id: dbRecord.id,
130
+ slug: manifest.slug,
131
+ name: manifest.name,
132
+ description: manifest.description || dbRecord.description,
133
+
134
+ // Role-based access (new array format)
135
+ required_roles: manifest.required_roles,
136
+ min_role: manifest.required_roles[0] || null, // Backward compat
137
+
138
+ // Navigation and routing
139
+ routes: manifest.routes,
140
+ nav_items: manifest.nav_items,
141
+
142
+ // Features and metadata
143
+ features: manifest.features || [],
144
+ dependencies: manifest.dependencies || [],
145
+ version: manifest.version,
146
+
147
+ // Database state fields
148
+ is_active: dbRecord.is_active,
149
+ is_system: dbRecord.is_system,
150
+ is_public: manifest.is_public ?? false,
151
+ auth_required: manifest.auth_required ?? true,
152
+
153
+ // Installation tracking
154
+ account_id: dbRecord.account_id,
155
+ pack_id: dbRecord.pack_id,
156
+ ownership: dbRecord.ownership,
157
+
158
+ // Internal
159
+ _source: 'manifest',
160
+ _manifest_path: dbRecord.manifest_path
161
+ }
162
+ }
163
+
164
+ /**
165
+ * Lists all available manifests from filesystem.
166
+ * Used for initial discovery before database tracking.
167
+ *
168
+ * @returns Array of discovered app slugs and their paths
169
+ */
170
+ export function discoverManifests(): Array<{slug: string, path: string}> {
171
+ const appsDir = resolve(process.cwd(), 'custom/apps')
172
+ if (!existsSync(appsDir)) return []
173
+
174
+ const results: Array<{slug: string, path: string}> = []
175
+ for (const entry of readdirSync(appsDir, { withFileTypes: true })) {
176
+ if (!entry.isDirectory()) continue
177
+ if (entry.name === 'lib' || entry.name.startsWith('.')) continue
178
+ const manifestPath = join('custom/apps', entry.name, 'manifest.json')
179
+ if (existsSync(resolve(process.cwd(), manifestPath))) {
180
+ results.push({ slug: entry.name, path: manifestPath })
181
+ }
182
+ }
183
+ return results
184
+ }
@@ -0,0 +1,150 @@
1
+ /**
2
+ * @module audit
3
+ * @audience both
4
+ * @layer shared-core
5
+ * @stability stable
6
+ *
7
+ * Unified audit logging for all operations in Spine. Every state-changing
8
+ * operation should call `emitAudit` to write a structured row to the `logs`
9
+ * table with full principal provenance. Audit failures never throw — a failed
10
+ * log write must never break the operation that triggered it.
11
+ *
12
+ * INVARIANT: always call `emitAudit` after a successful write, not before.
13
+ * Pass `result: 'failure'` only when the operation itself failed.
14
+ * INVARIANT: never pass sensitive secrets (API keys, tokens) in metadata.
15
+ *
16
+ * @seeAlso principal.ts (formatPrincipalForAudit — shapes the principal field)
17
+ * @seeAlso middleware.ts (CoreContext — ctx.requestId ties logs to HTTP requests)
18
+ * @seeAlso logs.ts (API handler that queries the logs table)
19
+ * @seeAlso permissions.ts (getPrincipalPermissionSummary — used in metadata)
20
+ */
21
+
22
+ import { CoreContext } from './middleware'
23
+ import { adminDb } from './db'
24
+ import { Principal, formatPrincipalForAudit } from './principal'
25
+
26
+ // ─── PRIMARY AUDIT FUNCTION ───────────────────────────────────────────────────
27
+
28
+ // ─── CHUNK_START: SHARED_AUDIT_EMIT ──────────────────────────────────────────────
29
+ /**
30
+ * @chunk-id SHARED_AUDIT_EMIT_1_0_0
31
+ * @version 1.0.0
32
+ * @hash d9c3dbc103f5f2f0543dc4c154bbad256e59c885643a20bc20ca07198eabd67c
33
+ * @macro Audit Log Emitter
34
+ * @micro Writes structured audit logs to logs table with principal provenance
35
+ * @inputs ctx: CoreContext — Request context with principal and database
36
+ * @inputs action: string — Dot-namespaced action (e.g. 'items.create')
37
+ * @inputs target: {type, id?, account_id?} — Resource being acted upon
38
+ * @inputs metadata: {changes?, result?, error?, ...} — Optional context
39
+ * @outputs void — Always resolves, never rejects
40
+ * @depends-on [adminDb, formatPrincipalForAudit]
41
+ * @depended-by [All state-changing API functions, pipeline-runner, trigger-engine]
42
+ * @side-effects [DB insert to logs table, console.error on failure]
43
+ * @tags audit, logging, security, compliance
44
+ */
45
+ export async function emitAudit(
46
+ ctx: CoreContext,
47
+ action: string,
48
+ target: { type: string; id?: string; account_id?: string },
49
+ metadata?: {
50
+ changes?: { before?: any; after?: any }
51
+ result?: 'success' | 'failure' | 'denied'
52
+ error?: string
53
+ [key: string]: any
54
+ }
55
+ ): Promise<void> {
56
+ try {
57
+ // Use the RLS-scoped db from context, or fallback to adminDb
58
+ const logDb = ctx.db || adminDb
59
+
60
+ await logDb.from('logs').insert({
61
+ level: metadata?.result === 'failure' || metadata?.result === 'denied' ? 'warning' : 'info',
62
+ source: 'audit',
63
+ message: `${action} by ${ctx.principal?.type || 'unknown'}:${ctx.principal?.id || 'anonymous'}`,
64
+ metadata: {
65
+ principal: ctx.principal ? formatPrincipalForAudit(ctx.principal) : null,
66
+ action,
67
+ target: {
68
+ type: target.type,
69
+ id: target.id,
70
+ account_id: target.account_id || ctx.accountId
71
+ },
72
+ request_id: ctx.requestId,
73
+ ...metadata
74
+ },
75
+ account_id: target.account_id || ctx.accountId || ctx.principal?.accountId || null
76
+ })
77
+ } catch (err) {
78
+ console.error('Failed to emit audit log:', err)
79
+ // Don't throw - audit failures shouldn't break operations
80
+ }
81
+ }
82
+ // ─── CHUNK_END: SHARED_AUDIT_EMIT ────────────────────────────────────────────────
83
+
84
+ // ─── LEGACY EXPORTS ───────────────────────────────────────────────────────────
85
+
86
+ // ─── CHUNK_START: SHARED_AUDIT_EMIT_LOG ──────────────────────────────────────────────
87
+ /**
88
+ * @chunk-id SHARED_AUDIT_EMIT_LOG_1_0_0
89
+ * @version 1.0.0
90
+ * @hash 148fb1ce7badf1d3df08e2daa38bac4c084c94ba2f262c782c9df092a22890dd
91
+ * @macro Legacy Audit Log Wrapper
92
+ * @micro Backward compatibility wrapper around emitAudit
93
+ * @inputs ctx: CoreContext — Request context
94
+ * @inputs eventType: string — Action string (maps to emitAudit's action)
95
+ * @inputs target: {type, id} | undefined — Resource target
96
+ * @inputs changes: {before?, after?} | undefined — Change data
97
+ * @inputs metadata: Record<string, any> — Additional context
98
+ * @outputs void — Always resolves
99
+ * @depends-on [emitAudit]
100
+ * @depended-by [Legacy code, should not be used in new code]
101
+ * @side-effects [DB insert via emitAudit, console.error on failure]
102
+ * @tags audit, logging, legacy, wrapper, deprecated
103
+ */
104
+ export async function emitLog(
105
+ ctx: CoreContext,
106
+ eventType: string,
107
+ target?: { type: string; id: string },
108
+ changes?: { before?: any; after?: any },
109
+ metadata: Record<string, any> = {}
110
+ ): Promise<void> {
111
+ try {
112
+ await emitAudit(ctx, eventType, {
113
+ type: target?.type || 'unknown',
114
+ id: target?.id,
115
+ account_id: ctx.accountId || undefined
116
+ }, {
117
+ changes,
118
+ ...metadata
119
+ })
120
+ } catch (error) {
121
+ console.error('Failed to emit log:', error)
122
+ // Don't throw - logging failures shouldn't break operations
123
+ }
124
+ }
125
+ // ─── CHUNK_END: SHARED_AUDIT_EMIT_LOG ────────────────────────────────────────────────
126
+
127
+ // ─── CHUNK_START: SHARED_AUDIT_EMIT_ACTIVITY ──────────────────────────────────────────────
128
+ /**
129
+ * @chunk-id SHARED_AUDIT_EMIT_ACTIVITY_1_0_0
130
+ * @version 1.0.0
131
+ * @hash 58e532a743fdae480ca24d311be66e82612477309270ec7462fd7dfd695d5282
132
+ * @macro Legacy Activity Logger
133
+ * @micro Wraps emitLog with activity. prefix for backward compatibility
134
+ * @inputs ctx: CoreContext — Request context
135
+ * @inputs type: string — Activity type (prefixed with 'activity.')
136
+ * @inputs details: Record<string, any> — Metadata context
137
+ * @outputs void — Always resolves
138
+ * @depends-on [emitLog]
139
+ * @depended-by [Legacy code, should not be used in new code]
140
+ * @side-effects [DB insert via emitLog → emitAudit, console.error on failure]
141
+ * @tags audit, logging, legacy, activity, deprecated
142
+ */
143
+ export async function emitActivity(
144
+ ctx: CoreContext,
145
+ type: string,
146
+ details: Record<string, any> = {}
147
+ ): Promise<void> {
148
+ await emitLog(ctx, `activity.${type}`, undefined, undefined, details)
149
+ }
150
+ // ─── CHUNK_END: SHARED_AUDIT_EMIT_ACTIVITY ────────────────────────────────────────────────
@@ -0,0 +1,174 @@
1
+ /**
2
+ * @module db
3
+ * @audience both
4
+ * @layer shared-core
5
+ * @stability stable
6
+ *
7
+ * Supabase client factory and PostgREST join helpers. This module owns the
8
+ * two-client pattern that is central to Spine's security model: `adminDb`
9
+ * bypasses RLS for system operations; `getUserDb` enforces RLS for all
10
+ * human-principal requests. Never use `adminDb` for user-scoped queries —
11
+ * doing so silently bypasses account isolation.
12
+ *
13
+ * @seeAlso principal.ts (getPrincipalDb selects between these two clients)
14
+ * @seeAlso middleware.ts (ctx.db is set from getPrincipalDb at request time)
15
+ */
16
+
17
+ import { createClient } from '@supabase/supabase-js'
18
+
19
+ // ─── ENVIRONMENT RESOLUTION ──────────────────────────────────────────────────
20
+
21
+ const _env = (globalThis as any).process?.env || {}
22
+ const supabaseUrl: string = _env.SUPABASE_URL!
23
+ const supabaseServiceKey: string = _env.SUPABASE_SERVICE_ROLE_KEY!
24
+ const supabaseAnonKey: string = _env.SUPABASE_ANON_KEY!
25
+
26
+ /**
27
+ * Active database schema name, read from `DB_SCHEMA` env var.
28
+ *
29
+ * Defaults to `'public'` (production schema). Set to `'v2'` only in legacy
30
+ * environments. All new migrations target `public`.
31
+ *
32
+ * @inputSpec DB_SCHEMA: string — one of 'public' | 'v2'. Any other value is
33
+ * passed through as-is and will cause runtime query errors.
34
+ * @outputSpec string — schema name applied to both Supabase clients.
35
+ * @sideEffects none
36
+ * @calledBy adminDb, getUserDb (applied at client construction time)
37
+ */
38
+ const dbSchema: string = _env.DB_SCHEMA || 'public'
39
+
40
+ // ─── CLIENTS ─────────────────────────────────────────────────────────────────
41
+
42
+ /**
43
+ * Service-role Supabase client. Bypasses Row Level Security.
44
+ *
45
+ * Use this ONLY for:
46
+ * - System/cron operations that must cross account boundaries (`system-cron.ts`)
47
+ * - Principal resolution lookups (`principal.ts` — resolving auth_uid to person)
48
+ * - Machine principal validation RPCs
49
+ * - Test helpers that need to seed/clean data across accounts
50
+ *
51
+ * Do NOT use this in request handlers for user-scoped data reads or writes.
52
+ * Always prefer `ctx.db` (set by `getPrincipalDb` in middleware) for those.
53
+ *
54
+ * @inputSpec SUPABASE_URL: string — valid Supabase project URL, required
55
+ * @inputSpec SUPABASE_SERVICE_ROLE_KEY: string — service role JWT, required
56
+ * @outputSpec SupabaseClient — PostgREST client scoped to `dbSchema`, RLS disabled
57
+ * @sideEffects none (client construction only)
58
+ * @calledBy principal.ts, middleware.ts, system-cron.ts, permissions.ts,
59
+ * tests/integration/helpers.ts
60
+ * @calls createClient (supabase-js)
61
+ * @testUnit tests/unit/pipeline-runner.test.ts — mocked via vi.mock
62
+ * @testIntegration tests/integration/helpers.ts — used directly as adminDb
63
+ *
64
+ * @example API handler (system operation)
65
+ * ```ts
66
+ * import { adminDb } from './_shared/db'
67
+ * const { data } = await adminDb.from('types').select('*').eq('slug', 'item')
68
+ * ```
69
+ *
70
+ * @example Import usage (v2-custom/ — system-level only)
71
+ * ```ts
72
+ * import { adminDb } from '../_shared/index'
73
+ * // Only use adminDb if your custom code runs as a system/cron principal
74
+ * ```
75
+ */
76
+ export const adminDb = createClient(supabaseUrl, supabaseServiceKey, {
77
+ db: {
78
+ schema: dbSchema
79
+ }
80
+ })
81
+
82
+ // ─── CHUNK_START: SHARED_DB_GET_USER_DB ──────────────────────────────────────────────
83
+ /**
84
+ * @chunk-id SHARED_DB_GET_USER_DB_1_0_0
85
+ * @version 1.0.0
86
+ * @hash af3c792634c60ced1c1c4184cfc6c20add90ab97eb62f7e46bdf40ae2899a0f8
87
+ * @macro User Database Client Factory
88
+ * @micro Creates RLS-enforced Supabase client for specific user JWT
89
+ * @inputs jwt: string — Valid Supabase JWT from Authorization header
90
+ * @outputs SupabaseClient — PostgREST client with RLS enforced
91
+ * @depends-on [createClient, supabaseUrl, supabaseAnonKey, dbSchema]
92
+ * @depended-by [principal.ts, middleware.ts]
93
+ * @side-effects [Client construction with Authorization header]
94
+ * @tags database, supabase, rls, authentication, user-scoped
95
+ */
96
+ export function getUserDb(jwt: string) {
97
+ return createClient(supabaseUrl, supabaseAnonKey, {
98
+ db: {
99
+ schema: dbSchema
100
+ },
101
+ global: {
102
+ headers: {
103
+ Authorization: `Bearer ${jwt}`
104
+ }
105
+ }
106
+ })
107
+ }
108
+ // ─── CHUNK_END: SHARED_DB_GET_USER_DB ────────────────────────────────────────────────
109
+
110
+ // ─── TYPES ───────────────────────────────────────────────────────────────────
111
+
112
+ /**
113
+ * Standard shape returned by all Supabase PostgREST queries.
114
+ *
115
+ * Both `data` and `error` follow the Supabase JS client convention: on success,
116
+ * `error` is null; on failure, `data` is null and `error` contains the Postgres
117
+ * error details. Always check `error` before using `data`.
118
+ *
119
+ * @inputSpec T — the expected shape of a successful result row
120
+ * @outputSpec data: T | null — the query result, null on error
121
+ * @outputSpec error: any — null on success, Postgres/PostgREST error object on failure
122
+ * @calledBy used as return type annotation across all functions/*.ts handlers
123
+ *
124
+ * @example
125
+ * ```ts
126
+ * const result: DbResult<Item> = await adminDb.from('items').select('*').single()
127
+ * if (result.error) throw result.error
128
+ * return result.data!
129
+ * ```
130
+ */
131
+ export type DbResult<T> = {
132
+ data: T | null
133
+ error: any
134
+ }
135
+
136
+ // ─── JOIN HELPERS ─────────────────────────────────────────────────────────────
137
+
138
+ /**
139
+ * PostgREST relationship hint strings for all foreign keys in the public schema.
140
+ *
141
+ * These strings are interpolated into `.select()` calls to eager-load related
142
+ * records in a single query. They use explicit `!fk_column` hints to resolve
143
+ * ambiguous relationships — required when a table has multiple FKs to the same
144
+ * target table, or when the FK column name doesn't follow PostgREST's default
145
+ * `tablename_id` inference convention (e.g. `created_by` → `people.id`).
146
+ *
147
+ * Only add a join here when it is used in two or more handlers. One-off joins
148
+ * should be written inline.
149
+ *
150
+ * @inputSpec none — these are static string constants
151
+ * @outputSpec string — valid PostgREST embed expression for use in .select()
152
+ * @sideEffects none
153
+ * @calledBy types.ts, apps.ts, pipelines.ts, triggers.ts, admin-data.ts, and others
154
+ * @testUnit none — these are string constants; incorrect joins fail at runtime
155
+ * @testIntegration tests/integration/admin-data-accounts.test.ts — exercises joins.type
156
+ *
157
+ * @example
158
+ * ```ts
159
+ * import { joins } from './_shared/db'
160
+ * const { data } = await ctx.db
161
+ * .from('items')
162
+ * .select(`*, ${joins.type}, ${joins.app}`)
163
+ * // Returns items with nested type and app objects
164
+ * ```
165
+ */
166
+ export const joins = {
167
+ type: 'type:types!type_id(id, slug, name, icon, color, design_schema)',
168
+ app: 'app:apps!app_id(id, slug, name)',
169
+ ownerAccount: 'owner_account:accounts!owner_account_id(id, slug, display_name)',
170
+ createdBy: 'created_by_person:people!created_by(id, full_name, email)',
171
+ parentAccount:'parent:accounts!parent_id(id, slug, display_name)',
172
+ role: 'role:roles!role_id(id, slug, name)',
173
+ pipeline: 'pipeline:pipelines!pipeline_id(id, name)',
174
+ }