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,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module agent-runner
|
|
3
|
+
* @audience both
|
|
4
|
+
* @layer shared-core
|
|
5
|
+
* @stability stable
|
|
6
|
+
*
|
|
7
|
+
* AI agent inference orchestrator with RAG, tool dispatch, and confidence-based
|
|
8
|
+
* escalation. All agent behavior is defined via JSONB configuration stored in
|
|
9
|
+
* existing schema tables — no dedicated migrations are needed.
|
|
10
|
+
*
|
|
11
|
+
* Configuration resolution chain (highest to lowest priority):
|
|
12
|
+
* 1. `thread.data.agent_id` → `thread.type.design_schema.default_agent_id`
|
|
13
|
+
* 2. `thread.data.prompt_config_id` → `agent.metadata.default_prompt_config_id`
|
|
14
|
+
*
|
|
15
|
+
* Inference loop (per `runAgent` call):
|
|
16
|
+
* 1. `resolveAgentConfig` — resolve agent + prompt_config from thread
|
|
17
|
+
* 2. Save user message to `messages` table
|
|
18
|
+
* 3. `executeAgentInference` — iterative tool-call loop (max 5 iterations):
|
|
19
|
+
* a. `buildContext` — assemble system prompt + RAG + history + tools
|
|
20
|
+
* b. `callInference` — call OpenAI-compatible API (or return mock)
|
|
21
|
+
* c. `dispatchTools` — execute any tool_calls via actions table
|
|
22
|
+
* d. Rebuild context with tool results and repeat
|
|
23
|
+
* 4. Confidence check — if below threshold, `handleEscalation`
|
|
24
|
+
* 5. Save agent response to `messages` table
|
|
25
|
+
* 6. Emit `agent.inference.completed` audit log
|
|
26
|
+
*
|
|
27
|
+
* Environment variables used by `callInference`:
|
|
28
|
+
* - `OPENAI_API_KEY` / `ANTHROPIC_API_KEY` / `LLM_API_KEY` — LLM auth
|
|
29
|
+
* - `OPENAI_BASE_URL` / `LLM_BASE_URL` — API base URL (default: OpenAI)
|
|
30
|
+
* - `LLM_DEFAULT_MODEL` — model name fallback (default: 'gpt-4o')
|
|
31
|
+
*
|
|
32
|
+
* INVARIANT: if no API key is set, `callInference` returns a mock response
|
|
33
|
+
* instead of throwing — safe for local development without credentials.
|
|
34
|
+
* INVARIANT: `runAgent` throws on critical failures (config missing, inference
|
|
35
|
+
* error) — callers must handle the rejection.
|
|
36
|
+
* INVARIANT: `resolveAgentConfig` returns null (not throws) on missing config;
|
|
37
|
+
* `runAgent` converts this to a throw.
|
|
38
|
+
*
|
|
39
|
+
* @seeAlso pipeline-runner.ts (tool dispatch calls runPipeline for run_pipeline tool)
|
|
40
|
+
* @seeAlso audit.ts (emitAudit for agent.inference.* events)
|
|
41
|
+
* @seeAlso index.ts (runAgent, resolveAgentConfig re-exported)
|
|
42
|
+
*/
|
|
43
|
+
import { CoreContext } from './middleware';
|
|
44
|
+
/**
|
|
45
|
+
* Resolved agent configuration bundle. Output of `resolveAgentConfig`.
|
|
46
|
+
* Passed to `executeAgentInference` and `buildContext`.
|
|
47
|
+
*
|
|
48
|
+
* @outputSpec agent: ai_agents row (system_prompt, model_config, metadata)
|
|
49
|
+
* @outputSpec promptConfig: prompt_configs row (context_template,
|
|
50
|
+
* knowledge_sources, available_tools, confidence_threshold, escalation_*)
|
|
51
|
+
* @outputSpec thread: threads row with joined type record
|
|
52
|
+
* @outputSpec threadType: types row (design_schema.default_agent_id)
|
|
53
|
+
*/
|
|
54
|
+
export interface AgentConfig {
|
|
55
|
+
agent: any;
|
|
56
|
+
promptConfig: any;
|
|
57
|
+
thread: any;
|
|
58
|
+
threadType: any;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Structured result from a single LLM inference call.
|
|
62
|
+
*
|
|
63
|
+
* @outputSpec content: string — agent response text
|
|
64
|
+
* @outputSpec confidence: number — 0-1 score; derived from logprobs or 0.85 default
|
|
65
|
+
* @outputSpec tool_calls: ToolCall[] | undefined — tools the model wants to call
|
|
66
|
+
* @outputSpec metadata: { model, usage, finish_reason } | undefined
|
|
67
|
+
*/
|
|
68
|
+
export interface InferenceResult {
|
|
69
|
+
content: string;
|
|
70
|
+
confidence: number;
|
|
71
|
+
tool_calls?: ToolCall[];
|
|
72
|
+
metadata?: Record<string, any>;
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* A single tool invocation requested by the LLM in an `InferenceResult`.
|
|
76
|
+
*
|
|
77
|
+
* @inputSpec tool: string — action.slug to look up in the actions table
|
|
78
|
+
* @inputSpec params: Record<string, any> — parsed from OpenAI function call arguments
|
|
79
|
+
* @inputSpec id: string — opaque tool_call ID from the LLM response
|
|
80
|
+
*/
|
|
81
|
+
export interface ToolCall {
|
|
82
|
+
tool: string;
|
|
83
|
+
params: Record<string, any>;
|
|
84
|
+
id: string;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Result of executing a single `ToolCall`.
|
|
88
|
+
*
|
|
89
|
+
* @outputSpec tool: string — mirrors ToolCall.tool
|
|
90
|
+
* @outputSpec result: any — handler return value on success; null on error
|
|
91
|
+
* @outputSpec error: string | undefined — error message if execution failed
|
|
92
|
+
* @outputSpec id: string — mirrors ToolCall.id for correlation
|
|
93
|
+
*/
|
|
94
|
+
export interface ToolResult {
|
|
95
|
+
tool: string;
|
|
96
|
+
result: any;
|
|
97
|
+
error?: string;
|
|
98
|
+
id: string;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Main entry point: run a full agent inference cycle for a user message.
|
|
102
|
+
*
|
|
103
|
+
* Saves the user message, runs the inference loop (with tool calls), checks
|
|
104
|
+
* confidence, saves the agent response, and emits audit logs.
|
|
105
|
+
*
|
|
106
|
+
* @param threadId - UUID of the thread to run inference on
|
|
107
|
+
* @param userMessage - Raw message text from the user
|
|
108
|
+
* @param ctx - CoreContext with accountId, principal, requestId
|
|
109
|
+
* @returns Promise<any> — the saved agent message record from the `messages` table
|
|
110
|
+
* @throws Error — if agent config cannot be resolved, or LLM inference fails
|
|
111
|
+
* @inputSpec threadId: string — valid UUID in threads table
|
|
112
|
+
* @inputSpec userMessage: string — non-empty message text
|
|
113
|
+
* @inputSpec ctx.accountId: string | null — used to scope DB lookups
|
|
114
|
+
* @outputSpec messages row — the inserted agent reply with content and metadata
|
|
115
|
+
* @sideEffects DB write: inserts 2 messages rows (user + agent)
|
|
116
|
+
* @sideEffects DB write: emitAudit (agent.inference.completed or agent.inference.failed)
|
|
117
|
+
* @sideEffects HTTP call: callInference (LLM API)
|
|
118
|
+
* @sideEffects DB write (conditional): handleEscalation if confidence < threshold
|
|
119
|
+
* @calledBy functions/ai-agents.ts handler for POST ?action=run
|
|
120
|
+
* @calledBy v2-custom/ import callers
|
|
121
|
+
* @calls resolveAgentConfig, saveMessage, executeAgentInference,
|
|
122
|
+
* handleEscalation, emitAudit
|
|
123
|
+
* @testUnit tests/unit/agent-runner.test.ts
|
|
124
|
+
* @testIntegration tests/integration/agent-runner.test.ts
|
|
125
|
+
*
|
|
126
|
+
* @example API handler usage
|
|
127
|
+
* ```ts
|
|
128
|
+
* import { runAgent } from './_shared/index'
|
|
129
|
+
* const agentMsg = await runAgent(body.thread_id, body.message, ctx)
|
|
130
|
+
* return agentMsg
|
|
131
|
+
* ```
|
|
132
|
+
*/
|
|
133
|
+
export declare function runAgent(threadId: string, userMessage: string, ctx: CoreContext): Promise<any>;
|
|
134
|
+
/**
|
|
135
|
+
* Resolves the agent, prompt config, thread, and thread type for a given thread.
|
|
136
|
+
*
|
|
137
|
+
* Resolution priority:
|
|
138
|
+
* - `agent_id`: `thread.data.agent_id` → `thread.type.design_schema.default_agent_id`
|
|
139
|
+
* - `prompt_config_id`: `thread.data.prompt_config_id` →
|
|
140
|
+
* `agent.metadata.default_prompt_config_id`
|
|
141
|
+
*
|
|
142
|
+
* Returns `null` (does not throw) when any required record is missing. `runAgent`
|
|
143
|
+
* converts a null return to a thrown Error.
|
|
144
|
+
*
|
|
145
|
+
* @param threadId - UUID of the thread
|
|
146
|
+
* @param ctx - CoreContext (requestId used for error logging)
|
|
147
|
+
* @returns Promise<AgentConfig | null> — null if config cannot be resolved
|
|
148
|
+
* @throws never — errors logged to console, returns null
|
|
149
|
+
* @inputSpec threadId: string — valid UUID in threads table
|
|
150
|
+
* @outputSpec AgentConfig | null
|
|
151
|
+
* @sideEffects DB reads: threads (with type join), ai_agents, prompt_configs
|
|
152
|
+
* @calledBy runAgent
|
|
153
|
+
* @testUnit tests/unit/agent-runner.test.ts — 'resolveAgentConfig'
|
|
154
|
+
*/
|
|
155
|
+
export declare function resolveAgentConfig(threadId: string, ctx: CoreContext): Promise<AgentConfig | null>;
|
|
156
|
+
//# sourceMappingURL=agent-runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-runner.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/agent-runner.ts"],"names":[],"mappings":"AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAM1C;;;;;;;;;GASG;AACH,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,GAAG,CAAA;IACV,YAAY,EAAE,GAAG,CAAA;IACjB,MAAM,EAAE,GAAG,CAAA;IACX,UAAU,EAAE,GAAG,CAAA;CAChB;AAED;;;;;;;GAOG;AACH,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,CAAA;IACf,UAAU,EAAE,MAAM,CAAA;IAClB,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAA;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAC/B;AAED;;;;;;GAMG;AACH,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAC3B,EAAE,EAAE,MAAM,CAAA;CACX;AAED;;;;;;;GAOG;AACH,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,GAAG,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,EAAE,EAAE,MAAM,CAAA;CACX;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,WAAW,GACf,OAAO,CAAC,GAAG,CAAC,CA0Ed;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,WAAW,GACf,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAmE7B"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module app-manifest
|
|
3
|
+
* @audience core-contributor
|
|
4
|
+
* @layer shared-util
|
|
5
|
+
* @stability evolving
|
|
6
|
+
*
|
|
7
|
+
* Utility for loading and merging app manifests with database records.
|
|
8
|
+
* Enables file-first app configuration with database tracking installations.
|
|
9
|
+
*
|
|
10
|
+
* **Pattern:**
|
|
11
|
+
* 1. Manifest files in custom/apps/{slug}/manifest.json are source of truth
|
|
12
|
+
* 2. Database tracks which tenant has which app installed/enabled
|
|
13
|
+
* 3. This utility merges both sources for the API response
|
|
14
|
+
*
|
|
15
|
+
* @seeAlso apps.ts (uses this for manifest-driven responses)
|
|
16
|
+
* @seeAlso 015_simplify_apps_table.sql (database structure)
|
|
17
|
+
*/
|
|
18
|
+
export interface AppManifest {
|
|
19
|
+
name: string;
|
|
20
|
+
slug: string;
|
|
21
|
+
description?: string;
|
|
22
|
+
version?: string;
|
|
23
|
+
required_roles: string[];
|
|
24
|
+
routes: string[];
|
|
25
|
+
nav_items: NavItem[];
|
|
26
|
+
features?: string[];
|
|
27
|
+
dependencies?: string[];
|
|
28
|
+
entry_point: string;
|
|
29
|
+
is_public?: boolean;
|
|
30
|
+
auth_required?: boolean;
|
|
31
|
+
}
|
|
32
|
+
export interface NavItem {
|
|
33
|
+
title: string;
|
|
34
|
+
path: string;
|
|
35
|
+
icon?: string;
|
|
36
|
+
order?: number;
|
|
37
|
+
children?: NavItem[];
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Loads a manifest.json file from the filesystem.
|
|
41
|
+
*
|
|
42
|
+
* @param manifestPath - Relative path to manifest (e.g., 'custom/apps/cortex/manifest.json')
|
|
43
|
+
* @returns Parsed manifest or null if not found
|
|
44
|
+
*/
|
|
45
|
+
export declare function loadManifest(manifestPath: string): AppManifest | null;
|
|
46
|
+
/**
|
|
47
|
+
* Clears the manifest cache. Useful for testing.
|
|
48
|
+
*/
|
|
49
|
+
export declare function clearManifestCache(): void;
|
|
50
|
+
/**
|
|
51
|
+
* Merges database app record with manifest data.
|
|
52
|
+
* Manifest takes precedence for metadata fields.
|
|
53
|
+
*
|
|
54
|
+
* @param dbRecord - App record from app_definitions table
|
|
55
|
+
* @returns Merged app data for API response
|
|
56
|
+
*/
|
|
57
|
+
export declare function mergeWithManifest(dbRecord: any): any;
|
|
58
|
+
/**
|
|
59
|
+
* Lists all available manifests from filesystem.
|
|
60
|
+
* Used for initial discovery before database tracking.
|
|
61
|
+
*
|
|
62
|
+
* @returns Array of discovered app slugs and their paths
|
|
63
|
+
*/
|
|
64
|
+
export declare function discoverManifests(): Array<{
|
|
65
|
+
slug: string;
|
|
66
|
+
path: string;
|
|
67
|
+
}>;
|
|
68
|
+
//# sourceMappingURL=app-manifest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-manifest.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/app-manifest.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;GAgBG;AAKH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,cAAc,EAAE,MAAM,EAAE,CAAA;IACxB,MAAM,EAAE,MAAM,EAAE,CAAA;IAChB,SAAS,EAAE,OAAO,EAAE,CAAA;IACpB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAA;CACrB;AAKD;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,YAAY,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,CAiCrE;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC;AAED;;;;;;GAMG;AACH,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,GAAG,GAAG,GAAG,CA2DpD;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,IAAI,KAAK,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAC,CAAC,CAcvE"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module audit
|
|
3
|
+
* @audience both
|
|
4
|
+
* @layer shared-core
|
|
5
|
+
* @stability stable
|
|
6
|
+
*
|
|
7
|
+
* Unified audit logging for all operations in Spine. Every state-changing
|
|
8
|
+
* operation should call `emitAudit` to write a structured row to the `logs`
|
|
9
|
+
* table with full principal provenance. Audit failures never throw — a failed
|
|
10
|
+
* log write must never break the operation that triggered it.
|
|
11
|
+
*
|
|
12
|
+
* INVARIANT: always call `emitAudit` after a successful write, not before.
|
|
13
|
+
* Pass `result: 'failure'` only when the operation itself failed.
|
|
14
|
+
* INVARIANT: never pass sensitive secrets (API keys, tokens) in metadata.
|
|
15
|
+
*
|
|
16
|
+
* @seeAlso principal.ts (formatPrincipalForAudit — shapes the principal field)
|
|
17
|
+
* @seeAlso middleware.ts (CoreContext — ctx.requestId ties logs to HTTP requests)
|
|
18
|
+
* @seeAlso logs.ts (API handler that queries the logs table)
|
|
19
|
+
* @seeAlso permissions.ts (getPrincipalPermissionSummary — used in metadata)
|
|
20
|
+
*/
|
|
21
|
+
import { CoreContext } from './middleware';
|
|
22
|
+
/**
|
|
23
|
+
* @chunk-id SHARED_AUDIT_EMIT_1_0_0
|
|
24
|
+
* @version 1.0.0
|
|
25
|
+
* @hash d9c3dbc103f5f2f0543dc4c154bbad256e59c885643a20bc20ca07198eabd67c
|
|
26
|
+
* @macro Audit Log Emitter
|
|
27
|
+
* @micro Writes structured audit logs to logs table with principal provenance
|
|
28
|
+
* @inputs ctx: CoreContext — Request context with principal and database
|
|
29
|
+
* @inputs action: string — Dot-namespaced action (e.g. 'items.create')
|
|
30
|
+
* @inputs target: {type, id?, account_id?} — Resource being acted upon
|
|
31
|
+
* @inputs metadata: {changes?, result?, error?, ...} — Optional context
|
|
32
|
+
* @outputs void — Always resolves, never rejects
|
|
33
|
+
* @depends-on [adminDb, formatPrincipalForAudit]
|
|
34
|
+
* @depended-by [All state-changing API functions, pipeline-runner, trigger-engine]
|
|
35
|
+
* @side-effects [DB insert to logs table, console.error on failure]
|
|
36
|
+
* @tags audit, logging, security, compliance
|
|
37
|
+
*/
|
|
38
|
+
export declare function emitAudit(ctx: CoreContext, action: string, target: {
|
|
39
|
+
type: string;
|
|
40
|
+
id?: string;
|
|
41
|
+
account_id?: string;
|
|
42
|
+
}, metadata?: {
|
|
43
|
+
changes?: {
|
|
44
|
+
before?: any;
|
|
45
|
+
after?: any;
|
|
46
|
+
};
|
|
47
|
+
result?: 'success' | 'failure' | 'denied';
|
|
48
|
+
error?: string;
|
|
49
|
+
[key: string]: any;
|
|
50
|
+
}): Promise<void>;
|
|
51
|
+
/**
|
|
52
|
+
* @chunk-id SHARED_AUDIT_EMIT_LOG_1_0_0
|
|
53
|
+
* @version 1.0.0
|
|
54
|
+
* @hash 148fb1ce7badf1d3df08e2daa38bac4c084c94ba2f262c782c9df092a22890dd
|
|
55
|
+
* @macro Legacy Audit Log Wrapper
|
|
56
|
+
* @micro Backward compatibility wrapper around emitAudit
|
|
57
|
+
* @inputs ctx: CoreContext — Request context
|
|
58
|
+
* @inputs eventType: string — Action string (maps to emitAudit's action)
|
|
59
|
+
* @inputs target: {type, id} | undefined — Resource target
|
|
60
|
+
* @inputs changes: {before?, after?} | undefined — Change data
|
|
61
|
+
* @inputs metadata: Record<string, any> — Additional context
|
|
62
|
+
* @outputs void — Always resolves
|
|
63
|
+
* @depends-on [emitAudit]
|
|
64
|
+
* @depended-by [Legacy code, should not be used in new code]
|
|
65
|
+
* @side-effects [DB insert via emitAudit, console.error on failure]
|
|
66
|
+
* @tags audit, logging, legacy, wrapper, deprecated
|
|
67
|
+
*/
|
|
68
|
+
export declare function emitLog(ctx: CoreContext, eventType: string, target?: {
|
|
69
|
+
type: string;
|
|
70
|
+
id: string;
|
|
71
|
+
}, changes?: {
|
|
72
|
+
before?: any;
|
|
73
|
+
after?: any;
|
|
74
|
+
}, metadata?: Record<string, any>): Promise<void>;
|
|
75
|
+
/**
|
|
76
|
+
* @chunk-id SHARED_AUDIT_EMIT_ACTIVITY_1_0_0
|
|
77
|
+
* @version 1.0.0
|
|
78
|
+
* @hash 58e532a743fdae480ca24d311be66e82612477309270ec7462fd7dfd695d5282
|
|
79
|
+
* @macro Legacy Activity Logger
|
|
80
|
+
* @micro Wraps emitLog with activity. prefix for backward compatibility
|
|
81
|
+
* @inputs ctx: CoreContext — Request context
|
|
82
|
+
* @inputs type: string — Activity type (prefixed with 'activity.')
|
|
83
|
+
* @inputs details: Record<string, any> — Metadata context
|
|
84
|
+
* @outputs void — Always resolves
|
|
85
|
+
* @depends-on [emitLog]
|
|
86
|
+
* @depended-by [Legacy code, should not be used in new code]
|
|
87
|
+
* @side-effects [DB insert via emitLog → emitAudit, console.error on failure]
|
|
88
|
+
* @tags audit, logging, legacy, activity, deprecated
|
|
89
|
+
*/
|
|
90
|
+
export declare function emitActivity(ctx: CoreContext, type: string, details?: Record<string, any>): Promise<void>;
|
|
91
|
+
//# sourceMappingURL=audit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/audit.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAO1C;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,SAAS,CAC7B,GAAG,EAAE,WAAW,EAChB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,EAAE,CAAC,EAAE,MAAM,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,CAAA;CAAE,EAC1D,QAAQ,CAAC,EAAE;IACT,OAAO,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,GAAG,CAAC;QAAC,KAAK,CAAC,EAAE,GAAG,CAAA;KAAE,CAAA;IACvC,MAAM,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAA;IACzC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB,GACA,OAAO,CAAC,IAAI,CAAC,CA0Bf;AAMD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,OAAO,CAC3B,GAAG,EAAE,WAAW,EAChB,SAAS,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,EAAE,EAAE,MAAM,CAAA;CAAE,EACrC,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,GAAG,CAAC;IAAC,KAAK,CAAC,EAAE,GAAG,CAAA;CAAE,EACvC,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GACjC,OAAO,CAAC,IAAI,CAAC,CAcf;AAID;;;;;;;;;;;;;;GAcG;AACH,wBAAsB,YAAY,CAChC,GAAG,EAAE,WAAW,EAChB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,GAChC,OAAO,CAAC,IAAI,CAAC,CAEf"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module db
|
|
3
|
+
* @audience both
|
|
4
|
+
* @layer shared-core
|
|
5
|
+
* @stability stable
|
|
6
|
+
*
|
|
7
|
+
* Supabase client factory and PostgREST join helpers. This module owns the
|
|
8
|
+
* two-client pattern that is central to Spine's security model: `adminDb`
|
|
9
|
+
* bypasses RLS for system operations; `getUserDb` enforces RLS for all
|
|
10
|
+
* human-principal requests. Never use `adminDb` for user-scoped queries —
|
|
11
|
+
* doing so silently bypasses account isolation.
|
|
12
|
+
*
|
|
13
|
+
* @seeAlso principal.ts (getPrincipalDb selects between these two clients)
|
|
14
|
+
* @seeAlso middleware.ts (ctx.db is set from getPrincipalDb at request time)
|
|
15
|
+
*/
|
|
16
|
+
/**
|
|
17
|
+
* Service-role Supabase client. Bypasses Row Level Security.
|
|
18
|
+
*
|
|
19
|
+
* Use this ONLY for:
|
|
20
|
+
* - System/cron operations that must cross account boundaries (`system-cron.ts`)
|
|
21
|
+
* - Principal resolution lookups (`principal.ts` — resolving auth_uid to person)
|
|
22
|
+
* - Machine principal validation RPCs
|
|
23
|
+
* - Test helpers that need to seed/clean data across accounts
|
|
24
|
+
*
|
|
25
|
+
* Do NOT use this in request handlers for user-scoped data reads or writes.
|
|
26
|
+
* Always prefer `ctx.db` (set by `getPrincipalDb` in middleware) for those.
|
|
27
|
+
*
|
|
28
|
+
* @inputSpec SUPABASE_URL: string — valid Supabase project URL, required
|
|
29
|
+
* @inputSpec SUPABASE_SERVICE_ROLE_KEY: string — service role JWT, required
|
|
30
|
+
* @outputSpec SupabaseClient — PostgREST client scoped to `dbSchema`, RLS disabled
|
|
31
|
+
* @sideEffects none (client construction only)
|
|
32
|
+
* @calledBy principal.ts, middleware.ts, system-cron.ts, permissions.ts,
|
|
33
|
+
* tests/integration/helpers.ts
|
|
34
|
+
* @calls createClient (supabase-js)
|
|
35
|
+
* @testUnit tests/unit/pipeline-runner.test.ts — mocked via vi.mock
|
|
36
|
+
* @testIntegration tests/integration/helpers.ts — used directly as adminDb
|
|
37
|
+
*
|
|
38
|
+
* @example API handler (system operation)
|
|
39
|
+
* ```ts
|
|
40
|
+
* import { adminDb } from './_shared/db'
|
|
41
|
+
* const { data } = await adminDb.from('types').select('*').eq('slug', 'item')
|
|
42
|
+
* ```
|
|
43
|
+
*
|
|
44
|
+
* @example Import usage (v2-custom/ — system-level only)
|
|
45
|
+
* ```ts
|
|
46
|
+
* import { adminDb } from '../_shared/index'
|
|
47
|
+
* // Only use adminDb if your custom code runs as a system/cron principal
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export declare const adminDb: import("@supabase/supabase-js").SupabaseClient<any, "public", string, any, any>;
|
|
51
|
+
/**
|
|
52
|
+
* @chunk-id SHARED_DB_GET_USER_DB_1_0_0
|
|
53
|
+
* @version 1.0.0
|
|
54
|
+
* @hash af3c792634c60ced1c1c4184cfc6c20add90ab97eb62f7e46bdf40ae2899a0f8
|
|
55
|
+
* @macro User Database Client Factory
|
|
56
|
+
* @micro Creates RLS-enforced Supabase client for specific user JWT
|
|
57
|
+
* @inputs jwt: string — Valid Supabase JWT from Authorization header
|
|
58
|
+
* @outputs SupabaseClient — PostgREST client with RLS enforced
|
|
59
|
+
* @depends-on [createClient, supabaseUrl, supabaseAnonKey, dbSchema]
|
|
60
|
+
* @depended-by [principal.ts, middleware.ts]
|
|
61
|
+
* @side-effects [Client construction with Authorization header]
|
|
62
|
+
* @tags database, supabase, rls, authentication, user-scoped
|
|
63
|
+
*/
|
|
64
|
+
export declare function getUserDb(jwt: string): import("@supabase/supabase-js").SupabaseClient<any, "public", string, any, any>;
|
|
65
|
+
/**
|
|
66
|
+
* Standard shape returned by all Supabase PostgREST queries.
|
|
67
|
+
*
|
|
68
|
+
* Both `data` and `error` follow the Supabase JS client convention: on success,
|
|
69
|
+
* `error` is null; on failure, `data` is null and `error` contains the Postgres
|
|
70
|
+
* error details. Always check `error` before using `data`.
|
|
71
|
+
*
|
|
72
|
+
* @inputSpec T — the expected shape of a successful result row
|
|
73
|
+
* @outputSpec data: T | null — the query result, null on error
|
|
74
|
+
* @outputSpec error: any — null on success, Postgres/PostgREST error object on failure
|
|
75
|
+
* @calledBy used as return type annotation across all functions/*.ts handlers
|
|
76
|
+
*
|
|
77
|
+
* @example
|
|
78
|
+
* ```ts
|
|
79
|
+
* const result: DbResult<Item> = await adminDb.from('items').select('*').single()
|
|
80
|
+
* if (result.error) throw result.error
|
|
81
|
+
* return result.data!
|
|
82
|
+
* ```
|
|
83
|
+
*/
|
|
84
|
+
export type DbResult<T> = {
|
|
85
|
+
data: T | null;
|
|
86
|
+
error: any;
|
|
87
|
+
};
|
|
88
|
+
/**
|
|
89
|
+
* PostgREST relationship hint strings for all foreign keys in the public schema.
|
|
90
|
+
*
|
|
91
|
+
* These strings are interpolated into `.select()` calls to eager-load related
|
|
92
|
+
* records in a single query. They use explicit `!fk_column` hints to resolve
|
|
93
|
+
* ambiguous relationships — required when a table has multiple FKs to the same
|
|
94
|
+
* target table, or when the FK column name doesn't follow PostgREST's default
|
|
95
|
+
* `tablename_id` inference convention (e.g. `created_by` → `people.id`).
|
|
96
|
+
*
|
|
97
|
+
* Only add a join here when it is used in two or more handlers. One-off joins
|
|
98
|
+
* should be written inline.
|
|
99
|
+
*
|
|
100
|
+
* @inputSpec none — these are static string constants
|
|
101
|
+
* @outputSpec string — valid PostgREST embed expression for use in .select()
|
|
102
|
+
* @sideEffects none
|
|
103
|
+
* @calledBy types.ts, apps.ts, pipelines.ts, triggers.ts, admin-data.ts, and others
|
|
104
|
+
* @testUnit none — these are string constants; incorrect joins fail at runtime
|
|
105
|
+
* @testIntegration tests/integration/admin-data-accounts.test.ts — exercises joins.type
|
|
106
|
+
*
|
|
107
|
+
* @example
|
|
108
|
+
* ```ts
|
|
109
|
+
* import { joins } from './_shared/db'
|
|
110
|
+
* const { data } = await ctx.db
|
|
111
|
+
* .from('items')
|
|
112
|
+
* .select(`*, ${joins.type}, ${joins.app}`)
|
|
113
|
+
* // Returns items with nested type and app objects
|
|
114
|
+
* ```
|
|
115
|
+
*/
|
|
116
|
+
export declare const joins: {
|
|
117
|
+
type: string;
|
|
118
|
+
app: string;
|
|
119
|
+
ownerAccount: string;
|
|
120
|
+
createdBy: string;
|
|
121
|
+
parentAccount: string;
|
|
122
|
+
role: string;
|
|
123
|
+
pipeline: string;
|
|
124
|
+
};
|
|
125
|
+
//# sourceMappingURL=db.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../../.framework/functions/_shared/db.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AA2BH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,eAAO,MAAM,OAAO,iFAIlB,CAAA;AAGF;;;;;;;;;;;;GAYG;AACH,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,mFAWpC;AAKD;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,MAAM,QAAQ,CAAC,CAAC,IAAI;IACxB,IAAI,EAAE,CAAC,GAAG,IAAI,CAAA;IACd,KAAK,EAAE,GAAG,CAAA;CACX,CAAA;AAID;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,eAAO,MAAM,KAAK;;;;;;;;CAQjB,CAAA"}
|