@lssm/lib.contracts 1.41.1 → 1.42.2
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/LICENSE +21 -0
- package/README.md +7 -4
- package/dist/_virtual/rolldown_runtime.js +37 -1
- package/dist/app-config/app-config.feature.d.ts +11 -0
- package/dist/app-config/app-config.feature.js +54 -1
- package/dist/app-config/branding.d.ts +55 -0
- package/dist/app-config/contracts.d.ts +245 -0
- package/dist/app-config/contracts.js +395 -1
- package/dist/app-config/docs/app-config.docblock.d.ts +6 -0
- package/dist/app-config/docs/app-config.docblock.js +21 -220
- package/dist/app-config/events.d.ts +122 -0
- package/dist/app-config/events.js +174 -1
- package/dist/app-config/index.d.ts +9 -0
- package/dist/app-config/index.js +8 -1
- package/dist/app-config/lifecycle-contracts.d.ts +273 -0
- package/dist/app-config/lifecycle-contracts.js +440 -1
- package/dist/app-config/lifecycle.d.ts +27 -0
- package/dist/app-config/runtime.d.ts +117 -0
- package/dist/app-config/runtime.js +617 -1
- package/dist/app-config/spec.d.ts +172 -0
- package/dist/app-config/spec.js +36 -1
- package/dist/app-config/validation.d.ts +49 -0
- package/dist/app-config/validation.js +538 -1
- package/dist/capabilities/capabilities.d.ts +48 -0
- package/dist/capabilities/capabilities.js +50 -0
- package/dist/capabilities/docs/capabilities.docblock.d.ts +6 -0
- package/dist/capabilities/docs/capabilities.docblock.js +21 -1
- package/dist/capabilities/index.d.ts +3 -0
- package/dist/capabilities/index.js +4 -0
- package/dist/capabilities/openbanking.d.ts +10 -0
- package/dist/capabilities/openbanking.js +92 -1
- package/dist/client/index.d.ts +6 -0
- package/dist/client/index.js +9 -1
- package/dist/client/react/drivers/rn-reusables.d.ts +22 -0
- package/dist/client/react/drivers/rn-reusables.js +21 -1
- package/dist/client/react/drivers/shadcn.d.ts +12 -0
- package/dist/client/react/drivers/shadcn.js +11 -1
- package/dist/client/react/feature-render.d.ts +21 -0
- package/dist/client/react/feature-render.js +44 -1
- package/dist/client/react/form-render.d.ts +92 -0
- package/dist/client/react/form-render.js +298 -1
- package/dist/client/react/index.d.ts +5 -0
- package/dist/client/react/index.js +8 -1
- package/dist/contract-registry/index.d.ts +3 -0
- package/dist/contract-registry/index.js +3 -1
- package/dist/contract-registry/schemas.d.ts +124 -0
- package/dist/contract-registry/schemas.js +61 -1
- package/dist/contract-registry/types.d.ts +46 -0
- package/dist/data-views/data-views.d.ts +138 -0
- package/dist/data-views/data-views.js +58 -0
- package/dist/data-views/docs/data-views.docblock.d.ts +6 -0
- package/dist/data-views/docs/data-views.docblock.js +21 -1
- package/dist/data-views/index.d.ts +4 -0
- package/dist/data-views/index.js +5 -0
- package/dist/data-views/query-generator.d.ts +40 -0
- package/dist/data-views/query-generator.js +48 -1
- package/dist/data-views/runtime.d.ts +27 -0
- package/dist/data-views/runtime.js +39 -1
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.d.ts +6 -0
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.js +17 -350
- package/dist/docs/index.d.ts +6 -0
- package/dist/docs/index.js +27 -1
- package/dist/docs/meta.docs.d.ts +6 -0
- package/dist/docs/meta.docs.js +18 -2
- package/dist/docs/presentations.d.ts +33 -0
- package/dist/docs/presentations.js +64 -1
- package/dist/docs/registry.d.ts +23 -0
- package/dist/docs/registry.js +51 -1
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.d.ts +6 -0
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.js +25 -2
- package/dist/docs/tech/contracts/README.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/README.docblock.js +21 -1
- package/dist/docs/tech/contracts/create-subscription.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/create-subscription.docblock.js +21 -1
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.js +21 -180
- package/dist/docs/tech/contracts/migrations.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/migrations.docblock.js +21 -1
- package/dist/docs/tech/contracts/openapi-export.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/openapi-export.docblock.js +25 -5
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.js +19 -60
- package/dist/docs/tech/contracts/overlays.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/overlays.docblock.js +21 -68
- package/dist/docs/tech/contracts/tests.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/tests.docblock.js +21 -132
- package/dist/docs/tech/contracts/themes.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/themes.docblock.js +21 -1
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.d.ts +6 -0
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.js +21 -106
- package/dist/docs/tech/lifecycle-stage-system.docblock.d.ts +6 -0
- package/dist/docs/tech/lifecycle-stage-system.docblock.js +17 -213
- package/dist/docs/tech/llm/llm-integration.docblock.d.ts +7 -0
- package/dist/docs/tech/llm/llm-integration.docblock.js +76 -7
- package/dist/docs/tech/mcp-endpoints.docblock.d.ts +6 -0
- package/dist/docs/tech/mcp-endpoints.docblock.js +38 -1
- package/dist/docs/tech/presentation-runtime.docblock.d.ts +6 -0
- package/dist/docs/tech/presentation-runtime.docblock.js +17 -1
- package/dist/docs/tech/schema/README.docblock.d.ts +6 -0
- package/dist/docs/tech/schema/README.docblock.js +21 -262
- package/dist/docs/tech/studio/learning-events.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/learning-events.docblock.js +49 -1
- package/dist/docs/tech/studio/learning-journeys.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/learning-journeys.docblock.js +25 -2
- package/dist/docs/tech/studio/platform-admin-panel.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/platform-admin-panel.docblock.js +24 -2
- package/dist/docs/tech/studio/project-access-teams.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/project-access-teams.docblock.js +26 -16
- package/dist/docs/tech/studio/project-routing.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/project-routing.docblock.js +68 -1
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.js +23 -2
- package/dist/docs/tech/studio/team-invitations.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/team-invitations.docblock.js +41 -36
- package/dist/docs/tech/studio/workspace-ops.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/workspace-ops.docblock.js +48 -1
- package/dist/docs/tech/studio/workspaces.docblock.d.ts +6 -0
- package/dist/docs/tech/studio/workspaces.docblock.js +24 -2
- package/dist/docs/tech/telemetry-ingest.docblock.d.ts +6 -0
- package/dist/docs/tech/telemetry-ingest.docblock.js +37 -3
- package/dist/docs/tech/templates/runtime.docblock.d.ts +6 -0
- package/dist/docs/tech/templates/runtime.docblock.js +21 -1
- package/dist/docs/tech/vscode-extension.docblock.d.ts +6 -0
- package/dist/docs/tech/vscode-extension.docblock.js +37 -3
- package/dist/docs/tech/workflows/overview.docblock.d.ts +6 -0
- package/dist/docs/tech/workflows/overview.docblock.js +21 -1
- package/dist/docs/tech-contracts.docs.d.ts +6 -0
- package/dist/docs/tech-contracts.docs.js +27 -7
- package/dist/docs/types.d.ts +41 -0
- package/dist/events.d.ts +47 -0
- package/dist/events.js +19 -1
- package/dist/experiments/docs/experiments.docblock.d.ts +6 -0
- package/dist/experiments/docs/experiments.docblock.js +21 -128
- package/dist/experiments/evaluator.d.ts +37 -0
- package/dist/experiments/evaluator.js +101 -1
- package/dist/experiments/spec-resolver.d.ts +17 -0
- package/dist/experiments/spec.d.ts +82 -0
- package/dist/experiments/spec.js +33 -1
- package/dist/features.d.ts +104 -0
- package/dist/features.js +91 -1
- package/dist/forms/docs/forms.docblock.d.ts +6 -0
- package/dist/forms/docs/forms.docblock.js +21 -1
- package/dist/forms/forms.d.ts +266 -0
- package/dist/forms/forms.js +146 -0
- package/dist/forms/index.d.ts +2 -0
- package/dist/forms/index.js +3 -0
- package/dist/index.d.ts +142 -0
- package/dist/index.js +119 -1
- package/dist/install.d.ts +77 -0
- package/dist/install.js +40 -1
- package/dist/integrations/binding.d.ts +17 -0
- package/dist/integrations/connection.d.ts +51 -0
- package/dist/integrations/docs/integrations.docblock.d.ts +6 -0
- package/dist/integrations/docs/integrations.docblock.js +94 -1
- package/dist/integrations/health.d.ts +21 -0
- package/dist/integrations/health.js +69 -1
- package/dist/integrations/index.d.ts +34 -0
- package/dist/integrations/index.js +23 -1
- package/dist/integrations/integrations.feature.d.ts +11 -0
- package/dist/integrations/integrations.feature.js +60 -0
- package/dist/integrations/openbanking/contracts/accounts.d.ts +289 -0
- package/dist/integrations/openbanking/contracts/accounts.js +236 -1
- package/dist/integrations/openbanking/contracts/balances.d.ts +165 -0
- package/dist/integrations/openbanking/contracts/balances.js +166 -1
- package/dist/integrations/openbanking/contracts/index.d.ts +10 -0
- package/dist/integrations/openbanking/contracts/index.js +12 -1
- package/dist/integrations/openbanking/contracts/transactions.d.ts +213 -0
- package/dist/integrations/openbanking/contracts/transactions.js +217 -1
- package/dist/integrations/openbanking/guards.d.ts +12 -0
- package/dist/integrations/openbanking/guards.js +33 -1
- package/dist/integrations/openbanking/models.d.ts +228 -0
- package/dist/integrations/openbanking/models.js +240 -1
- package/dist/integrations/openbanking/openbanking.feature.d.ts +11 -0
- package/dist/integrations/openbanking/openbanking.feature.js +69 -1
- package/dist/integrations/openbanking/telemetry.d.ts +15 -0
- package/dist/integrations/openbanking/telemetry.js +39 -1
- package/dist/integrations/operations.d.ts +437 -0
- package/dist/integrations/operations.js +392 -0
- package/dist/integrations/providers/calendar.d.ts +78 -0
- package/dist/integrations/providers/elevenlabs.d.ts +7 -0
- package/dist/integrations/providers/elevenlabs.js +55 -1
- package/dist/integrations/providers/email.d.ts +86 -0
- package/dist/integrations/providers/embedding.d.ts +24 -0
- package/dist/integrations/providers/gcs-storage.d.ts +7 -0
- package/dist/integrations/providers/gcs-storage.js +78 -1
- package/dist/integrations/providers/gmail.d.ts +7 -0
- package/dist/integrations/providers/gmail.js +90 -1
- package/dist/integrations/providers/google-calendar.d.ts +7 -0
- package/dist/integrations/providers/google-calendar.js +69 -1
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts +20 -0
- package/dist/integrations/providers/impls/elevenlabs-voice.js +95 -1
- package/dist/integrations/providers/impls/gcs-storage.d.ts +24 -0
- package/dist/integrations/providers/impls/gcs-storage.js +88 -1
- package/dist/integrations/providers/impls/gmail-inbound.d.ts +26 -0
- package/dist/integrations/providers/impls/gmail-inbound.js +200 -1
- package/dist/integrations/providers/impls/gmail-outbound.d.ts +18 -0
- package/dist/integrations/providers/impls/gmail-outbound.js +104 -5
- package/dist/integrations/providers/impls/google-calendar.d.ts +23 -0
- package/dist/integrations/providers/impls/google-calendar.js +154 -1
- package/dist/integrations/providers/impls/index.d.ts +15 -0
- package/dist/integrations/providers/impls/index.js +16 -1
- package/dist/integrations/providers/impls/mistral-embedding.d.ts +23 -0
- package/dist/integrations/providers/impls/mistral-embedding.js +41 -1
- package/dist/integrations/providers/impls/mistral-llm.d.ts +31 -0
- package/dist/integrations/providers/impls/mistral-llm.js +247 -1
- package/dist/integrations/providers/impls/postmark-email.d.ts +19 -0
- package/dist/integrations/providers/impls/postmark-email.js +55 -1
- package/dist/integrations/providers/impls/powens-client.d.ts +124 -0
- package/dist/integrations/providers/impls/powens-client.js +171 -1
- package/dist/integrations/providers/impls/powens-openbanking.d.ts +27 -0
- package/dist/integrations/providers/impls/powens-openbanking.js +218 -1
- package/dist/integrations/providers/impls/provider-factory.d.ts +26 -0
- package/dist/integrations/providers/impls/provider-factory.js +145 -1
- package/dist/integrations/providers/impls/qdrant-vector.d.ts +24 -0
- package/dist/integrations/providers/impls/qdrant-vector.js +69 -1
- package/dist/integrations/providers/impls/stripe-payments.d.ts +28 -0
- package/dist/integrations/providers/impls/stripe-payments.js +202 -1
- package/dist/integrations/providers/impls/twilio-sms.d.ts +20 -0
- package/dist/integrations/providers/impls/twilio-sms.js +58 -1
- package/dist/integrations/providers/index.d.ts +22 -0
- package/dist/integrations/providers/index.js +13 -1
- package/dist/integrations/providers/llm.d.ts +82 -0
- package/dist/integrations/providers/mistral.d.ts +7 -0
- package/dist/integrations/providers/mistral.js +71 -1
- package/dist/integrations/providers/openbanking.d.ts +128 -0
- package/dist/integrations/providers/payments.d.ts +109 -0
- package/dist/integrations/providers/postmark.d.ts +7 -0
- package/dist/integrations/providers/postmark.js +71 -1
- package/dist/integrations/providers/powens.d.ts +7 -0
- package/dist/integrations/providers/powens.js +119 -1
- package/dist/integrations/providers/qdrant.d.ts +7 -0
- package/dist/integrations/providers/qdrant.js +76 -1
- package/dist/integrations/providers/registry.d.ts +11 -0
- package/dist/integrations/providers/registry.js +34 -1
- package/dist/integrations/providers/sms.d.ts +34 -0
- package/dist/integrations/providers/storage.d.ts +60 -0
- package/dist/integrations/providers/stripe.d.ts +7 -0
- package/dist/integrations/providers/stripe.js +86 -1
- package/dist/integrations/providers/twilio-sms.d.ts +7 -0
- package/dist/integrations/providers/twilio-sms.js +64 -1
- package/dist/integrations/providers/vector-store.d.ts +43 -0
- package/dist/integrations/providers/voice.d.ts +34 -0
- package/dist/integrations/runtime.d.ts +99 -0
- package/dist/integrations/runtime.js +186 -1
- package/dist/integrations/secrets/aws-secret-manager.d.ts +31 -0
- package/dist/integrations/secrets/aws-secret-manager.js +231 -1
- package/dist/integrations/secrets/env-secret-provider.d.ts +31 -0
- package/dist/integrations/secrets/env-secret-provider.js +81 -1
- package/dist/integrations/secrets/gcp-secret-manager.d.ts +32 -0
- package/dist/integrations/secrets/gcp-secret-manager.js +229 -1
- package/dist/integrations/secrets/index.d.ts +7 -0
- package/dist/integrations/secrets/index.js +8 -1
- package/dist/integrations/secrets/manager.d.ts +47 -0
- package/dist/integrations/secrets/manager.js +103 -1
- package/dist/integrations/secrets/provider.d.ts +52 -0
- package/dist/integrations/secrets/provider.js +58 -1
- package/dist/integrations/secrets/scaleway-secret-manager.d.ts +38 -0
- package/dist/integrations/secrets/scaleway-secret-manager.js +247 -1
- package/dist/integrations/secrets-types.d.ts +17 -0
- package/dist/integrations/spec.d.ts +75 -0
- package/dist/integrations/spec.js +39 -1
- package/dist/jobs/define-job.d.ts +18 -0
- package/dist/jobs/define-job.js +16 -1
- package/dist/jobs/gcp-cloud-tasks.d.ts +41 -0
- package/dist/jobs/gcp-cloud-tasks.js +53 -1
- package/dist/jobs/gcp-pubsub.d.ts +25 -0
- package/dist/jobs/gcp-pubsub.js +39 -1
- package/dist/jobs/handlers/gmail-sync-handler.d.ts +9 -0
- package/dist/jobs/handlers/gmail-sync-handler.js +9 -1
- package/dist/jobs/handlers/index.d.ts +9 -0
- package/dist/jobs/handlers/index.js +12 -1
- package/dist/jobs/handlers/ping-handler.d.ts +10 -0
- package/dist/jobs/handlers/ping-handler.js +15 -1
- package/dist/jobs/handlers/storage-document-handler.d.ts +12 -0
- package/dist/jobs/handlers/storage-document-handler.js +14 -1
- package/dist/jobs/index.d.ts +3 -0
- package/dist/jobs/index.js +4 -1
- package/dist/jobs/memory-queue.d.ts +18 -0
- package/dist/jobs/memory-queue.js +71 -1
- package/dist/jobs/queue.d.ts +131 -0
- package/dist/jobs/queue.js +33 -1
- package/dist/jobs/scaleway-sqs-queue.d.ts +30 -0
- package/dist/jobs/scaleway-sqs-queue.js +153 -1
- package/dist/jsonschema.d.ts +28 -0
- package/dist/jsonschema.js +32 -1
- package/dist/knowledge/binding.d.ts +25 -0
- package/dist/knowledge/docs/knowledge.docblock.d.ts +6 -0
- package/dist/knowledge/docs/knowledge.docblock.js +21 -138
- package/dist/knowledge/index.d.ts +11 -0
- package/dist/knowledge/index.js +10 -1
- package/dist/knowledge/ingestion/document-processor.d.ts +24 -0
- package/dist/knowledge/ingestion/document-processor.js +54 -1
- package/dist/knowledge/ingestion/embedding-service.d.ts +12 -0
- package/dist/knowledge/ingestion/embedding-service.js +25 -1
- package/dist/knowledge/ingestion/gmail-adapter.d.ts +18 -0
- package/dist/knowledge/ingestion/gmail-adapter.js +50 -5
- package/dist/knowledge/ingestion/index.d.ts +6 -0
- package/dist/knowledge/ingestion/index.js +7 -1
- package/dist/knowledge/ingestion/storage-adapter.d.ts +15 -0
- package/dist/knowledge/ingestion/storage-adapter.js +26 -1
- package/dist/knowledge/ingestion/vector-indexer.d.ts +18 -0
- package/dist/knowledge/ingestion/vector-indexer.js +32 -1
- package/dist/knowledge/knowledge.feature.d.ts +11 -0
- package/dist/knowledge/knowledge.feature.js +61 -0
- package/dist/knowledge/operations.d.ts +318 -0
- package/dist/knowledge/operations.js +321 -0
- package/dist/knowledge/query/index.d.ts +2 -0
- package/dist/knowledge/query/index.js +3 -1
- package/dist/knowledge/query/service.d.ts +29 -0
- package/dist/knowledge/query/service.js +64 -2
- package/dist/knowledge/runtime.d.ts +32 -0
- package/dist/knowledge/runtime.js +49 -1
- package/dist/knowledge/source.d.ts +32 -0
- package/dist/knowledge/spaces/email-threads.d.ts +7 -0
- package/dist/knowledge/spaces/email-threads.js +37 -1
- package/dist/knowledge/spaces/financial-docs.d.ts +7 -0
- package/dist/knowledge/spaces/financial-docs.js +37 -1
- package/dist/knowledge/spaces/financial-overview.d.ts +7 -0
- package/dist/knowledge/spaces/financial-overview.js +41 -1
- package/dist/knowledge/spaces/index.d.ts +7 -0
- package/dist/knowledge/spaces/index.js +8 -1
- package/dist/knowledge/spaces/product-canon.d.ts +7 -0
- package/dist/knowledge/spaces/product-canon.js +37 -1
- package/dist/knowledge/spaces/support-faq.d.ts +7 -0
- package/dist/knowledge/spaces/support-faq.js +40 -1
- package/dist/knowledge/spaces/uploaded-docs.d.ts +7 -0
- package/dist/knowledge/spaces/uploaded-docs.js +37 -1
- package/dist/knowledge/spec.d.ts +48 -0
- package/dist/knowledge/spec.js +39 -1
- package/dist/llm/exporters.d.ts +69 -0
- package/dist/llm/exporters.js +542 -8
- package/dist/llm/index.d.ts +4 -0
- package/dist/llm/index.js +4 -1
- package/dist/llm/prompts.d.ts +52 -0
- package/dist/llm/prompts.js +246 -56
- package/dist/llm/types.d.ts +214 -0
- package/dist/markdown.d.ts +22 -0
- package/dist/markdown.js +119 -3
- package/dist/migrations.d.ts +52 -0
- package/dist/migrations.js +33 -1
- package/dist/onboarding-base.d.ts +138 -0
- package/dist/onboarding-base.js +195 -1
- package/dist/openapi.d.ts +31 -0
- package/dist/openapi.js +75 -1
- package/dist/operations/index.d.ts +3 -0
- package/dist/operations/index.js +4 -0
- package/dist/operations/operation.d.ts +180 -0
- package/dist/operations/operation.js +35 -0
- package/dist/operations/registry.d.ts +103 -0
- package/dist/operations/registry.js +252 -0
- package/dist/ownership.d.ts +84 -0
- package/dist/ownership.js +38 -1
- package/dist/policy/docs/policy.docblock.d.ts +6 -0
- package/dist/policy/docs/policy.docblock.js +21 -1
- package/dist/policy/engine.d.ts +40 -0
- package/dist/policy/engine.js +223 -1
- package/dist/policy/index.d.ts +5 -0
- package/dist/policy/index.js +5 -0
- package/dist/policy/opa-adapter.d.ts +45 -0
- package/dist/policy/opa-adapter.js +71 -1
- package/dist/policy/registry.d.ts +9 -0
- package/dist/policy/registry.js +11 -0
- package/dist/policy/spec.d.ts +103 -0
- package/dist/policy/spec.js +0 -1
- package/dist/presentations/docs/presentations-conventions.docblock.d.ts +6 -0
- package/dist/presentations/docs/presentations-conventions.docblock.js +20 -7
- package/dist/presentations/index.d.ts +4 -0
- package/dist/presentations/index.js +5 -0
- package/dist/presentations/presentations.d.ts +50 -0
- package/dist/presentations/presentations.js +7 -0
- package/dist/presentations/registry.d.ts +10 -0
- package/dist/presentations/registry.js +12 -0
- package/dist/presentations/transform-engine.d.ts +66 -0
- package/dist/presentations/transform-engine.js +282 -0
- package/dist/prompt.d.ts +60 -0
- package/dist/prompt.js +10 -1
- package/dist/promptRegistry.d.ts +15 -0
- package/dist/promptRegistry.js +34 -1
- package/dist/regenerator/adapters.d.ts +19 -0
- package/dist/regenerator/docs/regenerator.docblock.d.ts +6 -0
- package/dist/regenerator/docs/regenerator.docblock.js +21 -184
- package/dist/regenerator/executor.d.ts +70 -0
- package/dist/regenerator/executor.js +86 -1
- package/dist/regenerator/index.d.ts +7 -0
- package/dist/regenerator/index.js +6 -1
- package/dist/regenerator/service.d.ts +33 -0
- package/dist/regenerator/service.js +92 -1
- package/dist/regenerator/sinks.d.ts +26 -0
- package/dist/regenerator/sinks.js +32 -1
- package/dist/regenerator/types.d.ts +107 -0
- package/dist/regenerator/utils.d.ts +9 -0
- package/dist/regenerator/utils.js +51 -1
- package/dist/registry-utils.d.ts +106 -0
- package/dist/registry-utils.js +122 -0
- package/dist/registry.d.ts +30 -0
- package/dist/registry.js +58 -1
- package/dist/resources.d.ts +64 -0
- package/dist/resources.js +50 -1
- package/dist/schema-to-markdown.d.ts +54 -0
- package/dist/schema-to-markdown.js +214 -10
- package/dist/server/contracts-adapter-hydration.d.ts +15 -0
- package/dist/server/contracts-adapter-hydration.js +41 -0
- package/dist/server/contracts-adapter-input.d.ts +9 -0
- package/dist/server/contracts-adapter-input.js +77 -0
- package/dist/server/graphql-pothos.d.ts +31 -0
- package/dist/server/graphql-pothos.js +127 -1
- package/dist/server/index.d.ts +9 -0
- package/dist/server/index.js +10 -1
- package/dist/server/mcp/createMcpServer.d.ts +15 -0
- package/dist/server/mcp/createMcpServer.js +28 -1
- package/dist/server/mcp/mcpTypes.d.ts +30 -0
- package/dist/server/mcp/registerPresentations.d.ts +7 -0
- package/dist/server/mcp/registerPresentations.js +112 -1
- package/dist/server/mcp/registerPrompts.d.ts +8 -0
- package/dist/server/mcp/registerPrompts.js +36 -2
- package/dist/server/mcp/registerResources.d.ts +8 -0
- package/dist/server/mcp/registerResources.js +35 -1
- package/dist/server/mcp/registerTools.d.ts +8 -0
- package/dist/server/mcp/registerTools.js +22 -1
- package/dist/server/provider-mcp.d.ts +2 -0
- package/dist/server/provider-mcp.js +3 -1
- package/dist/server/rest-elysia.d.ts +40 -0
- package/dist/server/rest-elysia.js +20 -1
- package/dist/server/rest-express.d.ts +16 -0
- package/dist/server/rest-express.js +36 -1
- package/dist/server/rest-generic.d.ts +32 -0
- package/dist/server/rest-generic.js +124 -1
- package/dist/server/rest-next-app.d.ts +35 -0
- package/dist/server/rest-next-app.js +38 -1
- package/dist/server/rest-next-mcp.d.ts +11 -0
- package/dist/server/rest-next-mcp.js +45 -1
- package/dist/server/rest-next-pages.d.ts +9 -0
- package/dist/server/rest-next-pages.js +22 -1
- package/dist/telemetry/anomaly.d.ts +27 -0
- package/dist/telemetry/anomaly.js +48 -1
- package/dist/telemetry/docs/telemetry.docblock.d.ts +6 -0
- package/dist/telemetry/docs/telemetry.docblock.js +21 -139
- package/dist/telemetry/index.d.ts +4 -0
- package/dist/telemetry/index.js +5 -1
- package/dist/telemetry/spec.d.ts +91 -0
- package/dist/telemetry/spec.js +69 -1
- package/dist/telemetry/tracker.d.ts +51 -0
- package/dist/telemetry/tracker.js +76 -1
- package/dist/tests/index.d.ts +3 -0
- package/dist/tests/index.js +4 -1
- package/dist/tests/runner.d.ts +43 -0
- package/dist/tests/runner.js +150 -1
- package/dist/tests/spec.d.ts +89 -0
- package/dist/tests/spec.js +33 -1
- package/dist/themes.d.ts +53 -0
- package/dist/themes.js +39 -1
- package/dist/translations/catalog.d.ts +28 -0
- package/dist/translations/tenant.d.ts +15 -0
- package/dist/types.d.ts +92 -0
- package/dist/workflow/adapters/db-adapter.d.ts +46 -0
- package/dist/workflow/adapters/db-adapter.js +83 -1
- package/dist/workflow/adapters/file-adapter.d.ts +14 -0
- package/dist/workflow/adapters/file-adapter.js +11 -1
- package/dist/workflow/adapters/index.d.ts +4 -0
- package/dist/workflow/adapters/index.js +5 -1
- package/dist/workflow/adapters/memory-store.d.ts +18 -0
- package/dist/workflow/adapters/memory-store.js +58 -1
- package/dist/workflow/expression.d.ts +9 -0
- package/dist/workflow/expression.js +99 -1
- package/dist/workflow/index.d.ts +10 -0
- package/dist/workflow/index.js +9 -1
- package/dist/workflow/runner.d.ts +74 -0
- package/dist/workflow/runner.js +337 -1
- package/dist/workflow/sla-monitor.d.ts +20 -0
- package/dist/workflow/sla-monitor.js +47 -1
- package/dist/workflow/spec.d.ts +105 -0
- package/dist/workflow/spec.js +55 -1
- package/dist/workflow/state.d.ts +35 -0
- package/dist/workflow/validation.d.ts +29 -0
- package/dist/workflow/validation.js +176 -1
- package/dist/workspace-config/contractsrc-schema.d.ts +786 -0
- package/dist/workspace-config/contractsrc-schema.js +247 -0
- package/dist/workspace-config/index.d.ts +2 -0
- package/dist/workspace-config/index.js +3 -0
- package/package.json +286 -266
- package/dist/capabilities.js +0 -1
- package/dist/contracts-adapter-hydration.js +0 -1
- package/dist/contracts-adapter-input.js +0 -1
- package/dist/data-views.js +0 -1
- package/dist/docs/PUBLISHING.docblock.js +0 -76
- package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +0 -383
- package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +0 -68
- package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +0 -140
- package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +0 -86
- package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +0 -1
- package/dist/forms.js +0 -1
- package/dist/integrations/contracts.js +0 -1
- package/dist/knowledge/contracts.js +0 -1
- package/dist/openbanking/docs/openbanking.docblock.js +0 -109
- package/dist/presentations.backcompat.js +0 -1
- package/dist/presentations.js +0 -1
- package/dist/presentations.v2.js +0 -7
- package/dist/spec.js +0 -1
- /package/dist/{types/all.js → integrations/secrets-types.js} +0 -0
|
@@ -1 +1,231 @@
|
|
|
1
|
-
import{SecretProviderError
|
|
1
|
+
import { SecretProviderError, normalizeSecretPayload, parseSecretUri } from "./provider.js";
|
|
2
|
+
import { Buffer } from "node:buffer";
|
|
3
|
+
import { CreateSecretCommand, DeleteSecretCommand, GetSecretValueCommand, PutSecretValueCommand, SecretsManagerClient } from "@aws-sdk/client-secrets-manager";
|
|
4
|
+
|
|
5
|
+
//#region src/integrations/secrets/aws-secret-manager.ts
|
|
6
|
+
const DEFAULT_DELETE_RECOVERY_DAYS = 7;
|
|
7
|
+
var AwsSecretsManagerProvider = class {
|
|
8
|
+
id = "aws-secrets-manager";
|
|
9
|
+
explicitRegion;
|
|
10
|
+
injectedClient;
|
|
11
|
+
clientConfig;
|
|
12
|
+
clientsByRegion = /* @__PURE__ */ new Map();
|
|
13
|
+
constructor(options = {}) {
|
|
14
|
+
this.explicitRegion = options.region;
|
|
15
|
+
this.injectedClient = options.client;
|
|
16
|
+
this.clientConfig = options.clientConfig;
|
|
17
|
+
}
|
|
18
|
+
canHandle(reference) {
|
|
19
|
+
try {
|
|
20
|
+
const parsed = parseSecretUri(reference);
|
|
21
|
+
return parsed.provider === "aws" && (parsed.path === "secretsmanager" || parsed.path.startsWith("secretsmanager/"));
|
|
22
|
+
} catch {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async getSecret(reference, options) {
|
|
27
|
+
const location = this.parseReference(reference);
|
|
28
|
+
const client = this.getClient(location.region);
|
|
29
|
+
const requestedVersion = options?.version ?? location.stage ?? location.version;
|
|
30
|
+
const input = {
|
|
31
|
+
SecretId: location.secretId,
|
|
32
|
+
...this.buildVersionSelector(requestedVersion)
|
|
33
|
+
};
|
|
34
|
+
try {
|
|
35
|
+
const result = await client.send(new GetSecretValueCommand(input));
|
|
36
|
+
return {
|
|
37
|
+
data: extractAwsSecretBytes(result, reference, this.id),
|
|
38
|
+
version: typeof result.VersionId === "string" && result.VersionId ? result.VersionId : requestedVersion,
|
|
39
|
+
metadata: {
|
|
40
|
+
region: location.region,
|
|
41
|
+
secretId: location.secretId,
|
|
42
|
+
...requestedVersion ? { requestedVersion } : {}
|
|
43
|
+
},
|
|
44
|
+
retrievedAt: /* @__PURE__ */ new Date()
|
|
45
|
+
};
|
|
46
|
+
} catch (error) {
|
|
47
|
+
throw toAwsSecretProviderError({
|
|
48
|
+
error,
|
|
49
|
+
provider: this.id,
|
|
50
|
+
reference,
|
|
51
|
+
operation: "getSecret"
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
async setSecret(reference, payload) {
|
|
56
|
+
const location = this.parseReference(reference);
|
|
57
|
+
const client = this.getClient(location.region);
|
|
58
|
+
const bytes = normalizeSecretPayload(payload);
|
|
59
|
+
try {
|
|
60
|
+
const result = await client.send(new PutSecretValueCommand({
|
|
61
|
+
SecretId: location.secretId,
|
|
62
|
+
SecretBinary: bytes
|
|
63
|
+
}));
|
|
64
|
+
const versionId = typeof result.VersionId === "string" && result.VersionId ? result.VersionId : "latest";
|
|
65
|
+
return {
|
|
66
|
+
reference: this.buildReference(location.region, location.secretId, { version: versionId }),
|
|
67
|
+
version: versionId
|
|
68
|
+
};
|
|
69
|
+
} catch (error) {
|
|
70
|
+
if (!isAwsNotFound(error)) throw toAwsSecretProviderError({
|
|
71
|
+
error,
|
|
72
|
+
provider: this.id,
|
|
73
|
+
reference,
|
|
74
|
+
operation: "putSecretValue"
|
|
75
|
+
});
|
|
76
|
+
if (looksLikeAwsArn(location.secretId)) throw new SecretProviderError({
|
|
77
|
+
message: `Secret not found: ${location.secretId}`,
|
|
78
|
+
provider: this.id,
|
|
79
|
+
reference,
|
|
80
|
+
code: "NOT_FOUND",
|
|
81
|
+
cause: error
|
|
82
|
+
});
|
|
83
|
+
try {
|
|
84
|
+
const created = await client.send(new CreateSecretCommand({
|
|
85
|
+
Name: location.secretId,
|
|
86
|
+
SecretBinary: bytes
|
|
87
|
+
}));
|
|
88
|
+
const versionId = typeof created.VersionId === "string" && created.VersionId ? created.VersionId : "latest";
|
|
89
|
+
return {
|
|
90
|
+
reference: this.buildReference(location.region, location.secretId, { version: versionId }),
|
|
91
|
+
version: versionId
|
|
92
|
+
};
|
|
93
|
+
} catch (creationError) {
|
|
94
|
+
throw toAwsSecretProviderError({
|
|
95
|
+
error: creationError,
|
|
96
|
+
provider: this.id,
|
|
97
|
+
reference,
|
|
98
|
+
operation: "createSecret"
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
async rotateSecret(reference, payload) {
|
|
104
|
+
return this.setSecret(reference, payload);
|
|
105
|
+
}
|
|
106
|
+
async deleteSecret(reference) {
|
|
107
|
+
const location = this.parseReference(reference);
|
|
108
|
+
const client = this.getClient(location.region);
|
|
109
|
+
try {
|
|
110
|
+
await client.send(new DeleteSecretCommand({
|
|
111
|
+
SecretId: location.secretId,
|
|
112
|
+
RecoveryWindowInDays: DEFAULT_DELETE_RECOVERY_DAYS
|
|
113
|
+
}));
|
|
114
|
+
} catch (error) {
|
|
115
|
+
throw toAwsSecretProviderError({
|
|
116
|
+
error,
|
|
117
|
+
provider: this.id,
|
|
118
|
+
reference,
|
|
119
|
+
operation: "deleteSecret"
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
getClient(region) {
|
|
124
|
+
if (this.injectedClient) return this.injectedClient;
|
|
125
|
+
const cached = this.clientsByRegion.get(region);
|
|
126
|
+
if (cached) return cached;
|
|
127
|
+
const client = new SecretsManagerClient({
|
|
128
|
+
...this.clientConfig ?? {},
|
|
129
|
+
region
|
|
130
|
+
});
|
|
131
|
+
this.clientsByRegion.set(region, client);
|
|
132
|
+
return client;
|
|
133
|
+
}
|
|
134
|
+
parseReference(reference) {
|
|
135
|
+
const parsed = parseSecretUri(reference);
|
|
136
|
+
if (parsed.provider !== "aws") throw new SecretProviderError({
|
|
137
|
+
message: `Unsupported secret provider: ${parsed.provider}`,
|
|
138
|
+
provider: this.id,
|
|
139
|
+
reference,
|
|
140
|
+
code: "INVALID"
|
|
141
|
+
});
|
|
142
|
+
const segments = parsed.path.split("/").filter(Boolean);
|
|
143
|
+
if (segments.length < 3 || segments[0] !== "secretsmanager") throw new SecretProviderError({
|
|
144
|
+
message: "Expected secret reference format aws://secretsmanager/{region}/{secretIdOrArn}[?version=...]",
|
|
145
|
+
provider: this.id,
|
|
146
|
+
reference,
|
|
147
|
+
code: "INVALID"
|
|
148
|
+
});
|
|
149
|
+
const regionCandidate = segments[1];
|
|
150
|
+
const region = this.resolveRegion(regionCandidate);
|
|
151
|
+
const secretId = segments.slice(2).join("/");
|
|
152
|
+
if (!secretId) throw new SecretProviderError({
|
|
153
|
+
message: `Unable to resolve secret id from reference "${parsed.path}"`,
|
|
154
|
+
provider: this.id,
|
|
155
|
+
reference,
|
|
156
|
+
code: "INVALID"
|
|
157
|
+
});
|
|
158
|
+
return {
|
|
159
|
+
region,
|
|
160
|
+
secretId,
|
|
161
|
+
version: parsed.extras?.version,
|
|
162
|
+
stage: parsed.extras?.stage
|
|
163
|
+
};
|
|
164
|
+
}
|
|
165
|
+
resolveRegion(regionCandidate) {
|
|
166
|
+
const region = regionCandidate ?? this.explicitRegion ?? process.env.AWS_REGION ?? process.env.AWS_DEFAULT_REGION;
|
|
167
|
+
if (!region) throw new SecretProviderError({
|
|
168
|
+
message: "AWS region must be provided either in reference (aws://secretsmanager/{region}/...) or via AWS_REGION/AWS_DEFAULT_REGION.",
|
|
169
|
+
provider: this.id,
|
|
170
|
+
reference: "aws://secretsmanager//",
|
|
171
|
+
code: "INVALID"
|
|
172
|
+
});
|
|
173
|
+
return region;
|
|
174
|
+
}
|
|
175
|
+
buildVersionSelector(version) {
|
|
176
|
+
if (!version) return {};
|
|
177
|
+
if (version === "latest" || version === "current") return { VersionStage: "AWSCURRENT" };
|
|
178
|
+
if (version.startsWith("AWS")) return { VersionStage: version };
|
|
179
|
+
return { VersionId: version };
|
|
180
|
+
}
|
|
181
|
+
buildReference(region, secretId, extras) {
|
|
182
|
+
const base = `aws://secretsmanager/${region}/${secretId}`;
|
|
183
|
+
const query = extras ? Object.entries(extras).filter(([, value]) => Boolean(value)).map(([key, value]) => `${encodeURIComponent(key)}=${encodeURIComponent(value)}`).join("&") : "";
|
|
184
|
+
return query ? `${base}?${query}` : base;
|
|
185
|
+
}
|
|
186
|
+
};
|
|
187
|
+
function extractAwsSecretBytes(result, reference, provider) {
|
|
188
|
+
if (!result || typeof result !== "object") throw new SecretProviderError({
|
|
189
|
+
message: "Invalid AWS Secrets Manager response",
|
|
190
|
+
provider,
|
|
191
|
+
reference,
|
|
192
|
+
code: "UNKNOWN",
|
|
193
|
+
cause: result
|
|
194
|
+
});
|
|
195
|
+
const record = result;
|
|
196
|
+
if (record.SecretBinary instanceof Uint8Array) return record.SecretBinary;
|
|
197
|
+
if (typeof record.SecretBinary === "string") return Buffer.from(record.SecretBinary, "base64");
|
|
198
|
+
if (typeof record.SecretString === "string") return Buffer.from(record.SecretString, "utf-8");
|
|
199
|
+
throw new SecretProviderError({
|
|
200
|
+
message: "AWS secret value is empty",
|
|
201
|
+
provider,
|
|
202
|
+
reference,
|
|
203
|
+
code: "NOT_FOUND",
|
|
204
|
+
cause: result
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
function looksLikeAwsArn(secretId) {
|
|
208
|
+
return secretId.startsWith("arn:aws:secretsmanager:");
|
|
209
|
+
}
|
|
210
|
+
function isAwsNotFound(error) {
|
|
211
|
+
if (!error || typeof error !== "object") return false;
|
|
212
|
+
const err = error;
|
|
213
|
+
if (typeof err.$metadata?.httpStatusCode === "number") return err.$metadata.httpStatusCode === 404;
|
|
214
|
+
return err.name === "ResourceNotFoundException";
|
|
215
|
+
}
|
|
216
|
+
function toAwsSecretProviderError(params) {
|
|
217
|
+
const { error, provider, reference, operation } = params;
|
|
218
|
+
if (error instanceof SecretProviderError) return error;
|
|
219
|
+
const httpStatusCode = typeof error === "object" && error !== null && "$metadata" in error && typeof error.$metadata === "object" && error.$metadata?.httpStatusCode;
|
|
220
|
+
const code = httpStatusCode === 404 ? "NOT_FOUND" : httpStatusCode === 401 || httpStatusCode === 403 ? "FORBIDDEN" : httpStatusCode === 400 ? "INVALID" : "UNKNOWN";
|
|
221
|
+
return new SecretProviderError({
|
|
222
|
+
message: error instanceof Error ? error.message : `Unknown error during ${operation}`,
|
|
223
|
+
provider,
|
|
224
|
+
reference,
|
|
225
|
+
code,
|
|
226
|
+
cause: error
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
//#endregion
|
|
231
|
+
export { AwsSecretsManagerProvider };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/secrets/env-secret-provider.d.ts
|
|
4
|
+
interface EnvSecretProviderOptions {
|
|
5
|
+
/**
|
|
6
|
+
* Optional map to alias secret references to environment variable names.
|
|
7
|
+
* Useful when referencing secrets from other providers (e.g. gcp://...)
|
|
8
|
+
* while still allowing local overrides.
|
|
9
|
+
*/
|
|
10
|
+
aliases?: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Environment-variable backed secret provider. Read-only by design.
|
|
14
|
+
* Allows overriding other secret providers by deriving environment variable
|
|
15
|
+
* names from secret references (or by using explicit aliases).
|
|
16
|
+
*/
|
|
17
|
+
declare class EnvSecretProvider implements SecretProvider {
|
|
18
|
+
readonly id = "env";
|
|
19
|
+
private readonly aliases;
|
|
20
|
+
constructor(options?: EnvSecretProviderOptions);
|
|
21
|
+
canHandle(reference: SecretReference): boolean;
|
|
22
|
+
getSecret(reference: SecretReference): Promise<SecretValue>;
|
|
23
|
+
setSecret(reference: SecretReference, _payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
24
|
+
rotateSecret(reference: SecretReference, _payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
25
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
26
|
+
private resolveEnvKey;
|
|
27
|
+
private deriveEnvKey;
|
|
28
|
+
private forbiddenError;
|
|
29
|
+
}
|
|
30
|
+
//#endregion
|
|
31
|
+
export { EnvSecretProvider };
|
|
@@ -1 +1,81 @@
|
|
|
1
|
-
import{SecretProviderError
|
|
1
|
+
import { SecretProviderError, parseSecretUri } from "./provider.js";
|
|
2
|
+
|
|
3
|
+
//#region src/integrations/secrets/env-secret-provider.ts
|
|
4
|
+
/**
|
|
5
|
+
* Environment-variable backed secret provider. Read-only by design.
|
|
6
|
+
* Allows overriding other secret providers by deriving environment variable
|
|
7
|
+
* names from secret references (or by using explicit aliases).
|
|
8
|
+
*/
|
|
9
|
+
var EnvSecretProvider = class {
|
|
10
|
+
id = "env";
|
|
11
|
+
aliases;
|
|
12
|
+
constructor(options = {}) {
|
|
13
|
+
this.aliases = options.aliases ?? {};
|
|
14
|
+
}
|
|
15
|
+
canHandle(reference) {
|
|
16
|
+
const envKey = this.resolveEnvKey(reference);
|
|
17
|
+
return envKey !== void 0 && process.env[envKey] !== void 0;
|
|
18
|
+
}
|
|
19
|
+
async getSecret(reference) {
|
|
20
|
+
const envKey = this.resolveEnvKey(reference);
|
|
21
|
+
if (!envKey) throw new SecretProviderError({
|
|
22
|
+
message: `Unable to resolve environment variable for reference "${reference}".`,
|
|
23
|
+
provider: this.id,
|
|
24
|
+
reference,
|
|
25
|
+
code: "INVALID"
|
|
26
|
+
});
|
|
27
|
+
const value = process.env[envKey];
|
|
28
|
+
if (value === void 0) throw new SecretProviderError({
|
|
29
|
+
message: `Environment variable "${envKey}" not found for reference "${reference}".`,
|
|
30
|
+
provider: this.id,
|
|
31
|
+
reference,
|
|
32
|
+
code: "NOT_FOUND"
|
|
33
|
+
});
|
|
34
|
+
return {
|
|
35
|
+
data: Buffer.from(value, "utf-8"),
|
|
36
|
+
version: "current",
|
|
37
|
+
metadata: {
|
|
38
|
+
source: "env",
|
|
39
|
+
envKey
|
|
40
|
+
},
|
|
41
|
+
retrievedAt: /* @__PURE__ */ new Date()
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
async setSecret(reference, _payload) {
|
|
45
|
+
throw this.forbiddenError("setSecret", reference);
|
|
46
|
+
}
|
|
47
|
+
async rotateSecret(reference, _payload) {
|
|
48
|
+
throw this.forbiddenError("rotateSecret", reference);
|
|
49
|
+
}
|
|
50
|
+
async deleteSecret(reference) {
|
|
51
|
+
throw this.forbiddenError("deleteSecret", reference);
|
|
52
|
+
}
|
|
53
|
+
resolveEnvKey(reference) {
|
|
54
|
+
if (!reference) return;
|
|
55
|
+
if (this.aliases[reference]) return this.aliases[reference];
|
|
56
|
+
if (!reference.includes("://")) return reference;
|
|
57
|
+
try {
|
|
58
|
+
const parsed = parseSecretUri(reference);
|
|
59
|
+
if (parsed.provider === "env") return parsed.path;
|
|
60
|
+
if (parsed.extras?.env) return parsed.extras.env;
|
|
61
|
+
return this.deriveEnvKey(parsed.path);
|
|
62
|
+
} catch {
|
|
63
|
+
return reference;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
deriveEnvKey(path) {
|
|
67
|
+
if (!path) return void 0;
|
|
68
|
+
return path.split(/[\/:\-\.]/).filter(Boolean).map((segment) => segment.replace(/[^a-zA-Z0-9]/g, "_").replace(/_{2,}/g, "_").toUpperCase()).join("_");
|
|
69
|
+
}
|
|
70
|
+
forbiddenError(operation, reference) {
|
|
71
|
+
return new SecretProviderError({
|
|
72
|
+
message: `EnvSecretProvider is read-only. "${operation}" is not allowed for ${reference}.`,
|
|
73
|
+
provider: this.id,
|
|
74
|
+
reference,
|
|
75
|
+
code: "FORBIDDEN"
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
//#endregion
|
|
81
|
+
export { EnvSecretProvider };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { SecretProvider, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload } from "./provider.js";
|
|
2
|
+
import { SecretManagerServiceClient, protos } from "@google-cloud/secret-manager";
|
|
3
|
+
import { CallOptions } from "google-gax";
|
|
4
|
+
|
|
5
|
+
//#region src/integrations/secrets/gcp-secret-manager.d.ts
|
|
6
|
+
type SecretManagerClient = SecretManagerServiceClient;
|
|
7
|
+
interface GcpSecretManagerProviderOptions {
|
|
8
|
+
projectId?: string;
|
|
9
|
+
client?: SecretManagerClient;
|
|
10
|
+
clientOptions?: ConstructorParameters<typeof SecretManagerServiceClient>[0];
|
|
11
|
+
defaultReplication?: protos.google.cloud.secretmanager.v1.IReplication;
|
|
12
|
+
}
|
|
13
|
+
declare class GcpSecretManagerProvider implements SecretProvider {
|
|
14
|
+
readonly id = "gcp-secret-manager";
|
|
15
|
+
private readonly client;
|
|
16
|
+
private readonly explicitProjectId?;
|
|
17
|
+
private readonly replication;
|
|
18
|
+
constructor(options?: GcpSecretManagerProviderOptions);
|
|
19
|
+
canHandle(reference: SecretReference): boolean;
|
|
20
|
+
getSecret(reference: SecretReference, options?: {
|
|
21
|
+
version?: string;
|
|
22
|
+
}, callOptions?: CallOptions): Promise<SecretValue>;
|
|
23
|
+
setSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
24
|
+
rotateSecret(reference: SecretReference, payload: SecretWritePayload): Promise<SecretRotationResult>;
|
|
25
|
+
deleteSecret(reference: SecretReference): Promise<void>;
|
|
26
|
+
private parseReference;
|
|
27
|
+
private buildNames;
|
|
28
|
+
private buildVersionName;
|
|
29
|
+
private ensureSecretExists;
|
|
30
|
+
}
|
|
31
|
+
//#endregion
|
|
32
|
+
export { GcpSecretManagerProvider };
|
|
@@ -1 +1,229 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { SecretProviderError, normalizeSecretPayload, parseSecretUri } from "./provider.js";
|
|
2
|
+
import { SecretManagerServiceClient, protos } from "@google-cloud/secret-manager";
|
|
3
|
+
|
|
4
|
+
//#region src/integrations/secrets/gcp-secret-manager.ts
|
|
5
|
+
const DEFAULT_REPLICATION = { automatic: {} };
|
|
6
|
+
var GcpSecretManagerProvider = class {
|
|
7
|
+
id = "gcp-secret-manager";
|
|
8
|
+
client;
|
|
9
|
+
explicitProjectId;
|
|
10
|
+
replication;
|
|
11
|
+
constructor(options = {}) {
|
|
12
|
+
this.client = options.client ?? new SecretManagerServiceClient(options.clientOptions ?? {});
|
|
13
|
+
this.explicitProjectId = options.projectId;
|
|
14
|
+
this.replication = options.defaultReplication ?? DEFAULT_REPLICATION;
|
|
15
|
+
}
|
|
16
|
+
canHandle(reference) {
|
|
17
|
+
try {
|
|
18
|
+
return parseSecretUri(reference).provider === "gcp";
|
|
19
|
+
} catch {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
async getSecret(reference, options, callOptions) {
|
|
24
|
+
const location = this.parseReference(reference);
|
|
25
|
+
const secretVersionName = this.buildVersionName(location, options?.version);
|
|
26
|
+
try {
|
|
27
|
+
const [result] = await this.client.accessSecretVersion({ name: secretVersionName }, callOptions ?? {});
|
|
28
|
+
const payload = result.payload;
|
|
29
|
+
if (!payload?.data) throw new SecretProviderError({
|
|
30
|
+
message: `Secret payload empty for ${secretVersionName}`,
|
|
31
|
+
provider: this.id,
|
|
32
|
+
reference,
|
|
33
|
+
code: "UNKNOWN"
|
|
34
|
+
});
|
|
35
|
+
const version = extractVersionFromName(result.name ?? secretVersionName);
|
|
36
|
+
return {
|
|
37
|
+
data: payload.data,
|
|
38
|
+
version,
|
|
39
|
+
metadata: payload.dataCrc32c ? { crc32c: payload.dataCrc32c.toString() } : void 0,
|
|
40
|
+
retrievedAt: /* @__PURE__ */ new Date()
|
|
41
|
+
};
|
|
42
|
+
} catch (error) {
|
|
43
|
+
throw toSecretProviderError({
|
|
44
|
+
error,
|
|
45
|
+
provider: this.id,
|
|
46
|
+
reference,
|
|
47
|
+
operation: "access"
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
async setSecret(reference, payload) {
|
|
52
|
+
const location = this.parseReference(reference);
|
|
53
|
+
const { secretName } = this.buildNames(location);
|
|
54
|
+
const data = normalizeSecretPayload(payload);
|
|
55
|
+
await this.ensureSecretExists(location, payload);
|
|
56
|
+
try {
|
|
57
|
+
const response = await this.client.addSecretVersion({
|
|
58
|
+
parent: secretName,
|
|
59
|
+
payload: { data }
|
|
60
|
+
});
|
|
61
|
+
if (!response) throw new SecretProviderError({
|
|
62
|
+
message: `No version returned when adding secret version for ${secretName}`,
|
|
63
|
+
provider: this.id,
|
|
64
|
+
reference,
|
|
65
|
+
code: "UNKNOWN"
|
|
66
|
+
});
|
|
67
|
+
const [version] = response;
|
|
68
|
+
const versionName = version?.name ?? `${secretName}/versions/latest`;
|
|
69
|
+
return {
|
|
70
|
+
reference: `gcp://${versionName}`,
|
|
71
|
+
version: extractVersionFromName(versionName) ?? "latest"
|
|
72
|
+
};
|
|
73
|
+
} catch (error) {
|
|
74
|
+
throw toSecretProviderError({
|
|
75
|
+
error,
|
|
76
|
+
provider: this.id,
|
|
77
|
+
reference,
|
|
78
|
+
operation: "addSecretVersion"
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
async rotateSecret(reference, payload) {
|
|
83
|
+
return this.setSecret(reference, payload);
|
|
84
|
+
}
|
|
85
|
+
async deleteSecret(reference) {
|
|
86
|
+
const location = this.parseReference(reference);
|
|
87
|
+
const { secretName } = this.buildNames(location);
|
|
88
|
+
try {
|
|
89
|
+
await this.client.deleteSecret({ name: secretName });
|
|
90
|
+
} catch (error) {
|
|
91
|
+
throw toSecretProviderError({
|
|
92
|
+
error,
|
|
93
|
+
provider: this.id,
|
|
94
|
+
reference,
|
|
95
|
+
operation: "delete"
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
parseReference(reference) {
|
|
100
|
+
const parsed = parseSecretUri(reference);
|
|
101
|
+
if (parsed.provider !== "gcp") throw new SecretProviderError({
|
|
102
|
+
message: `Unsupported secret provider: ${parsed.provider}`,
|
|
103
|
+
provider: this.id,
|
|
104
|
+
reference,
|
|
105
|
+
code: "INVALID"
|
|
106
|
+
});
|
|
107
|
+
const segments = parsed.path.split("/").filter(Boolean);
|
|
108
|
+
if (segments.length < 4 || segments[0] !== "projects") throw new SecretProviderError({
|
|
109
|
+
message: `Expected secret reference format gcp://projects/{project}/secrets/{secret}[(/versions/{version})] but received "${parsed.path}"`,
|
|
110
|
+
provider: this.id,
|
|
111
|
+
reference,
|
|
112
|
+
code: "INVALID"
|
|
113
|
+
});
|
|
114
|
+
const projectIdCandidate = segments[1] ?? this.explicitProjectId;
|
|
115
|
+
if (!projectIdCandidate) throw new SecretProviderError({
|
|
116
|
+
message: `Unable to resolve project or secret from reference "${parsed.path}"`,
|
|
117
|
+
provider: this.id,
|
|
118
|
+
reference,
|
|
119
|
+
code: "INVALID"
|
|
120
|
+
});
|
|
121
|
+
const indexOfSecrets = segments.indexOf("secrets");
|
|
122
|
+
if (indexOfSecrets === -1 || indexOfSecrets + 1 >= segments.length) throw new SecretProviderError({
|
|
123
|
+
message: `Unable to resolve project or secret from reference "${parsed.path}"`,
|
|
124
|
+
provider: this.id,
|
|
125
|
+
reference,
|
|
126
|
+
code: "INVALID"
|
|
127
|
+
});
|
|
128
|
+
const resolvedProjectId = projectIdCandidate;
|
|
129
|
+
const secretIdCandidate = segments[indexOfSecrets + 1];
|
|
130
|
+
if (!secretIdCandidate) throw new SecretProviderError({
|
|
131
|
+
message: `Unable to resolve secret ID from reference "${parsed.path}"`,
|
|
132
|
+
provider: this.id,
|
|
133
|
+
reference,
|
|
134
|
+
code: "INVALID"
|
|
135
|
+
});
|
|
136
|
+
const secretId = secretIdCandidate;
|
|
137
|
+
const indexOfVersions = segments.indexOf("versions");
|
|
138
|
+
return {
|
|
139
|
+
projectId: resolvedProjectId,
|
|
140
|
+
secretId,
|
|
141
|
+
version: parsed.extras?.version ?? (indexOfVersions !== -1 && indexOfVersions + 1 < segments.length ? segments[indexOfVersions + 1] : void 0)
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
buildNames(location) {
|
|
145
|
+
const projectId = location.projectId ?? this.explicitProjectId;
|
|
146
|
+
if (!projectId) throw new SecretProviderError({
|
|
147
|
+
message: "Project ID must be provided either in reference or provider configuration",
|
|
148
|
+
provider: this.id,
|
|
149
|
+
reference: `gcp://projects//secrets/${location.secretId}`,
|
|
150
|
+
code: "INVALID"
|
|
151
|
+
});
|
|
152
|
+
const projectParent = `projects/${projectId}`;
|
|
153
|
+
return {
|
|
154
|
+
projectParent,
|
|
155
|
+
secretName: `${projectParent}/secrets/${location.secretId}`
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
buildVersionName(location, explicitVersion) {
|
|
159
|
+
const { secretName } = this.buildNames(location);
|
|
160
|
+
return `${secretName}/versions/${explicitVersion ?? location.version ?? "latest"}`;
|
|
161
|
+
}
|
|
162
|
+
async ensureSecretExists(location, payload) {
|
|
163
|
+
const { secretName, projectParent } = this.buildNames(location);
|
|
164
|
+
try {
|
|
165
|
+
await this.client.getSecret({ name: secretName });
|
|
166
|
+
} catch (error) {
|
|
167
|
+
const providerError = toSecretProviderError({
|
|
168
|
+
error,
|
|
169
|
+
provider: this.id,
|
|
170
|
+
reference: `gcp://${secretName}`,
|
|
171
|
+
operation: "getSecret",
|
|
172
|
+
suppressThrow: true
|
|
173
|
+
});
|
|
174
|
+
if (!providerError || providerError.code !== "NOT_FOUND") {
|
|
175
|
+
if (providerError) throw providerError;
|
|
176
|
+
throw error;
|
|
177
|
+
}
|
|
178
|
+
try {
|
|
179
|
+
await this.client.createSecret({
|
|
180
|
+
parent: projectParent,
|
|
181
|
+
secretId: location.secretId,
|
|
182
|
+
secret: {
|
|
183
|
+
replication: this.replication,
|
|
184
|
+
labels: payload.labels
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
} catch (creationError) {
|
|
188
|
+
throw toSecretProviderError({
|
|
189
|
+
error: creationError,
|
|
190
|
+
provider: this.id,
|
|
191
|
+
reference: `gcp://${secretName}`,
|
|
192
|
+
operation: "createSecret"
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
};
|
|
198
|
+
function extractVersionFromName(name) {
|
|
199
|
+
const segments = name.split("/").filter(Boolean);
|
|
200
|
+
const index = segments.indexOf("versions");
|
|
201
|
+
if (index === -1 || index + 1 >= segments.length) return;
|
|
202
|
+
return segments[index + 1];
|
|
203
|
+
}
|
|
204
|
+
function toSecretProviderError(params) {
|
|
205
|
+
const { error, provider, reference, operation, suppressThrow } = params;
|
|
206
|
+
if (error instanceof SecretProviderError) return error;
|
|
207
|
+
const code = deriveErrorCode(error);
|
|
208
|
+
const providerError = new SecretProviderError({
|
|
209
|
+
message: error instanceof Error ? error.message : `Unknown error during ${operation}`,
|
|
210
|
+
provider,
|
|
211
|
+
reference,
|
|
212
|
+
code,
|
|
213
|
+
cause: error
|
|
214
|
+
});
|
|
215
|
+
if (suppressThrow) return providerError;
|
|
216
|
+
throw providerError;
|
|
217
|
+
}
|
|
218
|
+
function deriveErrorCode(error) {
|
|
219
|
+
if (typeof error !== "object" || error === null) return "UNKNOWN";
|
|
220
|
+
const code = error.code;
|
|
221
|
+
if (code === 5 || code === "NOT_FOUND") return "NOT_FOUND";
|
|
222
|
+
if (code === 6 || code === "ALREADY_EXISTS") return "INVALID";
|
|
223
|
+
if (code === 7 || code === "PERMISSION_DENIED" || code === 403) return "FORBIDDEN";
|
|
224
|
+
if (code === 3 || code === "INVALID_ARGUMENT") return "INVALID";
|
|
225
|
+
return "UNKNOWN";
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
//#endregion
|
|
229
|
+
export { GcpSecretManagerProvider };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ParsedSecretUri, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri } from "./provider.js";
|
|
2
|
+
import { AwsSecretsManagerProvider } from "./aws-secret-manager.js";
|
|
3
|
+
import { EnvSecretProvider } from "./env-secret-provider.js";
|
|
4
|
+
import { GcpSecretManagerProvider } from "./gcp-secret-manager.js";
|
|
5
|
+
import { ScalewaySecretManagerProvider } from "./scaleway-secret-manager.js";
|
|
6
|
+
import { SecretProviderManager, SecretProviderManagerOptions } from "./manager.js";
|
|
7
|
+
export { AwsSecretsManagerProvider, EnvSecretProvider, GcpSecretManagerProvider, ParsedSecretUri, ScalewaySecretManagerProvider, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretProviderManager, SecretProviderManagerOptions, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri };
|
|
@@ -1 +1,8 @@
|
|
|
1
|
-
import{SecretProviderError
|
|
1
|
+
import { SecretProviderError, normalizeSecretPayload, parseSecretUri } from "./provider.js";
|
|
2
|
+
import { AwsSecretsManagerProvider } from "./aws-secret-manager.js";
|
|
3
|
+
import { EnvSecretProvider } from "./env-secret-provider.js";
|
|
4
|
+
import { GcpSecretManagerProvider } from "./gcp-secret-manager.js";
|
|
5
|
+
import { ScalewaySecretManagerProvider } from "./scaleway-secret-manager.js";
|
|
6
|
+
import { SecretProviderManager } from "./manager.js";
|
|
7
|
+
|
|
8
|
+
export { AwsSecretsManagerProvider, EnvSecretProvider, GcpSecretManagerProvider, ScalewaySecretManagerProvider, SecretProviderError, SecretProviderManager, normalizeSecretPayload, parseSecretUri };
|