@lssm/lib.contracts 0.0.0-canary-20251217080011 → 0.0.0-canary-20251219202229
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/dist/app-config/app-config.feature.d.ts +2 -1
- package/dist/app-config/app-config.feature.d.ts.map +1 -0
- package/dist/app-config/app-config.feature.js +2 -1
- package/dist/app-config/app-config.feature.js.map +1 -0
- package/dist/app-config/branding.d.ts +2 -1
- package/dist/app-config/branding.d.ts.map +1 -0
- package/dist/app-config/contracts.d.ts +52 -51
- package/dist/app-config/contracts.d.ts.map +1 -0
- package/dist/app-config/contracts.js +56 -57
- package/dist/app-config/contracts.js.map +1 -0
- package/dist/app-config/docs/app-config.docblock.d.ts +2 -1
- package/dist/app-config/docs/app-config.docblock.d.ts.map +1 -0
- package/dist/app-config/docs/app-config.docblock.js +2 -1
- package/dist/app-config/docs/app-config.docblock.js.map +1 -0
- package/dist/app-config/events.d.ts +29 -28
- package/dist/app-config/events.d.ts.map +1 -0
- package/dist/app-config/events.js +33 -34
- package/dist/app-config/events.js.map +1 -0
- package/dist/app-config/lifecycle-contracts.d.ts +82 -81
- package/dist/app-config/lifecycle-contracts.d.ts.map +1 -0
- package/dist/app-config/lifecycle-contracts.js +68 -69
- package/dist/app-config/lifecycle-contracts.js.map +1 -0
- package/dist/app-config/lifecycle.d.ts +2 -1
- package/dist/app-config/lifecycle.d.ts.map +1 -0
- package/dist/app-config/runtime.d.ts +2 -1
- package/dist/app-config/runtime.d.ts.map +1 -0
- package/dist/app-config/runtime.js +2 -1
- package/dist/app-config/runtime.js.map +1 -0
- package/dist/app-config/spec.d.ts +2 -1
- package/dist/app-config/spec.d.ts.map +1 -0
- package/dist/app-config/spec.js +2 -1
- package/dist/app-config/spec.js.map +1 -0
- package/dist/app-config/validation.d.ts +2 -1
- package/dist/app-config/validation.d.ts.map +1 -0
- package/dist/app-config/validation.js +2 -1
- package/dist/app-config/validation.js.map +1 -0
- package/dist/capabilities/docs/capabilities.docblock.d.ts +2 -1
- package/dist/capabilities/docs/capabilities.docblock.d.ts.map +1 -0
- package/dist/capabilities/docs/capabilities.docblock.js +2 -1
- package/dist/capabilities/docs/capabilities.docblock.js.map +1 -0
- package/dist/capabilities/openbanking.d.ts +2 -1
- package/dist/capabilities/openbanking.d.ts.map +1 -0
- package/dist/capabilities/openbanking.js +2 -1
- package/dist/capabilities/openbanking.js.map +1 -0
- package/dist/capabilities.d.ts +2 -1
- package/dist/capabilities.d.ts.map +1 -0
- package/dist/capabilities.js +2 -1
- package/dist/capabilities.js.map +1 -0
- package/dist/client/react/drivers/rn-reusables.d.ts +2 -1
- package/dist/client/react/drivers/rn-reusables.d.ts.map +1 -0
- package/dist/client/react/drivers/rn-reusables.js +2 -1
- package/dist/client/react/drivers/rn-reusables.js.map +1 -0
- package/dist/client/react/drivers/shadcn.d.ts +2 -1
- package/dist/client/react/drivers/shadcn.d.ts.map +1 -0
- package/dist/client/react/drivers/shadcn.js +2 -1
- package/dist/client/react/drivers/shadcn.js.map +1 -0
- package/dist/client/react/feature-render.d.ts +2 -1
- package/dist/client/react/feature-render.d.ts.map +1 -0
- package/dist/client/react/feature-render.js +2 -1
- package/dist/client/react/feature-render.js.map +1 -0
- package/dist/client/react/form-render.d.ts +8 -7
- package/dist/client/react/form-render.d.ts.map +1 -0
- package/dist/client/react/form-render.js +17 -16
- package/dist/client/react/form-render.js.map +1 -0
- package/dist/contract-registry/schemas.d.ts +2 -1
- package/dist/contract-registry/schemas.d.ts.map +1 -0
- package/dist/contract-registry/schemas.js +2 -1
- package/dist/contract-registry/schemas.js.map +1 -0
- package/dist/contract-registry/types.d.ts +2 -1
- package/dist/contract-registry/types.d.ts.map +1 -0
- package/dist/contracts-adapter-hydration.d.ts +2 -1
- package/dist/contracts-adapter-hydration.d.ts.map +1 -0
- package/dist/contracts-adapter-hydration.js +2 -1
- package/dist/contracts-adapter-hydration.js.map +1 -0
- package/dist/contracts-adapter-input.d.ts +2 -1
- package/dist/contracts-adapter-input.d.ts.map +1 -0
- package/dist/contracts-adapter-input.js +2 -1
- package/dist/contracts-adapter-input.js.map +1 -0
- package/dist/data-views/docs/data-views.docblock.d.ts +2 -1
- package/dist/data-views/docs/data-views.docblock.d.ts.map +1 -0
- package/dist/data-views/docs/data-views.docblock.js +2 -1
- package/dist/data-views/docs/data-views.docblock.js.map +1 -0
- package/dist/data-views/query-generator.d.ts +2 -1
- package/dist/data-views/query-generator.d.ts.map +1 -0
- package/dist/data-views/query-generator.js +2 -1
- package/dist/data-views/query-generator.js.map +1 -0
- package/dist/data-views/runtime.d.ts +2 -1
- package/dist/data-views/runtime.d.ts.map +1 -0
- package/dist/data-views/runtime.js +2 -1
- package/dist/data-views/runtime.js.map +1 -0
- package/dist/data-views.d.ts +2 -1
- package/dist/data-views.d.ts.map +1 -0
- package/dist/data-views.js +2 -1
- package/dist/data-views.js.map +1 -0
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.d.ts +2 -1
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.d.ts.map +1 -0
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.js +2 -1
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.js.map +1 -0
- package/dist/docs/index.js +0 -6
- package/dist/docs/meta.docs.d.ts +2 -1
- package/dist/docs/meta.docs.d.ts.map +1 -0
- package/dist/docs/meta.docs.js +5 -1
- package/dist/docs/meta.docs.js.map +1 -0
- package/dist/docs/presentations.d.ts +2 -1
- package/dist/docs/presentations.d.ts.map +1 -0
- package/dist/docs/presentations.js +2 -1
- package/dist/docs/presentations.js.map +1 -0
- package/dist/docs/registry.d.ts +2 -1
- package/dist/docs/registry.d.ts.map +1 -0
- package/dist/docs/registry.js +2 -1
- package/dist/docs/registry.js.map +1 -0
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.d.ts +2 -1
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.d.ts.map +1 -0
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.js +2 -1
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/README.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/README.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/README.docblock.js +2 -1
- package/dist/docs/tech/contracts/README.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/create-subscription.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/create-subscription.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/create-subscription.docblock.js +2 -1
- package/dist/docs/tech/contracts/create-subscription.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.js +2 -1
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/migrations.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/migrations.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/migrations.docblock.js +2 -1
- package/dist/docs/tech/contracts/migrations.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/openapi-export.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/openapi-export.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/openapi-export.docblock.js +2 -1
- package/dist/docs/tech/contracts/openapi-export.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.js +2 -1
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/overlays.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/overlays.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/overlays.docblock.js +2 -1
- package/dist/docs/tech/contracts/overlays.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/tests.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/tests.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/tests.docblock.js +2 -1
- package/dist/docs/tech/contracts/tests.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/themes.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/themes.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/themes.docblock.js +2 -1
- package/dist/docs/tech/contracts/themes.docblock.js.map +1 -0
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.d.ts +2 -1
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.d.ts.map +1 -0
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.js +2 -1
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.js.map +1 -0
- package/dist/docs/tech/lifecycle-stage-system.docblock.d.ts +2 -1
- package/dist/docs/tech/lifecycle-stage-system.docblock.d.ts.map +1 -0
- package/dist/docs/tech/lifecycle-stage-system.docblock.js +2 -1
- package/dist/docs/tech/lifecycle-stage-system.docblock.js.map +1 -0
- package/dist/docs/tech/llm/llm-integration.docblock.d.ts +2 -1
- package/dist/docs/tech/llm/llm-integration.docblock.d.ts.map +1 -0
- package/dist/docs/tech/llm/llm-integration.docblock.js +2 -1
- package/dist/docs/tech/llm/llm-integration.docblock.js.map +1 -0
- package/dist/docs/tech/mcp-endpoints.docblock.d.ts +2 -1
- package/dist/docs/tech/mcp-endpoints.docblock.d.ts.map +1 -0
- package/dist/docs/tech/mcp-endpoints.docblock.js +2 -1
- package/dist/docs/tech/mcp-endpoints.docblock.js.map +1 -0
- package/dist/docs/tech/presentation-runtime.docblock.d.ts +2 -1
- package/dist/docs/tech/presentation-runtime.docblock.d.ts.map +1 -0
- package/dist/docs/tech/presentation-runtime.docblock.js +2 -1
- package/dist/docs/tech/presentation-runtime.docblock.js.map +1 -0
- package/dist/docs/tech/schema/README.docblock.d.ts +2 -1
- package/dist/docs/tech/schema/README.docblock.d.ts.map +1 -0
- package/dist/docs/tech/schema/README.docblock.js +2 -1
- package/dist/docs/tech/schema/README.docblock.js.map +1 -0
- package/dist/docs/tech/studio/learning-events.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/learning-events.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/learning-events.docblock.js +2 -1
- package/dist/docs/tech/studio/learning-events.docblock.js.map +1 -0
- package/dist/docs/tech/studio/learning-journeys.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/learning-journeys.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/learning-journeys.docblock.js +2 -1
- package/dist/docs/tech/studio/learning-journeys.docblock.js.map +1 -0
- package/dist/docs/tech/studio/platform-admin-panel.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/platform-admin-panel.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/platform-admin-panel.docblock.js +2 -1
- package/dist/docs/tech/studio/platform-admin-panel.docblock.js.map +1 -0
- package/dist/docs/tech/studio/project-access-teams.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/project-access-teams.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/project-access-teams.docblock.js +2 -1
- package/dist/docs/tech/studio/project-access-teams.docblock.js.map +1 -0
- package/dist/docs/tech/studio/project-routing.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/project-routing.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/project-routing.docblock.js +2 -1
- package/dist/docs/tech/studio/project-routing.docblock.js.map +1 -0
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.js +2 -1
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.js.map +1 -0
- package/dist/docs/tech/studio/team-invitations.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/team-invitations.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/team-invitations.docblock.js +2 -1
- package/dist/docs/tech/studio/team-invitations.docblock.js.map +1 -0
- package/dist/docs/tech/studio/workspace-ops.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/workspace-ops.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/workspace-ops.docblock.js +2 -1
- package/dist/docs/tech/studio/workspace-ops.docblock.js.map +1 -0
- package/dist/docs/tech/studio/workspaces.docblock.d.ts +2 -1
- package/dist/docs/tech/studio/workspaces.docblock.d.ts.map +1 -0
- package/dist/docs/tech/studio/workspaces.docblock.js +2 -1
- package/dist/docs/tech/studio/workspaces.docblock.js.map +1 -0
- package/dist/docs/tech/telemetry-ingest.docblock.d.ts +2 -1
- package/dist/docs/tech/telemetry-ingest.docblock.d.ts.map +1 -0
- package/dist/docs/tech/telemetry-ingest.docblock.js +2 -1
- package/dist/docs/tech/telemetry-ingest.docblock.js.map +1 -0
- package/dist/docs/tech/templates/runtime.docblock.d.ts +2 -1
- package/dist/docs/tech/templates/runtime.docblock.d.ts.map +1 -0
- package/dist/docs/tech/templates/runtime.docblock.js +2 -1
- package/dist/docs/tech/templates/runtime.docblock.js.map +1 -0
- package/dist/docs/tech/vscode-extension.docblock.d.ts +2 -1
- package/dist/docs/tech/vscode-extension.docblock.d.ts.map +1 -0
- package/dist/docs/tech/vscode-extension.docblock.js +2 -1
- package/dist/docs/tech/vscode-extension.docblock.js.map +1 -0
- package/dist/docs/tech/workflows/overview.docblock.d.ts +2 -1
- package/dist/docs/tech/workflows/overview.docblock.d.ts.map +1 -0
- package/dist/docs/tech/workflows/overview.docblock.js +2 -1
- package/dist/docs/tech/workflows/overview.docblock.js.map +1 -0
- package/dist/docs/tech-contracts.docs.d.ts +2 -1
- package/dist/docs/tech-contracts.docs.d.ts.map +1 -0
- package/dist/docs/tech-contracts.docs.js +5 -1
- package/dist/docs/tech-contracts.docs.js.map +1 -0
- package/dist/docs/types.d.ts +2 -1
- package/dist/docs/types.d.ts.map +1 -0
- package/dist/events.d.ts +2 -1
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +2 -1
- package/dist/events.js.map +1 -0
- package/dist/experiments/docs/experiments.docblock.d.ts +2 -1
- package/dist/experiments/docs/experiments.docblock.d.ts.map +1 -0
- package/dist/experiments/docs/experiments.docblock.js +2 -1
- package/dist/experiments/docs/experiments.docblock.js.map +1 -0
- package/dist/experiments/evaluator.d.ts +2 -1
- package/dist/experiments/evaluator.d.ts.map +1 -0
- package/dist/experiments/evaluator.js +2 -1
- package/dist/experiments/evaluator.js.map +1 -0
- package/dist/experiments/spec-resolver.d.ts +2 -1
- package/dist/experiments/spec-resolver.d.ts.map +1 -0
- package/dist/experiments/spec.d.ts +2 -1
- package/dist/experiments/spec.d.ts.map +1 -0
- package/dist/experiments/spec.js +2 -1
- package/dist/experiments/spec.js.map +1 -0
- package/dist/features.d.ts +2 -1
- package/dist/features.d.ts.map +1 -0
- package/dist/features.js +2 -1
- package/dist/features.js.map +1 -0
- package/dist/forms/docs/forms.docblock.d.ts +2 -1
- package/dist/forms/docs/forms.docblock.d.ts.map +1 -0
- package/dist/forms/docs/forms.docblock.js +2 -1
- package/dist/forms/docs/forms.docblock.js.map +1 -0
- package/dist/forms.d.ts +2 -1
- package/dist/forms.d.ts.map +1 -0
- package/dist/forms.js +2 -1
- package/dist/forms.js.map +1 -0
- package/dist/index.js +2 -3
- package/dist/install.d.ts +2 -1
- package/dist/install.d.ts.map +1 -0
- package/dist/install.js +2 -1
- package/dist/install.js.map +1 -0
- package/dist/integrations/binding.d.ts +2 -1
- package/dist/integrations/binding.d.ts.map +1 -0
- package/dist/integrations/connection.d.ts +2 -1
- package/dist/integrations/connection.d.ts.map +1 -0
- package/dist/integrations/contracts.d.ts +104 -103
- package/dist/integrations/contracts.d.ts.map +1 -0
- package/dist/integrations/contracts.js +65 -66
- package/dist/integrations/contracts.js.map +1 -0
- package/dist/integrations/docs/integrations.docblock.d.ts +2 -1
- package/dist/integrations/docs/integrations.docblock.d.ts.map +1 -0
- package/dist/integrations/docs/integrations.docblock.js +2 -1
- package/dist/integrations/docs/integrations.docblock.js.map +1 -0
- package/dist/integrations/health.d.ts +2 -1
- package/dist/integrations/health.d.ts.map +1 -0
- package/dist/integrations/health.js +2 -1
- package/dist/integrations/health.js.map +1 -0
- package/dist/integrations/openbanking/contracts/accounts.d.ts +68 -67
- package/dist/integrations/openbanking/contracts/accounts.d.ts.map +1 -0
- package/dist/integrations/openbanking/contracts/accounts.js +31 -32
- package/dist/integrations/openbanking/contracts/accounts.js.map +1 -0
- package/dist/integrations/openbanking/contracts/balances.d.ts +2 -1
- package/dist/integrations/openbanking/contracts/balances.d.ts.map +1 -0
- package/dist/integrations/openbanking/contracts/balances.js +18 -19
- package/dist/integrations/openbanking/contracts/balances.js.map +1 -0
- package/dist/integrations/openbanking/contracts/index.d.ts +2 -1
- package/dist/integrations/openbanking/contracts/index.d.ts.map +1 -0
- package/dist/integrations/openbanking/contracts/index.js +2 -1
- package/dist/integrations/openbanking/contracts/index.js.map +1 -0
- package/dist/integrations/openbanking/contracts/transactions.d.ts +50 -49
- package/dist/integrations/openbanking/contracts/transactions.d.ts.map +1 -0
- package/dist/integrations/openbanking/contracts/transactions.js +32 -33
- package/dist/integrations/openbanking/contracts/transactions.js.map +1 -0
- package/dist/integrations/openbanking/guards.d.ts +2 -1
- package/dist/integrations/openbanking/guards.d.ts.map +1 -0
- package/dist/integrations/openbanking/guards.js +2 -1
- package/dist/integrations/openbanking/guards.js.map +1 -0
- package/dist/integrations/openbanking/models.d.ts +2 -1
- package/dist/integrations/openbanking/models.d.ts.map +1 -0
- package/dist/integrations/openbanking/models.js +60 -61
- package/dist/integrations/openbanking/models.js.map +1 -0
- package/dist/integrations/openbanking/openbanking.feature.d.ts +2 -1
- package/dist/integrations/openbanking/openbanking.feature.d.ts.map +1 -0
- package/dist/integrations/openbanking/openbanking.feature.js +2 -1
- package/dist/integrations/openbanking/openbanking.feature.js.map +1 -0
- package/dist/integrations/openbanking/telemetry.d.ts +2 -1
- package/dist/integrations/openbanking/telemetry.d.ts.map +1 -0
- package/dist/integrations/openbanking/telemetry.js +2 -1
- package/dist/integrations/openbanking/telemetry.js.map +1 -0
- package/dist/integrations/providers/calendar.d.ts +2 -1
- package/dist/integrations/providers/calendar.d.ts.map +1 -0
- package/dist/integrations/providers/elevenlabs.d.ts +2 -1
- package/dist/integrations/providers/elevenlabs.d.ts.map +1 -0
- package/dist/integrations/providers/elevenlabs.js +2 -1
- package/dist/integrations/providers/elevenlabs.js.map +1 -0
- package/dist/integrations/providers/email.d.ts +2 -1
- package/dist/integrations/providers/email.d.ts.map +1 -0
- package/dist/integrations/providers/embedding.d.ts +2 -1
- package/dist/integrations/providers/embedding.d.ts.map +1 -0
- package/dist/integrations/providers/gcs-storage.d.ts +2 -1
- package/dist/integrations/providers/gcs-storage.d.ts.map +1 -0
- package/dist/integrations/providers/gcs-storage.js +2 -1
- package/dist/integrations/providers/gcs-storage.js.map +1 -0
- package/dist/integrations/providers/gmail.d.ts +2 -1
- package/dist/integrations/providers/gmail.d.ts.map +1 -0
- package/dist/integrations/providers/gmail.js +2 -1
- package/dist/integrations/providers/gmail.js.map +1 -0
- package/dist/integrations/providers/google-calendar.d.ts +2 -1
- package/dist/integrations/providers/google-calendar.d.ts.map +1 -0
- package/dist/integrations/providers/google-calendar.js +2 -1
- package/dist/integrations/providers/google-calendar.js.map +1 -0
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts +2 -1
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts.map +1 -0
- package/dist/integrations/providers/impls/elevenlabs-voice.js +2 -1
- package/dist/integrations/providers/impls/elevenlabs-voice.js.map +1 -0
- package/dist/integrations/providers/impls/gcs-storage.d.ts +2 -1
- package/dist/integrations/providers/impls/gcs-storage.d.ts.map +1 -0
- package/dist/integrations/providers/impls/gcs-storage.js +2 -1
- package/dist/integrations/providers/impls/gcs-storage.js.map +1 -0
- package/dist/integrations/providers/impls/gmail-inbound.d.ts +2 -1
- package/dist/integrations/providers/impls/gmail-inbound.d.ts.map +1 -0
- package/dist/integrations/providers/impls/gmail-inbound.js +2 -1
- package/dist/integrations/providers/impls/gmail-inbound.js.map +1 -0
- package/dist/integrations/providers/impls/gmail-outbound.d.ts +2 -1
- package/dist/integrations/providers/impls/gmail-outbound.d.ts.map +1 -0
- package/dist/integrations/providers/impls/gmail-outbound.js +2 -1
- package/dist/integrations/providers/impls/gmail-outbound.js.map +1 -0
- package/dist/integrations/providers/impls/google-calendar.d.ts +2 -1
- package/dist/integrations/providers/impls/google-calendar.d.ts.map +1 -0
- package/dist/integrations/providers/impls/google-calendar.js +2 -1
- package/dist/integrations/providers/impls/google-calendar.js.map +1 -0
- package/dist/integrations/providers/impls/mistral-embedding.d.ts +2 -1
- package/dist/integrations/providers/impls/mistral-embedding.d.ts.map +1 -0
- package/dist/integrations/providers/impls/mistral-embedding.js +2 -1
- package/dist/integrations/providers/impls/mistral-embedding.js.map +1 -0
- package/dist/integrations/providers/impls/mistral-llm.d.ts +2 -1
- package/dist/integrations/providers/impls/mistral-llm.d.ts.map +1 -0
- package/dist/integrations/providers/impls/mistral-llm.js +2 -1
- package/dist/integrations/providers/impls/mistral-llm.js.map +1 -0
- package/dist/integrations/providers/impls/postmark-email.d.ts +2 -1
- package/dist/integrations/providers/impls/postmark-email.d.ts.map +1 -0
- package/dist/integrations/providers/impls/postmark-email.js +2 -1
- package/dist/integrations/providers/impls/postmark-email.js.map +1 -0
- package/dist/integrations/providers/impls/powens-client.d.ts +2 -1
- package/dist/integrations/providers/impls/powens-client.d.ts.map +1 -0
- package/dist/integrations/providers/impls/powens-client.js +2 -1
- package/dist/integrations/providers/impls/powens-client.js.map +1 -0
- package/dist/integrations/providers/impls/powens-openbanking.d.ts +2 -1
- package/dist/integrations/providers/impls/powens-openbanking.d.ts.map +1 -0
- package/dist/integrations/providers/impls/powens-openbanking.js +2 -1
- package/dist/integrations/providers/impls/powens-openbanking.js.map +1 -0
- package/dist/integrations/providers/impls/provider-factory.d.ts +2 -1
- package/dist/integrations/providers/impls/provider-factory.d.ts.map +1 -0
- package/dist/integrations/providers/impls/provider-factory.js +2 -1
- package/dist/integrations/providers/impls/provider-factory.js.map +1 -0
- package/dist/integrations/providers/impls/qdrant-vector.d.ts +2 -1
- package/dist/integrations/providers/impls/qdrant-vector.d.ts.map +1 -0
- package/dist/integrations/providers/impls/qdrant-vector.js +2 -1
- package/dist/integrations/providers/impls/qdrant-vector.js.map +1 -0
- package/dist/integrations/providers/impls/stripe-payments.d.ts +2 -1
- package/dist/integrations/providers/impls/stripe-payments.d.ts.map +1 -0
- package/dist/integrations/providers/impls/stripe-payments.js +2 -1
- package/dist/integrations/providers/impls/stripe-payments.js.map +1 -0
- package/dist/integrations/providers/impls/twilio-sms.d.ts +2 -1
- package/dist/integrations/providers/impls/twilio-sms.d.ts.map +1 -0
- package/dist/integrations/providers/impls/twilio-sms.js +2 -1
- package/dist/integrations/providers/impls/twilio-sms.js.map +1 -0
- package/dist/integrations/providers/llm.d.ts +2 -1
- package/dist/integrations/providers/llm.d.ts.map +1 -0
- package/dist/integrations/providers/mistral.d.ts +2 -1
- package/dist/integrations/providers/mistral.d.ts.map +1 -0
- package/dist/integrations/providers/mistral.js +2 -1
- package/dist/integrations/providers/mistral.js.map +1 -0
- package/dist/integrations/providers/openbanking.d.ts +2 -1
- package/dist/integrations/providers/openbanking.d.ts.map +1 -0
- package/dist/integrations/providers/payments.d.ts +2 -1
- package/dist/integrations/providers/payments.d.ts.map +1 -0
- package/dist/integrations/providers/postmark.d.ts +2 -1
- package/dist/integrations/providers/postmark.d.ts.map +1 -0
- package/dist/integrations/providers/postmark.js +2 -1
- package/dist/integrations/providers/postmark.js.map +1 -0
- package/dist/integrations/providers/powens.d.ts +2 -1
- package/dist/integrations/providers/powens.d.ts.map +1 -0
- package/dist/integrations/providers/powens.js +2 -1
- package/dist/integrations/providers/powens.js.map +1 -0
- package/dist/integrations/providers/qdrant.d.ts +2 -1
- package/dist/integrations/providers/qdrant.d.ts.map +1 -0
- package/dist/integrations/providers/qdrant.js +2 -1
- package/dist/integrations/providers/qdrant.js.map +1 -0
- package/dist/integrations/providers/registry.d.ts +2 -1
- package/dist/integrations/providers/registry.d.ts.map +1 -0
- package/dist/integrations/providers/registry.js +2 -1
- package/dist/integrations/providers/registry.js.map +1 -0
- package/dist/integrations/providers/sms.d.ts +2 -1
- package/dist/integrations/providers/sms.d.ts.map +1 -0
- package/dist/integrations/providers/storage.d.ts +2 -1
- package/dist/integrations/providers/storage.d.ts.map +1 -0
- package/dist/integrations/providers/stripe.d.ts +2 -1
- package/dist/integrations/providers/stripe.d.ts.map +1 -0
- package/dist/integrations/providers/stripe.js +2 -1
- package/dist/integrations/providers/stripe.js.map +1 -0
- package/dist/integrations/providers/twilio-sms.d.ts +2 -1
- package/dist/integrations/providers/twilio-sms.d.ts.map +1 -0
- package/dist/integrations/providers/twilio-sms.js +2 -1
- package/dist/integrations/providers/twilio-sms.js.map +1 -0
- package/dist/integrations/providers/vector-store.d.ts +2 -1
- package/dist/integrations/providers/vector-store.d.ts.map +1 -0
- package/dist/integrations/providers/voice.d.ts +2 -1
- package/dist/integrations/providers/voice.d.ts.map +1 -0
- package/dist/integrations/runtime.d.ts +2 -1
- package/dist/integrations/runtime.d.ts.map +1 -0
- package/dist/integrations/runtime.js +2 -1
- package/dist/integrations/runtime.js.map +1 -0
- package/dist/integrations/secrets/aws-secret-manager.d.ts +2 -1
- package/dist/integrations/secrets/aws-secret-manager.d.ts.map +1 -0
- package/dist/integrations/secrets/aws-secret-manager.js +2 -1
- package/dist/integrations/secrets/aws-secret-manager.js.map +1 -0
- package/dist/integrations/secrets/env-secret-provider.d.ts +2 -1
- package/dist/integrations/secrets/env-secret-provider.d.ts.map +1 -0
- package/dist/integrations/secrets/env-secret-provider.js +2 -1
- package/dist/integrations/secrets/env-secret-provider.js.map +1 -0
- package/dist/integrations/secrets/gcp-secret-manager.d.ts +2 -1
- package/dist/integrations/secrets/gcp-secret-manager.d.ts.map +1 -0
- package/dist/integrations/secrets/gcp-secret-manager.js +2 -1
- package/dist/integrations/secrets/gcp-secret-manager.js.map +1 -0
- package/dist/integrations/secrets/manager.d.ts +2 -1
- package/dist/integrations/secrets/manager.d.ts.map +1 -0
- package/dist/integrations/secrets/manager.js +2 -1
- package/dist/integrations/secrets/manager.js.map +1 -0
- package/dist/integrations/secrets/provider.d.ts +2 -1
- package/dist/integrations/secrets/provider.d.ts.map +1 -0
- package/dist/integrations/secrets/provider.js +2 -1
- package/dist/integrations/secrets/provider.js.map +1 -0
- package/dist/integrations/secrets/scaleway-secret-manager.d.ts +2 -1
- package/dist/integrations/secrets/scaleway-secret-manager.d.ts.map +1 -0
- package/dist/integrations/secrets/scaleway-secret-manager.js +2 -1
- package/dist/integrations/secrets/scaleway-secret-manager.js.map +1 -0
- package/dist/integrations/spec.d.ts +2 -1
- package/dist/integrations/spec.d.ts.map +1 -0
- package/dist/integrations/spec.js +2 -1
- package/dist/integrations/spec.js.map +1 -0
- package/dist/jobs/define-job.d.ts +2 -1
- package/dist/jobs/define-job.d.ts.map +1 -0
- package/dist/jobs/define-job.js +2 -1
- package/dist/jobs/define-job.js.map +1 -0
- package/dist/jobs/gcp-cloud-tasks.d.ts +2 -1
- package/dist/jobs/gcp-cloud-tasks.d.ts.map +1 -0
- package/dist/jobs/gcp-cloud-tasks.js +2 -1
- package/dist/jobs/gcp-cloud-tasks.js.map +1 -0
- package/dist/jobs/gcp-pubsub.d.ts +2 -1
- package/dist/jobs/gcp-pubsub.d.ts.map +1 -0
- package/dist/jobs/gcp-pubsub.js +2 -1
- package/dist/jobs/gcp-pubsub.js.map +1 -0
- package/dist/jobs/handlers/gmail-sync-handler.d.ts +2 -1
- package/dist/jobs/handlers/gmail-sync-handler.d.ts.map +1 -0
- package/dist/jobs/handlers/gmail-sync-handler.js +2 -1
- package/dist/jobs/handlers/gmail-sync-handler.js.map +1 -0
- package/dist/jobs/handlers/index.d.ts +2 -1
- package/dist/jobs/handlers/index.d.ts.map +1 -0
- package/dist/jobs/handlers/index.js +2 -1
- package/dist/jobs/handlers/index.js.map +1 -0
- package/dist/jobs/handlers/ping-handler.d.ts +2 -1
- package/dist/jobs/handlers/ping-handler.d.ts.map +1 -0
- package/dist/jobs/handlers/ping-handler.js +2 -1
- package/dist/jobs/handlers/ping-handler.js.map +1 -0
- package/dist/jobs/handlers/storage-document-handler.d.ts +2 -1
- package/dist/jobs/handlers/storage-document-handler.d.ts.map +1 -0
- package/dist/jobs/handlers/storage-document-handler.js +2 -1
- package/dist/jobs/handlers/storage-document-handler.js.map +1 -0
- package/dist/jobs/memory-queue.d.ts +2 -1
- package/dist/jobs/memory-queue.d.ts.map +1 -0
- package/dist/jobs/memory-queue.js +2 -1
- package/dist/jobs/memory-queue.js.map +1 -0
- package/dist/jobs/queue.d.ts +2 -1
- package/dist/jobs/queue.d.ts.map +1 -0
- package/dist/jobs/queue.js +2 -1
- package/dist/jobs/queue.js.map +1 -0
- package/dist/jobs/scaleway-sqs-queue.d.ts +2 -1
- package/dist/jobs/scaleway-sqs-queue.d.ts.map +1 -0
- package/dist/jobs/scaleway-sqs-queue.js +2 -1
- package/dist/jobs/scaleway-sqs-queue.js.map +1 -0
- package/dist/jsonschema.d.ts +5 -4
- package/dist/jsonschema.d.ts.map +1 -0
- package/dist/jsonschema.js +2 -1
- package/dist/jsonschema.js.map +1 -0
- package/dist/knowledge/binding.d.ts +2 -1
- package/dist/knowledge/binding.d.ts.map +1 -0
- package/dist/knowledge/contracts.d.ts +68 -67
- package/dist/knowledge/contracts.d.ts.map +1 -0
- package/dist/knowledge/contracts.js +44 -45
- package/dist/knowledge/contracts.js.map +1 -0
- package/dist/knowledge/docs/knowledge.docblock.d.ts +2 -1
- package/dist/knowledge/docs/knowledge.docblock.d.ts.map +1 -0
- package/dist/knowledge/docs/knowledge.docblock.js +2 -1
- package/dist/knowledge/docs/knowledge.docblock.js.map +1 -0
- package/dist/knowledge/ingestion/document-processor.d.ts +2 -1
- package/dist/knowledge/ingestion/document-processor.d.ts.map +1 -0
- package/dist/knowledge/ingestion/document-processor.js +2 -1
- package/dist/knowledge/ingestion/document-processor.js.map +1 -0
- package/dist/knowledge/ingestion/embedding-service.d.ts +2 -1
- package/dist/knowledge/ingestion/embedding-service.d.ts.map +1 -0
- package/dist/knowledge/ingestion/embedding-service.js +2 -1
- package/dist/knowledge/ingestion/embedding-service.js.map +1 -0
- package/dist/knowledge/ingestion/gmail-adapter.d.ts +2 -1
- package/dist/knowledge/ingestion/gmail-adapter.d.ts.map +1 -0
- package/dist/knowledge/ingestion/gmail-adapter.js +2 -1
- package/dist/knowledge/ingestion/gmail-adapter.js.map +1 -0
- package/dist/knowledge/ingestion/storage-adapter.d.ts +2 -1
- package/dist/knowledge/ingestion/storage-adapter.d.ts.map +1 -0
- package/dist/knowledge/ingestion/storage-adapter.js +2 -1
- package/dist/knowledge/ingestion/storage-adapter.js.map +1 -0
- package/dist/knowledge/ingestion/vector-indexer.d.ts +2 -1
- package/dist/knowledge/ingestion/vector-indexer.d.ts.map +1 -0
- package/dist/knowledge/ingestion/vector-indexer.js +2 -1
- package/dist/knowledge/ingestion/vector-indexer.js.map +1 -0
- package/dist/knowledge/query/service.d.ts +2 -1
- package/dist/knowledge/query/service.d.ts.map +1 -0
- package/dist/knowledge/query/service.js +2 -1
- package/dist/knowledge/query/service.js.map +1 -0
- package/dist/knowledge/runtime.d.ts +2 -1
- package/dist/knowledge/runtime.d.ts.map +1 -0
- package/dist/knowledge/runtime.js +2 -1
- package/dist/knowledge/runtime.js.map +1 -0
- package/dist/knowledge/source.d.ts +2 -1
- package/dist/knowledge/source.d.ts.map +1 -0
- package/dist/knowledge/spaces/email-threads.d.ts +2 -1
- package/dist/knowledge/spaces/email-threads.d.ts.map +1 -0
- package/dist/knowledge/spaces/email-threads.js +2 -1
- package/dist/knowledge/spaces/email-threads.js.map +1 -0
- package/dist/knowledge/spaces/financial-docs.d.ts +2 -1
- package/dist/knowledge/spaces/financial-docs.d.ts.map +1 -0
- package/dist/knowledge/spaces/financial-docs.js +2 -1
- package/dist/knowledge/spaces/financial-docs.js.map +1 -0
- package/dist/knowledge/spaces/financial-overview.d.ts +2 -1
- package/dist/knowledge/spaces/financial-overview.d.ts.map +1 -0
- package/dist/knowledge/spaces/financial-overview.js +2 -1
- package/dist/knowledge/spaces/financial-overview.js.map +1 -0
- package/dist/knowledge/spaces/product-canon.d.ts +2 -1
- package/dist/knowledge/spaces/product-canon.d.ts.map +1 -0
- package/dist/knowledge/spaces/product-canon.js +2 -1
- package/dist/knowledge/spaces/product-canon.js.map +1 -0
- package/dist/knowledge/spaces/support-faq.d.ts +2 -1
- package/dist/knowledge/spaces/support-faq.d.ts.map +1 -0
- package/dist/knowledge/spaces/support-faq.js +2 -1
- package/dist/knowledge/spaces/support-faq.js.map +1 -0
- package/dist/knowledge/spaces/uploaded-docs.d.ts +2 -1
- package/dist/knowledge/spaces/uploaded-docs.d.ts.map +1 -0
- package/dist/knowledge/spaces/uploaded-docs.js +2 -1
- package/dist/knowledge/spaces/uploaded-docs.js.map +1 -0
- package/dist/knowledge/spec.d.ts +2 -1
- package/dist/knowledge/spec.d.ts.map +1 -0
- package/dist/knowledge/spec.js +2 -1
- package/dist/knowledge/spec.js.map +1 -0
- package/dist/llm/exporters.d.ts +2 -1
- package/dist/llm/exporters.d.ts.map +1 -0
- package/dist/llm/exporters.js +2 -1
- package/dist/llm/exporters.js.map +1 -0
- package/dist/llm/prompts.d.ts +2 -1
- package/dist/llm/prompts.d.ts.map +1 -0
- package/dist/llm/prompts.js +2 -1
- package/dist/llm/prompts.js.map +1 -0
- package/dist/llm/types.d.ts +2 -1
- package/dist/llm/types.d.ts.map +1 -0
- package/dist/markdown.d.ts +2 -1
- package/dist/markdown.d.ts.map +1 -0
- package/dist/markdown.js +2 -1
- package/dist/markdown.js.map +1 -0
- package/dist/migrations.d.ts +2 -1
- package/dist/migrations.d.ts.map +1 -0
- package/dist/migrations.js +2 -1
- package/dist/migrations.js.map +1 -0
- package/dist/onboarding-base.d.ts +31 -30
- package/dist/onboarding-base.d.ts.map +1 -0
- package/dist/onboarding-base.js +22 -23
- package/dist/onboarding-base.js.map +1 -0
- package/dist/openapi.d.ts +2 -1
- package/dist/openapi.d.ts.map +1 -0
- package/dist/openapi.js +2 -1
- package/dist/openapi.js.map +1 -0
- package/dist/openbanking/docs/openbanking.docblock.d.ts +2 -1
- package/dist/openbanking/docs/openbanking.docblock.d.ts.map +1 -0
- package/dist/openbanking/docs/openbanking.docblock.js +2 -1
- package/dist/openbanking/docs/openbanking.docblock.js.map +1 -0
- package/dist/ownership.d.ts +6 -7
- package/dist/ownership.d.ts.map +1 -0
- package/dist/ownership.js +6 -6
- package/dist/ownership.js.map +1 -0
- package/dist/policy/docs/policy.docblock.d.ts +2 -1
- package/dist/policy/docs/policy.docblock.d.ts.map +1 -0
- package/dist/policy/docs/policy.docblock.js +2 -1
- package/dist/policy/docs/policy.docblock.js.map +1 -0
- package/dist/policy/engine.d.ts +2 -1
- package/dist/policy/engine.d.ts.map +1 -0
- package/dist/policy/engine.js +2 -1
- package/dist/policy/engine.js.map +1 -0
- package/dist/policy/opa-adapter.d.ts +2 -1
- package/dist/policy/opa-adapter.d.ts.map +1 -0
- package/dist/policy/opa-adapter.js +2 -1
- package/dist/policy/opa-adapter.js.map +1 -0
- package/dist/policy/spec.d.ts +2 -1
- package/dist/policy/spec.d.ts.map +1 -0
- package/dist/policy/spec.js +2 -1
- package/dist/policy/spec.js.map +1 -0
- package/dist/presentations/docs/presentations-conventions.docblock.d.ts +2 -1
- package/dist/presentations/docs/presentations-conventions.docblock.d.ts.map +1 -0
- package/dist/presentations/docs/presentations-conventions.docblock.js +2 -1
- package/dist/presentations/docs/presentations-conventions.docblock.js.map +1 -0
- package/dist/presentations.backcompat.d.ts +2 -1
- package/dist/presentations.backcompat.d.ts.map +1 -0
- package/dist/presentations.backcompat.js +2 -1
- package/dist/presentations.backcompat.js.map +1 -0
- package/dist/presentations.d.ts +5 -4
- package/dist/presentations.d.ts.map +1 -0
- package/dist/presentations.js +2 -1
- package/dist/presentations.js.map +1 -0
- package/dist/presentations.v2.d.ts +2 -1
- package/dist/presentations.v2.d.ts.map +1 -0
- package/dist/presentations.v2.js +2 -1
- package/dist/presentations.v2.js.map +1 -0
- package/dist/prompt.d.ts +2 -1
- package/dist/prompt.d.ts.map +1 -0
- package/dist/prompt.js +2 -1
- package/dist/prompt.js.map +1 -0
- package/dist/promptRegistry.d.ts +2 -1
- package/dist/promptRegistry.d.ts.map +1 -0
- package/dist/promptRegistry.js +2 -1
- package/dist/promptRegistry.js.map +1 -0
- package/dist/regenerator/adapters.d.ts +2 -1
- package/dist/regenerator/adapters.d.ts.map +1 -0
- package/dist/regenerator/docs/regenerator.docblock.d.ts +2 -1
- package/dist/regenerator/docs/regenerator.docblock.d.ts.map +1 -0
- package/dist/regenerator/docs/regenerator.docblock.js +2 -1
- package/dist/regenerator/docs/regenerator.docblock.js.map +1 -0
- package/dist/regenerator/executor.d.ts +2 -1
- package/dist/regenerator/executor.d.ts.map +1 -0
- package/dist/regenerator/executor.js +2 -1
- package/dist/regenerator/executor.js.map +1 -0
- package/dist/regenerator/service.d.ts +2 -1
- package/dist/regenerator/service.d.ts.map +1 -0
- package/dist/regenerator/service.js +2 -1
- package/dist/regenerator/service.js.map +1 -0
- package/dist/regenerator/sinks.d.ts +2 -1
- package/dist/regenerator/sinks.d.ts.map +1 -0
- package/dist/regenerator/sinks.js +2 -1
- package/dist/regenerator/sinks.js.map +1 -0
- package/dist/regenerator/types.d.ts +2 -1
- package/dist/regenerator/types.d.ts.map +1 -0
- package/dist/regenerator/utils.d.ts +2 -1
- package/dist/regenerator/utils.d.ts.map +1 -0
- package/dist/regenerator/utils.js +2 -1
- package/dist/regenerator/utils.js.map +1 -0
- package/dist/registry.d.ts +2 -1
- package/dist/registry.d.ts.map +1 -0
- package/dist/registry.js +2 -1
- package/dist/registry.js.map +1 -0
- package/dist/resources.d.ts +2 -1
- package/dist/resources.d.ts.map +1 -0
- package/dist/resources.js +2 -1
- package/dist/resources.js.map +1 -0
- package/dist/schema/dist/index.js +4684 -6
- package/dist/schema/dist/index.js.map +1 -0
- package/dist/schema-to-markdown.d.ts +2 -1
- package/dist/schema-to-markdown.d.ts.map +1 -0
- package/dist/schema-to-markdown.js +2 -1
- package/dist/schema-to-markdown.js.map +1 -0
- package/dist/server/graphql-pothos.d.ts +2 -1
- package/dist/server/graphql-pothos.d.ts.map +1 -0
- package/dist/server/graphql-pothos.js +2 -1
- package/dist/server/graphql-pothos.js.map +1 -0
- package/dist/server/mcp/createMcpServer.d.ts +2 -1
- package/dist/server/mcp/createMcpServer.d.ts.map +1 -0
- package/dist/server/mcp/createMcpServer.js +2 -1
- package/dist/server/mcp/createMcpServer.js.map +1 -0
- package/dist/server/mcp/mcpTypes.d.ts +2 -1
- package/dist/server/mcp/mcpTypes.d.ts.map +1 -0
- package/dist/server/mcp/registerPresentations.d.ts +2 -1
- package/dist/server/mcp/registerPresentations.d.ts.map +1 -0
- package/dist/server/mcp/registerPresentations.js +2 -1
- package/dist/server/mcp/registerPresentations.js.map +1 -0
- package/dist/server/mcp/registerPrompts.d.ts +2 -1
- package/dist/server/mcp/registerPrompts.d.ts.map +1 -0
- package/dist/server/mcp/registerPrompts.js +2 -1
- package/dist/server/mcp/registerPrompts.js.map +1 -0
- package/dist/server/mcp/registerResources.d.ts +2 -1
- package/dist/server/mcp/registerResources.d.ts.map +1 -0
- package/dist/server/mcp/registerResources.js +2 -1
- package/dist/server/mcp/registerResources.js.map +1 -0
- package/dist/server/mcp/registerTools.d.ts +2 -1
- package/dist/server/mcp/registerTools.d.ts.map +1 -0
- package/dist/server/mcp/registerTools.js +2 -1
- package/dist/server/mcp/registerTools.js.map +1 -0
- package/dist/server/rest-elysia.d.ts +2 -1
- package/dist/server/rest-elysia.d.ts.map +1 -0
- package/dist/server/rest-elysia.js +2 -1
- package/dist/server/rest-elysia.js.map +1 -0
- package/dist/server/rest-express.d.ts +2 -1
- package/dist/server/rest-express.d.ts.map +1 -0
- package/dist/server/rest-express.js +2 -1
- package/dist/server/rest-express.js.map +1 -0
- package/dist/server/rest-generic.d.ts +2 -1
- package/dist/server/rest-generic.d.ts.map +1 -0
- package/dist/server/rest-generic.js +2 -1
- package/dist/server/rest-generic.js.map +1 -0
- package/dist/server/rest-next-app.d.ts +2 -1
- package/dist/server/rest-next-app.d.ts.map +1 -0
- package/dist/server/rest-next-app.js +2 -1
- package/dist/server/rest-next-app.js.map +1 -0
- package/dist/server/rest-next-mcp.d.ts +2 -1
- package/dist/server/rest-next-mcp.d.ts.map +1 -0
- package/dist/server/rest-next-mcp.js +2 -1
- package/dist/server/rest-next-mcp.js.map +1 -0
- package/dist/server/rest-next-pages.d.ts +2 -1
- package/dist/server/rest-next-pages.d.ts.map +1 -0
- package/dist/server/rest-next-pages.js +2 -1
- package/dist/server/rest-next-pages.js.map +1 -0
- package/dist/spec.d.ts +2 -1
- package/dist/spec.d.ts.map +1 -0
- package/dist/spec.js +2 -1
- package/dist/spec.js.map +1 -0
- package/dist/telemetry/anomaly.d.ts +2 -1
- package/dist/telemetry/anomaly.d.ts.map +1 -0
- package/dist/telemetry/anomaly.js +2 -1
- package/dist/telemetry/anomaly.js.map +1 -0
- package/dist/telemetry/docs/telemetry.docblock.d.ts +2 -1
- package/dist/telemetry/docs/telemetry.docblock.d.ts.map +1 -0
- package/dist/telemetry/docs/telemetry.docblock.js +2 -1
- package/dist/telemetry/docs/telemetry.docblock.js.map +1 -0
- package/dist/telemetry/spec.d.ts +2 -1
- package/dist/telemetry/spec.d.ts.map +1 -0
- package/dist/telemetry/spec.js +2 -1
- package/dist/telemetry/spec.js.map +1 -0
- package/dist/telemetry/tracker.d.ts +2 -1
- package/dist/telemetry/tracker.d.ts.map +1 -0
- package/dist/telemetry/tracker.js +2 -1
- package/dist/telemetry/tracker.js.map +1 -0
- package/dist/tests/runner.d.ts +2 -1
- package/dist/tests/runner.d.ts.map +1 -0
- package/dist/tests/runner.js +2 -1
- package/dist/tests/runner.js.map +1 -0
- package/dist/tests/spec.d.ts +2 -1
- package/dist/tests/spec.d.ts.map +1 -0
- package/dist/tests/spec.js +2 -1
- package/dist/tests/spec.js.map +1 -0
- package/dist/themes.d.ts +2 -1
- package/dist/themes.d.ts.map +1 -0
- package/dist/themes.js +2 -1
- package/dist/themes.js.map +1 -0
- package/dist/translations/catalog.d.ts +2 -1
- package/dist/translations/catalog.d.ts.map +1 -0
- package/dist/translations/tenant.d.ts +2 -1
- package/dist/translations/tenant.d.ts.map +1 -0
- package/dist/types.d.ts +2 -1
- package/dist/types.d.ts.map +1 -0
- package/dist/workflow/adapters/db-adapter.d.ts +21 -8
- package/dist/workflow/adapters/db-adapter.d.ts.map +1 -0
- package/dist/workflow/adapters/db-adapter.js +5 -4
- package/dist/workflow/adapters/db-adapter.js.map +1 -0
- package/dist/workflow/adapters/file-adapter.d.ts +2 -1
- package/dist/workflow/adapters/file-adapter.d.ts.map +1 -0
- package/dist/workflow/adapters/file-adapter.js +2 -1
- package/dist/workflow/adapters/file-adapter.js.map +1 -0
- package/dist/workflow/adapters/memory-store.d.ts +2 -1
- package/dist/workflow/adapters/memory-store.d.ts.map +1 -0
- package/dist/workflow/adapters/memory-store.js +2 -1
- package/dist/workflow/adapters/memory-store.js.map +1 -0
- package/dist/workflow/expression.d.ts +2 -1
- package/dist/workflow/expression.d.ts.map +1 -0
- package/dist/workflow/expression.js +2 -1
- package/dist/workflow/expression.js.map +1 -0
- package/dist/workflow/runner.d.ts +2 -1
- package/dist/workflow/runner.d.ts.map +1 -0
- package/dist/workflow/runner.js +2 -1
- package/dist/workflow/runner.js.map +1 -0
- package/dist/workflow/sla-monitor.d.ts +2 -1
- package/dist/workflow/sla-monitor.d.ts.map +1 -0
- package/dist/workflow/sla-monitor.js +2 -1
- package/dist/workflow/sla-monitor.js.map +1 -0
- package/dist/workflow/spec.d.ts +2 -1
- package/dist/workflow/spec.d.ts.map +1 -0
- package/dist/workflow/spec.js +2 -1
- package/dist/workflow/spec.js.map +1 -0
- package/dist/workflow/state.d.ts +2 -1
- package/dist/workflow/state.d.ts.map +1 -0
- package/dist/workflow/validation.d.ts +2 -1
- package/dist/workflow/validation.d.ts.map +1 -0
- package/dist/workflow/validation.js +2 -1
- package/dist/workflow/validation.js.map +1 -0
- package/package.json +12 -17
- package/dist/docs/PUBLISHING.docblock.d.ts +0 -6
- package/dist/docs/PUBLISHING.docblock.js +0 -17
- package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.d.ts +0 -6
- package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +0 -17
- package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.d.ts +0 -6
- package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +0 -17
- package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.d.ts +0 -6
- package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +0 -17
- package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.d.ts +0 -6
- package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +0 -17
- package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.d.ts +0 -6
- package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +0 -17
- package/dist/schema/dist/EnumType.js +0 -2
- package/dist/schema/dist/FieldType.js +0 -49
- package/dist/schema/dist/ScalarTypeEnum.js +0 -236
- package/dist/schema/dist/SchemaModel.js +0 -39
- package/dist/schema/dist/entity/defineEntity.js +0 -1
- package/dist/schema/dist/entity/index.js +0 -2
- package/dist/schema/dist/entity/types.js +0 -1
|
@@ -49,4 +49,5 @@ declare class SecretProviderError extends Error {
|
|
|
49
49
|
declare function parseSecretUri(reference: SecretReference): ParsedSecretUri;
|
|
50
50
|
declare function normalizeSecretPayload(payload: SecretWritePayload): Uint8Array;
|
|
51
51
|
//#endregion
|
|
52
|
-
export { ParsedSecretUri, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri };
|
|
52
|
+
export { ParsedSecretUri, SecretFetchOptions, SecretPayloadEncoding, SecretProvider, SecretProviderError, SecretReference, SecretRotationResult, SecretValue, SecretWritePayload, normalizeSecretPayload, parseSecretUri };
|
|
53
|
+
//# sourceMappingURL=provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.d.ts","names":[],"sources":["../../../src/integrations/secrets/provider.ts"],"sourcesContent":[],"mappings":";KAEY,eAAA;AAAA,UAEK,WAAA,CAFU;EAEV,IAAA,EACT,UADoB;EACpB,OAAA,CAAA,EAAA,MAAA;EAEK,QAAA,CAAA,EAAA,MAAA,CAAA,MAAA,EAAA,MAAA,CAAA;EACE,WAAA,EAAA,IAAA;;AAGE,UAAA,kBAAA,CAAkB;EAIvB,OAAA,CAAA,EAAA,MAAA;AAEZ;AACiB,KAHL,qBAAA,GAGK,OAAA,GAAA,QAAA,GAAA,QAAA;AACJ,UAFI,kBAAA,CAEJ;EAEF,IAAA,EAAA,MAAA,GAHM,UAGN;EAAM,QAAA,CAAA,EAFJ,qBAEI;EAGA,WAAA,CAAA,EAAA,MAAA;EAKA,MAAA,CAAA,EARN,MAQM,CAAA,MAAc,EAAA,MAAA,CAAA;;AAIhB,UATE,oBAAA,CASF;EACD,SAAA,EATD,eASC;EACD,OAAA,EAAA,MAAA;;AAEE,UARE,cAAA,CAQF;EACF,SAAA,EAAA,EAAA,MAAA;EACA,SAAA,CAAA,SAAA,EARU,eAQV,CAAA,EAAA,OAAA;EAAR,SAAA,CAAA,SAAA,EANU,eAMV,EAAA,OAAA,CAAA,EALS,kBAKT,CAAA,EAJA,OAIA,CAJQ,WAIR,CAAA;EAEU,SAAA,CAAA,SAAA,EAJA,eAIA,EAAA,OAAA,EAHF,kBAGE,CAAA,EAFV,OAEU,CAFF,oBAEE,CAAA;EACF,YAAA,CAAA,SAAA,EADE,eACF,EAAA,OAAA,EAAA,kBAAA,CAAA,EACR,OADQ,CACA,oBADA,CAAA;EACA,YAAA,CAAA,SAAA,EACa,eADb,CAAA,EAC+B,OAD/B,CAAA,IAAA,CAAA;;AACa,UAGT,eAAA,CAHS;EAAkB,QAAA,EAAA,MAAA;EAAO,IAAA,EAAA,MAAA;EAGlC,MAAA,CAAA,EAGN,MAHM,CAAA,MAAe,EAAA,MAAA,CAGrB;AAGX;AAEsB,cAFT,mBAAA,SAA4B,KAAA,CAEnB;EAOP,SAAA,QAAA,EAAA,MAAA;EACJ,SAAA,SAAA,EARW,eAQX;EAV8B,SAAA,IAAA,EAAA,WAAA,GAAA,WAAA,GAAA,SAAA,GAAA,SAAA;EAAK,SAAA,KAAA,CAAA,EAAA,OAAA;EAsB9B,WAAA,CAAA,MAAc,EAAA;IAiDd,OAAA,EAAA,MAAA;;eA9DD;WACJ;;;;iBAYK,cAAA,YAA0B,kBAAkB;iBAiD5C,sBAAA,UACL,qBACR"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","names":[],"sources":["../../../src/integrations/secrets/provider.ts"],"sourcesContent":["import { Buffer } from 'node:buffer';\n\nexport type SecretReference = string;\n\nexport interface SecretValue {\n data: Uint8Array;\n version?: string;\n metadata?: Record<string, string>;\n retrievedAt: Date;\n}\n\nexport interface SecretFetchOptions {\n version?: string;\n}\n\nexport type SecretPayloadEncoding = 'utf-8' | 'base64' | 'binary';\n\nexport interface SecretWritePayload {\n data: string | Uint8Array;\n encoding?: SecretPayloadEncoding;\n contentType?: string;\n labels?: Record<string, string>;\n}\n\nexport interface SecretRotationResult {\n reference: SecretReference;\n version: string;\n}\n\nexport interface SecretProvider {\n readonly id: string;\n canHandle(reference: SecretReference): boolean;\n getSecret(\n reference: SecretReference,\n options?: SecretFetchOptions\n ): Promise<SecretValue>;\n setSecret(\n reference: SecretReference,\n payload: SecretWritePayload\n ): Promise<SecretRotationResult>;\n rotateSecret(\n reference: SecretReference,\n payload: SecretWritePayload\n ): Promise<SecretRotationResult>;\n deleteSecret(reference: SecretReference): Promise<void>;\n}\n\nexport interface ParsedSecretUri {\n provider: string;\n path: string;\n extras?: Record<string, string>;\n}\n\nexport class SecretProviderError extends Error {\n readonly provider: string;\n readonly reference: SecretReference;\n readonly code: 'NOT_FOUND' | 'FORBIDDEN' | 'INVALID' | 'UNKNOWN';\n readonly cause?: unknown;\n\n constructor(params: {\n message: string;\n provider: string;\n reference: SecretReference;\n code?: SecretProviderError['code'];\n cause?: unknown;\n }) {\n super(params.message);\n this.name = 'SecretProviderError';\n this.provider = params.provider;\n this.reference = params.reference;\n this.code = params.code ?? 'UNKNOWN';\n this.cause = params.cause;\n }\n}\n\nexport function parseSecretUri(reference: SecretReference): ParsedSecretUri {\n if (!reference) {\n throw new SecretProviderError({\n message: 'Secret reference cannot be empty',\n provider: 'unknown',\n reference,\n code: 'INVALID',\n });\n }\n\n const [scheme, rest] = reference.split('://');\n if (!scheme || !rest) {\n throw new SecretProviderError({\n message: `Invalid secret reference: ${reference}`,\n provider: 'unknown',\n reference,\n code: 'INVALID',\n });\n }\n\n const queryIndex = rest.indexOf('?');\n if (queryIndex === -1) {\n return {\n provider: scheme,\n path: rest,\n };\n }\n\n const path = rest.slice(0, queryIndex);\n const query = rest.slice(queryIndex + 1);\n const extras = Object.fromEntries(\n query\n .split('&')\n .filter(Boolean)\n .map((pair) => {\n const [keyRaw, valueRaw] = pair.split('=');\n const key = keyRaw ?? '';\n const value = valueRaw ?? '';\n return [decodeURIComponent(key), decodeURIComponent(value)];\n })\n );\n\n return {\n provider: scheme,\n path,\n extras,\n };\n}\n\nexport function normalizeSecretPayload(\n payload: SecretWritePayload\n): Uint8Array {\n if (payload.data instanceof Uint8Array) {\n return payload.data;\n }\n\n if (payload.encoding === 'base64') {\n return Buffer.from(payload.data, 'base64');\n }\n\n if (payload.encoding === 'binary') {\n return Buffer.from(payload.data, 'binary');\n }\n\n return Buffer.from(payload.data, 'utf-8');\n}\n"],"mappings":";;;AAqDA,IAAa,sBAAb,cAAyC,MAAM;CAC7C,AAAS;CACT,AAAS;CACT,AAAS;CACT,AAAS;CAET,YAAY,QAMT;AACD,QAAM,OAAO,QAAQ;AACrB,OAAK,OAAO;AACZ,OAAK,WAAW,OAAO;AACvB,OAAK,YAAY,OAAO;AACxB,OAAK,OAAO,OAAO,QAAQ;AAC3B,OAAK,QAAQ,OAAO;;;AAIxB,SAAgB,eAAe,WAA6C;AAC1E,KAAI,CAAC,UACH,OAAM,IAAI,oBAAoB;EAC5B,SAAS;EACT,UAAU;EACV;EACA,MAAM;EACP,CAAC;CAGJ,MAAM,CAAC,QAAQ,QAAQ,UAAU,MAAM,MAAM;AAC7C,KAAI,CAAC,UAAU,CAAC,KACd,OAAM,IAAI,oBAAoB;EAC5B,SAAS,6BAA6B;EACtC,UAAU;EACV;EACA,MAAM;EACP,CAAC;CAGJ,MAAM,aAAa,KAAK,QAAQ,IAAI;AACpC,KAAI,eAAe,GACjB,QAAO;EACL,UAAU;EACV,MAAM;EACP;CAGH,MAAM,OAAO,KAAK,MAAM,GAAG,WAAW;CACtC,MAAM,QAAQ,KAAK,MAAM,aAAa,EAAE;AAaxC,QAAO;EACL,UAAU;EACV;EACA,QAfa,OAAO,YACpB,MACG,MAAM,IAAI,CACV,OAAO,QAAQ,CACf,KAAK,SAAS;GACb,MAAM,CAAC,QAAQ,YAAY,KAAK,MAAM,IAAI;GAC1C,MAAM,MAAM,UAAU;GACtB,MAAM,QAAQ,YAAY;AAC1B,UAAO,CAAC,mBAAmB,IAAI,EAAE,mBAAmB,MAAM,CAAC;IAC3D,CACL;EAMA;;AAGH,SAAgB,uBACd,SACY;AACZ,KAAI,QAAQ,gBAAgB,WAC1B,QAAO,QAAQ;AAGjB,KAAI,QAAQ,aAAa,SACvB,QAAO,OAAO,KAAK,QAAQ,MAAM,SAAS;AAG5C,KAAI,QAAQ,aAAa,SACvB,QAAO,OAAO,KAAK,QAAQ,MAAM,SAAS;AAG5C,QAAO,OAAO,KAAK,QAAQ,MAAM,QAAQ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaleway-secret-manager.d.ts","names":[],"sources":["../../../src/integrations/secrets/scaleway-secret-manager.ts"],"sourcesContent":[],"mappings":";;;UAgBU,oCAAA;;AAFU;AA2BpB;;EA2BuB,KAAA,CAAA,EAAA,MAAA;EAcR;EACD,aAAA,CAAA,EAAA,MAAA;EACD;EAAR,gBAAA,CAAA,EAAA,MAAA;EA0DU;EACF,OAAA,CAAA,EAAA,MAAA;EACA;EAAR,KAAA,CAAA,EAAA,OAnHY,KAmHZ;;AAyCQ,cAhJA,6BAAA,YAAyC,cAgJzC,CAAA;EACA,SAAA,EAAA,GAAA,yBAAA;EAAR,iBAAA,KAAA;EAI2B,iBAAA,aAAA;EAAkB,iBAAA,gBAAA;EArJI,iBAAA,OAAA;EAAc,iBAAA,OAAA;wBAS7C;uBAkBA;uBAcR,2BACD,qBACT,QAAQ;uBA0DE,0BACF,qBACR,QAAQ;0BAwCE,0BACF,qBACR,QAAQ;0BAImB,kBAAkB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaleway-secret-manager.js","names":["code: SecretProviderError['code']"],"sources":["../../../src/integrations/secrets/scaleway-secret-manager.ts"],"sourcesContent":["import { Buffer } from 'node:buffer';\n\nimport {\n normalizeSecretPayload,\n parseSecretUri,\n SecretProviderError,\n} from './provider';\nimport type {\n SecretFetchOptions,\n SecretProvider,\n SecretReference,\n SecretRotationResult,\n SecretValue,\n SecretWritePayload,\n} from './provider';\n\ninterface ScalewaySecretManagerProviderOptions {\n /**\n * Scaleway API token (SCW secret key). If omitted, uses env vars.\n * Header: X-Auth-Token\n */\n token?: string;\n /** Default region when not present in reference (e.g. fr-par). */\n defaultRegion?: string;\n /** Default project id used when creating secrets by name. */\n defaultProjectId?: string;\n /** Override API base url (defaults to https://api.scaleway.com). */\n baseUrl?: string;\n /** Inject fetch for tests. */\n fetch?: typeof fetch;\n}\n\ninterface ScalewaySecretLocation {\n region: string;\n secretIdOrName: string;\n revision?: string;\n}\n\nconst UUID_V4_LIKE =\n /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;\n\nexport class ScalewaySecretManagerProvider implements SecretProvider {\n readonly id = 'scaleway-secret-manager';\n\n private readonly token: string;\n private readonly defaultRegion?: string;\n private readonly defaultProjectId?: string;\n private readonly baseUrl: string;\n private readonly fetchFn: typeof fetch;\n\n constructor(options: ScalewaySecretManagerProviderOptions = {}) {\n this.token =\n options.token ??\n process.env.SCW_SECRET_KEY ??\n process.env.SCALEWAY_SECRET_KEY ??\n '';\n this.defaultRegion =\n options.defaultRegion ??\n process.env.SCW_DEFAULT_REGION ??\n process.env.SCW_REGION;\n this.defaultProjectId =\n options.defaultProjectId ??\n process.env.SCW_DEFAULT_PROJECT_ID ??\n process.env.SCW_PROJECT_ID;\n this.baseUrl = options.baseUrl ?? 'https://api.scaleway.com';\n this.fetchFn = options.fetch ?? fetch;\n }\n\n canHandle(reference: SecretReference): boolean {\n try {\n const parsed = parseSecretUri(reference);\n return (\n parsed.provider === 'scw' &&\n (parsed.path === 'secret-manager' ||\n parsed.path.startsWith('secret-manager/'))\n );\n } catch {\n return false;\n }\n }\n\n async getSecret(\n reference: SecretReference,\n options?: SecretFetchOptions\n ): Promise<SecretValue> {\n const location = this.parseReference(reference);\n\n if (!this.token) {\n throw new SecretProviderError({\n message:\n 'Scaleway secret manager token is missing (set SCW_SECRET_KEY / SCALEWAY_SECRET_KEY).',\n provider: this.id,\n reference,\n code: 'FORBIDDEN',\n });\n }\n\n if (!UUID_V4_LIKE.test(location.secretIdOrName)) {\n throw new SecretProviderError({\n message:\n 'Scaleway getSecret requires a secretId (uuid) reference, not a secret name.',\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n const revision = options?.version ?? location.revision ?? 'latest';\n\n const url = `${this.baseUrl}/secret-manager/v1beta1/regions/${encodeURIComponent(location.region)}/secrets/${encodeURIComponent(location.secretIdOrName)}/versions/${encodeURIComponent(revision)}/access`;\n\n const response = await this.fetchFn(url, {\n method: 'GET',\n headers: {\n 'X-Auth-Token': this.token,\n },\n });\n\n if (!response.ok) {\n throw await toScalewayError({\n response,\n provider: this.id,\n reference,\n operation: 'getSecret',\n });\n }\n\n const payload = (await response.json()) as unknown;\n const dataB64 = extractScalewayData(payload);\n\n return {\n data: Buffer.from(dataB64, 'base64'),\n version: revision,\n metadata: {\n region: location.region,\n secretId: location.secretIdOrName,\n },\n retrievedAt: new Date(),\n };\n }\n\n async setSecret(\n reference: SecretReference,\n payload: SecretWritePayload\n ): Promise<SecretRotationResult> {\n const location = this.parseReference(reference);\n\n if (!this.token) {\n throw new SecretProviderError({\n message:\n 'Scaleway secret manager token is missing (set SCW_SECRET_KEY / SCALEWAY_SECRET_KEY).',\n provider: this.id,\n reference,\n code: 'FORBIDDEN',\n });\n }\n\n const bytes = normalizeSecretPayload(payload);\n const encoded = Buffer.from(bytes).toString('base64');\n\n const secretId = UUID_V4_LIKE.test(location.secretIdOrName)\n ? location.secretIdOrName\n : await this.createSecret({\n region: location.region,\n name: location.secretIdOrName,\n reference,\n });\n\n const version = await this.createSecretVersion({\n region: location.region,\n secretId,\n dataB64: encoded,\n reference,\n });\n\n return {\n reference: this.buildReference(location.region, secretId, {\n version,\n }),\n version,\n };\n }\n\n async rotateSecret(\n reference: SecretReference,\n payload: SecretWritePayload\n ): Promise<SecretRotationResult> {\n return this.setSecret(reference, payload);\n }\n\n async deleteSecret(reference: SecretReference): Promise<void> {\n const location = this.parseReference(reference);\n\n if (!this.token) {\n throw new SecretProviderError({\n message:\n 'Scaleway secret manager token is missing (set SCW_SECRET_KEY / SCALEWAY_SECRET_KEY).',\n provider: this.id,\n reference,\n code: 'FORBIDDEN',\n });\n }\n\n if (!UUID_V4_LIKE.test(location.secretIdOrName)) {\n throw new SecretProviderError({\n message:\n 'Scaleway deleteSecret requires a secretId (uuid) reference, not a secret name.',\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n const url = `${this.baseUrl}/secret-manager/v1beta1/regions/${encodeURIComponent(location.region)}/secrets/${encodeURIComponent(location.secretIdOrName)}`;\n\n const response = await this.fetchFn(url, {\n method: 'DELETE',\n headers: {\n 'X-Auth-Token': this.token,\n },\n });\n\n if (!response.ok) {\n throw await toScalewayError({\n response,\n provider: this.id,\n reference,\n operation: 'deleteSecret',\n });\n }\n }\n\n private parseReference(reference: SecretReference): ScalewaySecretLocation {\n const parsed = parseSecretUri(reference);\n if (parsed.provider !== 'scw') {\n throw new SecretProviderError({\n message: `Unsupported secret provider: ${parsed.provider}`,\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n const segments = parsed.path.split('/').filter(Boolean);\n if (segments.length < 2 || segments[0] !== 'secret-manager') {\n throw new SecretProviderError({\n message:\n 'Expected secret reference format scw://secret-manager/{region}/{secretIdOrName}[?version=...]',\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n const region = segments[1] ?? this.defaultRegion;\n if (!region) {\n throw new SecretProviderError({\n message:\n 'Scaleway region must be provided either in reference (scw://secret-manager/{region}/...) or via SCW_DEFAULT_REGION/SCW_REGION.',\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n const secretIdOrName = segments.slice(2).join('/');\n if (!secretIdOrName) {\n throw new SecretProviderError({\n message: `Unable to resolve secret id/name from reference \"${parsed.path}\"`,\n provider: this.id,\n reference,\n code: 'INVALID',\n });\n }\n\n return {\n region,\n secretIdOrName,\n revision: parsed.extras?.version,\n };\n }\n\n private async createSecret(params: {\n region: string;\n name: string;\n reference: SecretReference;\n }): Promise<string> {\n const projectId = this.defaultProjectId;\n if (!projectId) {\n throw new SecretProviderError({\n message:\n 'Scaleway project id is required to create secrets by name (set SCW_DEFAULT_PROJECT_ID/SCW_PROJECT_ID).',\n provider: this.id,\n reference: params.reference,\n code: 'INVALID',\n });\n }\n\n const url = `${this.baseUrl}/secret-manager/v1beta1/regions/${encodeURIComponent(params.region)}/secrets`;\n\n const response = await this.fetchFn(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'X-Auth-Token': this.token,\n },\n body: JSON.stringify({\n name: params.name,\n project_id: projectId,\n }),\n });\n\n if (!response.ok) {\n throw await toScalewayError({\n response,\n provider: this.id,\n reference: params.reference,\n operation: 'createSecret',\n });\n }\n\n const payload = (await response.json()) as unknown;\n const secretId = extractScalewaySecretId(payload);\n return secretId;\n }\n\n private async createSecretVersion(params: {\n region: string;\n secretId: string;\n dataB64: string;\n reference: SecretReference;\n }): Promise<string> {\n const url = `${this.baseUrl}/secret-manager/v1beta1/regions/${encodeURIComponent(params.region)}/secrets/${encodeURIComponent(params.secretId)}/versions`;\n\n const response = await this.fetchFn(url, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'X-Auth-Token': this.token,\n },\n body: JSON.stringify({\n data: params.dataB64,\n }),\n });\n\n if (!response.ok) {\n throw await toScalewayError({\n response,\n provider: this.id,\n reference: params.reference,\n operation: 'createSecretVersion',\n });\n }\n\n const payload = (await response.json()) as unknown;\n return extractScalewayRevision(payload) ?? 'latest';\n }\n\n private buildReference(\n region: string,\n secretId: string,\n extras?: Record<string, string>\n ): string {\n const base = `scw://secret-manager/${region}/${secretId}`;\n const query = extras\n ? Object.entries(extras)\n .filter(([, value]) => Boolean(value))\n .map(\n ([key, value]) =>\n `${encodeURIComponent(key)}=${encodeURIComponent(value)}`\n )\n .join('&')\n : '';\n\n return query ? `${base}?${query}` : base;\n }\n}\n\nfunction extractScalewayData(payload: unknown): string {\n if (!payload || typeof payload !== 'object') {\n throw new Error('Invalid scaleway secret payload');\n }\n\n const record = payload as { data?: unknown };\n if (typeof record.data === 'string' && record.data) {\n return record.data;\n }\n\n throw new Error('Scaleway secret payload is missing data');\n}\n\nfunction extractScalewaySecretId(payload: unknown): string {\n if (!payload || typeof payload !== 'object') {\n throw new Error('Invalid scaleway createSecret payload');\n }\n\n const record = payload as { id?: unknown };\n if (typeof record.id === 'string' && record.id) {\n return record.id;\n }\n\n throw new Error('Scaleway createSecret response is missing id');\n}\n\nfunction extractScalewayRevision(payload: unknown): string | undefined {\n if (!payload || typeof payload !== 'object') {\n return undefined;\n }\n\n const record = payload as { revision?: unknown; id?: unknown };\n if (typeof record.revision === 'number') {\n return String(record.revision);\n }\n if (typeof record.revision === 'string' && record.revision) {\n return record.revision;\n }\n if (typeof record.id === 'string' && record.id) {\n // Some API shapes may return \"id\" for the version.\n return record.id;\n }\n\n return undefined;\n}\n\nasync function toScalewayError(params: {\n response: Response;\n provider: string;\n reference: SecretReference;\n operation: string;\n}): Promise<SecretProviderError> {\n const { response, provider, reference, operation } = params;\n\n const code: SecretProviderError['code'] =\n response.status === 404\n ? 'NOT_FOUND'\n : response.status === 401 || response.status === 403\n ? 'FORBIDDEN'\n : response.status >= 400 && response.status < 500\n ? 'INVALID'\n : 'UNKNOWN';\n\n const bodyText = await safeReadBody(response);\n const message = bodyText\n ? `Scaleway Secret Manager ${operation} failed (${response.status}): ${bodyText}`\n : `Scaleway Secret Manager ${operation} failed (${response.status})`;\n\n return new SecretProviderError({\n message,\n provider,\n reference,\n code,\n });\n}\n\nasync function safeReadBody(response: Response): Promise<string | undefined> {\n try {\n const text = await response.text();\n const trimmed = text.trim();\n return trimmed.length ? trimmed : undefined;\n } catch {\n return undefined;\n }\n}\n"],"mappings":"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"}
|
|
@@ -76,4 +76,5 @@ declare class IntegrationSpecRegistry {
|
|
|
76
76
|
}
|
|
77
77
|
declare function makeIntegrationSpecKey(meta: IntegrationMeta): string;
|
|
78
78
|
//#endregion
|
|
79
|
-
export { IntegrationByokSetup, IntegrationCapabilityMapping, IntegrationCategory, IntegrationConfigSchema, IntegrationHealthCheck, IntegrationMeta, IntegrationOwnershipMode, IntegrationSecretSchema, IntegrationSpec, IntegrationSpecRegistry, makeIntegrationSpecKey };
|
|
79
|
+
export { IntegrationByokSetup, IntegrationCapabilityMapping, IntegrationCategory, IntegrationConfigSchema, IntegrationHealthCheck, IntegrationMeta, IntegrationOwnershipMode, IntegrationSecretSchema, IntegrationSpec, IntegrationSpecRegistry, makeIntegrationSpecKey };
|
|
80
|
+
//# sourceMappingURL=spec.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spec.d.ts","names":[],"sources":["../../src/integrations/spec.ts"],"sourcesContent":[],"mappings":";;;;KAGY,mBAAA;KAgBA,wBAAA;AAhBA,UAkBK,eAAA,SAAwB,aAlBV,CAAA;EAgBnB;EAEK,GAAA,EAAA,MAAA;EASA;EAOA,OAAA,EAAA,MAAA;EAOA,QAAA,EAlBL,mBAkB4B;EAOvB,WAAA,EAAA,MAAA;AAOjB;AAOiB,UAnCA,4BAAA,CAmCe;EACxB;EAEU,QAAA,EApCN,aAoCM,EAAA;EAEF;EAEA,QAAA,CAAA,EAtCH,qBAsCG,EAAA;;AAIA,UAvCC,uBAAA,CAuCD;EAMH;EAGC,MAAA,EAAA,OAAA;EAAoB;EAMrB,OAAA,CAAA,EAlDD,MAkDC,CAAA,MAAA,EAAA,OAAuB,CAAA;;AAY1B,UA3DO,uBAAA,CA2DP;EAI4B;EAgBZ,MAAA,EAAA,OAAA;EAAsB;EAAe,OAAA,CAAA,EA3EnD,MA2EmD,CAAA,MAAA,EAAA,MAAA,CAAA;AAK/D;UA7EiB,oBAAA;;;;;;UAOA,sBAAA;;;;;;UAOA,eAAA;QACT;;kBAEU;;gBAEF;;gBAEA;;gBAEA;;gBAEA;;;;;;;;;aAMH;;;cAGC;;cAMD,uBAAA;;iBAGI;UASP;sCAI4B;0BAgBZ,sBAAsB;;iBAKhC,sBAAA,OAA6B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spec.js","names":["latest: IntegrationSpec | undefined"],"sources":["../../src/integrations/spec.ts"],"sourcesContent":["import type { OwnerShipMeta } from '../ownership';\nimport type { CapabilityRef, CapabilityRequirement } from '../capabilities';\n\nexport type IntegrationCategory =\n | 'payments'\n | 'email'\n | 'calendar'\n | 'sms'\n | 'ai-llm'\n | 'ai-voice'\n | 'speech-to-text'\n | 'vector-db'\n | 'storage'\n | 'accounting'\n | 'crm'\n | 'helpdesk'\n | 'open-banking'\n | 'custom';\n\nexport type IntegrationOwnershipMode = 'managed' | 'byok';\n\nexport interface IntegrationMeta extends OwnerShipMeta {\n /** Stable provider slug (e.g., \"stripe\", \"openai\"). */\n key: string;\n /** Provider version (increment on breaking API changes). */\n version: number;\n category: IntegrationCategory;\n displayName: string;\n}\n\nexport interface IntegrationCapabilityMapping {\n /** Which CapabilitySpec this integration provides. */\n provides: CapabilityRef[];\n /** Optional: which capabilities it requires (e.g., storage for caching). */\n requires?: CapabilityRequirement[];\n}\n\nexport interface IntegrationConfigSchema {\n /** JSON Schema or SchemaModel defining required config fields. */\n schema: unknown;\n /** Example configuration (for docs/UI). */\n example?: Record<string, unknown>;\n}\n\nexport interface IntegrationSecretSchema {\n /** JSON Schema or SchemaModel describing secret fields. */\n schema: unknown;\n /** Redacted example for documentation/UI. */\n example?: Record<string, string>;\n}\n\nexport interface IntegrationByokSetup {\n /** Human-readable instructions for tenants configuring BYOK accounts. */\n setupInstructions?: string;\n /** Required scopes/permissions for BYOK accounts. */\n requiredScopes?: string[];\n}\n\nexport interface IntegrationHealthCheck {\n /** Endpoint or method to validate connection health. */\n method?: 'ping' | 'list' | 'custom';\n /** Timeout in ms for health check. */\n timeoutMs?: number;\n}\n\nexport interface IntegrationSpec {\n meta: IntegrationMeta;\n /** Supported ownership modes for this provider. */\n supportedModes: IntegrationOwnershipMode[];\n /** Which capabilities this integration provides/requires. */\n capabilities: IntegrationCapabilityMapping;\n /** Configuration schema (API keys, endpoints, etc.). */\n configSchema: IntegrationConfigSchema;\n /** Secret schema (API/key material stored via secretRef). */\n secretSchema: IntegrationSecretSchema;\n /** Optional health check configuration. */\n healthCheck?: IntegrationHealthCheck;\n /** Documentation URL. */\n docsUrl?: string;\n /** Rate limits or usage constraints. */\n constraints?: {\n rateLimit?: { rpm?: number; rph?: number };\n quotas?: Record<string, number>;\n };\n /** Provider-specific metadata for BYOK setup flows. */\n byokSetup?: IntegrationByokSetup;\n}\n\nconst integrationKey = (meta: Pick<IntegrationMeta, 'key' | 'version'>) =>\n `${meta.key}.v${meta.version}`;\n\nexport class IntegrationSpecRegistry {\n private readonly items = new Map<string, IntegrationSpec>();\n\n register(spec: IntegrationSpec): this {\n const key = integrationKey(spec.meta);\n if (this.items.has(key)) {\n throw new Error(`Duplicate IntegrationSpec ${key}`);\n }\n this.items.set(key, spec);\n return this;\n }\n\n list(): IntegrationSpec[] {\n return [...this.items.values()];\n }\n\n get(key: string, version?: number): IntegrationSpec | undefined {\n if (version != null) {\n return this.items.get(integrationKey({ key, version }));\n }\n let latest: IntegrationSpec | undefined;\n let maxVersion = -Infinity;\n for (const spec of this.items.values()) {\n if (spec.meta.key !== key) continue;\n if (spec.meta.version > maxVersion) {\n maxVersion = spec.meta.version;\n latest = spec;\n }\n }\n return latest;\n }\n\n getByCategory(category: IntegrationCategory): IntegrationSpec[] {\n return this.list().filter((spec) => spec.meta.category === category);\n }\n}\n\nexport function makeIntegrationSpecKey(meta: IntegrationMeta) {\n return integrationKey(meta);\n}\n"],"mappings":";AAwFA,MAAM,kBAAkB,SACtB,GAAG,KAAK,IAAI,IAAI,KAAK;AAEvB,IAAa,0BAAb,MAAqC;CACnC,AAAiB,wBAAQ,IAAI,KAA8B;CAE3D,SAAS,MAA6B;EACpC,MAAM,MAAM,eAAe,KAAK,KAAK;AACrC,MAAI,KAAK,MAAM,IAAI,IAAI,CACrB,OAAM,IAAI,MAAM,6BAA6B,MAAM;AAErD,OAAK,MAAM,IAAI,KAAK,KAAK;AACzB,SAAO;;CAGT,OAA0B;AACxB,SAAO,CAAC,GAAG,KAAK,MAAM,QAAQ,CAAC;;CAGjC,IAAI,KAAa,SAA+C;AAC9D,MAAI,WAAW,KACb,QAAO,KAAK,MAAM,IAAI,eAAe;GAAE;GAAK;GAAS,CAAC,CAAC;EAEzD,IAAIA;EACJ,IAAI,aAAa;AACjB,OAAK,MAAM,QAAQ,KAAK,MAAM,QAAQ,EAAE;AACtC,OAAI,KAAK,KAAK,QAAQ,IAAK;AAC3B,OAAI,KAAK,KAAK,UAAU,YAAY;AAClC,iBAAa,KAAK,KAAK;AACvB,aAAS;;;AAGb,SAAO;;CAGT,cAAc,UAAkD;AAC9D,SAAO,KAAK,MAAM,CAAC,QAAQ,SAAS,KAAK,KAAK,aAAa,SAAS;;;AAIxE,SAAgB,uBAAuB,MAAuB;AAC5D,QAAO,eAAe,KAAK"}
|
|
@@ -15,4 +15,5 @@ interface DefinedJob<TPayload> {
|
|
|
15
15
|
*/
|
|
16
16
|
declare function registerDefinedJob<TPayload>(queue: JobQueue, job: DefinedJob<TPayload>): void;
|
|
17
17
|
//#endregion
|
|
18
|
-
export { DefinedJob, registerDefinedJob };
|
|
18
|
+
export { DefinedJob, registerDefinedJob };
|
|
19
|
+
//# sourceMappingURL=define-job.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define-job.d.ts","names":[],"sources":["../../src/jobs/define-job.ts"],"sourcesContent":[],"mappings":";;;;UAIiB;EAAA,IAAA,EAAA,MAAA;EAEG,MAAA,EAAV,SAAU,CAAA,QAAA,CAAA;EAAV,OAAA,EAAA,CAAA,OAAA,EACW,QADX,EAAA,GAAA,EAC0B,GAD1B,CAC8B,QAD9B,CAAA,EAAA,GAC4C,OAD5C,CAAA,IAAA,CAAA;;;;;;AAUV;;AAEkB,iBAFF,kBAEE,CAAA,QAAA,CAAA,CAAA,KAAA,EADT,QACS,EAAA,GAAA,EAAX,UAAW,CAAA,QAAA,CAAA,CAAA,EAAA,IAAA"}
|
package/dist/jobs/define-job.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"define-job.js","names":[],"sources":["../../src/jobs/define-job.ts"],"sourcesContent":["import type { ZodSchema } from 'zod';\nimport type { Job } from './queue';\nimport type { JobQueue } from './queue';\n\nexport interface DefinedJob<TPayload> {\n type: string;\n schema: ZodSchema<TPayload>;\n handler: (payload: TPayload, job: Job<TPayload>) => Promise<void>;\n}\n\n/**\n * Register a `DefinedJob` on a queue with payload validation.\n *\n * - Parses and validates payload via the job's Zod schema\n * - Invokes the defined handler with the validated payload\n */\nexport function registerDefinedJob<TPayload>(\n queue: JobQueue,\n job: DefinedJob<TPayload>\n): void {\n queue.register<TPayload>(job.type, async (queuedJob) => {\n const parsed = job.schema.parse(queuedJob.payload);\n await job.handler(parsed, queuedJob as Job<TPayload>);\n });\n}\n"],"mappings":";;;;;;;AAgBA,SAAgB,mBACd,OACA,KACM;AACN,OAAM,SAAmB,IAAI,MAAM,OAAO,cAAc;EACtD,MAAM,SAAS,IAAI,OAAO,MAAM,UAAU,QAAQ;AAClD,QAAM,IAAI,QAAQ,QAAQ,UAA2B;GACrD"}
|
|
@@ -38,4 +38,5 @@ declare class GcpCloudTasksQueue implements JobQueue {
|
|
|
38
38
|
stop(): Promise<void>;
|
|
39
39
|
}
|
|
40
40
|
//#endregion
|
|
41
|
-
export { GcpCloudTasksQueue, GcpCloudTasksQueueOptions };
|
|
41
|
+
export { GcpCloudTasksQueue, GcpCloudTasksQueueOptions };
|
|
42
|
+
//# sourceMappingURL=gcp-cloud-tasks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gcp-cloud-tasks.d.ts","names":[],"sources":["../../src/jobs/gcp-cloud-tasks.ts"],"sourcesContent":[],"mappings":";;;UAUU,oBAAA;;IAAA,MAAA,EAAA,MAAA;IAOI,IAAA,EAAA;MACI,WAAA,EAAA;QAKZ,UAAA,EAAA,MAAA,GAAA,MAAA;QAAO,GAAA,EAAA,MAAA;QAGI,IAAA,EATH,MASG;QASJ,OAAA,CAAA,EAjBK,MAiBc,CAAA,MAAA,EAAA,MAAA,CAAA;QAGQ,SAAA,CAAA,EAAA;UAI3B,mBAAA,EAAA,MAAA;QACA,CAAA;MACI,CAAA;MAAJ,YAAA,CAAA,EAAA;QAAR,OAAA,EAAA,MAAA;MA6CmB,CAAA;IAAU,CAAA;EAArB,CAAA,CAAA,EAlEP,OAkEO,CAAA,OAAA,CAAA;;AAtD8B,UAT1B,yBAAA,CAS0B;EAAQ,MAAA,EARzC,oBAQyC;;;;;;;cAAtC,kBAAA,YAA8B;;;uBAGH;8CAI3B,oBACA,iBACR,QAAQ,IAAI;+DA6CJ,WAAW,UAAU;;UASlB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gcp-cloud-tasks.js","names":["options: GcpCloudTasksQueueOptions"],"sources":["../../src/jobs/gcp-cloud-tasks.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\n\nimport {\n DEFAULT_RETRY_POLICY,\n type EnqueueOptions,\n type Job,\n type JobHandler,\n type JobQueue,\n} from './queue';\n\ninterface CloudTasksClientLike {\n createTask(request: {\n parent: string;\n task: {\n httpRequest: {\n httpMethod: number | string;\n url: string;\n body: Buffer;\n headers?: Record<string, string>;\n oidcToken?: { serviceAccountEmail: string };\n };\n scheduleTime?: { seconds: number };\n };\n }): Promise<unknown>;\n}\n\nexport interface GcpCloudTasksQueueOptions {\n client: CloudTasksClientLike;\n projectId: string;\n location: string;\n queue: string;\n resolveUrl(jobType: string): string;\n serviceAccountEmail?: string;\n}\n\nexport class GcpCloudTasksQueue implements JobQueue {\n private readonly handlers = new Map<string, JobHandler>();\n\n constructor(private readonly options: GcpCloudTasksQueueOptions) {}\n\n async enqueue<TPayload>(\n jobType: string,\n payload: TPayload,\n options: EnqueueOptions = {}\n ): Promise<Job<TPayload>> {\n const enqueueTime =\n options.delaySeconds != null\n ? { seconds: Math.floor(Date.now() / 1000) + options.delaySeconds }\n : undefined;\n const body = Buffer.from(\n JSON.stringify({\n id: randomUUID(),\n type: jobType,\n payload,\n }),\n 'utf-8'\n );\n await this.options.client.createTask({\n parent: `projects/${this.options.projectId}/locations/${this.options.location}/queues/${this.options.queue}`,\n task: {\n httpRequest: {\n httpMethod: 'POST',\n url: this.options.resolveUrl(jobType),\n body,\n headers: { 'Content-Type': 'application/json' },\n oidcToken: this.options.serviceAccountEmail\n ? { serviceAccountEmail: this.options.serviceAccountEmail }\n : undefined,\n },\n scheduleTime: enqueueTime,\n },\n });\n\n return {\n id: randomUUID(),\n type: jobType,\n version: 1,\n payload,\n status: 'pending',\n priority: options.priority ?? 0,\n attempts: 0,\n maxRetries: options.maxRetries ?? DEFAULT_RETRY_POLICY.maxRetries,\n createdAt: new Date(),\n updatedAt: new Date(),\n };\n }\n\n register<TPayload, TResult = void>(\n jobType: string,\n handler: JobHandler<TPayload, TResult>\n ): void {\n this.handlers.set(jobType, handler as JobHandler);\n }\n\n start(): void {\n // Execution is handled by Cloud Tasks via HTTP callbacks.\n }\n\n async stop(): Promise<void> {\n this.handlers.clear();\n }\n}\n"],"mappings":";;;;AAmCA,IAAa,qBAAb,MAAoD;CAClD,AAAiB,2BAAW,IAAI,KAAyB;CAEzD,YAAY,AAAiBA,SAAoC;EAApC;;CAE7B,MAAM,QACJ,SACA,SACA,UAA0B,EAAE,EACJ;EACxB,MAAM,cACJ,QAAQ,gBAAgB,OACpB,EAAE,SAAS,KAAK,MAAM,KAAK,KAAK,GAAG,IAAK,GAAG,QAAQ,cAAc,GACjE;EACN,MAAM,OAAO,OAAO,KAClB,KAAK,UAAU;GACb,IAAI,YAAY;GAChB,MAAM;GACN;GACD,CAAC,EACF,QACD;AACD,QAAM,KAAK,QAAQ,OAAO,WAAW;GACnC,QAAQ,YAAY,KAAK,QAAQ,UAAU,aAAa,KAAK,QAAQ,SAAS,UAAU,KAAK,QAAQ;GACrG,MAAM;IACJ,aAAa;KACX,YAAY;KACZ,KAAK,KAAK,QAAQ,WAAW,QAAQ;KACrC;KACA,SAAS,EAAE,gBAAgB,oBAAoB;KAC/C,WAAW,KAAK,QAAQ,sBACpB,EAAE,qBAAqB,KAAK,QAAQ,qBAAqB,GACzD;KACL;IACD,cAAc;IACf;GACF,CAAC;AAEF,SAAO;GACL,IAAI,YAAY;GAChB,MAAM;GACN,SAAS;GACT;GACA,QAAQ;GACR,UAAU,QAAQ,YAAY;GAC9B,UAAU;GACV,YAAY,QAAQ,cAAc,qBAAqB;GACvD,2BAAW,IAAI,MAAM;GACrB,2BAAW,IAAI,MAAM;GACtB;;CAGH,SACE,SACA,SACM;AACN,OAAK,SAAS,IAAI,SAAS,QAAsB;;CAGnD,QAAc;CAId,MAAM,OAAsB;AAC1B,OAAK,SAAS,OAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gcp-pubsub.d.ts","names":[],"sources":["../../src/jobs/gcp-pubsub.ts"],"sourcesContent":[],"mappings":";;;UAUU,gBAAA;;IAAA,cAAA,CAAgB,OAAA,EAAA;MAMT,IAAA,EAJmB,MAInB;IAKJ,CAAA,CAAA,EATkC,OASlC,CAAA,MAAe,CAAA;EAGY,CAAA;;AAK3B,UAbI,qBAAA,CAaJ;EACI,MAAA,EAbP,gBAaO;EAAJ,SAAA,EAAA,MAAA;;AA4BW,cArCX,cAAA,YAA0B,QAqCf,CAAA;EAAU,iBAAA,OAAA;EAArB,iBAAA,QAAA;EASG,WAAA,CAAA,OAAA,EA3CwB,qBA2CxB;EA9CuB,OAAA,CAAA,QAAA,CAAA,CAAA,OAAA,EAAA,MAAA,EAAA,OAAA,EAO1B,QAP0B,EAAA,OAAA,CAAA,EAQ1B,cAR0B,CAAA,EASlC,OATkC,CAS1B,GAT0B,CAStB,QATsB,CAAA,CAAA;EAAQ,QAAA,CAAA,QAAA,EAAA,UAAA,IAAA,CAAA,CAAA,OAAA,EAAA,MAAA,EAAA,OAAA,EAqClC,UArCkC,CAqCvB,QArCuB,EAqCb,OArCa,CAAA,CAAA,EAAA,IAAA;;UA8C/B"}
|
package/dist/jobs/gcp-pubsub.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gcp-pubsub.js","names":["options: GcpPubSubQueueOptions"],"sources":["../../src/jobs/gcp-pubsub.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\n\nimport {\n DEFAULT_RETRY_POLICY,\n type EnqueueOptions,\n type Job,\n type JobHandler,\n type JobQueue,\n} from './queue';\n\ninterface PubSubClientLike {\n topic(name: string): {\n publishMessage(message: { data: Buffer }): Promise<string>;\n };\n}\n\nexport interface GcpPubSubQueueOptions {\n client: PubSubClientLike;\n topicName: string;\n}\n\nexport class GcpPubSubQueue implements JobQueue {\n private readonly handlers = new Map<string, JobHandler>();\n\n constructor(private readonly options: GcpPubSubQueueOptions) {}\n\n async enqueue<TPayload>(\n jobType: string,\n payload: TPayload,\n options: EnqueueOptions = {}\n ): Promise<Job<TPayload>> {\n await this.options.client.topic(this.options.topicName).publishMessage({\n data: Buffer.from(\n JSON.stringify({\n id: randomUUID(),\n type: jobType,\n payload,\n }),\n 'utf-8'\n ),\n });\n\n return {\n id: randomUUID(),\n type: jobType,\n version: 1,\n payload,\n status: 'pending',\n priority: options.priority ?? 0,\n attempts: 0,\n maxRetries: options.maxRetries ?? DEFAULT_RETRY_POLICY.maxRetries,\n createdAt: new Date(),\n updatedAt: new Date(),\n };\n }\n\n register<TPayload, TResult = void>(\n jobType: string,\n handler: JobHandler<TPayload, TResult>\n ): void {\n this.handlers.set(jobType, handler as JobHandler);\n }\n\n start(): void {\n // Message consumption handled externally via Pub/Sub subscription.\n }\n\n async stop(): Promise<void> {\n this.handlers.clear();\n }\n}\n"],"mappings":";;;;AAqBA,IAAa,iBAAb,MAAgD;CAC9C,AAAiB,2BAAW,IAAI,KAAyB;CAEzD,YAAY,AAAiBA,SAAgC;EAAhC;;CAE7B,MAAM,QACJ,SACA,SACA,UAA0B,EAAE,EACJ;AACxB,QAAM,KAAK,QAAQ,OAAO,MAAM,KAAK,QAAQ,UAAU,CAAC,eAAe,EACrE,MAAM,OAAO,KACX,KAAK,UAAU;GACb,IAAI,YAAY;GAChB,MAAM;GACN;GACD,CAAC,EACF,QACD,EACF,CAAC;AAEF,SAAO;GACL,IAAI,YAAY;GAChB,MAAM;GACN,SAAS;GACT;GACA,QAAQ;GACR,UAAU,QAAQ,YAAY;GAC9B,UAAU;GACV,YAAY,QAAQ,cAAc,qBAAqB;GACvD,2BAAW,IAAI,MAAM;GACrB,2BAAW,IAAI,MAAM;GACtB;;CAGH,SACE,SACA,SACM;AACN,OAAK,SAAS,IAAI,SAAS,QAAsB;;CAGnD,QAAc;CAId,MAAM,OAAsB;AAC1B,OAAK,SAAS,OAAO"}
|
|
@@ -6,4 +6,5 @@ import { GmailIngestionAdapter } from "../../knowledge/ingestion/gmail-adapter.j
|
|
|
6
6
|
interface GmailSyncJobPayload extends EmailThreadListQuery {}
|
|
7
7
|
declare function createGmailSyncHandler(adapter: GmailIngestionAdapter): JobHandler<GmailSyncJobPayload>;
|
|
8
8
|
//#endregion
|
|
9
|
-
export { GmailSyncJobPayload, createGmailSyncHandler };
|
|
9
|
+
export { GmailSyncJobPayload, createGmailSyncHandler };
|
|
10
|
+
//# sourceMappingURL=gmail-sync-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gmail-sync-handler.d.ts","names":[],"sources":["../../../src/jobs/handlers/gmail-sync-handler.ts"],"sourcesContent":[],"mappings":";;;;;UAIiB,mBAAA,SAA4B;AAA5B,iBAED,sBAAA,CAF6B,OAAA,EAGlC,qBAHsD,CAAA,EAI9D,UAJ8D,CAInD,mBAJmD,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gmail-sync-handler.js","names":[],"sources":["../../../src/jobs/handlers/gmail-sync-handler.ts"],"sourcesContent":["import type { JobHandler } from '../queue';\nimport type { GmailIngestionAdapter } from '../../knowledge/ingestion/gmail-adapter';\nimport type { EmailThreadListQuery } from '../../integrations/providers/email';\n\nexport interface GmailSyncJobPayload extends EmailThreadListQuery {}\n\nexport function createGmailSyncHandler(\n adapter: GmailIngestionAdapter\n): JobHandler<GmailSyncJobPayload> {\n return async (job) => {\n await adapter.syncThreads(job.payload);\n };\n}\n"],"mappings":";AAMA,SAAgB,uBACd,SACiC;AACjC,QAAO,OAAO,QAAQ;AACpB,QAAM,QAAQ,YAAY,IAAI,QAAQ"}
|
|
@@ -6,4 +6,5 @@ import { StorageDocumentJobPayload, createStorageDocumentHandler } from "./stora
|
|
|
6
6
|
//#region src/jobs/handlers/index.d.ts
|
|
7
7
|
declare function registerAllJobs(queue: JobQueue): void;
|
|
8
8
|
//#endregion
|
|
9
|
-
export { GmailSyncJobPayload, PING_JOB_TYPE, PingPayload, PingPayloadSchema, StorageDocumentJobPayload, createGmailSyncHandler, createStorageDocumentHandler, pingJob, registerAllJobs };
|
|
9
|
+
export { GmailSyncJobPayload, PING_JOB_TYPE, PingPayload, PingPayloadSchema, StorageDocumentJobPayload, createGmailSyncHandler, createStorageDocumentHandler, pingJob, registerAllJobs };
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","names":[],"sources":["../../../src/jobs/handlers/index.ts"],"sourcesContent":[],"mappings":";;;;;;iBAUgB,eAAA,QAAuB"}
|
|
@@ -9,4 +9,5 @@ function registerAllJobs(queue) {
|
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
//#endregion
|
|
12
|
-
export { PING_JOB_TYPE, PingPayloadSchema, createGmailSyncHandler, createStorageDocumentHandler, pingJob, registerAllJobs };
|
|
12
|
+
export { PING_JOB_TYPE, PingPayloadSchema, createGmailSyncHandler, createStorageDocumentHandler, pingJob, registerAllJobs };
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../src/jobs/handlers/index.ts"],"sourcesContent":["export * from './ping-handler';\nexport * from './gmail-sync-handler';\nexport * from './storage-document-handler';\nimport type { JobQueue } from '../queue';\nimport { registerDefinedJob } from '../define-job';\n\nimport { pingJob } from './ping-handler';\n// import { equityaRecomputePlanJob } from './types/equitya.recompute-plan';\n// import { artisanosGenerateQuoteJob } from './types/artisanos.generate-quote';\n\nexport function registerAllJobs(queue: JobQueue): void {\n registerDefinedJob(queue, pingJob);\n // registerDefinedJob(queue, equityaRecomputePlanJob);\n // registerDefinedJob(queue, artisanosGenerateQuoteJob);\n}\n"],"mappings":";;;;;;AAUA,SAAgB,gBAAgB,OAAuB;AACrD,oBAAmB,OAAO,QAAQ"}
|
|
@@ -7,4 +7,5 @@ declare const PingPayloadSchema: z$1.ZodObject<{}, z$1.core.$strip>;
|
|
|
7
7
|
type PingPayload = z$1.infer<typeof PingPayloadSchema>;
|
|
8
8
|
declare const pingJob: DefinedJob<PingPayload>;
|
|
9
9
|
//#endregion
|
|
10
|
-
export { PING_JOB_TYPE, PingPayload, PingPayloadSchema, pingJob };
|
|
10
|
+
export { PING_JOB_TYPE, PingPayload, PingPayloadSchema, pingJob };
|
|
11
|
+
//# sourceMappingURL=ping-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ping-handler.d.ts","names":[],"sources":["../../../src/jobs/handlers/ping-handler.ts"],"sourcesContent":[],"mappings":";;;;cAKa;cAEA,mBAAiB,GAAA,CAAA,cAAA,GAAA,CAAA,IAAA,CAAA;AAFjB,KAID,WAAA,GAAc,GAAA,CAAE,KAJqB,CAAA,OAIR,iBAJQ,CAAA;AAEpC,cAIA,OAJgC,EAIvB,UAJQ,CAIG,WAJH,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ping-handler.js","names":["z","pingJob: DefinedJob<PingPayload>"],"sources":["../../../src/jobs/handlers/ping-handler.ts"],"sourcesContent":["// jobs/types/ping.ts\nimport * as z from 'zod';\nimport type { Job } from '../queue';\nimport type { DefinedJob } from '../define-job';\n\nexport const PING_JOB_TYPE = 'core.ping' as const;\n\nexport const PingPayloadSchema = z.object({});\n\nexport type PingPayload = z.infer<typeof PingPayloadSchema>;\n\nexport const pingJob: DefinedJob<PingPayload> = {\n type: PING_JOB_TYPE,\n schema: PingPayloadSchema,\n handler: async (_payload: PingPayload, job: Job<PingPayload>) => {\n console.log('[ping] job id=%s attempts=%d', job.id, job.attempts);\n },\n};\n"],"mappings":";;;AAKA,MAAa,gBAAgB;AAE7B,MAAa,oBAAoBA,IAAE,OAAO,EAAE,CAAC;AAI7C,MAAaC,UAAmC;CAC9C,MAAM;CACN,QAAQ;CACR,SAAS,OAAO,UAAuB,QAA0B;AAC/D,UAAQ,IAAI,gCAAgC,IAAI,IAAI,IAAI,SAAS;;CAEpE"}
|
|
@@ -9,4 +9,5 @@ interface StorageDocumentJobPayload {
|
|
|
9
9
|
}
|
|
10
10
|
declare function createStorageDocumentHandler(storage: ObjectStorageProvider, adapter: StorageIngestionAdapter): JobHandler<StorageDocumentJobPayload>;
|
|
11
11
|
//#endregion
|
|
12
|
-
export { StorageDocumentJobPayload, createStorageDocumentHandler };
|
|
12
|
+
export { StorageDocumentJobPayload, createStorageDocumentHandler };
|
|
13
|
+
//# sourceMappingURL=storage-document-handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-document-handler.d.ts","names":[],"sources":["../../../src/jobs/handlers/storage-document-handler.ts"],"sourcesContent":[],"mappings":";;;;;UAIiB,yBAAA;;EAAA,GAAA,EAAA,MAAA;AAKjB;AACW,iBADK,4BAAA,CACL,OAAA,EAAA,qBAAA,EAAA,OAAA,EACA,uBADA,CAAA,EAER,UAFQ,CAEG,yBAFH,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-document-handler.js","names":[],"sources":["../../../src/jobs/handlers/storage-document-handler.ts"],"sourcesContent":["import type { ObjectStorageProvider } from '../../integrations/providers/storage';\nimport type { StorageIngestionAdapter } from '../../knowledge/ingestion/storage-adapter';\nimport type { JobHandler } from '../queue';\n\nexport interface StorageDocumentJobPayload {\n bucket: string;\n key: string;\n}\n\nexport function createStorageDocumentHandler(\n storage: ObjectStorageProvider,\n adapter: StorageIngestionAdapter\n): JobHandler<StorageDocumentJobPayload> {\n return async (job) => {\n const object = await storage.getObject({\n bucket: job.payload.bucket,\n key: job.payload.key,\n });\n if (!object) {\n throw new Error(\n `Object ${job.payload.bucket}/${job.payload.key} not found`\n );\n }\n await adapter.ingestObject(object);\n };\n}\n"],"mappings":";AASA,SAAgB,6BACd,SACA,SACuC;AACvC,QAAO,OAAO,QAAQ;EACpB,MAAM,SAAS,MAAM,QAAQ,UAAU;GACrC,QAAQ,IAAI,QAAQ;GACpB,KAAK,IAAI,QAAQ;GAClB,CAAC;AACF,MAAI,CAAC,OACH,OAAM,IAAI,MACR,UAAU,IAAI,QAAQ,OAAO,GAAG,IAAI,QAAQ,IAAI,YACjD;AAEH,QAAM,QAAQ,aAAa,OAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-queue.d.ts","names":[],"sources":["../../src/jobs/memory-queue.ts"],"sourcesContent":[],"mappings":";;;cAUa,cAAA,YAA0B;;EAA1B,iBAAe,IAAA;EAUf,iBAAA,QAAA;EACA,QAAA,KAAA;EACI,QAAA,UAAA;EAAJ,WAAA,CAAA,cAAA,CAAA,EAAA,MAAA;EAAR,OAAA,CAAA,QAAA,CAAA,CAAA,OAAA,EAAA,MAAA,EAAA,OAAA,EAFQ,QAER,EAAA,OAAA,CAAA,EADQ,cACR,CAAA,EAAA,OAAA,CAAQ,GAAR,CAAY,QAAZ,CAAA,CAAA;EAsBmB,QAAA,CAAA,QAAA,EAAA,UAAA,IAAA,CAAA,CAAA,OAAA,EAAA,MAAA,EAAA,OAAA,EAAX,UAAW,CAAA,QAAA,EAAU,OAAV,CAAA,CAAA,EAAA,IAAA;EAAU,KAAA,CAAA,CAAA,EAAA,IAAA;EAArB,IAAA,CAAA,CAAA,EAYG,OAZH,CAAA,IAAA,CAAA;EAYG,QAAA,WAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-queue.js","names":["job: Job<TPayload>"],"sources":["../../src/jobs/memory-queue.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\n\nimport {\n DEFAULT_RETRY_POLICY,\n type EnqueueOptions,\n type Job,\n type JobHandler,\n type JobQueue,\n} from './queue';\n\nexport class MemoryJobQueue implements JobQueue {\n private readonly jobs: Job[] = [];\n private readonly handlers = new Map<string, JobHandler>();\n private timer?: NodeJS.Timeout;\n private processing = false;\n\n constructor(private readonly pollIntervalMs = 200) {}\n\n async enqueue<TPayload>(\n jobType: string,\n payload: TPayload,\n options: EnqueueOptions = {}\n ): Promise<Job<TPayload>> {\n const job: Job<TPayload> = {\n id: randomUUID(),\n type: jobType,\n version: 1,\n payload,\n status: 'pending',\n priority: options.priority ?? 0,\n attempts: 0,\n maxRetries: options.maxRetries ?? DEFAULT_RETRY_POLICY.maxRetries,\n createdAt: new Date(),\n updatedAt: new Date(),\n };\n if (options.delaySeconds) {\n job.updatedAt = new Date(Date.now() + options.delaySeconds * 1000);\n }\n this.jobs.push(job);\n return job;\n }\n\n register<TPayload, TResult = void>(\n jobType: string,\n handler: JobHandler<TPayload, TResult>\n ): void {\n this.handlers.set(jobType, handler as JobHandler);\n }\n\n start(): void {\n if (this.timer) return;\n this.timer = setInterval(() => {\n void this.processNext();\n }, this.pollIntervalMs);\n }\n\n async stop(): Promise<void> {\n if (this.timer) {\n clearInterval(this.timer);\n this.timer = undefined;\n }\n while (this.processing) {\n await new Promise((resolve) => setTimeout(resolve, 10));\n }\n }\n\n private async processNext() {\n if (this.processing) return;\n const job = this.jobs.find(\n (j) => j.status === 'pending' && j.updatedAt <= new Date()\n );\n if (!job) return;\n const handler = this.handlers.get(job.type);\n if (!handler) return;\n\n this.processing = true;\n job.status = 'running';\n job.updatedAt = new Date();\n job.attempts += 1;\n\n try {\n await handler(job);\n job.status = 'completed';\n job.updatedAt = new Date();\n } catch (error) {\n job.status = 'failed';\n job.lastError =\n error instanceof Error ? error.message : 'Unknown job error';\n job.updatedAt = new Date();\n } finally {\n this.processing = false;\n }\n }\n}\n"],"mappings":";;;;AAUA,IAAa,iBAAb,MAAgD;CAC9C,AAAiB,OAAc,EAAE;CACjC,AAAiB,2BAAW,IAAI,KAAyB;CACzD,AAAQ;CACR,AAAQ,aAAa;CAErB,YAAY,AAAiB,iBAAiB,KAAK;EAAtB;;CAE7B,MAAM,QACJ,SACA,SACA,UAA0B,EAAE,EACJ;EACxB,MAAMA,MAAqB;GACzB,IAAI,YAAY;GAChB,MAAM;GACN,SAAS;GACT;GACA,QAAQ;GACR,UAAU,QAAQ,YAAY;GAC9B,UAAU;GACV,YAAY,QAAQ,cAAc,qBAAqB;GACvD,2BAAW,IAAI,MAAM;GACrB,2BAAW,IAAI,MAAM;GACtB;AACD,MAAI,QAAQ,aACV,KAAI,YAAY,IAAI,KAAK,KAAK,KAAK,GAAG,QAAQ,eAAe,IAAK;AAEpE,OAAK,KAAK,KAAK,IAAI;AACnB,SAAO;;CAGT,SACE,SACA,SACM;AACN,OAAK,SAAS,IAAI,SAAS,QAAsB;;CAGnD,QAAc;AACZ,MAAI,KAAK,MAAO;AAChB,OAAK,QAAQ,kBAAkB;AAC7B,GAAK,KAAK,aAAa;KACtB,KAAK,eAAe;;CAGzB,MAAM,OAAsB;AAC1B,MAAI,KAAK,OAAO;AACd,iBAAc,KAAK,MAAM;AACzB,QAAK,QAAQ;;AAEf,SAAO,KAAK,WACV,OAAM,IAAI,SAAS,YAAY,WAAW,SAAS,GAAG,CAAC;;CAI3D,MAAc,cAAc;AAC1B,MAAI,KAAK,WAAY;EACrB,MAAM,MAAM,KAAK,KAAK,MACnB,MAAM,EAAE,WAAW,aAAa,EAAE,6BAAa,IAAI,MAAM,CAC3D;AACD,MAAI,CAAC,IAAK;EACV,MAAM,UAAU,KAAK,SAAS,IAAI,IAAI,KAAK;AAC3C,MAAI,CAAC,QAAS;AAEd,OAAK,aAAa;AAClB,MAAI,SAAS;AACb,MAAI,4BAAY,IAAI,MAAM;AAC1B,MAAI,YAAY;AAEhB,MAAI;AACF,SAAM,QAAQ,IAAI;AAClB,OAAI,SAAS;AACb,OAAI,4BAAY,IAAI,MAAM;WACnB,OAAO;AACd,OAAI,SAAS;AACb,OAAI,YACF,iBAAiB,QAAQ,MAAM,UAAU;AAC3C,OAAI,4BAAY,IAAI,MAAM;YAClB;AACR,QAAK,aAAa"}
|
package/dist/jobs/queue.d.ts
CHANGED
|
@@ -128,4 +128,5 @@ interface JobTypeDef<TPayload = unknown> {
|
|
|
128
128
|
*/
|
|
129
129
|
declare function defineJobType<TPayload>(def: JobTypeDef<TPayload>): JobTypeDef<TPayload>;
|
|
130
130
|
//#endregion
|
|
131
|
-
export { DEFAULT_RETRY_POLICY, EnqueueOptions, Job, JobHandler, JobQueue, JobStatus, JobTypeDef, QueueStats, RetryPolicy, calculateBackoff, defineJobType };
|
|
131
|
+
export { DEFAULT_RETRY_POLICY, EnqueueOptions, Job, JobHandler, JobQueue, JobStatus, JobTypeDef, QueueStats, RetryPolicy, calculateBackoff, defineJobType };
|
|
132
|
+
//# sourceMappingURL=queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.d.ts","names":[],"sources":["../../src/jobs/queue.ts"],"sourcesContent":[],"mappings":";;;;;;AAKA;AAWiB,KAXL,SAAA,GAWQ,SAAA,GAAA,SAAA,GAAA,WAAA,GAAA,QAAA,GAAA,WAAA,GAAA,aAAA;;;;AAUP,UAVI,GAUJ,CAAA,WAAA,OAAA,CAAA,CAAA;EACG,EAAA,EAAA,MAAA;EACF,IAAA,EAAA,MAAA;EACE,OAAA,EAAA,MAAA;EACF,OAAA,EAVH,QAUG;EAMD,MAAA,EAfH,SAeG;EAAM,QAAA,EAAA,MAAA;EAOF,QAAA,EAAA,MAAA;EAwBL,UAAA,EAAA,MAAU;EACX,SAAA,EA3CE,IA2CF;EAAJ,SAAA,EA1CM,IA0CN;EACM,WAAA,CAAA,EA1CG,IA0CH;EAAR,SAAA,CAAA,EAzCS,IAyCT;EAAO,WAAA,CAAA,EAxCI,IAwCJ;EAKK,SAAA,CAAA,EA5CH,IA4CW;EAIZ,SAAA,CAAA,EAAA,MAAA;EACC,SAAA,CAAA,EAAA,MAAA;EACG,QAAA,CAAA,EAAA,MAAA;EAAJ,MAAA,CAAA,EAAA,MAAA;EAAR,OAAA,CAAA,EAAA,MAAA;EAKmB,QAAA,CAAA,EAjDX,MAiDW,CAAA,MAAA,EAAA,OAAA,CAAA;EAAU,MAAA,CAAA,EAAA,OAAA;;;;;AAaL,UAvDZ,cAAA,CAuDY;EAGN;EAAR,YAAA,CAAA,EAAA,MAAA;EAAO;EAML,SAAA,CAAA,EAAA,MAAU;EAWV;EAgBJ,UAAA,CAAA,EAAA,MAAA;EAWG;EAqBC,QAAA,CAAA,EAAA,MAAU;EAGN;EAAV,SAAE,CAAA,EAAA,MAAA;EACO;EAAR,QAAA,CAAA,EAAA,MAAA;EAAO;EAOH,MAAA,CAAA,EAAA,MAAA;EACE;EAAX,OAAA,CAAA,EAAA,MAAA;EACO;EAAX,QAAA,CAAA,EAtHU,MAsHV,CAAA,MAAA,EAAA,OAAA,CAAA;;;;;KAhHS,uDACL,IAAI,cACN,QAAQ;;;;UAKI,QAAA;;8CAIJ,oBACC,iBACT,QAAQ,IAAI;;+DAKJ,WAAW,UAAU;;;;UAOxB;;0BAGgB,QAAQ;;6BAGL;;eAGd,QAAQ;;;;;UAMN,UAAA;;;;;;;;;;UAWA,WAAA;;;;;;;;;;;;;;;cAgBJ,sBAAsB;;;;iBAWnB,gBAAA,2BAEN;;;;UAmBO;;;WAGN,GAAA,CAAE,QAAQ;YACT,QAAQ;;;;;;;;iBAOJ,6BACT,WAAW,YACf,WAAW"}
|
package/dist/jobs/queue.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.js","names":["DEFAULT_RETRY_POLICY: RetryPolicy"],"sources":["../../src/jobs/queue.ts"],"sourcesContent":["import * as z from 'zod';\n\n/**\n * Job status values.\n */\nexport type JobStatus =\n | 'pending'\n | 'running'\n | 'completed'\n | 'failed'\n | 'cancelled'\n | 'dead_letter';\n\n/**\n * A job in the queue.\n */\nexport interface Job<TPayload = unknown> {\n id: string;\n type: string;\n version: number;\n payload: TPayload;\n status: JobStatus;\n priority: number;\n attempts: number;\n maxRetries: number;\n createdAt: Date;\n updatedAt: Date;\n scheduledAt?: Date;\n startedAt?: Date;\n completedAt?: Date;\n timeoutAt?: Date;\n lastError?: string;\n dedupeKey?: string;\n tenantId?: string;\n userId?: string;\n traceId?: string;\n metadata?: Record<string, unknown>;\n result?: unknown;\n}\n\n/**\n * Options for enqueueing a job.\n */\nexport interface EnqueueOptions {\n /** Delay execution by this many seconds */\n delaySeconds?: number;\n /** Key for deduplication (only one job with this key can be pending) */\n dedupeKey?: string;\n /** Maximum retry attempts (overrides job type default) */\n maxRetries?: number;\n /** Job priority (higher = more urgent) */\n priority?: number;\n /** Timeout in milliseconds */\n timeoutMs?: number;\n /** Tenant context */\n tenantId?: string;\n /** User who enqueued */\n userId?: string;\n /** Trace ID for distributed tracing */\n traceId?: string;\n /** Additional metadata */\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Job handler function.\n */\nexport type JobHandler<TPayload = unknown, TResult = void> = (\n job: Job<TPayload>\n) => Promise<TResult>;\n\n/**\n * Job queue interface.\n */\nexport interface JobQueue {\n /** Enqueue a new job */\n enqueue<TPayload>(\n jobType: string,\n payload: TPayload,\n options?: EnqueueOptions\n ): Promise<Job<TPayload>>;\n\n /** Register a handler for a job type */\n register<TPayload, TResult = void>(\n jobType: string,\n handler: JobHandler<TPayload, TResult>\n ): void;\n\n /** Start processing jobs */\n start(): void;\n\n /** Stop processing jobs gracefully */\n stop(): Promise<void>;\n\n /** Get job by ID */\n getJob?(jobId: string): Promise<Job | null>;\n\n /** Cancel a pending job */\n cancelJob?(jobId: string): Promise<boolean>;\n\n /** Get queue stats */\n getStats?(): Promise<QueueStats>;\n}\n\n/**\n * Queue statistics.\n */\nexport interface QueueStats {\n pending: number;\n running: number;\n completed: number;\n failed: number;\n deadLetter: number;\n}\n\n/**\n * Retry policy configuration.\n */\nexport interface RetryPolicy {\n /** Maximum number of retry attempts */\n maxRetries: number;\n /** Initial backoff in milliseconds */\n initialBackoffMs: number;\n /** Maximum backoff in milliseconds */\n maxBackoffMs: number;\n /** Backoff multiplier (exponential) */\n multiplier: number;\n /** Add jitter to backoff */\n jitter: boolean;\n}\n\n/**\n * Default retry policy.\n */\nexport const DEFAULT_RETRY_POLICY: RetryPolicy = {\n maxRetries: 3,\n initialBackoffMs: 1000,\n maxBackoffMs: 60000,\n multiplier: 2,\n jitter: true,\n};\n\n/**\n * Calculate backoff delay for a retry attempt.\n */\nexport function calculateBackoff(\n attempt: number,\n policy: RetryPolicy = DEFAULT_RETRY_POLICY\n): number {\n const baseDelay = Math.min(\n policy.initialBackoffMs * Math.pow(policy.multiplier, attempt - 1),\n policy.maxBackoffMs\n );\n\n if (policy.jitter) {\n // Add up to 20% jitter\n const jitterFactor = 0.8 + Math.random() * 0.4;\n return Math.floor(baseDelay * jitterFactor);\n }\n\n return baseDelay;\n}\n\n/**\n * Job type definition.\n */\nexport interface JobTypeDef<TPayload = unknown> {\n type: string;\n version: number;\n payload: z.ZodType<TPayload>;\n options?: Partial<RetryPolicy & { timeoutMs: number }>;\n description?: string;\n}\n\n/**\n * Define a typed job type.\n */\nexport function defineJobType<TPayload>(\n def: JobTypeDef<TPayload>\n): JobTypeDef<TPayload> {\n return def;\n}\n"],"mappings":";;;;;;AAsIA,MAAaA,uBAAoC;CAC/C,YAAY;CACZ,kBAAkB;CAClB,cAAc;CACd,YAAY;CACZ,QAAQ;CACT;;;;AAKD,SAAgB,iBACd,SACA,SAAsB,sBACd;CACR,MAAM,YAAY,KAAK,IACrB,OAAO,mBAAmB,KAAK,IAAI,OAAO,YAAY,UAAU,EAAE,EAClE,OAAO,aACR;AAED,KAAI,OAAO,QAAQ;EAEjB,MAAM,eAAe,KAAM,KAAK,QAAQ,GAAG;AAC3C,SAAO,KAAK,MAAM,YAAY,aAAa;;AAG7C,QAAO;;;;;AAiBT,SAAgB,cACd,KACsB;AACtB,QAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaleway-sqs-queue.d.ts","names":[],"sources":["../../src/jobs/scaleway-sqs-queue.ts"],"sourcesContent":[],"mappings":";;;UAgBU,sBAAA;;EAAA,MAAA,CAAA,EAAA,MAAA;EAeG,QAAA,CAAA,EAAA,MAAA;EASS,eAAA,CAAA,EAAA,MAAA;EA8BT,mBAAA,CAAA,EAAA,MAAA;EACA,wBAAA,CAAA,EAAA,MAAA;;AACA,cAzCA,mBAAA,YAA+B,QAyC/B,CAAA;EAAR,iBAAA,GAAA;EAmCmB,iBAAA,QAAA;EAAU,iBAAA,eAAA;EAArB,iBAAA,mBAAA;EAkBG,iBAAA,wBAAA;EA9F4B,iBAAA,QAAA;EAAQ,QAAA,OAAA;sBAS9B;8CA8BT,oBACA,iBACR,QAAQ,IAAI;+DAmCJ,WAAW,UAAU;;UAkBlB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaleway-sqs-queue.js","names":["envelope: RawJobEnvelope<TPayload>","envelope: RawJobEnvelope","job: Job"],"sources":["../../src/jobs/scaleway-sqs-queue.ts"],"sourcesContent":["// jobs/scaleway-sqs-queue.ts\nimport { randomUUID } from 'crypto';\nimport {\n DeleteMessageCommand,\n ReceiveMessageCommand,\n SendMessageCommand,\n SQSClient,\n} from '@aws-sdk/client-sqs';\nimport {\n DEFAULT_RETRY_POLICY,\n type EnqueueOptions,\n type Job,\n type JobHandler,\n type JobQueue,\n} from './queue';\n\ninterface ScalewaySqsQueueConfig {\n queueUrl: string;\n region?: string;\n endpoint?: string;\n waitTimeSeconds?: number;\n maxNumberOfMessages?: number;\n visibilityTimeoutSeconds?: number;\n}\n\ninterface RawJobEnvelope<TPayload = unknown> {\n id: string;\n type: string;\n payload: TPayload;\n}\n\nexport class ScalewaySqsJobQueue implements JobQueue {\n private readonly sqs: SQSClient;\n private readonly queueUrl: string;\n private readonly waitTimeSeconds: number;\n private readonly maxNumberOfMessages: number;\n private readonly visibilityTimeoutSeconds: number;\n private readonly handlers = new Map<string, JobHandler>();\n private running = false;\n\n constructor(config: ScalewaySqsQueueConfig) {\n const accessKeyId = process.env.SCALEWAY_ACCESS_KEY_QUEUE;\n const secretAccessKey = process.env.SCALEWAY_SECRET_KEY_QUEUE;\n\n if (!accessKeyId || !secretAccessKey) {\n throw new Error(\n 'Missing SCALEWAY_ACCESS_KEY_QUEUE / SCALEWAY_SECRET_KEY_QUEUE in env'\n );\n }\n\n const region = config.region ?? process.env.SCALEWAY_REGION ?? 'par';\n const endpoint = 'https://sqs.mnq.fr-par.scaleway.com';\n\n this.sqs = new SQSClient({\n region,\n endpoint,\n credentials: {\n accessKeyId,\n secretAccessKey,\n },\n });\n\n this.queueUrl = config.queueUrl;\n this.waitTimeSeconds = config.waitTimeSeconds ?? 20;\n this.maxNumberOfMessages = config.maxNumberOfMessages ?? 5;\n this.visibilityTimeoutSeconds = config.visibilityTimeoutSeconds ?? 60;\n }\n\n async enqueue<TPayload>(\n jobType: string,\n payload: TPayload,\n options: EnqueueOptions = {}\n ): Promise<Job<TPayload>> {\n const id = randomUUID();\n const now = new Date();\n\n const envelope: RawJobEnvelope<TPayload> = {\n id,\n type: jobType,\n payload,\n };\n\n await this.sqs.send(\n new SendMessageCommand({\n QueueUrl: this.queueUrl,\n MessageBody: JSON.stringify(envelope),\n DelaySeconds: options.delaySeconds ?? 0,\n // If you use FIFO queues later, you'd set MessageGroupId / MessageDeduplicationId here.\n })\n );\n\n return {\n id,\n type: jobType,\n version: 1,\n payload,\n status: 'pending',\n priority: options.priority ?? 0,\n attempts: 0,\n maxRetries: options.maxRetries ?? DEFAULT_RETRY_POLICY.maxRetries,\n createdAt: now,\n updatedAt: now,\n };\n }\n\n register<TPayload, TResult = void>(\n jobType: string,\n handler: JobHandler<TPayload, TResult>\n ): void {\n if (this.handlers.has(jobType)) {\n throw new Error(`Handler already registered for job type \"${jobType}\"`);\n }\n this.handlers.set(jobType, handler as JobHandler);\n }\n\n start(): void {\n if (this.running) return;\n this.running = true;\n this.pollLoop().catch((err) => {\n console.error('[queue] Fatal error in poll loop', err);\n // Let systemd restart the process if needed.\n process.exit(1);\n });\n }\n\n async stop(): Promise<void> {\n this.running = false;\n // Worst-case we wait for the current ReceiveMessage to finish (<= waitTimeSeconds)\n }\n\n private async pollLoop(): Promise<void> {\n console.log('[queue] SQS worker started for queue:', this.queueUrl);\n\n while (this.running) {\n try {\n const res = await this.sqs.send(\n new ReceiveMessageCommand({\n QueueUrl: this.queueUrl,\n MaxNumberOfMessages: this.maxNumberOfMessages,\n WaitTimeSeconds: this.waitTimeSeconds,\n VisibilityTimeout: this.visibilityTimeoutSeconds,\n MessageSystemAttributeNames: ['ApproximateReceiveCount'],\n })\n );\n\n const messages = res.Messages ?? [];\n\n if (messages.length === 0) {\n continue;\n }\n\n for (const msg of messages) {\n if (!msg.Body || !msg.ReceiptHandle) {\n console.warn(\n '[queue] Message missing Body or ReceiptHandle',\n msg.MessageId\n );\n continue;\n }\n\n let envelope: RawJobEnvelope;\n\n try {\n envelope = JSON.parse(msg.Body) as RawJobEnvelope;\n } catch (err) {\n console.error(\n `[queue] Failed to parse message body (id=${msg.MessageId}), deleting`,\n err\n );\n await this.deleteMessage(msg.ReceiptHandle);\n continue;\n }\n\n const handler = this.handlers.get(envelope.type);\n if (!handler) {\n console.error(\n `[queue] No handler registered for type \"${envelope.type}\", deleting message`\n );\n await this.deleteMessage(msg.ReceiptHandle);\n continue;\n }\n\n const now = new Date();\n const attempts = parseInt(\n (msg.Attributes?.ApproximateReceiveCount as string | undefined) ??\n '1',\n 10\n );\n\n const job: Job = {\n id: envelope.id,\n type: envelope.type,\n version: 1,\n payload: envelope.payload,\n status: 'pending',\n priority: 0,\n attempts,\n maxRetries: DEFAULT_RETRY_POLICY.maxRetries,\n createdAt: now,\n updatedAt: now,\n };\n\n job.status = 'running';\n job.updatedAt = new Date();\n\n try {\n await handler(job);\n job.status = 'completed';\n job.updatedAt = new Date();\n await this.deleteMessage(msg.ReceiptHandle);\n } catch (err) {\n job.status = 'failed';\n job.lastError =\n err instanceof Error ? err.message : 'Unknown job error';\n job.updatedAt = new Date();\n\n console.error(\n `[queue] Error while handling job type=${job.type} id=${job.id}`,\n err\n );\n // Do NOT delete message on failure:\n // - SQS/Scaleway will redeliver until MaxReceiveCount, then DLQ takes over.\n }\n }\n } catch (err) {\n if (!!err && typeof err === 'object' && '$response' in err) {\n console.error('[queue] Error while polling SQS', err, err.$response);\n } else {\n console.error('[queue] Error while polling SQS', err);\n }\n await this.sleep(5000);\n }\n }\n\n console.log('[queue] SQS worker stopped');\n }\n\n private async deleteMessage(receiptHandle: string): Promise<void> {\n try {\n await this.sqs.send(\n new DeleteMessageCommand({\n QueueUrl: this.queueUrl,\n ReceiptHandle: receiptHandle,\n })\n );\n } catch (err) {\n console.error('[queue] Failed to delete message', err);\n }\n }\n\n private async sleep(ms: number): Promise<void> {\n await new Promise((resolve) => setTimeout(resolve, ms));\n }\n}\n"],"mappings":"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"}
|
package/dist/jsonschema.d.ts
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Stability, Tag } from "./ownership.js";
|
|
2
2
|
import { ContractSpec, OpKind } from "./spec.js";
|
|
3
3
|
import z from "zod";
|
|
4
|
-
import * as
|
|
4
|
+
import * as _lssm_lib_schema0 from "@lssm/lib.schema";
|
|
5
5
|
import { AnySchemaModel } from "@lssm/lib.schema";
|
|
6
6
|
|
|
7
7
|
//#region src/jsonschema.d.ts
|
|
8
8
|
declare function jsonSchemaForSpec(spec: ContractSpec<AnySchemaModel, AnySchemaModel>): {
|
|
9
|
-
input: z.core.ZodStandardJSONSchemaPayload<
|
|
10
|
-
output: z.core.ZodStandardJSONSchemaPayload<
|
|
9
|
+
input: z.core.ZodStandardJSONSchemaPayload<_lssm_lib_schema0.TopLevelZodFromModel<_lssm_lib_schema0.SchemaModelFieldsAnyConfig<AnySchemaModel | _lssm_lib_schema0.AnyFieldType | _lssm_lib_schema0.AnyEnumType>>> | null;
|
|
10
|
+
output: z.core.ZodStandardJSONSchemaPayload<_lssm_lib_schema0.TopLevelZodFromModel<_lssm_lib_schema0.SchemaModelFieldsAnyConfig<AnySchemaModel | _lssm_lib_schema0.AnyFieldType | _lssm_lib_schema0.AnyEnumType>>> | null;
|
|
11
11
|
meta: {
|
|
12
12
|
name: string;
|
|
13
13
|
version: number;
|
|
@@ -24,4 +24,5 @@ declare function defaultMcpTool(name: string, version: number): string;
|
|
|
24
24
|
/** Helper to derive default GraphQL field name */
|
|
25
25
|
declare function defaultGqlField(name: string, version: number): string;
|
|
26
26
|
//#endregion
|
|
27
|
-
export { defaultGqlField, defaultMcpTool, defaultRestPath, jsonSchemaForSpec };
|
|
27
|
+
export { defaultGqlField, defaultMcpTool, defaultRestPath, jsonSchemaForSpec };
|
|
28
|
+
//# sourceMappingURL=jsonschema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonschema.d.ts","names":[],"sources":["../src/jsonschema.ts"],"sourcesContent":[],"mappings":";;;;;;;iBAOgB,iBAAA,OACR,aAAa,gBAAgB;EADrB,KAAA,qCAAiB,uCAAA,6CAAA,eAAA,iEAAA,CAAA,CAAA,CAAA,GAAA,IAAA;EACZ,MAAA,qCAAA,uCAAA,6CAAA,eAAA,iEAAA,CAAA,CAAA,CAAA,GAAA,IAAA;EAAgB,IAAA,EAAA;IAA7B,IAAA,EAAA,MAAA;;;;;;;;;iBAiBQ,eAAA;;iBAKA,cAAA;;iBAKA,eAAA"}
|
package/dist/jsonschema.js
CHANGED
|
@@ -29,4 +29,5 @@ function defaultGqlField(name, version) {
|
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
//#endregion
|
|
32
|
-
export { defaultGqlField, defaultMcpTool, defaultRestPath, jsonSchemaForSpec };
|
|
32
|
+
export { defaultGqlField, defaultMcpTool, defaultRestPath, jsonSchemaForSpec };
|
|
33
|
+
//# sourceMappingURL=jsonschema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonschema.js","names":[],"sources":["../src/jsonschema.ts"],"sourcesContent":["/**\n * Convert zod I/O to JSON Schema so adapters can generate OpenAPI/MCP.\n */\nimport type { ContractSpec } from './spec';\nimport type { AnySchemaModel } from '@lssm/lib.schema';\nimport z from 'zod';\n\nexport function jsonSchemaForSpec(\n spec: ContractSpec<AnySchemaModel, AnySchemaModel>\n) {\n return {\n input: spec.io.input ? z.toJSONSchema(spec.io.input.getZod()) : null,\n output: spec.io.output ? z.toJSONSchema(spec.io.output.getZod()) : null,\n meta: {\n name: spec.meta.name,\n version: spec.meta.version,\n kind: spec.meta.kind,\n description: spec.meta.description,\n tags: spec.meta.tags ?? [],\n stability: spec.meta.stability ?? 'stable',\n },\n };\n}\n\n/** Helper to derive default REST path */\nexport function defaultRestPath(name: string, version: number) {\n return `/${name.replace(/\\./g, '/')}/v${version}`;\n}\n\n/** Helper to derive default MCP tool name */\nexport function defaultMcpTool(name: string, version: number) {\n return `${name}.v${version}`;\n}\n\n/** Helper to derive default GraphQL field name */\nexport function defaultGqlField(name: string, version: number) {\n return `${name.replace(/\\./g, '_')}_v${version}`;\n}\n"],"mappings":";;;AAOA,SAAgB,kBACd,MACA;AACA,QAAO;EACL,OAAO,KAAK,GAAG,QAAQ,EAAE,aAAa,KAAK,GAAG,MAAM,QAAQ,CAAC,GAAG;EAChE,QAAQ,KAAK,GAAG,SAAS,EAAE,aAAa,KAAK,GAAG,OAAO,QAAQ,CAAC,GAAG;EACnE,MAAM;GACJ,MAAM,KAAK,KAAK;GAChB,SAAS,KAAK,KAAK;GACnB,MAAM,KAAK,KAAK;GAChB,aAAa,KAAK,KAAK;GACvB,MAAM,KAAK,KAAK,QAAQ,EAAE;GAC1B,WAAW,KAAK,KAAK,aAAa;GACnC;EACF;;;AAIH,SAAgB,gBAAgB,MAAc,SAAiB;AAC7D,QAAO,IAAI,KAAK,QAAQ,OAAO,IAAI,CAAC,IAAI;;;AAI1C,SAAgB,eAAe,MAAc,SAAiB;AAC5D,QAAO,GAAG,KAAK,IAAI;;;AAIrB,SAAgB,gBAAgB,MAAc,SAAiB;AAC7D,QAAO,GAAG,KAAK,QAAQ,OAAO,IAAI,CAAC,IAAI"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binding.d.ts","names":[],"sources":["../../src/knowledge/binding.ts"],"sourcesContent":[],"mappings":";UAAiB,mBAAA;EAAA"}
|