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.
- package/.framework/README.md +129 -0
- package/.framework/cli/bin.cjs +14 -0
- package/.framework/cli/commands/agents.ts +153 -0
- package/.framework/cli/commands/auth.ts +94 -0
- package/.framework/cli/commands/create-app.ts +185 -0
- package/.framework/cli/commands/dev.ts +295 -0
- package/.framework/cli/commands/doctor.ts +442 -0
- package/.framework/cli/commands/generate.ts +332 -0
- package/.framework/cli/commands/init.ts +272 -0
- package/.framework/cli/commands/install-app.ts +391 -0
- package/.framework/cli/commands/items.ts +253 -0
- package/.framework/cli/commands/migrations.ts +141 -0
- package/.framework/cli/commands/pipelines.ts +166 -0
- package/.framework/cli/commands/status.ts +197 -0
- package/.framework/cli/commands/system.ts +184 -0
- package/.framework/cli/commands/test.ts +227 -0
- package/.framework/cli/commands/uninstall-app.ts +166 -0
- package/.framework/cli/context.ts +268 -0
- package/.framework/cli/env-loader.ts +36 -0
- package/.framework/cli/index.ts +106 -0
- package/.framework/cli/welcome.cjs +45 -0
- package/.framework/docs/API.md +384 -0
- package/.framework/docs/STABILITY.md +52 -0
- package/.framework/docs/admin-routes.md +76 -0
- package/.framework/docs/api-docs-progress.md +38 -0
- package/.framework/docs/api-governance.md +146 -0
- package/.framework/docs/api-testing-results.md +212 -0
- package/.framework/docs/apis/admin-configs.md +567 -0
- package/.framework/docs/apis/admin-data.md +272 -0
- package/.framework/docs/apis/index.md +231 -0
- package/.framework/docs/apis/internal.md +295 -0
- package/.framework/docs/apis/runtime.md +537 -0
- package/.framework/docs/assembly-launch-guide.md +138 -0
- package/.framework/docs/audit-results.md +590 -0
- package/.framework/docs/authorization-model.md +170 -0
- package/.framework/docs/db-api-inventory.md +95 -0
- package/.framework/docs/examples/custom-app/README.md +77 -0
- package/.framework/docs/examples/custom-function/README.md +27 -0
- package/.framework/docs/examples/custom-function/handler.ts +48 -0
- package/.framework/docs/examples/custom-webhook/README.md +68 -0
- package/.framework/docs/gap-remediation-backlog.md +103 -0
- package/.framework/docs/guides/cli-guide.md +224 -0
- package/.framework/docs/guides/getting-started.md +103 -0
- package/.framework/docs/guides/import-guide.md +193 -0
- package/.framework/docs/guides/testing-guide.md +229 -0
- package/.framework/docs/permission-examples.md +326 -0
- package/.framework/docs/ui-adoption-verification.md +111 -0
- package/.framework/docs/ui-api-coverage.md +84 -0
- package/.framework/docs/v2-compatibility-audit.md +228 -0
- package/.framework/functions/.gitkeep +1 -0
- package/.framework/functions/_shared/agent-runner.ts +1097 -0
- package/.framework/functions/_shared/app-manifest.ts +184 -0
- package/.framework/functions/_shared/audit.ts +150 -0
- package/.framework/functions/_shared/db.ts +174 -0
- package/.framework/functions/_shared/index.ts +382 -0
- package/.framework/functions/_shared/middleware.ts +490 -0
- package/.framework/functions/_shared/permissions.ts +1325 -0
- package/.framework/functions/_shared/pipeline-runner.ts +731 -0
- package/.framework/functions/_shared/principal.ts +760 -0
- package/.framework/functions/_shared/schema-utils.ts +967 -0
- package/.framework/functions/_shared/testing.ts +258 -0
- package/.framework/functions/_shared/trigger-engine.ts +425 -0
- package/.framework/functions/_shared/webhook-registration.ts +168 -0
- package/.framework/functions/_shared/webhook-registry.ts +129 -0
- package/.framework/functions/account-nodes.ts +111 -0
- package/.framework/functions/admin-data.ts +606 -0
- package/.framework/functions/ai-agents.ts +323 -0
- package/.framework/functions/api-keys.ts +376 -0
- package/.framework/functions/apps.ts +483 -0
- package/.framework/functions/auth.ts +196 -0
- package/.framework/functions/debug-auth.ts +107 -0
- package/.framework/functions/embeddings.ts +556 -0
- package/.framework/functions/integration-routes.ts +523 -0
- package/.framework/functions/integrations.ts +319 -0
- package/.framework/functions/item-progress.ts +272 -0
- package/.framework/functions/logs.ts +438 -0
- package/.framework/functions/observability.ts +275 -0
- package/.framework/functions/pipeline-executions.ts +494 -0
- package/.framework/functions/pipelines.ts +485 -0
- package/.framework/functions/prompt-configs.ts +339 -0
- package/.framework/functions/roles.ts +387 -0
- package/.framework/functions/system-cron.ts +742 -0
- package/.framework/functions/system.ts +323 -0
- package/.framework/functions/tests.ts +119 -0
- package/.framework/functions/timers.ts +357 -0
- package/.framework/functions/triggers.ts +563 -0
- package/.framework/functions/types.ts +604 -0
- package/.framework/migrations/000_foundation.sql +1256 -0
- package/.framework/migrations/001_seed.sql +92 -0
- package/.framework/migrations/002_seed_constraints.sql +13 -0
- package/.framework/migrations/003_auth_user_trigger.sql +59 -0
- package/.framework/src/App.tsx +126 -0
- package/.framework/src/apps/admin/index.tsx +173 -0
- package/.framework/src/components/AppWrapper.tsx +56 -0
- package/.framework/src/components/CustomAppLoader.tsx +116 -0
- package/.framework/src/components/admin/AdminListPage.tsx +151 -0
- package/.framework/src/components/admin/AdminSidebar.tsx +166 -0
- package/.framework/src/components/admin/AdminStatsCard.tsx +62 -0
- package/.framework/src/components/admin/SortableTableHeader.tsx +42 -0
- package/.framework/src/components/app-shell/GenericAppShell.tsx +181 -0
- package/.framework/src/components/app-shell/GenericDetailPage.tsx +200 -0
- package/.framework/src/components/app-shell/GenericListPage.tsx +116 -0
- package/.framework/src/components/app-sidebar.tsx +228 -0
- package/.framework/src/components/auth/ProtectedRoute.tsx +88 -0
- package/.framework/src/components/layout/AppShell.tsx +91 -0
- package/.framework/src/components/layout/Header.tsx +88 -0
- package/.framework/src/components/layout/Layout.tsx +95 -0
- package/.framework/src/components/layout/Sidebar.tsx +329 -0
- package/.framework/src/components/runtime/DataDetailHeader.tsx +77 -0
- package/.framework/src/components/runtime/DataDetailPage.tsx +171 -0
- package/.framework/src/components/runtime/DataFilters.tsx +91 -0
- package/.framework/src/components/runtime/DataHeader.tsx +68 -0
- package/.framework/src/components/runtime/DataListPage.tsx +124 -0
- package/.framework/src/components/runtime/DataStats.tsx +70 -0
- package/.framework/src/components/runtime/DataTable.tsx +174 -0
- package/.framework/src/components/runtime/SchemaDetailForm.tsx +134 -0
- package/.framework/src/components/runtime/index.ts +18 -0
- package/.framework/src/components/search-form.tsx +29 -0
- package/.framework/src/components/shared/AgentView.tsx +213 -0
- package/.framework/src/components/shared/FieldRenderer.tsx +478 -0
- package/.framework/src/components/shared/SchemaFields.tsx +226 -0
- package/.framework/src/components/ui/DataTable.tsx +343 -0
- package/.framework/src/components/ui/Form.tsx +281 -0
- package/.framework/src/components/ui/ItemCard.tsx +296 -0
- package/.framework/src/components/ui/ItemListView.tsx +308 -0
- package/.framework/src/components/ui/LoadingSpinner.tsx +52 -0
- package/.framework/src/components/ui/Modal.tsx +61 -0
- package/.framework/src/components/ui/RichTextEditor.tsx +210 -0
- package/.framework/src/components/ui/accordion.tsx +82 -0
- package/.framework/src/components/ui/alert-dialog.tsx +197 -0
- package/.framework/src/components/ui/alert.tsx +76 -0
- package/.framework/src/components/ui/aspect-ratio.tsx +11 -0
- package/.framework/src/components/ui/avatar.tsx +110 -0
- package/.framework/src/components/ui/badge.tsx +49 -0
- package/.framework/src/components/ui/breadcrumb.tsx +122 -0
- package/.framework/src/components/ui/button-group.tsx +83 -0
- package/.framework/src/components/ui/button.tsx +65 -0
- package/.framework/src/components/ui/calendar.tsx +222 -0
- package/.framework/src/components/ui/card.tsx +100 -0
- package/.framework/src/components/ui/carousel.tsx +240 -0
- package/.framework/src/components/ui/chart.tsx +373 -0
- package/.framework/src/components/ui/checkbox.tsx +31 -0
- package/.framework/src/components/ui/collapsible.tsx +33 -0
- package/.framework/src/components/ui/combobox.tsx +299 -0
- package/.framework/src/components/ui/command.tsx +193 -0
- package/.framework/src/components/ui/context-menu.tsx +261 -0
- package/.framework/src/components/ui/dialog.tsx +165 -0
- package/.framework/src/components/ui/direction.tsx +22 -0
- package/.framework/src/components/ui/drawer.tsx +132 -0
- package/.framework/src/components/ui/dropdown-menu.tsx +269 -0
- package/.framework/src/components/ui/empty.tsx +104 -0
- package/.framework/src/components/ui/field.tsx +238 -0
- package/.framework/src/components/ui/hover-card.tsx +42 -0
- package/.framework/src/components/ui/input-group.tsx +153 -0
- package/.framework/src/components/ui/input-otp.tsx +87 -0
- package/.framework/src/components/ui/input.tsx +19 -0
- package/.framework/src/components/ui/item.tsx +196 -0
- package/.framework/src/components/ui/kbd.tsx +26 -0
- package/.framework/src/components/ui/label.tsx +22 -0
- package/.framework/src/components/ui/menubar.tsx +277 -0
- package/.framework/src/components/ui/native-select.tsx +61 -0
- package/.framework/src/components/ui/navigation-menu.tsx +164 -0
- package/.framework/src/components/ui/pagination.tsx +129 -0
- package/.framework/src/components/ui/popover.tsx +87 -0
- package/.framework/src/components/ui/progress.tsx +31 -0
- package/.framework/src/components/ui/radio-group.tsx +42 -0
- package/.framework/src/components/ui/resizable.tsx +50 -0
- package/.framework/src/components/ui/scroll-area.tsx +53 -0
- package/.framework/src/components/ui/select.tsx +195 -0
- package/.framework/src/components/ui/separator.tsx +26 -0
- package/.framework/src/components/ui/sheet.tsx +145 -0
- package/.framework/src/components/ui/sidebar.tsx +706 -0
- package/.framework/src/components/ui/skeleton.tsx +13 -0
- package/.framework/src/components/ui/slider.tsx +59 -0
- package/.framework/src/components/ui/sonner.tsx +47 -0
- package/.framework/src/components/ui/spinner.tsx +10 -0
- package/.framework/src/components/ui/switch.tsx +33 -0
- package/.framework/src/components/ui/table-primitives.tsx +141 -0
- package/.framework/src/components/ui/table.tsx +114 -0
- package/.framework/src/components/ui/tabs.tsx +90 -0
- package/.framework/src/components/ui/textarea.tsx +18 -0
- package/.framework/src/components/ui/toggle-group.tsx +89 -0
- package/.framework/src/components/ui/toggle.tsx +45 -0
- package/.framework/src/components/ui/tooltip.tsx +57 -0
- package/.framework/src/contexts/AppContext.tsx +133 -0
- package/.framework/src/contexts/AuthContext.tsx +371 -0
- package/.framework/src/hooks/use-mobile.ts +19 -0
- package/.framework/src/hooks/useApi.ts +526 -0
- package/.framework/src/hooks/useApps.ts +114 -0
- package/.framework/src/hooks/useEntityList.ts +190 -0
- package/.framework/src/hooks/useEntityRecord.ts +308 -0
- package/.framework/src/hooks/useForm.ts +307 -0
- package/.framework/src/hooks/useListSchema.ts +264 -0
- package/.framework/src/hooks/useSchemaRecord.ts +223 -0
- package/.framework/src/index.css +128 -0
- package/.framework/src/lib/api.ts +156 -0
- package/.framework/src/lib/supabase.ts +94 -0
- package/.framework/src/lib/utils.ts +317 -0
- package/.framework/src/main.tsx +27 -0
- package/.framework/src/pages/DashboardPage.tsx +181 -0
- package/.framework/src/pages/NotFoundPage.tsx +39 -0
- package/.framework/src/pages/admin/AIAgentDetailPage.tsx +161 -0
- package/.framework/src/pages/admin/AIAgentsPage.tsx +318 -0
- package/.framework/src/pages/admin/APIKeyDetailPage.tsx +199 -0
- package/.framework/src/pages/admin/APIKeysPage.tsx +303 -0
- package/.framework/src/pages/admin/AlertsConfigPage.tsx +523 -0
- package/.framework/src/pages/admin/AppDetailPage.tsx +493 -0
- package/.framework/src/pages/admin/AppsPage.tsx +355 -0
- package/.framework/src/pages/admin/DesignedPage.tsx +491 -0
- package/.framework/src/pages/admin/EmbeddingDetailPage.tsx +534 -0
- package/.framework/src/pages/admin/EmbeddingsPage.tsx +424 -0
- package/.framework/src/pages/admin/ExtendedShadcnTestPage.tsx +176 -0
- package/.framework/src/pages/admin/IncrementalShadcnTestPage.tsx +109 -0
- package/.framework/src/pages/admin/IntegratedDashboard.tsx +402 -0
- package/.framework/src/pages/admin/IntegrationDetailPage.tsx +187 -0
- package/.framework/src/pages/admin/IntegrationsPage.tsx +301 -0
- package/.framework/src/pages/admin/LogsPage.tsx +283 -0
- package/.framework/src/pages/admin/MinimalShadcnTestPage.tsx +85 -0
- package/.framework/src/pages/admin/ObservabilityDashboard.tsx +470 -0
- package/.framework/src/pages/admin/PipelineDetailPage.tsx +183 -0
- package/.framework/src/pages/admin/PipelineExecutionsPage.tsx +279 -0
- package/.framework/src/pages/admin/PipelinesPage.tsx +390 -0
- package/.framework/src/pages/admin/PromptConfigDetailPage.tsx +299 -0
- package/.framework/src/pages/admin/PromptConfigsPage.tsx +292 -0
- package/.framework/src/pages/admin/ProperlyDesignedPage.tsx +434 -0
- package/.framework/src/pages/admin/RoleDetailPage.tsx +273 -0
- package/.framework/src/pages/admin/RolesPage.tsx +292 -0
- package/.framework/src/pages/admin/SelectTestPage.tsx +61 -0
- package/.framework/src/pages/admin/ShadcnTestPage.tsx +588 -0
- package/.framework/src/pages/admin/SimpleDashboard.tsx +387 -0
- package/.framework/src/pages/admin/TestRunDetailPage.tsx +172 -0
- package/.framework/src/pages/admin/TestingDashboard.tsx +257 -0
- package/.framework/src/pages/admin/TimerDetailPage.tsx +151 -0
- package/.framework/src/pages/admin/TimersPage.tsx +376 -0
- package/.framework/src/pages/admin/TriggerDetailPage.tsx +149 -0
- package/.framework/src/pages/admin/TriggersPage.tsx +381 -0
- package/.framework/src/pages/admin/TypeDetailPage.tsx +694 -0
- package/.framework/src/pages/admin/TypesPage.tsx +295 -0
- package/.framework/src/pages/auth/LoginPage.tsx +188 -0
- package/.framework/src/pages/auth/RegisterPage.tsx +163 -0
- package/.framework/src/pages/spine-framework/APIPage.tsx +17 -0
- package/.framework/src/pages/spine-framework/CLIPage.tsx +25 -0
- package/.framework/src/types/auth.ts +125 -0
- package/.framework/src/types/types.ts +407 -0
- package/STRUCTURE.md +150 -0
- package/config/components.json +25 -0
- package/config/deno.lock +108 -0
- package/config/package-lock.json +17183 -0
- package/config/postcss.config.cjs +10 -0
- package/config/tailwind.config.cjs +78 -0
- package/config/tsconfig.build.json +32 -0
- package/config/tsconfig.cli.json +18 -0
- package/config/tsconfig.json +41 -0
- package/config/tsconfig.node.json +17 -0
- package/config/tsconfig.node.tsbuildinfo +1 -0
- package/config/tsconfig.tsbuildinfo +1 -0
- package/config/typedoc.json +16 -0
- package/config/vite.config.d.ts +2 -0
- package/config/vite.config.ts +72 -0
- package/dist/cli/commands/agents.d.ts +39 -0
- package/dist/cli/commands/agents.d.ts.map +1 -0
- package/dist/cli/commands/auth.d.ts +36 -0
- package/dist/cli/commands/auth.d.ts.map +1 -0
- package/dist/cli/commands/create-app.d.ts +23 -0
- package/dist/cli/commands/create-app.d.ts.map +1 -0
- package/dist/cli/commands/dev.d.ts +39 -0
- package/dist/cli/commands/dev.d.ts.map +1 -0
- package/dist/cli/commands/doctor.d.ts +42 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/generate.d.ts +36 -0
- package/dist/cli/commands/generate.d.ts.map +1 -0
- package/dist/cli/commands/init.d.ts +30 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/install-app.d.ts +30 -0
- package/dist/cli/commands/install-app.d.ts.map +1 -0
- package/dist/cli/commands/items.d.ts +45 -0
- package/dist/cli/commands/items.d.ts.map +1 -0
- package/dist/cli/commands/migrations.d.ts +41 -0
- package/dist/cli/commands/migrations.d.ts.map +1 -0
- package/dist/cli/commands/pipelines.d.ts +40 -0
- package/dist/cli/commands/pipelines.d.ts.map +1 -0
- package/dist/cli/commands/status.d.ts +23 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/system.d.ts +29 -0
- package/dist/cli/commands/system.d.ts.map +1 -0
- package/dist/cli/commands/test.d.ts +46 -0
- package/dist/cli/commands/test.d.ts.map +1 -0
- package/dist/cli/commands/uninstall-app.d.ts +23 -0
- package/dist/cli/commands/uninstall-app.d.ts.map +1 -0
- package/dist/cli/context.d.ts +88 -0
- package/dist/cli/context.d.ts.map +1 -0
- package/dist/cli/env-loader.d.ts +14 -0
- package/dist/cli/env-loader.d.ts.map +1 -0
- package/dist/cli/index.d.ts +41 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/functions/_shared/agent-runner.d.ts +156 -0
- package/dist/functions/_shared/agent-runner.d.ts.map +1 -0
- package/dist/functions/_shared/app-manifest.d.ts +68 -0
- package/dist/functions/_shared/app-manifest.d.ts.map +1 -0
- package/dist/functions/_shared/audit.d.ts +91 -0
- package/dist/functions/_shared/audit.d.ts.map +1 -0
- package/dist/functions/_shared/db.d.ts +125 -0
- package/dist/functions/_shared/db.d.ts.map +1 -0
- package/dist/functions/_shared/index.d.ts +298 -0
- package/dist/functions/_shared/index.d.ts.map +1 -0
- package/dist/functions/_shared/middleware.d.ts +315 -0
- package/dist/functions/_shared/middleware.d.ts.map +1 -0
- package/dist/functions/_shared/permissions.d.ts +626 -0
- package/dist/functions/_shared/permissions.d.ts.map +1 -0
- package/dist/functions/_shared/pipeline-runner.d.ts +124 -0
- package/dist/functions/_shared/pipeline-runner.d.ts.map +1 -0
- package/dist/functions/_shared/principal.d.ts +284 -0
- package/dist/functions/_shared/principal.d.ts.map +1 -0
- package/dist/functions/_shared/schema-utils.d.ts +181 -0
- package/dist/functions/_shared/schema-utils.d.ts.map +1 -0
- package/dist/functions/_shared/testing.d.ts +172 -0
- package/dist/functions/_shared/testing.d.ts.map +1 -0
- package/dist/functions/_shared/trigger-engine.d.ts +140 -0
- package/dist/functions/_shared/trigger-engine.d.ts.map +1 -0
- package/dist/functions/_shared/webhook-registration.d.ts +81 -0
- package/dist/functions/_shared/webhook-registration.d.ts.map +1 -0
- package/dist/functions/_shared/webhook-registry.d.ts +57 -0
- package/dist/functions/_shared/webhook-registry.d.ts.map +1 -0
- package/dist/functions/account-nodes.d.ts +48 -0
- package/dist/functions/account-nodes.d.ts.map +1 -0
- package/dist/functions/admin-data.d.ts +178 -0
- package/dist/functions/admin-data.d.ts.map +1 -0
- package/dist/functions/ai-agents.d.ts +125 -0
- package/dist/functions/ai-agents.d.ts.map +1 -0
- package/dist/functions/api-keys.d.ts +140 -0
- package/dist/functions/api-keys.d.ts.map +1 -0
- package/dist/functions/apps.d.ts +163 -0
- package/dist/functions/apps.d.ts.map +1 -0
- package/dist/functions/auth.d.ts +74 -0
- package/dist/functions/auth.d.ts.map +1 -0
- package/dist/functions/debug-auth.d.ts +33 -0
- package/dist/functions/debug-auth.d.ts.map +1 -0
- package/dist/functions/embeddings.d.ts +205 -0
- package/dist/functions/embeddings.d.ts.map +1 -0
- package/dist/functions/integration-routes.d.ts +45 -0
- package/dist/functions/integration-routes.d.ts.map +1 -0
- package/dist/functions/integrations.d.ts +124 -0
- package/dist/functions/integrations.d.ts.map +1 -0
- package/dist/functions/item-progress.d.ts +41 -0
- package/dist/functions/item-progress.d.ts.map +1 -0
- package/dist/functions/logs.d.ts +162 -0
- package/dist/functions/logs.d.ts.map +1 -0
- package/dist/functions/observability.d.ts +123 -0
- package/dist/functions/observability.d.ts.map +1 -0
- package/dist/functions/pipeline-executions.d.ts +190 -0
- package/dist/functions/pipeline-executions.d.ts.map +1 -0
- package/dist/functions/pipelines.d.ts +171 -0
- package/dist/functions/pipelines.d.ts.map +1 -0
- package/dist/functions/prompt-configs.d.ts +125 -0
- package/dist/functions/prompt-configs.d.ts.map +1 -0
- package/dist/functions/roles.d.ts +118 -0
- package/dist/functions/roles.d.ts.map +1 -0
- package/dist/functions/system-cron.d.ts +65 -0
- package/dist/functions/system-cron.d.ts.map +1 -0
- package/dist/functions/system.d.ts +29 -0
- package/dist/functions/system.d.ts.map +1 -0
- package/dist/functions/tests.d.ts +28 -0
- package/dist/functions/tests.d.ts.map +1 -0
- package/dist/functions/timers.d.ts +139 -0
- package/dist/functions/timers.d.ts.map +1 -0
- package/dist/functions/triggers.d.ts +203 -0
- package/dist/functions/triggers.d.ts.map +1 -0
- package/dist/functions/types.d.ts +151 -0
- package/dist/functions/types.d.ts.map +1 -0
- package/dist/src/types/types.d.ts +364 -0
- package/dist/src/types/types.d.ts.map +1 -0
- package/package.json +192 -0
- package/scripts/app-install-cli.ts +286 -0
- package/scripts/assemble-frontend.sh +79 -0
- package/scripts/assemble-functions.sh +62 -0
- package/scripts/assemble.sh +35 -0
- package/scripts/boundary-check.sh +106 -0
- package/scripts/build-manifest.sh +80 -0
- package/scripts/check-core-integrity.sh +82 -0
- package/scripts/ingest-chunks.cjs +202 -0
- package/scripts/kb-chunk-parser.cjs +312 -0
- package/scripts/kb-chunk-parser.ts +330 -0
- package/scripts/load-test-app-install.ts +484 -0
- package/scripts/netlify-dev-wrapper.sh +22 -0
- package/scripts/verify-integrity.sh +69 -0
|
@@ -0,0 +1,590 @@
|
|
|
1
|
+
# Spine v2 — Two-Pass Codebase Audit Results
|
|
2
|
+
|
|
3
|
+
Generated: 2026-04-26
|
|
4
|
+
Auditor: Cascade (automated trace + sweep)
|
|
5
|
+
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## Summary
|
|
9
|
+
|
|
10
|
+
- **Live frontend files:** 78 (all files in `v2-core/src/`)
|
|
11
|
+
- **Live function files:** 18 handlers + 6 shared files
|
|
12
|
+
- **Orphaned / dead files:** 11 identified
|
|
13
|
+
- **Legacy candidates:** 8 identified
|
|
14
|
+
- **Tables required by live code:** 21 distinct tables
|
|
15
|
+
- **RPC functions required:** 8 distinct RPCs
|
|
16
|
+
- **Hardcoded values found:** 0 in source (schema targets `v2` — see note)
|
|
17
|
+
- **Duplicate migration prefix:** 1 (`047`)
|
|
18
|
+
- **Critical note:** ALL code targets the `v2` schema, NOT `public`. Day-zero migrations must use `v2` schema OR code must be updated to use `public`.
|
|
19
|
+
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
## Live Set
|
|
23
|
+
|
|
24
|
+
### Frontend Entry Chain (`v2-core/src/`)
|
|
25
|
+
|
|
26
|
+
**Entry:** `main.tsx` → `App.tsx`
|
|
27
|
+
|
|
28
|
+
#### Core files (always live)
|
|
29
|
+
- `main.tsx`
|
|
30
|
+
- `App.tsx`
|
|
31
|
+
- `index.css`
|
|
32
|
+
- `contexts/AuthContext.tsx`
|
|
33
|
+
- `types/types.ts`
|
|
34
|
+
- `types/auth.ts`
|
|
35
|
+
- `lib/` (all files)
|
|
36
|
+
|
|
37
|
+
#### Layout
|
|
38
|
+
- `components/layout/Layout.tsx`
|
|
39
|
+
- `components/layout/Header.tsx`
|
|
40
|
+
- `components/layout/Sidebar.tsx`
|
|
41
|
+
|
|
42
|
+
#### Auth
|
|
43
|
+
- `components/auth/ProtectedRoute.tsx`
|
|
44
|
+
- `pages/auth/LoginPage.tsx`
|
|
45
|
+
|
|
46
|
+
#### Pages
|
|
47
|
+
- `pages/DashboardPage.tsx`
|
|
48
|
+
- `pages/NotFoundPage.tsx`
|
|
49
|
+
- `pages/admin/TypesPage.tsx`
|
|
50
|
+
- `pages/admin/TypeDetailPage.tsx`
|
|
51
|
+
- `pages/admin/AppsPage.tsx`
|
|
52
|
+
- `pages/admin/AppDetailPage.tsx`
|
|
53
|
+
- `pages/admin/PipelinesPage.tsx`
|
|
54
|
+
- `pages/admin/PipelineDetailPage.tsx`
|
|
55
|
+
- `pages/admin/TriggersPage.tsx`
|
|
56
|
+
- `pages/admin/TriggerDetailPage.tsx`
|
|
57
|
+
- `pages/admin/AIAgentsPage.tsx`
|
|
58
|
+
- `pages/admin/AIAgentDetailPage.tsx`
|
|
59
|
+
- `pages/admin/EmbeddingsPage.tsx`
|
|
60
|
+
- `pages/admin/EmbeddingDetailPage.tsx`
|
|
61
|
+
- `pages/admin/TimersPage.tsx`
|
|
62
|
+
- `pages/admin/TimerDetailPage.tsx`
|
|
63
|
+
- `pages/admin/IntegrationsPage.tsx`
|
|
64
|
+
- `pages/admin/IntegrationDetailPage.tsx`
|
|
65
|
+
- `pages/admin/AccountTypesPage.tsx`
|
|
66
|
+
- `pages/admin/AccountTypeDetailPage.tsx`
|
|
67
|
+
- `pages/admin/PersonTypesPage.tsx`
|
|
68
|
+
- `pages/admin/PersonTypeDetailPage.tsx`
|
|
69
|
+
- `pages/admin/RolesPage.tsx`
|
|
70
|
+
- `pages/admin/RoleDetailPage.tsx`
|
|
71
|
+
- `pages/admin/ThreadTypesPage.tsx`
|
|
72
|
+
- `pages/admin/MessageTypesPage.tsx`
|
|
73
|
+
- `pages/admin/AttachmentTypesPage.tsx`
|
|
74
|
+
- `pages/admin/PromptConfigsPage.tsx`
|
|
75
|
+
- `pages/admin/PromptConfigDetailPage.tsx`
|
|
76
|
+
- `pages/admin/APIKeysPage.tsx`
|
|
77
|
+
- `pages/admin/APIKeyDetailPage.tsx`
|
|
78
|
+
- `pages/admin/PipelineExecutionsPage.tsx`
|
|
79
|
+
- `pages/admin/LogsPage.tsx`
|
|
80
|
+
|
|
81
|
+
#### Runtime components (live — routed via `DataListPage` / `DataDetailPage`)
|
|
82
|
+
- `components/runtime/DataListPage.tsx`
|
|
83
|
+
- `components/runtime/DataDetailPage.tsx`
|
|
84
|
+
- `components/runtime/DataTable.tsx`
|
|
85
|
+
- `components/runtime/DataStats.tsx`
|
|
86
|
+
- `components/runtime/DataFilters.tsx`
|
|
87
|
+
- `components/runtime/DataHeader.tsx`
|
|
88
|
+
- `components/runtime/DataDetailHeader.tsx`
|
|
89
|
+
- `components/runtime/SchemaDetailForm.tsx`
|
|
90
|
+
- `components/runtime/index.ts`
|
|
91
|
+
|
|
92
|
+
#### Shared components
|
|
93
|
+
- `components/shared/FieldRenderer.tsx`
|
|
94
|
+
- `components/shared/SchemaFields.tsx`
|
|
95
|
+
|
|
96
|
+
#### Admin components
|
|
97
|
+
- `components/admin/AdminListPage.tsx`
|
|
98
|
+
- `components/admin/AdminStatsCard.tsx`
|
|
99
|
+
- `components/admin/SortableTableHeader.tsx`
|
|
100
|
+
|
|
101
|
+
#### Hooks
|
|
102
|
+
- `hooks/useApi.ts`
|
|
103
|
+
- `hooks/useEntityList.ts`
|
|
104
|
+
- `hooks/useEntityRecord.ts`
|
|
105
|
+
- `hooks/useForm.ts`
|
|
106
|
+
- `hooks/useListSchema.ts`
|
|
107
|
+
- `hooks/useSchemaRecord.ts`
|
|
108
|
+
|
|
109
|
+
### Live Functions (`v2-core/functions/`)
|
|
110
|
+
|
|
111
|
+
All 18 handlers are reachable from `netlify.toml [functions] directory = "v2-core/functions"`:
|
|
112
|
+
|
|
113
|
+
| Handler | Tables accessed |
|
|
114
|
+
|---|---|
|
|
115
|
+
| `admin-data.ts` | accounts, people, items, threads, messages, links, attachments, watchers, types |
|
|
116
|
+
| `types.ts` | types, accounts, apps |
|
|
117
|
+
| `roles.ts` | roles, apps |
|
|
118
|
+
| `apps.ts` | apps, accounts |
|
|
119
|
+
| `auth.ts` | people, accounts, roles |
|
|
120
|
+
| `pipelines.ts` | pipelines, pipeline_executions, apps, people |
|
|
121
|
+
| `pipeline-executions.ts` | pipeline_executions, pipelines, people |
|
|
122
|
+
| `triggers.ts` | triggers, trigger_executions, apps, people |
|
|
123
|
+
| `timers.ts` | timers, apps, people |
|
|
124
|
+
| `ai-agents.ts` | ai_agents, apps, people |
|
|
125
|
+
| `embeddings.ts` | embeddings |
|
|
126
|
+
| `integrations.ts` | integrations, apps, people |
|
|
127
|
+
| `logs.ts` | logs |
|
|
128
|
+
| `prompt-configs.ts` | prompt_configs, apps, people |
|
|
129
|
+
| `api-keys.ts` | api_keys, api_key_usage_logs, integrations, people |
|
|
130
|
+
| `account-nodes.ts` | accounts, types |
|
|
131
|
+
| `debug-auth.ts` | (no DB — JWT debug only) |
|
|
132
|
+
| `system-cron.ts` | actions, api_keys, schedule_executions (via `adminDb.rpc`) |
|
|
133
|
+
|
|
134
|
+
### Live `_shared/` Files
|
|
135
|
+
|
|
136
|
+
All 6 are imported by live handlers:
|
|
137
|
+
- `_shared/db.ts` — Supabase clients, `joins` constants
|
|
138
|
+
- `_shared/middleware.ts` — `createHandler`, `RequestContext`
|
|
139
|
+
- `_shared/permissions.ts` — `PermissionEngine`, `sanitizeRecordData`
|
|
140
|
+
- `_shared/principal.ts` — `resolvePrincipal`, `getPrincipalDb`
|
|
141
|
+
- `_shared/audit.ts` — `emitLog`, `emitAudit`
|
|
142
|
+
- `_shared/schema-utils.ts` — `generateValidationSchema` (used by `types.ts`)
|
|
143
|
+
|
|
144
|
+
### Live Scripts
|
|
145
|
+
|
|
146
|
+
| Script | Status | Called by |
|
|
147
|
+
|---|---|---|
|
|
148
|
+
| `scripts/netlify-dev-wrapper.sh` | ✅ Live | `netlify.toml [dev].command` |
|
|
149
|
+
| `scripts/assemble-v2.sh` | ✅ Live | `package.json` prebuild |
|
|
150
|
+
| `scripts/assemble-v2-functions.sh` | ✅ Live | `assemble-v2.sh` |
|
|
151
|
+
| `scripts/assemble-v2-frontend.sh` | ✅ Live | `assemble-v2.sh` |
|
|
152
|
+
| `scripts/assemble-v2-custom.sh` | ✅ Live | `assemble-v2.sh` |
|
|
153
|
+
| `scripts/build-manifest.sh` | ✅ Live | `package.json` prebuild |
|
|
154
|
+
| `scripts/verify-integrity.sh` | ✅ Live | `package.json` prebuild |
|
|
155
|
+
|
|
156
|
+
---
|
|
157
|
+
|
|
158
|
+
## Orphaned Files
|
|
159
|
+
|
|
160
|
+
These files exist but nothing in the live code path imports or routes to them:
|
|
161
|
+
|
|
162
|
+
| File | Reason |
|
|
163
|
+
|---|---|
|
|
164
|
+
| `v2-core/src/pages/admin/AccountDetailPage.tsx.new` | Zero-byte file with `.new` extension — artifact |
|
|
165
|
+
| `v2-core/x-netlify-functions/` (entire dir, 40 files) | Legacy function snapshot — no live code imports from here; superseded by `v2-core/functions/` |
|
|
166
|
+
| `v2-core/functions/schema-utils.ts` *(if exists at root)* | Confirm — `schema-utils` lives in `_shared/`; any root-level copy is orphaned |
|
|
167
|
+
| `scripts/assemble-apps.sh` | Not called by any live script |
|
|
168
|
+
| `scripts/assemble-apps-simple.sh` | Not called by any live script |
|
|
169
|
+
| `scripts/assemble-frontend.sh` | v1-era script, superseded by `assemble-v2-frontend.sh` |
|
|
170
|
+
| `scripts/assemble-functions.sh` | v1-era script, superseded by `assemble-v2-functions.sh` |
|
|
171
|
+
| `scripts/quarantine-legacy.sh` | One-time-use script, no longer needed |
|
|
172
|
+
| `scripts/app-install-cli.ts` | Not called by any live script or route |
|
|
173
|
+
| `scripts/load-test-app-install.ts` | Test/dev script, not part of any build chain |
|
|
174
|
+
| `_quarantine/` (entire dir) | All contents are retired artifacts — no imports anywhere |
|
|
175
|
+
|
|
176
|
+
---
|
|
177
|
+
|
|
178
|
+
## Legacy Candidates
|
|
179
|
+
|
|
180
|
+
Files that contain references to old patterns, deleted tables, or v1-era architecture:
|
|
181
|
+
|
|
182
|
+
| File | Issue |
|
|
183
|
+
|---|---|
|
|
184
|
+
| `v2-core/migrations/047_provisioning.sql` | Duplicate `047_` prefix — conflicts with `047_simplify_auth_model.sql`; migration order is ambiguous on fresh install |
|
|
185
|
+
| `v2-core/migrations/047_simplify_auth_model.sql` | Same duplicate prefix issue |
|
|
186
|
+
| `v2-core/src/App.tsx` lines 376–390 | Legacy redirect routes (`/admin/data/:entity` → `/admin/runtime/:entity`) — safe to keep short-term but dead routes |
|
|
187
|
+
| `v2-core/docs/` (various .md files) | Contains stale audit reports, gap-remediation notes referencing old state — not harmful, but stale |
|
|
188
|
+
| `v2-core/fix-functions.sh` | One-off fix script at `v2-core/` root — purpose served, should be deleted |
|
|
189
|
+
| `v2-core/.windsurf/` | Unknown contents — confirm empty or remove |
|
|
190
|
+
| `v2-core/.vscode/` | Editor config — OK to keep, but confirm not containing hardcoded values |
|
|
191
|
+
| `v2-core/README.md` | May reference old architecture — needs refresh for clean install |
|
|
192
|
+
|
|
193
|
+
---
|
|
194
|
+
|
|
195
|
+
## DB: Code→Table Map
|
|
196
|
+
|
|
197
|
+
> **CRITICAL:** `db.ts` connects to schema `v2` (not `public`). Day-zero migrations must either:
|
|
198
|
+
> (a) Create tables in the `v2` schema, OR
|
|
199
|
+
> (b) Update `db.ts` to use `schema: 'public'`
|
|
200
|
+
> This decision must be made before writing migration files.
|
|
201
|
+
|
|
202
|
+
---
|
|
203
|
+
|
|
204
|
+
### Table: `accounts`
|
|
205
|
+
```
|
|
206
|
+
columns used: id, slug, display_name, is_active, parent_id, type_id, owner_account_id
|
|
207
|
+
FKs: parent_id → accounts.id
|
|
208
|
+
type_id → types.id
|
|
209
|
+
owner_account_id → accounts.id
|
|
210
|
+
joins: type:types!type_id, parent:accounts!parent_id, owner_account:accounts!owner_account_id
|
|
211
|
+
accessed by: admin-data.ts (ctx.db + adminDb), auth.ts (ctx.db), types.ts (adminDb), account-nodes.ts (ctx.db)
|
|
212
|
+
RLS required: yes (account hierarchy filtering)
|
|
213
|
+
RPCs: get_account_hierarchy(parent_account_id), get_account_ancestors(account_id),
|
|
214
|
+
get_account_descendants(account_id), get_account_apps(account_id, include_system, include_inactive)
|
|
215
|
+
```
|
|
216
|
+
|
|
217
|
+
### Table: `people`
|
|
218
|
+
```
|
|
219
|
+
columns used: id, email, full_name, avatar_url, account_id, role_id, is_active
|
|
220
|
+
FKs: account_id → accounts.id
|
|
221
|
+
role_id → roles.id
|
|
222
|
+
joins: account:accounts!people_account_id_fkey, role:roles
|
|
223
|
+
accessed by: auth.ts (ctx.db), admin-data.ts (ctx.db), pipeline-executions.ts (join),
|
|
224
|
+
prompt-configs.ts (join), api-keys.ts (join), ai-agents.ts (join),
|
|
225
|
+
triggers.ts (join), timers.ts (join), pipelines.ts (join), integrations.ts (join)
|
|
226
|
+
RLS required: yes
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
### Table: `types`
|
|
230
|
+
```
|
|
231
|
+
columns used: id, slug, name, kind, description, icon, color, app_id, is_active,
|
|
232
|
+
design_schema, validation_schema, ownership
|
|
233
|
+
FKs: app_id → apps.id
|
|
234
|
+
joins: app:apps!app_id
|
|
235
|
+
accessed by: types.ts (ctx.db + adminDb), admin-data.ts (adminDb — type lookup for items),
|
|
236
|
+
account-nodes.ts (join on accounts)
|
|
237
|
+
RLS required: yes
|
|
238
|
+
RPCs: get_type_schema(kind, slug, app_id)
|
|
239
|
+
```
|
|
240
|
+
|
|
241
|
+
### Table: `apps`
|
|
242
|
+
```
|
|
243
|
+
columns used: id, slug, name, description, icon, color, version, app_type, source,
|
|
244
|
+
owner_account_id, config, nav_items, min_role, integration_deps, metadata,
|
|
245
|
+
is_active, is_system
|
|
246
|
+
FKs: owner_account_id → accounts.id
|
|
247
|
+
joins: owner_account:accounts!owner_account_id
|
|
248
|
+
accessed by: apps.ts (ctx.db), types.ts (adminDb), roles.ts (ctx.db),
|
|
249
|
+
pipelines.ts (join), triggers.ts (join), timers.ts (join),
|
|
250
|
+
ai-agents.ts (join), integrations.ts (join), prompt-configs.ts (join)
|
|
251
|
+
RLS required: yes
|
|
252
|
+
RPCs: get_account_apps(account_id, include_system, include_inactive),
|
|
253
|
+
get_app_schema(app_slug),
|
|
254
|
+
is_app_available(app_slug, account_id),
|
|
255
|
+
update_app_version(app_id, new_version)
|
|
256
|
+
```
|
|
257
|
+
|
|
258
|
+
### Table: `roles`
|
|
259
|
+
```
|
|
260
|
+
columns used: id, slug, name, description, permissions, is_system, is_active, app_id
|
|
261
|
+
FKs: app_id → apps.id
|
|
262
|
+
joins: app:apps!app_id
|
|
263
|
+
accessed by: roles.ts (ctx.db + adminDb), auth.ts (join on people)
|
|
264
|
+
RLS required: yes
|
|
265
|
+
```
|
|
266
|
+
|
|
267
|
+
### Table: `items`
|
|
268
|
+
```
|
|
269
|
+
columns used: id, item_type_id, title, is_active, design_schema, validation_schema,
|
|
270
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
271
|
+
FKs: item_type_id → types.id
|
|
272
|
+
account_id → accounts.id
|
|
273
|
+
created_by → people.id
|
|
274
|
+
accessed by: admin-data.ts (ctx.db — full CRUD via VALID_ENTITIES)
|
|
275
|
+
search field: title
|
|
276
|
+
soft delete: yes (is_active)
|
|
277
|
+
RLS required: yes
|
|
278
|
+
```
|
|
279
|
+
|
|
280
|
+
### Table: `threads`
|
|
281
|
+
```
|
|
282
|
+
columns used: id, title, is_active, design_schema, validation_schema,
|
|
283
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
284
|
+
FKs: account_id → accounts.id
|
|
285
|
+
accessed by: admin-data.ts (ctx.db — VALID_ENTITIES)
|
|
286
|
+
search field: title
|
|
287
|
+
soft delete: yes (is_active)
|
|
288
|
+
RLS required: yes
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
### Table: `messages`
|
|
292
|
+
```
|
|
293
|
+
columns used: id, content, is_active, design_schema, validation_schema,
|
|
294
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
295
|
+
FKs: account_id → accounts.id
|
|
296
|
+
accessed by: admin-data.ts (ctx.db — VALID_ENTITIES)
|
|
297
|
+
search field: content
|
|
298
|
+
soft delete: yes (is_active)
|
|
299
|
+
RLS required: yes
|
|
300
|
+
```
|
|
301
|
+
|
|
302
|
+
### Table: `links`
|
|
303
|
+
```
|
|
304
|
+
columns used: id, link_type, design_schema, validation_schema,
|
|
305
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
306
|
+
FKs: account_id → accounts.id
|
|
307
|
+
accessed by: admin-data.ts (ctx.db — VALID_ENTITIES)
|
|
308
|
+
search field: link_type
|
|
309
|
+
soft delete: no (hard delete)
|
|
310
|
+
RLS required: yes
|
|
311
|
+
```
|
|
312
|
+
|
|
313
|
+
### Table: `attachments`
|
|
314
|
+
```
|
|
315
|
+
columns used: id, filename, design_schema, validation_schema,
|
|
316
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
317
|
+
FKs: account_id → accounts.id
|
|
318
|
+
accessed by: admin-data.ts (ctx.db — VALID_ENTITIES)
|
|
319
|
+
search field: filename
|
|
320
|
+
soft delete: no
|
|
321
|
+
RLS required: yes
|
|
322
|
+
```
|
|
323
|
+
|
|
324
|
+
### Table: `watchers`
|
|
325
|
+
```
|
|
326
|
+
columns used: id, watch_type, is_active, design_schema, validation_schema,
|
|
327
|
+
account_id, type_id, created_by, created_at, updated_at, updated_by
|
|
328
|
+
FKs: account_id → accounts.id
|
|
329
|
+
accessed by: admin-data.ts (ctx.db — VALID_ENTITIES)
|
|
330
|
+
search field: watch_type
|
|
331
|
+
soft delete: yes (is_active)
|
|
332
|
+
RLS required: yes
|
|
333
|
+
```
|
|
334
|
+
|
|
335
|
+
### Table: `pipelines`
|
|
336
|
+
```
|
|
337
|
+
columns used: id, name, description, trigger_type, config, stages, metadata, is_active,
|
|
338
|
+
app_id, account_id, created_by, created_at, updated_at
|
|
339
|
+
FKs: app_id → apps.id
|
|
340
|
+
account_id → accounts.id
|
|
341
|
+
created_by → people.id
|
|
342
|
+
joins: app:apps!app_id, created_by_person:people!created_by
|
|
343
|
+
accessed by: pipelines.ts (ctx.db), pipeline-executions.ts (join)
|
|
344
|
+
RLS required: yes
|
|
345
|
+
```
|
|
346
|
+
|
|
347
|
+
### Table: `pipeline_executions`
|
|
348
|
+
```
|
|
349
|
+
columns used: id, pipeline_id, status, trigger_data, result, error_message,
|
|
350
|
+
started_at, completed_at, duration_ms, created_by, account_id, created_at
|
|
351
|
+
FKs: pipeline_id → pipelines.id
|
|
352
|
+
created_by → people.id
|
|
353
|
+
account_id → accounts.id
|
|
354
|
+
joins: pipeline:pipelines!pipeline_id, triggered_by_person:people!pipeline_executions_created_by_fkey
|
|
355
|
+
accessed by: pipeline-executions.ts (ctx.db), pipelines.ts (ctx.db — getExecutions)
|
|
356
|
+
RLS required: yes
|
|
357
|
+
```
|
|
358
|
+
|
|
359
|
+
### Table: `triggers`
|
|
360
|
+
```
|
|
361
|
+
columns used: id, name, description, trigger_type, event_type, config, pipeline_id,
|
|
362
|
+
metadata, is_active, app_id, account_id, created_by, created_at, updated_at
|
|
363
|
+
FKs: app_id → apps.id
|
|
364
|
+
account_id → accounts.id
|
|
365
|
+
created_by → people.id
|
|
366
|
+
pipeline_id → pipelines.id
|
|
367
|
+
joins: app:apps!app_id, created_by_person:people!created_by
|
|
368
|
+
accessed by: triggers.ts (ctx.db)
|
|
369
|
+
RLS required: yes
|
|
370
|
+
```
|
|
371
|
+
|
|
372
|
+
### Table: `trigger_executions`
|
|
373
|
+
```
|
|
374
|
+
columns used: id, trigger_id, triggered_at, status (implicit via ordering)
|
|
375
|
+
FKs: trigger_id → triggers.id
|
|
376
|
+
accessed by: triggers.ts (ctx.db — getExecutions)
|
|
377
|
+
RLS required: yes
|
|
378
|
+
```
|
|
379
|
+
|
|
380
|
+
### Table: `timers`
|
|
381
|
+
```
|
|
382
|
+
columns used: id, name, description, timer_type, config, pipeline_id, metadata, is_active,
|
|
383
|
+
app_id, account_id, created_by, created_at, updated_at
|
|
384
|
+
FKs: app_id → apps.id
|
|
385
|
+
account_id → accounts.id
|
|
386
|
+
created_by → people.id
|
|
387
|
+
pipeline_id → pipelines.id
|
|
388
|
+
joins: app:apps!app_id, created_by_person:people!created_by
|
|
389
|
+
accessed by: timers.ts (ctx.db)
|
|
390
|
+
RLS required: yes
|
|
391
|
+
```
|
|
392
|
+
|
|
393
|
+
### Table: `ai_agents`
|
|
394
|
+
```
|
|
395
|
+
columns used: id, name, description, agent_type, model_config, system_prompt, tools,
|
|
396
|
+
capabilities, constraints, metadata, is_active, app_id, account_id,
|
|
397
|
+
created_by, created_at, updated_at
|
|
398
|
+
FKs: app_id → apps.id
|
|
399
|
+
account_id → accounts.id
|
|
400
|
+
created_by → people.id
|
|
401
|
+
joins: app:apps!app_id, created_by_person:people!created_by
|
|
402
|
+
accessed by: ai-agents.ts (ctx.db)
|
|
403
|
+
RLS required: yes
|
|
404
|
+
```
|
|
405
|
+
|
|
406
|
+
### Table: `embeddings`
|
|
407
|
+
```
|
|
408
|
+
columns used: id, model_id, document_id, chunk_index, content, metadata,
|
|
409
|
+
account_id, created_at
|
|
410
|
+
FKs: account_id → accounts.id
|
|
411
|
+
accessed by: embeddings.ts (ctx.db)
|
|
412
|
+
RLS required: yes
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
### Table: `integrations`
|
|
416
|
+
```
|
|
417
|
+
columns used: id, name, description, integration_type, provider, version, config,
|
|
418
|
+
credentials, metadata, is_active, is_configured, app_id, account_id,
|
|
419
|
+
created_by, created_at, updated_at
|
|
420
|
+
FKs: app_id → apps.id
|
|
421
|
+
account_id → accounts.id
|
|
422
|
+
created_by → people.id
|
|
423
|
+
joins: app:apps!app_id, created_by_person:people!created_by
|
|
424
|
+
accessed by: integrations.ts (ctx.db), api-keys.ts (join)
|
|
425
|
+
RLS required: yes
|
|
426
|
+
```
|
|
427
|
+
|
|
428
|
+
### Table: `logs`
|
|
429
|
+
```
|
|
430
|
+
columns used: id, level, message, context, source, source_type, source_id,
|
|
431
|
+
person_id, account_id, metadata, created_at
|
|
432
|
+
FKs: account_id → accounts.id
|
|
433
|
+
person_id → people.id (nullable)
|
|
434
|
+
accessed by: logs.ts (ctx.db), audit.ts (ctx.db or adminDb — all functions via emitLog/emitAudit)
|
|
435
|
+
RLS required: yes (scoped to account_id)
|
|
436
|
+
```
|
|
437
|
+
|
|
438
|
+
### Table: `prompt_configs`
|
|
439
|
+
```
|
|
440
|
+
columns used: id, name, slug, system_prompt, context_template, model, temperature,
|
|
441
|
+
max_tokens, is_multi_turn, max_history_messages, confidence_threshold,
|
|
442
|
+
escalation_action, escalation_target, output_mode, output_field,
|
|
443
|
+
requires_review, knowledge_sources, available_tools, tool_constraints,
|
|
444
|
+
metadata, is_active, app_id, account_id, created_by, created_at, updated_at
|
|
445
|
+
FKs: app_id → apps.id
|
|
446
|
+
account_id → accounts.id
|
|
447
|
+
created_by → people.id
|
|
448
|
+
joins: app:apps!app_id, created_by_person:people!prompt_configs_created_by_fkey
|
|
449
|
+
accessed by: prompt-configs.ts (ctx.db)
|
|
450
|
+
RLS required: yes
|
|
451
|
+
```
|
|
452
|
+
|
|
453
|
+
### Table: `api_keys`
|
|
454
|
+
```
|
|
455
|
+
columns used: id, integration_id, name, key_type, key_prefix, permissions, rate_limit,
|
|
456
|
+
expires_at, metadata, is_active, account_id, created_by, created_at, updated_at
|
|
457
|
+
machine_type, is_internal, scopes (read by system-cron.ts)
|
|
458
|
+
FKs: integration_id → integrations.id (nullable)
|
|
459
|
+
account_id → accounts.id
|
|
460
|
+
created_by → people.id
|
|
461
|
+
joins: integration:integrations, created_by_person:people
|
|
462
|
+
accessed by: api-keys.ts (ctx.db), system-cron.ts (adminDb — machine principal lookup)
|
|
463
|
+
RLS required: yes
|
|
464
|
+
RPCs: create_api_key(...), validate_api_key(key_value, required_permissions)
|
|
465
|
+
```
|
|
466
|
+
|
|
467
|
+
### Table: `api_key_usage_logs`
|
|
468
|
+
```
|
|
469
|
+
columns used: id, api_key_id, response_status, success, created_at
|
|
470
|
+
FKs: api_key_id → api_keys.id
|
|
471
|
+
joins: api_key:api_keys
|
|
472
|
+
accessed by: api-keys.ts (ctx.db — listUsageLogs)
|
|
473
|
+
RLS required: yes
|
|
474
|
+
```
|
|
475
|
+
|
|
476
|
+
### Table: `actions` *(system-cron only)*
|
|
477
|
+
```
|
|
478
|
+
columns used: id, handler, handler_module, config, required_scopes
|
|
479
|
+
FKs: (none explicit in code)
|
|
480
|
+
accessed by: system-cron.ts (adminDb)
|
|
481
|
+
RLS required: no (adminDb only)
|
|
482
|
+
```
|
|
483
|
+
|
|
484
|
+
### Table: `schedule_executions` *(system-cron only)*
|
|
485
|
+
```
|
|
486
|
+
columns used: schedule_id, account_id, machine_principal_id, status,
|
|
487
|
+
input_params, output_result, error_message, duration_ms
|
|
488
|
+
FKs: schedule_id → schedules (implied), account_id → accounts.id
|
|
489
|
+
accessed by: system-cron.ts (adminDb)
|
|
490
|
+
RLS required: no (adminDb only)
|
|
491
|
+
```
|
|
492
|
+
|
|
493
|
+
---
|
|
494
|
+
|
|
495
|
+
## Tables: `select *` (columns not fully enumerated in code)
|
|
496
|
+
|
|
497
|
+
These tables are queried with `select('*')` — full column set must be verified against DB schema:
|
|
498
|
+
|
|
499
|
+
| Table | Location |
|
|
500
|
+
|---|---|
|
|
501
|
+
| `accounts` | `admin-data.ts`, `types.ts`, `account-nodes.ts` |
|
|
502
|
+
| `people` | `admin-data.ts` |
|
|
503
|
+
| `items` | `admin-data.ts` |
|
|
504
|
+
| `threads` | `admin-data.ts` |
|
|
505
|
+
| `messages` | `admin-data.ts` |
|
|
506
|
+
| `links` | `admin-data.ts` |
|
|
507
|
+
| `attachments` | `admin-data.ts` |
|
|
508
|
+
| `watchers` | `admin-data.ts` |
|
|
509
|
+
| `types` | `types.ts` (full record), `admin-data.ts` (type lookup) |
|
|
510
|
+
| `roles` | `roles.ts` |
|
|
511
|
+
| `pipelines` | `pipelines.ts` |
|
|
512
|
+
| `triggers` | `triggers.ts` |
|
|
513
|
+
| `timers` | `timers.ts` |
|
|
514
|
+
| `ai_agents` | `ai-agents.ts` |
|
|
515
|
+
| `integrations` | `integrations.ts` |
|
|
516
|
+
| `prompt_configs` | `prompt-configs.ts` |
|
|
517
|
+
| `api_keys` | `api-keys.ts` |
|
|
518
|
+
|
|
519
|
+
---
|
|
520
|
+
|
|
521
|
+
## RPC Functions Required
|
|
522
|
+
|
|
523
|
+
| RPC name | Called by | Purpose |
|
|
524
|
+
|---|---|---|
|
|
525
|
+
| `get_account_hierarchy(parent_account_id)` | `auth.ts` | Get all accessible child accounts |
|
|
526
|
+
| `get_account_ancestors(account_id)` | `account-nodes.ts` | Ancestor chain for breadcrumb |
|
|
527
|
+
| `get_account_descendants(account_id)` | `account-nodes.ts` | Subtree for tree view |
|
|
528
|
+
| `get_account_apps(account_id, include_system, include_inactive)` | `apps.ts` | Apps visible to account |
|
|
529
|
+
| `get_type_schema(kind, slug, app_id)` | `types.ts` | Resolve design_schema for a type |
|
|
530
|
+
| `get_app_schema(app_slug)` | `apps.ts` | App schema lookup |
|
|
531
|
+
| `is_app_available(app_slug, account_id)` | `apps.ts` | Marketplace availability check |
|
|
532
|
+
| `update_app_version(app_id, new_version)` | `apps.ts` | Version bump |
|
|
533
|
+
| `create_api_key(...)` | `api-keys.ts` | Secure key generation |
|
|
534
|
+
| `validate_api_key(key_value, required_permissions)` | `api-keys.ts` | Key validation |
|
|
535
|
+
| `get_due_schedules(p_now)` | `system-cron.ts` | Cron schedule polling |
|
|
536
|
+
| `validate_schedule_creator(p_schedule_id)` | `system-cron.ts` | Cron safety check |
|
|
537
|
+
| `update_schedule_after_run(p_schedule_id, p_success, p_error_message)` | `system-cron.ts` | Cron state update |
|
|
538
|
+
|
|
539
|
+
---
|
|
540
|
+
|
|
541
|
+
## Hardcoded Values Found
|
|
542
|
+
|
|
543
|
+
| File | Type | Value |
|
|
544
|
+
|---|---|---|
|
|
545
|
+
| `functions/_shared/db.ts` | Schema target | `schema: 'v2'` — hardcoded in both `adminDb` and `getUserDb`. **Must change to `'public'` for day-zero migration** |
|
|
546
|
+
| `vite.config.ts` | (check) | Confirm `VITE_DB_SCHEMA` env var path |
|
|
547
|
+
|
|
548
|
+
No hardcoded tenant IDs, account UUIDs, or emails found in `v2-core/functions/` or `v2-core/src/`.
|
|
549
|
+
|
|
550
|
+
---
|
|
551
|
+
|
|
552
|
+
## Migration Chain Issues
|
|
553
|
+
|
|
554
|
+
| Issue | Detail |
|
|
555
|
+
|---|---|
|
|
556
|
+
| **Duplicate prefix `047`** | `047_provisioning.sql` AND `047_simplify_auth_model.sql` both exist — ambiguous execution order on fresh install |
|
|
557
|
+
| **65 migrations total** | Chain is long; many migrations are incremental patches to the current hodgepodge schema — NOT suitable as a clean day-zero chain |
|
|
558
|
+
| **Schema target mismatch** | All migrations use `v2` schema; day-zero plan must decide: keep `v2` schema or migrate to `public` and update `db.ts` |
|
|
559
|
+
| **`x-netlify-functions/`** | Contains `_shared/` with `db.ts` likely targeting a different/older schema — confirm and delete |
|
|
560
|
+
|
|
561
|
+
---
|
|
562
|
+
|
|
563
|
+
## Recommended Deletion List (Pending Your Sign-off)
|
|
564
|
+
|
|
565
|
+
| Path | Action | Risk |
|
|
566
|
+
|---|---|---|
|
|
567
|
+
| `v2-core/x-netlify-functions/` | Delete entire directory | Low — nothing imports from here |
|
|
568
|
+
| `v2-core/src/pages/admin/AccountDetailPage.tsx.new` | Delete | None — zero bytes |
|
|
569
|
+
| `scripts/assemble-apps.sh` | Delete | Low — not in any build chain |
|
|
570
|
+
| `scripts/assemble-apps-simple.sh` | Delete | Low — not in any build chain |
|
|
571
|
+
| `scripts/assemble-frontend.sh` | Delete | Low — v1-era, superseded |
|
|
572
|
+
| `scripts/assemble-functions.sh` | Delete | Low — v1-era, superseded |
|
|
573
|
+
| `scripts/quarantine-legacy.sh` | Delete | Low — one-time use done |
|
|
574
|
+
| `scripts/app-install-cli.ts` | Delete | Medium — confirm no external tooling depends on it |
|
|
575
|
+
| `scripts/load-test-app-install.ts` | Delete | Medium — confirm not used in CI |
|
|
576
|
+
| `_quarantine/` | Delete entire directory | Low — all contents are retired artifacts |
|
|
577
|
+
| `v2-core/fix-functions.sh` | Delete | Low — one-off fix script |
|
|
578
|
+
| `v2-core/migrations/` | Do NOT delete yet — keep as reference for day-zero spec | — |
|
|
579
|
+
|
|
580
|
+
---
|
|
581
|
+
|
|
582
|
+
## Key Decisions Required Before Day-Zero Migration
|
|
583
|
+
|
|
584
|
+
1. **Schema: `v2` or `public`?** — `db.ts` hardcodes `schema: 'v2'`. Day-zero plan must pick one. Changing to `public` requires a one-line edit in `db.ts`; keeping `v2` requires `CREATE SCHEMA v2` in migration 001.
|
|
585
|
+
|
|
586
|
+
2. **RPC functions** — 13 RPCs are called by live code. Each needs a `CREATE FUNCTION` in the day-zero migrations. These are currently buried across the 65-migration chain.
|
|
587
|
+
|
|
588
|
+
3. **`system-cron` tables** — `actions`, `schedule_executions`, `schedules` are only accessed by `system-cron.ts` via `adminDb` with no RLS. These need their own migration section.
|
|
589
|
+
|
|
590
|
+
4. **`api_key_usage_logs`** — Small table, only read by `api-keys.ts`. Needs creation in day-zero chain.
|