@lssm/lib.contracts 1.11.0 → 1.41.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/_virtual/rolldown_runtime.js +1 -0
- package/dist/app-config/app-config.feature.js +1 -0
- package/dist/app-config/contracts.js +1 -2
- package/dist/app-config/docs/app-config.docblock.js +220 -0
- package/dist/app-config/events.js +1 -2
- package/dist/app-config/index.js +1 -1
- package/dist/app-config/lifecycle-contracts.js +1 -2
- package/dist/app-config/runtime.js +1 -2
- package/dist/app-config/spec.js +1 -2
- package/dist/app-config/validation.js +1 -2
- package/dist/capabilities/docs/capabilities.docblock.js +1 -0
- package/dist/capabilities/openbanking.js +1 -2
- package/dist/capabilities.js +1 -2
- package/dist/client/react/drivers/rn-reusables.js +1 -2
- package/dist/client/react/drivers/shadcn.js +1 -2
- package/dist/client/react/feature-render.js +1 -2
- package/dist/client/react/form-render.js +1 -2
- package/dist/contract-registry/index.js +1 -0
- package/dist/contract-registry/schemas.js +1 -0
- package/dist/contract-registry/types.js +0 -0
- package/dist/contracts-adapter-hydration.js +1 -2
- package/dist/contracts-adapter-input.js +1 -2
- package/dist/data-views/docs/data-views.docblock.js +1 -0
- package/dist/data-views/query-generator.js +1 -2
- package/dist/data-views/runtime.js +1 -2
- package/dist/data-views.js +1 -2
- package/dist/docs/PUBLISHING.docblock.js +76 -0
- package/dist/docs/accessibility_wcag_compliance_specs.docblock.js +350 -0
- package/dist/docs/index.js +1 -0
- package/dist/docs/meta.docs.js +13 -0
- package/dist/docs/presentations.js +1 -0
- package/dist/docs/registry.js +1 -0
- package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +383 -0
- package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +68 -0
- package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +140 -0
- package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +86 -0
- package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +1 -0
- package/dist/docs/tech/auth/better-auth-nextjs.docblock.js +58 -0
- package/dist/docs/tech/contracts/README.docblock.js +1 -0
- package/dist/docs/tech/contracts/create-subscription.docblock.js +1 -0
- package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.js +180 -0
- package/dist/docs/tech/contracts/migrations.docblock.js +1 -0
- package/dist/docs/tech/contracts/openapi-export.docblock.js +38 -0
- package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.js +62 -0
- package/dist/docs/tech/contracts/overlays.docblock.js +68 -0
- package/dist/docs/tech/contracts/tests.docblock.js +132 -0
- package/dist/docs/tech/contracts/themes.docblock.js +1 -0
- package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.js +106 -0
- package/dist/docs/tech/lifecycle-stage-system.docblock.js +213 -0
- package/dist/docs/tech/llm/llm-integration.docblock.js +289 -0
- package/dist/docs/tech/mcp-endpoints.docblock.js +1 -0
- package/dist/docs/tech/presentation-runtime.docblock.js +1 -0
- package/dist/docs/tech/schema/README.docblock.js +262 -0
- package/dist/docs/tech/studio/learning-events.docblock.js +1 -0
- package/dist/docs/tech/studio/learning-journeys.docblock.js +57 -0
- package/dist/docs/tech/studio/platform-admin-panel.docblock.js +63 -0
- package/dist/docs/tech/studio/project-access-teams.docblock.js +36 -0
- package/dist/docs/tech/studio/project-routing.docblock.js +1 -0
- package/dist/docs/tech/studio/sandbox-unlogged.docblock.js +20 -0
- package/dist/docs/tech/studio/team-invitations.docblock.js +65 -0
- package/dist/docs/tech/studio/workspace-ops.docblock.js +1 -0
- package/dist/docs/tech/studio/workspaces.docblock.js +41 -0
- package/dist/docs/tech/telemetry-ingest.docblock.js +122 -0
- package/dist/docs/tech/templates/runtime.docblock.js +1 -0
- package/dist/docs/tech/vscode-extension.docblock.js +68 -0
- package/dist/docs/tech/workflows/overview.docblock.js +1 -0
- package/dist/docs/tech-contracts.docs.js +76 -0
- package/dist/docs/types.js +0 -0
- package/dist/events.js +1 -2
- package/dist/experiments/docs/experiments.docblock.js +128 -0
- package/dist/experiments/evaluator.js +1 -2
- package/dist/experiments/spec.js +1 -2
- package/dist/features.js +1 -2
- package/dist/forms/docs/forms.docblock.js +1 -0
- package/dist/forms.js +1 -2
- package/dist/index.js +1 -1
- package/dist/install.js +1 -2
- package/dist/integrations/contracts.js +1 -2
- package/dist/integrations/docs/integrations.docblock.js +1 -0
- package/dist/integrations/health.js +1 -2
- package/dist/integrations/index.js +1 -1
- package/dist/integrations/openbanking/contracts/accounts.js +1 -2
- package/dist/integrations/openbanking/contracts/balances.js +1 -2
- package/dist/integrations/openbanking/contracts/index.js +1 -2
- package/dist/integrations/openbanking/contracts/transactions.js +1 -2
- package/dist/integrations/openbanking/guards.js +1 -2
- package/dist/integrations/openbanking/models.js +1 -2
- package/dist/integrations/openbanking/openbanking.feature.js +1 -0
- package/dist/integrations/openbanking/telemetry.js +1 -2
- package/dist/integrations/providers/elevenlabs.js +1 -2
- package/dist/integrations/providers/gcs-storage.js +1 -2
- package/dist/integrations/providers/gmail.js +1 -2
- package/dist/integrations/providers/google-calendar.js +1 -2
- package/dist/integrations/providers/impls/elevenlabs-voice.js +1 -2
- package/dist/integrations/providers/impls/gcs-storage.js +1 -2
- package/dist/integrations/providers/impls/gmail-inbound.js +1 -2
- package/dist/integrations/providers/impls/gmail-outbound.js +1 -2
- package/dist/integrations/providers/impls/google-calendar.js +1 -2
- package/dist/integrations/providers/impls/index.js +1 -1
- package/dist/integrations/providers/impls/mistral-embedding.js +1 -2
- package/dist/integrations/providers/impls/mistral-llm.js +1 -2
- package/dist/integrations/providers/impls/postmark-email.js +1 -2
- package/dist/integrations/providers/impls/powens-client.js +1 -2
- package/dist/integrations/providers/impls/powens-openbanking.js +1 -2
- package/dist/integrations/providers/impls/provider-factory.js +1 -2
- package/dist/integrations/providers/impls/qdrant-vector.js +1 -2
- package/dist/integrations/providers/impls/stripe-payments.js +1 -2
- package/dist/integrations/providers/impls/twilio-sms.js +1 -2
- package/dist/integrations/providers/index.js +1 -1
- package/dist/integrations/providers/mistral.js +1 -2
- package/dist/integrations/providers/postmark.js +1 -2
- package/dist/integrations/providers/powens.js +1 -2
- package/dist/integrations/providers/qdrant.js +1 -2
- package/dist/integrations/providers/registry.js +1 -0
- package/dist/integrations/providers/stripe.js +1 -2
- package/dist/integrations/providers/twilio-sms.js +1 -2
- package/dist/integrations/runtime.js +1 -2
- package/dist/integrations/secrets/aws-secret-manager.js +1 -0
- package/dist/integrations/secrets/env-secret-provider.js +1 -2
- package/dist/integrations/secrets/gcp-secret-manager.js +1 -2
- package/dist/integrations/secrets/index.js +1 -1
- package/dist/integrations/secrets/manager.js +1 -2
- package/dist/integrations/secrets/provider.js +1 -2
- package/dist/integrations/secrets/scaleway-secret-manager.js +1 -0
- package/dist/integrations/spec.js +1 -2
- package/dist/jobs/define-job.js +1 -0
- package/dist/jobs/gcp-cloud-tasks.js +1 -2
- package/dist/jobs/gcp-pubsub.js +1 -2
- package/dist/jobs/handlers/gmail-sync-handler.js +1 -2
- package/dist/jobs/handlers/index.js +1 -1
- package/dist/jobs/handlers/ping-handler.js +1 -0
- package/dist/jobs/handlers/storage-document-handler.js +1 -2
- package/dist/jobs/index.js +1 -1
- package/dist/jobs/memory-queue.js +1 -2
- package/dist/jobs/queue.js +1 -0
- package/dist/jobs/scaleway-sqs-queue.js +1 -0
- package/dist/jsonschema.js +1 -2
- package/dist/knowledge/contracts.js +1 -2
- package/dist/knowledge/docs/knowledge.docblock.js +138 -0
- package/dist/knowledge/ingestion/document-processor.js +1 -2
- package/dist/knowledge/ingestion/embedding-service.js +1 -2
- package/dist/knowledge/ingestion/gmail-adapter.js +1 -2
- package/dist/knowledge/ingestion/storage-adapter.js +1 -2
- package/dist/knowledge/ingestion/vector-indexer.js +1 -2
- package/dist/knowledge/query/service.js +1 -2
- package/dist/knowledge/runtime.js +1 -2
- package/dist/knowledge/spaces/email-threads.js +1 -2
- package/dist/knowledge/spaces/financial-docs.js +1 -2
- package/dist/knowledge/spaces/financial-overview.js +1 -2
- package/dist/knowledge/spaces/product-canon.js +1 -2
- package/dist/knowledge/spaces/support-faq.js +1 -2
- package/dist/knowledge/spaces/uploaded-docs.js +1 -2
- package/dist/knowledge/spec.js +1 -2
- package/dist/llm/exporters.js +8 -0
- package/dist/llm/index.js +1 -0
- package/dist/llm/prompts.js +220 -0
- package/dist/llm/types.js +0 -0
- package/dist/markdown.js +1 -2
- package/dist/migrations.js +1 -2
- package/dist/node_modules/@pothos/plugin-complexity/esm/calculate-complexity.js +1 -0
- package/dist/node_modules/@pothos/plugin-complexity/esm/defaults.js +1 -0
- package/dist/node_modules/@pothos/plugin-complexity/esm/index.js +1 -0
- package/dist/node_modules/@pothos/plugin-complexity/esm/types.js +1 -0
- package/dist/node_modules/@pothos/plugin-complexity/esm/util.js +1 -0
- package/dist/node_modules/@pothos/plugin-complexity/esm/validator.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/field-builder.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/index.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/refs/index.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/refs/interface.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/refs/node.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/refs/object.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/refs/union.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/schema-builder.js +1 -0
- package/dist/node_modules/@pothos/plugin-dataloader/esm/util.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/connection-helpers.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/field-builder.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/index.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/interface-ref.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/model-loader.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/node-ref.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/object-ref.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/prisma-field-builder.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/schema-builder.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/types.js +0 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/cursors.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/datamodel.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/deep-equal.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/description.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/get-client.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/loader-map.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/map-query.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/relation-map.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/selections.js +1 -0
- package/dist/node_modules/@pothos/plugin-prisma/esm/util/usage.js +1 -0
- package/dist/node_modules/@pothos/plugin-tracing/esm/index.js +1 -0
- package/dist/node_modules/@pothos/plugin-tracing/esm/util.js +1 -0
- package/dist/node_modules/dataloader/index.js +7 -0
- package/dist/node_modules/graphql/error/GraphQLError.js +5 -0
- package/dist/node_modules/graphql/error/index.js +1 -0
- package/dist/node_modules/graphql/error/locatedError.js +1 -0
- package/dist/node_modules/graphql/error/syntaxError.js +1 -0
- package/dist/node_modules/graphql/execution/collectFields.js +1 -0
- package/dist/node_modules/graphql/execution/execute.js +1 -0
- package/dist/node_modules/graphql/execution/index.js +1 -0
- package/dist/node_modules/graphql/execution/mapAsyncIterator.js +1 -0
- package/dist/node_modules/graphql/execution/subscribe.js +1 -0
- package/dist/node_modules/graphql/execution/values.js +1 -0
- package/dist/node_modules/graphql/graphql.js +1 -0
- package/dist/node_modules/graphql/index.js +1 -0
- package/dist/node_modules/graphql/jsutils/Path.js +1 -0
- package/dist/node_modules/graphql/jsutils/devAssert.js +1 -0
- package/dist/node_modules/graphql/jsutils/didYouMean.js +1 -0
- package/dist/node_modules/graphql/jsutils/groupBy.js +1 -0
- package/dist/node_modules/graphql/jsutils/identityFunc.js +1 -0
- package/dist/node_modules/graphql/jsutils/inspect.js +1 -0
- package/dist/node_modules/graphql/jsutils/instanceOf.js +12 -0
- package/dist/node_modules/graphql/jsutils/invariant.js +1 -0
- package/dist/node_modules/graphql/jsutils/isAsyncIterable.js +1 -0
- package/dist/node_modules/graphql/jsutils/isIterableObject.js +1 -0
- package/dist/node_modules/graphql/jsutils/isObjectLike.js +1 -0
- package/dist/node_modules/graphql/jsutils/isPromise.js +1 -0
- package/dist/node_modules/graphql/jsutils/keyMap.js +1 -0
- package/dist/node_modules/graphql/jsutils/keyValMap.js +1 -0
- package/dist/node_modules/graphql/jsutils/mapValue.js +1 -0
- package/dist/node_modules/graphql/jsutils/memoize3.js +1 -0
- package/dist/node_modules/graphql/jsutils/naturalCompare.js +1 -0
- package/dist/node_modules/graphql/jsutils/printPathArray.js +1 -0
- package/dist/node_modules/graphql/jsutils/promiseForObject.js +1 -0
- package/dist/node_modules/graphql/jsutils/promiseReduce.js +1 -0
- package/dist/node_modules/graphql/jsutils/suggestionList.js +1 -0
- package/dist/node_modules/graphql/jsutils/toError.js +1 -0
- package/dist/node_modules/graphql/jsutils/toObjMap.js +1 -0
- package/dist/node_modules/graphql/language/ast.js +1 -0
- package/dist/node_modules/graphql/language/blockString.js +3 -0
- package/dist/node_modules/graphql/language/characterClasses.js +1 -0
- package/dist/node_modules/graphql/language/directiveLocation.js +1 -0
- package/dist/node_modules/graphql/language/index.js +1 -0
- package/dist/node_modules/graphql/language/kinds.js +1 -0
- package/dist/node_modules/graphql/language/lexer.js +3 -0
- package/dist/node_modules/graphql/language/location.js +1 -0
- package/dist/node_modules/graphql/language/parser.js +1 -0
- package/dist/node_modules/graphql/language/predicates.js +1 -0
- package/dist/node_modules/graphql/language/printLocation.js +2 -0
- package/dist/node_modules/graphql/language/printString.js +1 -0
- package/dist/node_modules/graphql/language/printer.js +34 -0
- package/dist/node_modules/graphql/language/schemaCoordinateLexer.js +1 -0
- package/dist/node_modules/graphql/language/source.js +1 -0
- package/dist/node_modules/graphql/language/tokenKind.js +1 -0
- package/dist/node_modules/graphql/language/visitor.js +1 -0
- package/dist/node_modules/graphql/type/assertName.js +1 -0
- package/dist/node_modules/graphql/type/definition.js +1 -0
- package/dist/node_modules/graphql/type/directives.js +1 -0
- package/dist/node_modules/graphql/type/index.js +1 -0
- package/dist/node_modules/graphql/type/introspection.js +3 -0
- package/dist/node_modules/graphql/type/scalars.js +1 -0
- package/dist/node_modules/graphql/type/schema.js +1 -0
- package/dist/node_modules/graphql/type/validate.js +3 -0
- package/dist/node_modules/graphql/utilities/TypeInfo.js +1 -0
- package/dist/node_modules/graphql/utilities/assertValidName.js +1 -0
- package/dist/node_modules/graphql/utilities/astFromValue.js +1 -0
- package/dist/node_modules/graphql/utilities/buildASTSchema.js +1 -0
- package/dist/node_modules/graphql/utilities/buildClientSchema.js +1 -0
- package/dist/node_modules/graphql/utilities/coerceInputValue.js +1 -0
- package/dist/node_modules/graphql/utilities/concatAST.js +1 -0
- package/dist/node_modules/graphql/utilities/extendSchema.js +1 -0
- package/dist/node_modules/graphql/utilities/findBreakingChanges.js +1 -0
- package/dist/node_modules/graphql/utilities/getIntrospectionQuery.js +107 -0
- package/dist/node_modules/graphql/utilities/getOperationAST.js +1 -0
- package/dist/node_modules/graphql/utilities/getOperationRootType.js +1 -0
- package/dist/node_modules/graphql/utilities/index.js +1 -0
- package/dist/node_modules/graphql/utilities/introspectionFromSchema.js +1 -0
- package/dist/node_modules/graphql/utilities/lexicographicSortSchema.js +1 -0
- package/dist/node_modules/graphql/utilities/printSchema.js +13 -0
- package/dist/node_modules/graphql/utilities/resolveSchemaCoordinate.js +1 -0
- package/dist/node_modules/graphql/utilities/separateOperations.js +1 -0
- package/dist/node_modules/graphql/utilities/sortValueNode.js +1 -0
- package/dist/node_modules/graphql/utilities/stripIgnoredCharacters.js +1 -0
- package/dist/node_modules/graphql/utilities/typeComparators.js +1 -0
- package/dist/node_modules/graphql/utilities/typeFromAST.js +1 -0
- package/dist/node_modules/graphql/utilities/valueFromAST.js +1 -0
- package/dist/node_modules/graphql/utilities/valueFromASTUntyped.js +1 -0
- package/dist/node_modules/graphql/validation/ValidationContext.js +1 -0
- package/dist/node_modules/graphql/validation/index.js +1 -0
- package/dist/node_modules/graphql/validation/rules/ExecutableDefinitionsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/KnownArgumentNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/KnownDirectivesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/KnownFragmentNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/KnownTypeNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/LoneAnonymousOperationRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/MaxIntrospectionDepthRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/NoFragmentCyclesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/NoUndefinedVariablesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/NoUnusedFragmentsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/NoUnusedVariablesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/ScalarLeafsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueArgumentNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueFragmentNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueOperationNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueOperationTypesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueTypeNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/UniqueVariableNamesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/VariablesAreInputTypesRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.js +1 -0
- package/dist/node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.js +1 -0
- package/dist/node_modules/graphql/validation/specifiedRules.js +1 -0
- package/dist/node_modules/graphql/validation/validate.js +5 -0
- package/dist/node_modules/graphql/version.js +1 -0
- package/dist/onboarding-base.js +1 -2
- package/dist/openapi.js +1 -0
- package/dist/openbanking/docs/openbanking.docblock.js +109 -0
- package/dist/ownership.js +1 -2
- package/dist/policy/docs/policy.docblock.js +1 -0
- package/dist/policy/engine.js +1 -2
- package/dist/policy/opa-adapter.js +1 -2
- package/dist/policy/spec.js +1 -2
- package/dist/presentations/docs/presentations-conventions.docblock.js +8 -0
- package/dist/presentations.backcompat.js +1 -2
- package/dist/presentations.js +1 -2
- package/dist/presentations.v2.js +7 -2
- package/dist/prompt.js +1 -2
- package/dist/promptRegistry.js +1 -2
- package/dist/regenerator/docs/regenerator.docblock.js +184 -0
- package/dist/regenerator/executor.js +1 -2
- package/dist/regenerator/service.js +1 -2
- package/dist/regenerator/sinks.js +1 -2
- package/dist/regenerator/utils.js +1 -2
- package/dist/registry.js +1 -2
- package/dist/resources.js +1 -2
- package/dist/schema-to-markdown.js +10 -0
- package/dist/server/graphql-pothos.js +1 -2
- package/dist/server/index.js +1 -1
- package/dist/server/mcp/createMcpServer.js +1 -0
- package/dist/server/mcp/mcpTypes.js +0 -0
- package/dist/server/mcp/registerPresentations.js +1 -0
- package/dist/server/mcp/registerPrompts.js +3 -0
- package/dist/server/mcp/registerResources.js +1 -0
- package/dist/server/mcp/registerTools.js +1 -0
- package/dist/server/provider-mcp.js +1 -2
- package/dist/server/rest-elysia.js +1 -2
- package/dist/server/rest-express.js +1 -2
- package/dist/server/rest-generic.js +1 -2
- package/dist/server/rest-next-app.js +1 -2
- package/dist/server/rest-next-mcp.js +1 -2
- package/dist/server/rest-next-pages.js +1 -2
- package/dist/spec.js +1 -2
- package/dist/telemetry/anomaly.js +1 -2
- package/dist/telemetry/docs/telemetry.docblock.js +139 -0
- package/dist/telemetry/spec.js +1 -2
- package/dist/telemetry/tracker.js +1 -2
- package/dist/tests/runner.js +1 -2
- package/dist/tests/spec.js +1 -2
- package/dist/themes.js +1 -2
- package/dist/workflow/adapters/db-adapter.js +1 -2
- package/dist/workflow/adapters/file-adapter.js +1 -2
- package/dist/workflow/adapters/memory-store.js +1 -2
- package/dist/workflow/expression.js +1 -2
- package/dist/workflow/runner.js +1 -2
- package/dist/workflow/sla-monitor.js +1 -2
- package/dist/workflow/spec.js +1 -2
- package/dist/workflow/validation.js +1 -2
- package/package.json +353 -193
- package/dist/app-config/branding.d.ts +0 -56
- package/dist/app-config/branding.d.ts.map +0 -1
- package/dist/app-config/contracts.d.ts +0 -245
- package/dist/app-config/contracts.d.ts.map +0 -1
- package/dist/app-config/contracts.js.map +0 -1
- package/dist/app-config/events.d.ts +0 -123
- package/dist/app-config/events.d.ts.map +0 -1
- package/dist/app-config/events.js.map +0 -1
- package/dist/app-config/index.d.ts +0 -8
- package/dist/app-config/lifecycle-contracts.d.ts +0 -383
- package/dist/app-config/lifecycle-contracts.d.ts.map +0 -1
- package/dist/app-config/lifecycle-contracts.js.map +0 -1
- package/dist/app-config/lifecycle.d.ts +0 -28
- package/dist/app-config/lifecycle.d.ts.map +0 -1
- package/dist/app-config/runtime.d.ts +0 -115
- package/dist/app-config/runtime.d.ts.map +0 -1
- package/dist/app-config/runtime.js.map +0 -1
- package/dist/app-config/spec.d.ts +0 -176
- package/dist/app-config/spec.d.ts.map +0 -1
- package/dist/app-config/spec.js.map +0 -1
- package/dist/app-config/validation.d.ts +0 -48
- package/dist/app-config/validation.d.ts.map +0 -1
- package/dist/app-config/validation.js.map +0 -1
- package/dist/capabilities/openbanking.d.ts +0 -10
- package/dist/capabilities/openbanking.d.ts.map +0 -1
- package/dist/capabilities/openbanking.js.map +0 -1
- package/dist/capabilities.d.ts +0 -46
- package/dist/capabilities.d.ts.map +0 -1
- package/dist/capabilities.js.map +0 -1
- package/dist/client/index.d.ts +0 -6
- package/dist/client/react/drivers/rn-reusables.d.ts +0 -23
- package/dist/client/react/drivers/rn-reusables.d.ts.map +0 -1
- package/dist/client/react/drivers/rn-reusables.js.map +0 -1
- package/dist/client/react/drivers/shadcn.d.ts +0 -13
- package/dist/client/react/drivers/shadcn.d.ts.map +0 -1
- package/dist/client/react/drivers/shadcn.js.map +0 -1
- package/dist/client/react/feature-render.d.ts +0 -21
- package/dist/client/react/feature-render.d.ts.map +0 -1
- package/dist/client/react/feature-render.js.map +0 -1
- package/dist/client/react/form-render.d.ts +0 -92
- package/dist/client/react/form-render.d.ts.map +0 -1
- package/dist/client/react/form-render.js.map +0 -1
- package/dist/client/react/index.d.ts +0 -5
- package/dist/contracts-adapter-hydration.d.ts +0 -16
- package/dist/contracts-adapter-hydration.d.ts.map +0 -1
- package/dist/contracts-adapter-hydration.js.map +0 -1
- package/dist/contracts-adapter-input.d.ts +0 -11
- package/dist/contracts-adapter-input.d.ts.map +0 -1
- package/dist/contracts-adapter-input.js.map +0 -1
- package/dist/data-views/query-generator.d.ts +0 -40
- package/dist/data-views/query-generator.d.ts.map +0 -1
- package/dist/data-views/query-generator.js.map +0 -1
- package/dist/data-views/runtime.d.ts +0 -27
- package/dist/data-views/runtime.d.ts.map +0 -1
- package/dist/data-views/runtime.js.map +0 -1
- package/dist/data-views.d.ts +0 -132
- package/dist/data-views.d.ts.map +0 -1
- package/dist/data-views.js.map +0 -1
- package/dist/events.d.ts +0 -45
- package/dist/events.d.ts.map +0 -1
- package/dist/events.js.map +0 -1
- package/dist/experiments/evaluator.d.ts +0 -38
- package/dist/experiments/evaluator.d.ts.map +0 -1
- package/dist/experiments/evaluator.js.map +0 -1
- package/dist/experiments/spec-resolver.d.ts +0 -17
- package/dist/experiments/spec-resolver.d.ts.map +0 -1
- package/dist/experiments/spec.d.ts +0 -90
- package/dist/experiments/spec.d.ts.map +0 -1
- package/dist/experiments/spec.js.map +0 -1
- package/dist/features.d.ts +0 -88
- package/dist/features.d.ts.map +0 -1
- package/dist/features.js.map +0 -1
- package/dist/forms.d.ts +0 -259
- package/dist/forms.d.ts.map +0 -1
- package/dist/forms.js.map +0 -1
- package/dist/graphql-federation/dist/index.js +0 -2
- package/dist/graphql-federation/dist/index.js.map +0 -1
- package/dist/index.d.ts +0 -130
- package/dist/install.d.ts +0 -77
- package/dist/install.d.ts.map +0 -1
- package/dist/install.js.map +0 -1
- package/dist/integrations/binding.d.ts +0 -18
- package/dist/integrations/binding.d.ts.map +0 -1
- package/dist/integrations/connection.d.ts +0 -52
- package/dist/integrations/connection.d.ts.map +0 -1
- package/dist/integrations/contracts.d.ts +0 -436
- package/dist/integrations/contracts.d.ts.map +0 -1
- package/dist/integrations/contracts.js.map +0 -1
- package/dist/integrations/health.d.ts +0 -22
- package/dist/integrations/health.d.ts.map +0 -1
- package/dist/integrations/health.js.map +0 -1
- package/dist/integrations/index.d.ts +0 -53
- package/dist/integrations/openbanking/contracts/accounts.d.ts +0 -288
- package/dist/integrations/openbanking/contracts/accounts.d.ts.map +0 -1
- package/dist/integrations/openbanking/contracts/accounts.js.map +0 -1
- package/dist/integrations/openbanking/contracts/balances.d.ts +0 -164
- package/dist/integrations/openbanking/contracts/balances.d.ts.map +0 -1
- package/dist/integrations/openbanking/contracts/balances.js.map +0 -1
- package/dist/integrations/openbanking/contracts/index.d.ts +0 -10
- package/dist/integrations/openbanking/contracts/index.d.ts.map +0 -1
- package/dist/integrations/openbanking/contracts/index.js.map +0 -1
- package/dist/integrations/openbanking/contracts/transactions.d.ts +0 -212
- package/dist/integrations/openbanking/contracts/transactions.d.ts.map +0 -1
- package/dist/integrations/openbanking/contracts/transactions.js.map +0 -1
- package/dist/integrations/openbanking/guards.d.ts +0 -13
- package/dist/integrations/openbanking/guards.d.ts.map +0 -1
- package/dist/integrations/openbanking/guards.js.map +0 -1
- package/dist/integrations/openbanking/models.d.ts +0 -229
- package/dist/integrations/openbanking/models.d.ts.map +0 -1
- package/dist/integrations/openbanking/models.js.map +0 -1
- package/dist/integrations/openbanking/telemetry.d.ts +0 -16
- package/dist/integrations/openbanking/telemetry.d.ts.map +0 -1
- package/dist/integrations/openbanking/telemetry.js.map +0 -1
- package/dist/integrations/providers/calendar.d.ts +0 -79
- package/dist/integrations/providers/calendar.d.ts.map +0 -1
- package/dist/integrations/providers/elevenlabs.d.ts +0 -8
- package/dist/integrations/providers/elevenlabs.d.ts.map +0 -1
- package/dist/integrations/providers/elevenlabs.js.map +0 -1
- package/dist/integrations/providers/email.d.ts +0 -87
- package/dist/integrations/providers/email.d.ts.map +0 -1
- package/dist/integrations/providers/embedding.d.ts +0 -25
- package/dist/integrations/providers/embedding.d.ts.map +0 -1
- package/dist/integrations/providers/gcs-storage.d.ts +0 -8
- package/dist/integrations/providers/gcs-storage.d.ts.map +0 -1
- package/dist/integrations/providers/gcs-storage.js.map +0 -1
- package/dist/integrations/providers/gmail.d.ts +0 -8
- package/dist/integrations/providers/gmail.d.ts.map +0 -1
- package/dist/integrations/providers/gmail.js.map +0 -1
- package/dist/integrations/providers/google-calendar.d.ts +0 -8
- package/dist/integrations/providers/google-calendar.d.ts.map +0 -1
- package/dist/integrations/providers/google-calendar.js.map +0 -1
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts +0 -21
- package/dist/integrations/providers/impls/elevenlabs-voice.d.ts.map +0 -1
- package/dist/integrations/providers/impls/elevenlabs-voice.js.map +0 -1
- package/dist/integrations/providers/impls/gcs-storage.d.ts +0 -25
- package/dist/integrations/providers/impls/gcs-storage.d.ts.map +0 -1
- package/dist/integrations/providers/impls/gcs-storage.js.map +0 -1
- package/dist/integrations/providers/impls/gmail-inbound.d.ts +0 -27
- package/dist/integrations/providers/impls/gmail-inbound.d.ts.map +0 -1
- package/dist/integrations/providers/impls/gmail-inbound.js.map +0 -1
- package/dist/integrations/providers/impls/gmail-outbound.d.ts +0 -19
- package/dist/integrations/providers/impls/gmail-outbound.d.ts.map +0 -1
- package/dist/integrations/providers/impls/gmail-outbound.js.map +0 -1
- package/dist/integrations/providers/impls/google-calendar.d.ts +0 -24
- package/dist/integrations/providers/impls/google-calendar.d.ts.map +0 -1
- package/dist/integrations/providers/impls/google-calendar.js.map +0 -1
- package/dist/integrations/providers/impls/index.d.ts +0 -15
- package/dist/integrations/providers/impls/mistral-embedding.d.ts +0 -24
- package/dist/integrations/providers/impls/mistral-embedding.d.ts.map +0 -1
- package/dist/integrations/providers/impls/mistral-embedding.js.map +0 -1
- package/dist/integrations/providers/impls/mistral-llm.d.ts +0 -32
- package/dist/integrations/providers/impls/mistral-llm.d.ts.map +0 -1
- package/dist/integrations/providers/impls/mistral-llm.js.map +0 -1
- package/dist/integrations/providers/impls/postmark-email.d.ts +0 -20
- package/dist/integrations/providers/impls/postmark-email.d.ts.map +0 -1
- package/dist/integrations/providers/impls/postmark-email.js.map +0 -1
- package/dist/integrations/providers/impls/powens-client.d.ts +0 -125
- package/dist/integrations/providers/impls/powens-client.d.ts.map +0 -1
- package/dist/integrations/providers/impls/powens-client.js.map +0 -1
- package/dist/integrations/providers/impls/powens-openbanking.d.ts +0 -28
- package/dist/integrations/providers/impls/powens-openbanking.d.ts.map +0 -1
- package/dist/integrations/providers/impls/powens-openbanking.js.map +0 -1
- package/dist/integrations/providers/impls/provider-factory.d.ts +0 -27
- package/dist/integrations/providers/impls/provider-factory.d.ts.map +0 -1
- package/dist/integrations/providers/impls/provider-factory.js.map +0 -1
- package/dist/integrations/providers/impls/qdrant-vector.d.ts +0 -25
- package/dist/integrations/providers/impls/qdrant-vector.d.ts.map +0 -1
- package/dist/integrations/providers/impls/qdrant-vector.js.map +0 -1
- package/dist/integrations/providers/impls/stripe-payments.d.ts +0 -29
- package/dist/integrations/providers/impls/stripe-payments.d.ts.map +0 -1
- package/dist/integrations/providers/impls/stripe-payments.js.map +0 -1
- package/dist/integrations/providers/impls/twilio-sms.d.ts +0 -21
- package/dist/integrations/providers/impls/twilio-sms.d.ts.map +0 -1
- package/dist/integrations/providers/impls/twilio-sms.js.map +0 -1
- package/dist/integrations/providers/index.d.ts +0 -36
- package/dist/integrations/providers/llm.d.ts +0 -83
- package/dist/integrations/providers/llm.d.ts.map +0 -1
- package/dist/integrations/providers/mistral.d.ts +0 -8
- package/dist/integrations/providers/mistral.d.ts.map +0 -1
- package/dist/integrations/providers/mistral.js.map +0 -1
- package/dist/integrations/providers/openbanking.d.ts +0 -129
- package/dist/integrations/providers/openbanking.d.ts.map +0 -1
- package/dist/integrations/providers/payments.d.ts +0 -110
- package/dist/integrations/providers/payments.d.ts.map +0 -1
- package/dist/integrations/providers/postmark.d.ts +0 -8
- package/dist/integrations/providers/postmark.d.ts.map +0 -1
- package/dist/integrations/providers/postmark.js.map +0 -1
- package/dist/integrations/providers/powens.d.ts +0 -8
- package/dist/integrations/providers/powens.d.ts.map +0 -1
- package/dist/integrations/providers/powens.js.map +0 -1
- package/dist/integrations/providers/qdrant.d.ts +0 -8
- package/dist/integrations/providers/qdrant.d.ts.map +0 -1
- package/dist/integrations/providers/qdrant.js.map +0 -1
- package/dist/integrations/providers/sms.d.ts +0 -35
- package/dist/integrations/providers/sms.d.ts.map +0 -1
- package/dist/integrations/providers/storage.d.ts +0 -61
- package/dist/integrations/providers/storage.d.ts.map +0 -1
- package/dist/integrations/providers/stripe.d.ts +0 -8
- package/dist/integrations/providers/stripe.d.ts.map +0 -1
- package/dist/integrations/providers/stripe.js.map +0 -1
- package/dist/integrations/providers/twilio-sms.d.ts +0 -8
- package/dist/integrations/providers/twilio-sms.d.ts.map +0 -1
- package/dist/integrations/providers/twilio-sms.js.map +0 -1
- package/dist/integrations/providers/vector-store.d.ts +0 -44
- package/dist/integrations/providers/vector-store.d.ts.map +0 -1
- package/dist/integrations/providers/voice.d.ts +0 -35
- package/dist/integrations/providers/voice.d.ts.map +0 -1
- package/dist/integrations/runtime.d.ts +0 -100
- package/dist/integrations/runtime.d.ts.map +0 -1
- package/dist/integrations/runtime.js.map +0 -1
- package/dist/integrations/secrets/env-secret-provider.d.ts +0 -32
- package/dist/integrations/secrets/env-secret-provider.d.ts.map +0 -1
- package/dist/integrations/secrets/env-secret-provider.js.map +0 -1
- package/dist/integrations/secrets/gcp-secret-manager.d.ts +0 -33
- package/dist/integrations/secrets/gcp-secret-manager.d.ts.map +0 -1
- package/dist/integrations/secrets/gcp-secret-manager.js.map +0 -1
- package/dist/integrations/secrets/index.d.ts +0 -5
- package/dist/integrations/secrets/manager.d.ts +0 -48
- package/dist/integrations/secrets/manager.d.ts.map +0 -1
- package/dist/integrations/secrets/manager.js.map +0 -1
- package/dist/integrations/secrets/provider.d.ts +0 -53
- package/dist/integrations/secrets/provider.d.ts.map +0 -1
- package/dist/integrations/secrets/provider.js.map +0 -1
- package/dist/integrations/spec.d.ts +0 -80
- package/dist/integrations/spec.d.ts.map +0 -1
- package/dist/integrations/spec.js.map +0 -1
- package/dist/jobs/gcp-cloud-tasks.d.ts +0 -42
- package/dist/jobs/gcp-cloud-tasks.d.ts.map +0 -1
- package/dist/jobs/gcp-cloud-tasks.js.map +0 -1
- package/dist/jobs/gcp-pubsub.d.ts +0 -26
- package/dist/jobs/gcp-pubsub.d.ts.map +0 -1
- package/dist/jobs/gcp-pubsub.js.map +0 -1
- package/dist/jobs/handlers/gmail-sync-handler.d.ts +0 -10
- package/dist/jobs/handlers/gmail-sync-handler.d.ts.map +0 -1
- package/dist/jobs/handlers/gmail-sync-handler.js.map +0 -1
- package/dist/jobs/handlers/index.d.ts +0 -3
- package/dist/jobs/handlers/storage-document-handler.d.ts +0 -13
- package/dist/jobs/handlers/storage-document-handler.d.ts.map +0 -1
- package/dist/jobs/handlers/storage-document-handler.js.map +0 -1
- package/dist/jobs/index.d.ts +0 -7
- package/dist/jobs/memory-queue.d.ts +0 -19
- package/dist/jobs/memory-queue.d.ts.map +0 -1
- package/dist/jobs/memory-queue.js.map +0 -1
- package/dist/jobs/queue.d.ts +0 -27
- package/dist/jobs/queue.d.ts.map +0 -1
- package/dist/jsonschema.d.ts +0 -27
- package/dist/jsonschema.d.ts.map +0 -1
- package/dist/jsonschema.js.map +0 -1
- package/dist/knowledge/binding.d.ts +0 -26
- package/dist/knowledge/binding.d.ts.map +0 -1
- package/dist/knowledge/contracts.d.ts +0 -317
- package/dist/knowledge/contracts.d.ts.map +0 -1
- package/dist/knowledge/contracts.js.map +0 -1
- package/dist/knowledge/index.d.ts +0 -10
- package/dist/knowledge/ingestion/document-processor.d.ts +0 -25
- package/dist/knowledge/ingestion/document-processor.d.ts.map +0 -1
- package/dist/knowledge/ingestion/document-processor.js.map +0 -1
- package/dist/knowledge/ingestion/embedding-service.d.ts +0 -13
- package/dist/knowledge/ingestion/embedding-service.d.ts.map +0 -1
- package/dist/knowledge/ingestion/embedding-service.js.map +0 -1
- package/dist/knowledge/ingestion/gmail-adapter.d.ts +0 -19
- package/dist/knowledge/ingestion/gmail-adapter.d.ts.map +0 -1
- package/dist/knowledge/ingestion/gmail-adapter.js.map +0 -1
- package/dist/knowledge/ingestion/index.d.ts +0 -6
- package/dist/knowledge/ingestion/storage-adapter.d.ts +0 -16
- package/dist/knowledge/ingestion/storage-adapter.d.ts.map +0 -1
- package/dist/knowledge/ingestion/storage-adapter.js.map +0 -1
- package/dist/knowledge/ingestion/vector-indexer.d.ts +0 -19
- package/dist/knowledge/ingestion/vector-indexer.d.ts.map +0 -1
- package/dist/knowledge/ingestion/vector-indexer.js.map +0 -1
- package/dist/knowledge/query/index.d.ts +0 -2
- package/dist/knowledge/query/service.d.ts +0 -30
- package/dist/knowledge/query/service.d.ts.map +0 -1
- package/dist/knowledge/query/service.js.map +0 -1
- package/dist/knowledge/runtime.d.ts +0 -33
- package/dist/knowledge/runtime.d.ts.map +0 -1
- package/dist/knowledge/runtime.js.map +0 -1
- package/dist/knowledge/source.d.ts +0 -33
- package/dist/knowledge/source.d.ts.map +0 -1
- package/dist/knowledge/spaces/email-threads.d.ts +0 -8
- package/dist/knowledge/spaces/email-threads.d.ts.map +0 -1
- package/dist/knowledge/spaces/email-threads.js.map +0 -1
- package/dist/knowledge/spaces/financial-docs.d.ts +0 -8
- package/dist/knowledge/spaces/financial-docs.d.ts.map +0 -1
- package/dist/knowledge/spaces/financial-docs.js.map +0 -1
- package/dist/knowledge/spaces/financial-overview.d.ts +0 -8
- package/dist/knowledge/spaces/financial-overview.d.ts.map +0 -1
- package/dist/knowledge/spaces/financial-overview.js.map +0 -1
- package/dist/knowledge/spaces/index.d.ts +0 -7
- package/dist/knowledge/spaces/product-canon.d.ts +0 -8
- package/dist/knowledge/spaces/product-canon.d.ts.map +0 -1
- package/dist/knowledge/spaces/product-canon.js.map +0 -1
- package/dist/knowledge/spaces/support-faq.d.ts +0 -8
- package/dist/knowledge/spaces/support-faq.d.ts.map +0 -1
- package/dist/knowledge/spaces/support-faq.js.map +0 -1
- package/dist/knowledge/spaces/uploaded-docs.d.ts +0 -8
- package/dist/knowledge/spaces/uploaded-docs.d.ts.map +0 -1
- package/dist/knowledge/spaces/uploaded-docs.js.map +0 -1
- package/dist/knowledge/spec.d.ts +0 -53
- package/dist/knowledge/spec.d.ts.map +0 -1
- package/dist/knowledge/spec.js.map +0 -1
- package/dist/markdown.d.ts +0 -22
- package/dist/markdown.d.ts.map +0 -1
- package/dist/markdown.js.map +0 -1
- package/dist/migrations.d.ts +0 -53
- package/dist/migrations.d.ts.map +0 -1
- package/dist/migrations.js.map +0 -1
- package/dist/onboarding-base.d.ts +0 -138
- package/dist/onboarding-base.d.ts.map +0 -1
- package/dist/onboarding-base.js.map +0 -1
- package/dist/ownership.d.ts +0 -76
- package/dist/ownership.d.ts.map +0 -1
- package/dist/ownership.js.map +0 -1
- package/dist/policy/engine.d.ts +0 -40
- package/dist/policy/engine.d.ts.map +0 -1
- package/dist/policy/engine.js.map +0 -1
- package/dist/policy/opa-adapter.d.ts +0 -46
- package/dist/policy/opa-adapter.d.ts.map +0 -1
- package/dist/policy/opa-adapter.js.map +0 -1
- package/dist/policy/spec.d.ts +0 -115
- package/dist/policy/spec.d.ts.map +0 -1
- package/dist/policy/spec.js.map +0 -1
- package/dist/presentations.backcompat.d.ts +0 -8
- package/dist/presentations.backcompat.d.ts.map +0 -1
- package/dist/presentations.backcompat.js.map +0 -1
- package/dist/presentations.d.ts +0 -97
- package/dist/presentations.d.ts.map +0 -1
- package/dist/presentations.js.map +0 -1
- package/dist/presentations.v2.d.ts +0 -96
- package/dist/presentations.v2.d.ts.map +0 -1
- package/dist/presentations.v2.js.map +0 -1
- package/dist/prompt.d.ts +0 -61
- package/dist/prompt.d.ts.map +0 -1
- package/dist/prompt.js.map +0 -1
- package/dist/promptRegistry.d.ts +0 -16
- package/dist/promptRegistry.d.ts.map +0 -1
- package/dist/promptRegistry.js.map +0 -1
- package/dist/regenerator/adapters.d.ts +0 -20
- package/dist/regenerator/adapters.d.ts.map +0 -1
- package/dist/regenerator/executor.d.ts +0 -71
- package/dist/regenerator/executor.d.ts.map +0 -1
- package/dist/regenerator/executor.js.map +0 -1
- package/dist/regenerator/index.d.ts +0 -7
- package/dist/regenerator/service.d.ts +0 -34
- package/dist/regenerator/service.d.ts.map +0 -1
- package/dist/regenerator/service.js.map +0 -1
- package/dist/regenerator/sinks.d.ts +0 -27
- package/dist/regenerator/sinks.d.ts.map +0 -1
- package/dist/regenerator/sinks.js.map +0 -1
- package/dist/regenerator/types.d.ts +0 -108
- package/dist/regenerator/types.d.ts.map +0 -1
- package/dist/regenerator/utils.d.ts +0 -10
- package/dist/regenerator/utils.d.ts.map +0 -1
- package/dist/regenerator/utils.js.map +0 -1
- package/dist/registry.d.ts +0 -73
- package/dist/registry.d.ts.map +0 -1
- package/dist/registry.js.map +0 -1
- package/dist/resources.d.ts +0 -65
- package/dist/resources.d.ts.map +0 -1
- package/dist/resources.js.map +0 -1
- package/dist/schema/dist/EnumType.js +0 -1
- package/dist/schema/dist/FieldType.js +0 -2
- package/dist/schema/dist/FieldType.js.map +0 -1
- package/dist/schema/dist/ScalarTypeEnum.js +0 -2
- package/dist/schema/dist/ScalarTypeEnum.js.map +0 -1
- package/dist/schema/dist/SchemaModel.js +0 -2
- package/dist/schema/dist/SchemaModel.js.map +0 -1
- package/dist/schema/dist/index.js +0 -1
- package/dist/server/graphql-pothos.d.ts +0 -32
- package/dist/server/graphql-pothos.d.ts.map +0 -1
- package/dist/server/graphql-pothos.js.map +0 -1
- package/dist/server/graphql-schema-export.d.ts +0 -7
- package/dist/server/graphql-schema-export.d.ts.map +0 -1
- package/dist/server/graphql-schema-export.js +0 -2
- package/dist/server/graphql-schema-export.js.map +0 -1
- package/dist/server/index.d.ts +0 -9
- package/dist/server/provider-mcp.d.ts +0 -52
- package/dist/server/provider-mcp.d.ts.map +0 -1
- package/dist/server/provider-mcp.js.map +0 -1
- package/dist/server/rest-elysia.d.ts +0 -41
- package/dist/server/rest-elysia.d.ts.map +0 -1
- package/dist/server/rest-elysia.js.map +0 -1
- package/dist/server/rest-express.d.ts +0 -17
- package/dist/server/rest-express.d.ts.map +0 -1
- package/dist/server/rest-express.js.map +0 -1
- package/dist/server/rest-generic.d.ts +0 -33
- package/dist/server/rest-generic.d.ts.map +0 -1
- package/dist/server/rest-generic.js.map +0 -1
- package/dist/server/rest-next-app.d.ts +0 -36
- package/dist/server/rest-next-app.d.ts.map +0 -1
- package/dist/server/rest-next-app.js.map +0 -1
- package/dist/server/rest-next-mcp.d.ts +0 -12
- package/dist/server/rest-next-mcp.d.ts.map +0 -1
- package/dist/server/rest-next-mcp.js.map +0 -1
- package/dist/server/rest-next-pages.d.ts +0 -10
- package/dist/server/rest-next-pages.d.ts.map +0 -1
- package/dist/server/rest-next-pages.js.map +0 -1
- package/dist/spec.d.ts +0 -172
- package/dist/spec.d.ts.map +0 -1
- package/dist/spec.js.map +0 -1
- package/dist/telemetry/anomaly.d.ts +0 -28
- package/dist/telemetry/anomaly.d.ts.map +0 -1
- package/dist/telemetry/anomaly.js.map +0 -1
- package/dist/telemetry/index.d.ts +0 -4
- package/dist/telemetry/spec.d.ts +0 -99
- package/dist/telemetry/spec.d.ts.map +0 -1
- package/dist/telemetry/spec.js.map +0 -1
- package/dist/telemetry/tracker.d.ts +0 -52
- package/dist/telemetry/tracker.d.ts.map +0 -1
- package/dist/telemetry/tracker.js.map +0 -1
- package/dist/tests/index.d.ts +0 -3
- package/dist/tests/runner.d.ts +0 -44
- package/dist/tests/runner.d.ts.map +0 -1
- package/dist/tests/runner.js.map +0 -1
- package/dist/tests/spec.d.ts +0 -90
- package/dist/tests/spec.d.ts.map +0 -1
- package/dist/tests/spec.js.map +0 -1
- package/dist/themes.d.ts +0 -56
- package/dist/themes.d.ts.map +0 -1
- package/dist/themes.js.map +0 -1
- package/dist/translations/catalog.d.ts +0 -29
- package/dist/translations/catalog.d.ts.map +0 -1
- package/dist/translations/tenant.d.ts +0 -16
- package/dist/translations/tenant.d.ts.map +0 -1
- package/dist/types/all.d.ts +0 -60
- package/dist/types.d.ts +0 -89
- package/dist/types.d.ts.map +0 -1
- package/dist/workflow/adapters/db-adapter.d.ts +0 -35
- package/dist/workflow/adapters/db-adapter.d.ts.map +0 -1
- package/dist/workflow/adapters/db-adapter.js.map +0 -1
- package/dist/workflow/adapters/file-adapter.d.ts +0 -15
- package/dist/workflow/adapters/file-adapter.d.ts.map +0 -1
- package/dist/workflow/adapters/file-adapter.js.map +0 -1
- package/dist/workflow/adapters/index.d.ts +0 -4
- package/dist/workflow/adapters/memory-store.d.ts +0 -19
- package/dist/workflow/adapters/memory-store.d.ts.map +0 -1
- package/dist/workflow/adapters/memory-store.js.map +0 -1
- package/dist/workflow/expression.d.ts +0 -10
- package/dist/workflow/expression.d.ts.map +0 -1
- package/dist/workflow/expression.js.map +0 -1
- package/dist/workflow/index.d.ts +0 -10
- package/dist/workflow/runner.d.ts +0 -75
- package/dist/workflow/runner.d.ts.map +0 -1
- package/dist/workflow/runner.js.map +0 -1
- package/dist/workflow/sla-monitor.d.ts +0 -21
- package/dist/workflow/sla-monitor.d.ts.map +0 -1
- package/dist/workflow/sla-monitor.js.map +0 -1
- package/dist/workflow/spec.d.ts +0 -100
- package/dist/workflow/spec.d.ts.map +0 -1
- package/dist/workflow/spec.js.map +0 -1
- package/dist/workflow/state.d.ts +0 -36
- package/dist/workflow/state.d.ts.map +0 -1
- package/dist/workflow/validation.d.ts +0 -29
- package/dist/workflow/validation.d.ts.map +0 -1
- package/dist/workflow/validation.js.map +0 -1
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
import { ResolvedBranding } from "../app-config/branding.js";
|
|
2
|
-
import { OpRef } from "../features.js";
|
|
3
|
-
import { GuardCondition, Step, WorkflowRegistry } from "./spec.js";
|
|
4
|
-
import { ResolvedAppConfig, ResolvedIntegration, ResolvedKnowledge, ResolvedTranslation } from "../app-config/runtime.js";
|
|
5
|
-
import { SecretProvider } from "../integrations/secrets/provider.js";
|
|
6
|
-
import { TranslationResolver } from "../types.js";
|
|
7
|
-
import { StateStore, WorkflowState } from "./state.js";
|
|
8
|
-
|
|
9
|
-
//#region src/workflow/runner.d.ts
|
|
10
|
-
interface OperationExecutorContext {
|
|
11
|
-
workflow: WorkflowState;
|
|
12
|
-
step: Step;
|
|
13
|
-
resolvedAppConfig?: ResolvedAppConfig;
|
|
14
|
-
integrations?: ResolvedIntegration[];
|
|
15
|
-
knowledge?: ResolvedKnowledge[];
|
|
16
|
-
branding?: ResolvedBranding;
|
|
17
|
-
translation?: ResolvedTranslation;
|
|
18
|
-
translationResolver?: TranslationResolver;
|
|
19
|
-
secretProvider?: SecretProvider;
|
|
20
|
-
}
|
|
21
|
-
type OperationExecutor = (op: OpRef, input: unknown, context: OperationExecutorContext) => Promise<unknown>;
|
|
22
|
-
type WorkflowPreFlightIssueType = 'integration' | 'capability';
|
|
23
|
-
type WorkflowPreFlightIssueSeverity = 'error' | 'warning';
|
|
24
|
-
interface WorkflowPreFlightIssue {
|
|
25
|
-
stepId: string;
|
|
26
|
-
type: WorkflowPreFlightIssueType;
|
|
27
|
-
identifier: string;
|
|
28
|
-
severity: WorkflowPreFlightIssueSeverity;
|
|
29
|
-
reason: string;
|
|
30
|
-
}
|
|
31
|
-
interface WorkflowPreFlightResult {
|
|
32
|
-
canStart: boolean;
|
|
33
|
-
issues: WorkflowPreFlightIssue[];
|
|
34
|
-
}
|
|
35
|
-
interface GuardContext {
|
|
36
|
-
workflow: WorkflowState;
|
|
37
|
-
step: Step;
|
|
38
|
-
input?: unknown;
|
|
39
|
-
}
|
|
40
|
-
type GuardEvaluator = (guard: GuardCondition, context: GuardContext) => Promise<boolean> | boolean;
|
|
41
|
-
interface WorkflowRunnerConfig {
|
|
42
|
-
registry: WorkflowRegistry;
|
|
43
|
-
stateStore: StateStore;
|
|
44
|
-
opExecutor: OperationExecutor;
|
|
45
|
-
guardEvaluator?: GuardEvaluator;
|
|
46
|
-
eventEmitter?: (event: string, payload: Record<string, unknown>) => void;
|
|
47
|
-
appConfigProvider?: (state: WorkflowState) => ResolvedAppConfig | undefined | Promise<ResolvedAppConfig | undefined>;
|
|
48
|
-
enforceCapabilities?: (operation: OpRef, context: OperationExecutorContext) => void | Promise<void>;
|
|
49
|
-
secretProvider?: SecretProvider;
|
|
50
|
-
translationResolver?: TranslationResolver;
|
|
51
|
-
}
|
|
52
|
-
declare class WorkflowRunner {
|
|
53
|
-
private readonly config;
|
|
54
|
-
constructor(config: WorkflowRunnerConfig);
|
|
55
|
-
preFlightCheck(workflowName: string, version?: number, resolvedConfig?: ResolvedAppConfig): Promise<WorkflowPreFlightResult>;
|
|
56
|
-
start(workflowName: string, version?: number, initialData?: Record<string, unknown>): Promise<string>;
|
|
57
|
-
executeStep(workflowId: string, input?: unknown): Promise<void>;
|
|
58
|
-
rollback(workflowId: string): Promise<void>;
|
|
59
|
-
getState(workflowId: string): Promise<WorkflowState>;
|
|
60
|
-
cancel(workflowId: string): Promise<void>;
|
|
61
|
-
private performPreFlight;
|
|
62
|
-
private evaluateGuard;
|
|
63
|
-
private runStepAction;
|
|
64
|
-
private pickNextStepId;
|
|
65
|
-
private getSpec;
|
|
66
|
-
private getStateOrThrow;
|
|
67
|
-
private emit;
|
|
68
|
-
}
|
|
69
|
-
declare class WorkflowPreFlightError extends Error {
|
|
70
|
-
readonly issues: WorkflowPreFlightIssue[];
|
|
71
|
-
constructor(issues: WorkflowPreFlightIssue[]);
|
|
72
|
-
}
|
|
73
|
-
//#endregion
|
|
74
|
-
export { GuardContext, GuardEvaluator, OperationExecutor, OperationExecutorContext, WorkflowPreFlightError, WorkflowPreFlightIssue, WorkflowPreFlightIssueSeverity, WorkflowPreFlightIssueType, WorkflowPreFlightResult, WorkflowRunner, WorkflowRunnerConfig };
|
|
75
|
-
//# sourceMappingURL=runner.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"runner.d.ts","names":[],"sources":["../../src/workflow/runner.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"runner.js","names":["config: WorkflowRunnerConfig","state: WorkflowState","execution: StepExecution","workingState: WorkflowState","executorContext: OperationExecutorContext","nextState: WorkflowState","issues: WorkflowPreFlightIssue[]"],"sources":["../../src/workflow/runner.ts"],"sourcesContent":["import { randomUUID } from 'node:crypto';\nimport type {\n GuardCondition,\n Step,\n WorkflowRegistry,\n WorkflowSpec,\n} from './spec';\nimport type { StateStore, WorkflowState, StepExecution } from './state';\nimport { evaluateExpression } from './expression';\nimport type { OpRef } from '../features';\nimport type { CapabilityRef } from '../capabilities';\nimport type {\n ResolvedAppConfig,\n ResolvedIntegration,\n ResolvedKnowledge,\n ResolvedTranslation,\n} from '../app-config/runtime';\nimport type { ResolvedBranding } from '../app-config/branding';\nimport type { TranslationResolver } from '../types';\nimport type { SecretProvider } from '../integrations/secrets/provider';\n\nexport interface OperationExecutorContext {\n workflow: WorkflowState;\n step: Step;\n resolvedAppConfig?: ResolvedAppConfig;\n integrations?: ResolvedIntegration[];\n knowledge?: ResolvedKnowledge[];\n branding?: ResolvedBranding;\n translation?: ResolvedTranslation;\n translationResolver?: TranslationResolver;\n secretProvider?: SecretProvider;\n}\n\nexport type OperationExecutor = (\n op: OpRef,\n input: unknown,\n context: OperationExecutorContext\n) => Promise<unknown>;\n\nexport type WorkflowPreFlightIssueType = 'integration' | 'capability';\n\nexport type WorkflowPreFlightIssueSeverity = 'error' | 'warning';\n\nexport interface WorkflowPreFlightIssue {\n stepId: string;\n type: WorkflowPreFlightIssueType;\n identifier: string;\n severity: WorkflowPreFlightIssueSeverity;\n reason: string;\n}\n\nexport interface WorkflowPreFlightResult {\n canStart: boolean;\n issues: WorkflowPreFlightIssue[];\n}\n\nexport interface GuardContext {\n workflow: WorkflowState;\n step: Step;\n input?: unknown;\n}\n\nexport type GuardEvaluator = (\n guard: GuardCondition,\n context: GuardContext\n) => Promise<boolean> | boolean;\n\nexport interface WorkflowRunnerConfig {\n registry: WorkflowRegistry;\n stateStore: StateStore;\n opExecutor: OperationExecutor;\n guardEvaluator?: GuardEvaluator;\n eventEmitter?: (event: string, payload: Record<string, unknown>) => void;\n appConfigProvider?: (\n state: WorkflowState\n ) => ResolvedAppConfig | undefined | Promise<ResolvedAppConfig | undefined>;\n enforceCapabilities?: (\n operation: OpRef,\n context: OperationExecutorContext\n ) => void | Promise<void>;\n secretProvider?: SecretProvider;\n translationResolver?: TranslationResolver;\n}\n\nexport class WorkflowRunner {\n constructor(private readonly config: WorkflowRunnerConfig) {}\n\n async preFlightCheck(\n workflowName: string,\n version?: number,\n resolvedConfig?: ResolvedAppConfig\n ): Promise<WorkflowPreFlightResult> {\n const spec = this.getSpec(workflowName, version);\n return this.performPreFlight(spec, resolvedConfig);\n }\n\n async start(\n workflowName: string,\n version?: number,\n initialData?: Record<string, unknown>\n ): Promise<string> {\n const spec = this.getSpec(workflowName, version);\n const entryStepId = resolveEntryStepId(spec);\n const now = new Date();\n const workflowId = randomUUID();\n\n const state: WorkflowState = {\n workflowId,\n workflowName: spec.meta.name,\n workflowVersion: spec.meta.version,\n currentStep: entryStepId,\n data: { ...(initialData ?? {}) },\n retryCounts: {},\n history: [],\n status: 'running',\n createdAt: now,\n updatedAt: now,\n };\n\n const resolvedAppConfig = this.config.appConfigProvider\n ? await this.config.appConfigProvider(state)\n : undefined;\n\n const preFlightResult = await this.performPreFlight(\n spec,\n resolvedAppConfig\n );\n if (!preFlightResult.canStart) {\n throw new WorkflowPreFlightError(preFlightResult.issues);\n }\n\n await this.config.stateStore.create(state);\n this.emit('workflow.started', {\n workflowId,\n workflowName: spec.meta.name,\n workflowVersion: spec.meta.version,\n currentStep: entryStepId,\n });\n return workflowId;\n }\n\n async executeStep(workflowId: string, input?: unknown): Promise<void> {\n const state = await this.getStateOrThrow(workflowId);\n if (isTerminalStatus(state.status)) {\n throw new Error(\n `Workflow ${workflowId} is in terminal status \"${state.status}\".`\n );\n }\n\n const spec = this.getSpec(state.workflowName, state.workflowVersion);\n const step = getCurrentStep(spec, state.currentStep);\n const guardOk = await this.evaluateGuard(step, state, input);\n if (!guardOk)\n throw new Error(`GuardRejected: ${state.workflowName} -> ${step.id}`);\n\n const execution: StepExecution = {\n stepId: step.id,\n startedAt: new Date(),\n status: 'running',\n input,\n };\n\n const workingState: WorkflowState = {\n ...state,\n data: { ...state.data },\n history: [...state.history],\n };\n\n try {\n const output = await this.runStepAction(step, workingState, input);\n execution.output = output;\n execution.status = 'completed';\n execution.completedAt = new Date();\n workingState.history.push(execution);\n workingState.updatedAt = new Date();\n\n if (isRecord(input)) {\n workingState.data = { ...workingState.data, ...input };\n }\n if (isRecord(output)) {\n workingState.data = { ...workingState.data, ...output };\n }\n\n const nextStepId = this.pickNextStepId(\n spec,\n workingState,\n step,\n input,\n output\n );\n\n if (nextStepId) {\n workingState.currentStep = nextStepId;\n workingState.status = 'running';\n } else if (!hasOutgoing(spec, step.id)) {\n workingState.status = 'completed';\n } else {\n throw new Error(\n `No transition matched after executing step \"${step.id}\".`\n );\n }\n\n await this.config.stateStore.update(workflowId, () => workingState);\n this.emit('workflow.step_completed', {\n workflowId,\n workflowName: state.workflowName,\n stepId: step.id,\n status: workingState.status,\n });\n } catch (error) {\n execution.status = 'failed';\n execution.completedAt = new Date();\n execution.error = error instanceof Error ? error.message : String(error);\n workingState.history.push(execution);\n workingState.updatedAt = new Date();\n\n if (step.retry) {\n const retries = state.retryCounts?.[step.id] ?? 0;\n if (retries < step.retry.maxAttempts) {\n const backoff = step.retry.backoff ?? 'exponential';\n const baseDelay = step.retry.delayMs ?? 1000;\n const delay =\n backoff === 'exponential'\n ? baseDelay * Math.pow(2, retries)\n : baseDelay;\n const cappedDelay = Math.min(\n delay,\n step.retry.maxDelayMs ?? Infinity\n );\n\n workingState.retryCounts = {\n ...(state.retryCounts ?? {}),\n [step.id]: retries + 1,\n };\n workingState.status = 'running';\n\n await this.config.stateStore.update(workflowId, () => workingState);\n this.emit('workflow.step_retrying', {\n workflowId,\n workflowName: state.workflowName,\n stepId: step.id,\n attempt: retries + 1,\n delay: cappedDelay,\n error: execution.error,\n });\n\n await new Promise((resolve) => setTimeout(resolve, cappedDelay));\n return this.executeStep(workflowId, input);\n }\n }\n\n workingState.status = 'failed';\n await this.config.stateStore.update(workflowId, () => workingState);\n this.emit('workflow.step_failed', {\n workflowId,\n workflowName: state.workflowName,\n stepId: step.id,\n error: execution.error ?? 'unknown',\n });\n\n // Trigger compensation if configured\n if (spec.definition.compensation?.trigger === 'on_failure') {\n await this.rollback(workflowId);\n }\n\n throw error;\n }\n }\n\n async rollback(workflowId: string): Promise<void> {\n const state = await this.getStateOrThrow(workflowId);\n const spec = this.getSpec(state.workflowName, state.workflowVersion);\n\n if (!spec.definition.compensation) {\n return;\n }\n\n this.emit('workflow.rollback_started', { workflowId });\n\n // Filter history for completed automation steps in reverse order\n const completedSteps = state.history\n .filter((h) => h.status === 'completed')\n .reverse();\n\n for (const execution of completedSteps) {\n const compStep = spec.definition.compensation.steps.find(\n (s) => s.stepId === execution.stepId\n );\n if (compStep) {\n const input = {\n stepId: execution.stepId,\n originalInput: execution.input,\n originalOutput: execution.output,\n workflowData: state.data,\n };\n\n try {\n // Create a context for the compensation step\n // We use the same state as it provides access to data/history\n const step = getCurrentStep(spec, execution.stepId);\n const resolvedAppConfig = this.config.appConfigProvider\n ? await this.config.appConfigProvider(state)\n : undefined;\n\n const executorContext: OperationExecutorContext = {\n workflow: state,\n step,\n resolvedAppConfig,\n integrations: resolvedAppConfig?.integrations ?? [],\n knowledge: resolvedAppConfig?.knowledge ?? [],\n branding: resolvedAppConfig?.branding,\n translation: resolvedAppConfig?.translation,\n translationResolver: this.config.translationResolver,\n secretProvider: this.config.secretProvider,\n };\n\n await this.config.opExecutor(\n compStep.operation,\n input,\n executorContext\n );\n\n this.emit('workflow.compensation_step_completed', {\n workflowId,\n stepId: execution.stepId,\n compensationOp: compStep.operation.name,\n });\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : String(error);\n this.emit('workflow.compensation_step_failed', {\n workflowId,\n stepId: execution.stepId,\n compensationOp: compStep.operation.name,\n error: errorMessage,\n });\n // We continue with other compensations even if one fails (best effort)\n }\n }\n }\n\n // We don't change status from 'failed' or 'cancelled' usually,\n // but we might want to mark that rollback was attempted/completed.\n // For now, just emitting events is enough.\n this.emit('workflow.rollback_completed', { workflowId });\n }\n\n async getState(workflowId: string): Promise<WorkflowState> {\n return this.getStateOrThrow(workflowId);\n }\n\n async cancel(workflowId: string): Promise<void> {\n const state = await this.getStateOrThrow(workflowId);\n if (state.status === 'cancelled') return;\n\n const nextState: WorkflowState = {\n ...state,\n status: 'cancelled',\n updatedAt: new Date(),\n };\n await this.config.stateStore.update(workflowId, () => nextState);\n this.emit('workflow.cancelled', {\n workflowId,\n workflowName: state.workflowName,\n });\n }\n\n private async performPreFlight(\n spec: WorkflowSpec,\n resolvedConfig?: ResolvedAppConfig\n ): Promise<WorkflowPreFlightResult> {\n if (!resolvedConfig) {\n return { canStart: true, issues: [] };\n }\n\n const issues: WorkflowPreFlightIssue[] = [];\n const integrationBySlot = new Map<string, ResolvedIntegration>();\n for (const integration of resolvedConfig.integrations) {\n integrationBySlot.set(integration.slot.slotId, integration);\n }\n\n for (const step of spec.definition.steps) {\n for (const slotId of step.requiredIntegrations ?? []) {\n const integration = integrationBySlot.get(slotId);\n if (!integration) {\n issues.push({\n stepId: step.id,\n type: 'integration',\n identifier: slotId,\n severity: 'error',\n reason: `Integration slot \"${slotId}\" is not bound in the resolved app config.`,\n });\n continue;\n }\n const status = integration.connection.status;\n if (status === 'disconnected' || status === 'error') {\n issues.push({\n stepId: step.id,\n type: 'integration',\n identifier: slotId,\n severity: 'error',\n reason: `Integration slot \"${slotId}\" is in status \"${status}\".`,\n });\n } else if (status === 'unknown') {\n issues.push({\n stepId: step.id,\n type: 'integration',\n identifier: slotId,\n severity: 'warning',\n reason: `Integration slot \"${slotId}\" reports unknown health status.`,\n });\n }\n }\n }\n\n const enabledCapabilities = new Set(\n resolvedConfig.capabilities.enabled.map(capabilityKey)\n );\n for (const step of spec.definition.steps) {\n for (const required of step.requiredCapabilities ?? []) {\n if (!enabledCapabilities.has(capabilityKey(required))) {\n issues.push({\n stepId: step.id,\n type: 'capability',\n identifier: capabilityKey(required),\n severity: 'error',\n reason: `Capability \"${required.key}@${required.version}\" is not enabled.`,\n });\n }\n }\n }\n\n const canStart = issues.every((issue) => issue.severity !== 'error');\n return { canStart, issues };\n }\n\n private async evaluateGuard(\n step: Step,\n state: WorkflowState,\n input: unknown\n ) {\n if (!step.guard) return true;\n if (this.config.guardEvaluator)\n return this.config.guardEvaluator(step.guard, {\n workflow: state,\n step,\n input,\n });\n if (step.guard.type === 'expression') {\n return evaluateExpression(step.guard.value, {\n data: state.data,\n input,\n });\n }\n return true;\n }\n\n private async runStepAction(\n step: Step,\n state: WorkflowState,\n input: unknown\n ): Promise<unknown> {\n if (step.type === 'automation') {\n const op = step.action?.operation;\n if (!op)\n throw new Error(`Automation step \"${step.id}\" requires an operation.`);\n const resolvedAppConfig = this.config.appConfigProvider\n ? await this.config.appConfigProvider(state)\n : undefined;\n const executorContext: OperationExecutorContext = {\n workflow: state,\n step,\n resolvedAppConfig,\n integrations: resolvedAppConfig?.integrations ?? [],\n knowledge: resolvedAppConfig?.knowledge ?? [],\n branding: resolvedAppConfig?.branding,\n translation: resolvedAppConfig?.translation,\n translationResolver: this.config.translationResolver,\n secretProvider: this.config.secretProvider,\n };\n if (this.config.enforceCapabilities) {\n await this.config.enforceCapabilities(op, executorContext);\n }\n return this.config.opExecutor(op, input, executorContext);\n }\n\n if (step.type === 'human') {\n return input;\n }\n\n // decision step\n return input;\n }\n\n private pickNextStepId(\n spec: WorkflowSpec,\n state: WorkflowState,\n step: Step,\n input: unknown,\n output: unknown\n ): string | null {\n const transitions = spec.definition.transitions.filter(\n (t) => t.from === step.id\n );\n for (const transition of transitions) {\n if (\n evaluateExpression(transition.condition, {\n data: state.data,\n input,\n output,\n })\n ) {\n const target = spec.definition.steps.find(\n (s) => s.id === transition.to\n );\n if (!target)\n throw new Error(\n `Transition ${transition.from} -> ${transition.to} points to missing step.`\n );\n return target.id;\n }\n }\n return null;\n }\n\n private getSpec(name: string, version?: number): WorkflowSpec {\n const spec = this.config.registry.get(name, version);\n if (!spec)\n throw new Error(\n `Workflow spec not found for ${name}${version ? `.v${version}` : ''}`\n );\n return spec;\n }\n\n private async getStateOrThrow(workflowId: string): Promise<WorkflowState> {\n const state = await this.config.stateStore.get(workflowId);\n if (!state) throw new Error(`Workflow state not found for ${workflowId}`);\n return state;\n }\n\n private emit(event: string, payload: Record<string, unknown>) {\n this.config.eventEmitter?.(event, payload);\n }\n}\n\nfunction resolveEntryStepId(spec: WorkflowSpec): string {\n const entry =\n spec.definition.entryStepId ?? spec.definition.steps[0]?.id ?? null;\n if (!entry)\n throw new Error(\n `Workflow ${spec.meta.name}.v${spec.meta.version} has no entry step.`\n );\n return entry;\n}\n\nfunction getCurrentStep(spec: WorkflowSpec, stepId: string): Step {\n const step = spec.definition.steps.find((s) => s.id === stepId);\n if (!step)\n throw new Error(\n `Step \"${stepId}\" not found in workflow ${spec.meta.name}.v${spec.meta.version}.`\n );\n return step;\n}\n\nfunction hasOutgoing(spec: WorkflowSpec, stepId: string): boolean {\n return spec.definition.transitions.some((t) => t.from === stepId);\n}\n\nfunction isRecord(value: unknown): value is Record<string, unknown> {\n return value != null && typeof value === 'object' && !Array.isArray(value);\n}\n\nfunction isTerminalStatus(status: WorkflowState['status']) {\n return (\n status === 'completed' || status === 'failed' || status === 'cancelled'\n );\n}\n\nexport class WorkflowPreFlightError extends Error {\n constructor(public readonly issues: WorkflowPreFlightIssue[]) {\n super(\n `Workflow pre-flight failed: ${issues\n .filter((issue) => issue.severity === 'error')\n .map((issue) => `${issue.type}:${issue.identifier}`)\n .join(', ')}`\n );\n this.name = 'WorkflowPreFlightError';\n }\n}\n\nfunction capabilityKey(ref: CapabilityRef): string {\n return `${ref.key}@${ref.version}`;\n}\n"],"mappings":"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"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { WorkflowSpec } from "./spec.js";
|
|
2
|
-
import { WorkflowState } from "./state.js";
|
|
3
|
-
|
|
4
|
-
//#region src/workflow/sla-monitor.d.ts
|
|
5
|
-
interface SLABreachEvent {
|
|
6
|
-
workflowId: string;
|
|
7
|
-
workflowName: string;
|
|
8
|
-
type: 'workflow_duration' | 'step_duration';
|
|
9
|
-
stepId?: string;
|
|
10
|
-
expectedMs: number;
|
|
11
|
-
actualMs: number;
|
|
12
|
-
breachedAt: Date;
|
|
13
|
-
}
|
|
14
|
-
declare class SLAMonitor {
|
|
15
|
-
private readonly eventEmitter;
|
|
16
|
-
constructor(eventEmitter: (event: string, payload: SLABreachEvent) => void);
|
|
17
|
-
check(state: WorkflowState, spec: WorkflowSpec): void;
|
|
18
|
-
}
|
|
19
|
-
//#endregion
|
|
20
|
-
export { SLABreachEvent, SLAMonitor };
|
|
21
|
-
//# sourceMappingURL=sla-monitor.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sla-monitor.d.ts","names":[],"sources":["../../src/workflow/sla-monitor.ts"],"sourcesContent":[],"mappings":";;;;UAGiB,cAAA;;EAAA,YAAA,EAAA,MAAc;EAUlB,IAAA,EAAA,mBAAU,GAAA,eAAA;EAIR,MAAA,CAAA,EAAA,MAAA;EAIA,UAAA,EAAA,MAAA;EAAqB,QAAA,EAAA,MAAA;EAAY,UAAA,EAXlC,IAWkC;;cARnC,UAAA;;qDAIE;eAIA,qBAAqB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sla-monitor.js","names":["eventEmitter: (\n event: string,\n payload: SLABreachEvent\n ) => void"],"sources":["../../src/workflow/sla-monitor.ts"],"sourcesContent":["import type { WorkflowState } from './state';\nimport type { WorkflowSpec } from './spec';\n\nexport interface SLABreachEvent {\n workflowId: string;\n workflowName: string;\n type: 'workflow_duration' | 'step_duration';\n stepId?: string;\n expectedMs: number;\n actualMs: number;\n breachedAt: Date;\n}\n\nexport class SLAMonitor {\n constructor(\n private readonly eventEmitter: (\n event: string,\n payload: SLABreachEvent\n ) => void\n ) {}\n\n check(state: WorkflowState, spec: WorkflowSpec): void {\n const sla = spec.definition.sla;\n if (!sla) return;\n\n const now = new Date().getTime();\n\n // Check total workflow duration\n if (sla.totalDurationMs) {\n const duration = now - state.createdAt.getTime();\n if (duration > sla.totalDurationMs) {\n // Only emit if not already completed/failed/cancelled\n if (state.status === 'running' || state.status === 'paused') {\n this.eventEmitter('workflow.sla_breach', {\n workflowId: state.workflowId,\n workflowName: state.workflowName,\n type: 'workflow_duration',\n expectedMs: sla.totalDurationMs,\n actualMs: duration,\n breachedAt: new Date(),\n });\n }\n }\n }\n\n // Check step durations\n if (sla.stepDurationMs) {\n // Check currently running step\n if (state.status === 'running' && state.currentStep) {\n // Find when the current step started\n // It might be the last entry in history if it's running?\n // But history usually stores *completed* steps or *failed* attempts.\n // Runner updates history with status='running' at start of execution?\n // Let's check runner.ts:\n // const execution: StepExecution = { ... status: 'running' ... };\n // workingState.history.push(execution);\n // Yes, it pushes running execution.\n\n const currentExecution = state.history.find(\n (h) => h.stepId === state.currentStep && h.status === 'running'\n );\n\n if (currentExecution) {\n const stepLimit = sla.stepDurationMs[state.currentStep];\n if (stepLimit) {\n const stepDuration = now - currentExecution.startedAt.getTime();\n if (stepDuration > stepLimit) {\n this.eventEmitter('workflow.sla_breach', {\n workflowId: state.workflowId,\n workflowName: state.workflowName,\n type: 'step_duration',\n stepId: state.currentStep,\n expectedMs: stepLimit,\n actualMs: stepDuration,\n breachedAt: new Date(),\n });\n }\n }\n }\n }\n }\n }\n}\n"],"mappings":"AAaA,IAAa,EAAb,KAAwB,CACtB,YACE,EAIA,CAJiB,KAAA,aAAA,EAMnB,MAAM,EAAsB,EAA0B,CACpD,IAAM,EAAM,EAAK,WAAW,IAC5B,GAAI,CAAC,EAAK,OAEV,IAAM,EAAM,IAAI,MAAM,CAAC,SAAS,CAGhC,GAAI,EAAI,gBAAiB,CACvB,IAAM,EAAW,EAAM,EAAM,UAAU,SAAS,CAC5C,EAAW,EAAI,kBAEb,EAAM,SAAW,WAAa,EAAM,SAAW,WACjD,KAAK,aAAa,sBAAuB,CACvC,WAAY,EAAM,WAClB,aAAc,EAAM,aACpB,KAAM,oBACN,WAAY,EAAI,gBAChB,SAAU,EACV,WAAY,IAAI,KACjB,CAAC,CAMR,GAAI,EAAI,gBAEF,EAAM,SAAW,WAAa,EAAM,YAAa,CAUnD,IAAM,EAAmB,EAAM,QAAQ,KACpC,GAAM,EAAE,SAAW,EAAM,aAAe,EAAE,SAAW,UACvD,CAED,GAAI,EAAkB,CACpB,IAAM,EAAY,EAAI,eAAe,EAAM,aAC3C,GAAI,EAAW,CACb,IAAM,EAAe,EAAM,EAAiB,UAAU,SAAS,CAC3D,EAAe,GACjB,KAAK,aAAa,sBAAuB,CACvC,WAAY,EAAM,WAClB,aAAc,EAAM,aACpB,KAAM,gBACN,OAAQ,EAAM,YACd,WAAY,EACZ,SAAU,EACV,WAAY,IAAI,KACjB,CAAC"}
|
package/dist/workflow/spec.d.ts
DELETED
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { OwnerShipMeta } from "../ownership.js";
|
|
2
|
-
import { CapabilityRef } from "../capabilities.js";
|
|
3
|
-
import { ExperimentRef } from "../experiments/spec.js";
|
|
4
|
-
import { OpRef } from "../features.js";
|
|
5
|
-
|
|
6
|
-
//#region src/workflow/spec.d.ts
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Reference to a form spec declared in {@link FormRegistry}.
|
|
10
|
-
*/
|
|
11
|
-
interface FormRef {
|
|
12
|
-
key: string;
|
|
13
|
-
version: number;
|
|
14
|
-
}
|
|
15
|
-
type StepType = 'human' | 'automation' | 'decision';
|
|
16
|
-
type WorkflowStatus = 'running' | 'paused' | 'completed' | 'failed' | 'cancelled';
|
|
17
|
-
type GuardConditionKind = 'policy' | 'expression';
|
|
18
|
-
interface GuardCondition {
|
|
19
|
-
type: GuardConditionKind;
|
|
20
|
-
/** Policy name or expression string depending on the type. */
|
|
21
|
-
value: string;
|
|
22
|
-
}
|
|
23
|
-
interface RetryPolicy {
|
|
24
|
-
maxAttempts: number;
|
|
25
|
-
backoff: 'linear' | 'exponential';
|
|
26
|
-
delayMs: number;
|
|
27
|
-
/** Optional max delay cap for exponential backoff. */
|
|
28
|
-
maxDelayMs?: number;
|
|
29
|
-
}
|
|
30
|
-
interface StepAction {
|
|
31
|
-
/** Operation executed for automation steps. */
|
|
32
|
-
operation?: OpRef;
|
|
33
|
-
/** Form rendered for human input steps. */
|
|
34
|
-
form?: FormRef;
|
|
35
|
-
}
|
|
36
|
-
interface Step {
|
|
37
|
-
id: string;
|
|
38
|
-
type: StepType;
|
|
39
|
-
label: string;
|
|
40
|
-
description?: string;
|
|
41
|
-
action?: StepAction;
|
|
42
|
-
guard?: GuardCondition;
|
|
43
|
-
timeoutMs?: number;
|
|
44
|
-
retry?: RetryPolicy;
|
|
45
|
-
/** Integration slot identifiers required before this step can execute. */
|
|
46
|
-
requiredIntegrations?: string[];
|
|
47
|
-
/** Capabilities that must be enabled for this step to execute. */
|
|
48
|
-
requiredCapabilities?: CapabilityRef[];
|
|
49
|
-
}
|
|
50
|
-
interface Transition {
|
|
51
|
-
from: string;
|
|
52
|
-
to: string;
|
|
53
|
-
label?: string;
|
|
54
|
-
/** Expression evaluated against workflow data (e.g., `data.approved === true`). */
|
|
55
|
-
condition?: string;
|
|
56
|
-
}
|
|
57
|
-
interface SLA {
|
|
58
|
-
totalDurationMs?: number;
|
|
59
|
-
stepDurationMs?: Record<string, number>;
|
|
60
|
-
}
|
|
61
|
-
interface CompensationStep {
|
|
62
|
-
stepId: string;
|
|
63
|
-
operation: OpRef;
|
|
64
|
-
description?: string;
|
|
65
|
-
}
|
|
66
|
-
interface CompensationStrategy {
|
|
67
|
-
trigger?: 'on_failure' | 'manual';
|
|
68
|
-
steps: CompensationStep[];
|
|
69
|
-
}
|
|
70
|
-
interface WorkflowDefinition {
|
|
71
|
-
steps: Step[];
|
|
72
|
-
transitions: Transition[];
|
|
73
|
-
/** Optional explicit entry step. Defaults to the first step when omitted. */
|
|
74
|
-
entryStepId?: string;
|
|
75
|
-
sla?: SLA;
|
|
76
|
-
compensation?: CompensationStrategy;
|
|
77
|
-
}
|
|
78
|
-
interface WorkflowMeta extends OwnerShipMeta {
|
|
79
|
-
/** Fully-qualified workflow name (e.g., `sigil.onboarding.basic`). */
|
|
80
|
-
name: string;
|
|
81
|
-
/** Version of the workflow. Increment on breaking changes. */
|
|
82
|
-
version: number;
|
|
83
|
-
}
|
|
84
|
-
interface WorkflowSpec {
|
|
85
|
-
meta: WorkflowMeta;
|
|
86
|
-
definition: WorkflowDefinition;
|
|
87
|
-
policy?: {
|
|
88
|
-
flags?: string[];
|
|
89
|
-
};
|
|
90
|
-
experiments?: ExperimentRef[];
|
|
91
|
-
}
|
|
92
|
-
declare class WorkflowRegistry {
|
|
93
|
-
private readonly items;
|
|
94
|
-
register(spec: WorkflowSpec): this;
|
|
95
|
-
list(): WorkflowSpec[];
|
|
96
|
-
get(name: string, version?: number): WorkflowSpec | undefined;
|
|
97
|
-
}
|
|
98
|
-
//#endregion
|
|
99
|
-
export { CompensationStep, CompensationStrategy, FormRef, GuardCondition, GuardConditionKind, RetryPolicy, SLA, Step, StepAction, StepType, Transition, WorkflowDefinition, WorkflowMeta, WorkflowRegistry, WorkflowSpec, WorkflowStatus };
|
|
100
|
-
//# sourceMappingURL=spec.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spec.d.ts","names":[],"sources":["../../src/workflow/spec.ts"],"sourcesContent":[],"mappings":";;;;;;;;;AAQA;AAKY,UALK,OAAA,CAKG;EAER,GAAA,EAAA,MAAA;EAOA,OAAA,EAAA,MAAA;AAEZ;AAMiB,KAjBL,QAAA,GAiBgB,OAAA,GAAA,YAAA,GAAA,UAAA;AAQX,KAvBL,cAAA,GAuBe,SAIlB,GAAA,QAAO,GAAA,WAAA,GAAA,QAAA,GAAA,WAAA;AAGC,KAvBL,kBAAA,GAuBS,QAAA,GAAA,YAAA;AAEb,UAvBS,cAAA,CAuBT;EAGG,IAAA,EAzBH,kBAyBG;EACD;EAEA,KAAA,EAAA,MAAA;;AAI4B,UA3BrB,WAAA,CA2BqB;EAGrB,WAAA,EAAU,MAAA;EAQV,OAAG,EAAA,QAAA,GAED,aAAM;EAGR,OAAA,EAAA,MAAA;EAMA;EAKA,UAAA,CAAA,EAAA,MAAA;;AAEF,UAhDE,UAAA,CAgDF;EAGP;EACS,SAAA,CAAA,EAlDH,KAkDG;EAAoB;EAGpB,IAAA,CAAA,EAnDR,OAmDQ;AAOjB;AACQ,UAxDS,IAAA,CAwDT;EACM,EAAA,EAAA,MAAA;EAEE,IAAA,EAzDR,QAyDQ;EAAa,KAAA,EAAA,MAAA;EAOhB,WAAA,CAAA,EAAA,MAAgB;EAGZ,MAAA,CAAA,EAhEN,UAgEM;EAOP,KAAA,CAAA,EAtEA,cAsEA;EAI6B,SAAA,CAAA,EAAA,MAAA;EAAY,KAAA,CAAA,EAxEzC,WAwEyC;;;;yBApE1B;;UAGR,UAAA;;;;;;;UAQA,GAAA;;mBAEE;;UAGF,gBAAA;;aAEJ;;;UAII,oBAAA;;SAER;;UAGQ,kBAAA;SACR;eACM;;;QAGP;iBACS;;UAGA,YAAA,SAAqB;;;;;;UAOrB,YAAA;QACT;cACM;;;;gBAEE;;cAOH,gBAAA;;iBAGI;UAOP;uCAI6B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"spec.js","names":["candidate: WorkflowSpec | undefined"],"sources":["../../src/workflow/spec.ts"],"sourcesContent":["import type { CapabilityRef } from '../capabilities';\nimport type { OwnerShipMeta } from '../ownership';\nimport type { OpRef } from '../features';\nimport type { ExperimentRef } from '../experiments/spec';\n\n/**\n * Reference to a form spec declared in {@link FormRegistry}.\n */\nexport interface FormRef {\n key: string;\n version: number;\n}\n\nexport type StepType = 'human' | 'automation' | 'decision';\n\nexport type WorkflowStatus =\n | 'running'\n | 'paused'\n | 'completed'\n | 'failed'\n | 'cancelled';\n\nexport type GuardConditionKind = 'policy' | 'expression';\n\nexport interface GuardCondition {\n type: GuardConditionKind;\n /** Policy name or expression string depending on the type. */\n value: string;\n}\n\nexport interface RetryPolicy {\n maxAttempts: number;\n backoff: 'linear' | 'exponential';\n delayMs: number;\n /** Optional max delay cap for exponential backoff. */\n maxDelayMs?: number;\n}\n\nexport interface StepAction {\n /** Operation executed for automation steps. */\n operation?: OpRef;\n /** Form rendered for human input steps. */\n form?: FormRef;\n}\n\nexport interface Step {\n id: string;\n type: StepType;\n label: string;\n description?: string;\n action?: StepAction;\n guard?: GuardCondition;\n timeoutMs?: number;\n retry?: RetryPolicy;\n /** Integration slot identifiers required before this step can execute. */\n requiredIntegrations?: string[];\n /** Capabilities that must be enabled for this step to execute. */\n requiredCapabilities?: CapabilityRef[];\n}\n\nexport interface Transition {\n from: string;\n to: string;\n label?: string;\n /** Expression evaluated against workflow data (e.g., `data.approved === true`). */\n condition?: string;\n}\n\nexport interface SLA {\n totalDurationMs?: number;\n stepDurationMs?: Record<string, number>;\n}\n\nexport interface CompensationStep {\n stepId: string;\n operation: OpRef;\n description?: string;\n}\n\nexport interface CompensationStrategy {\n trigger?: 'on_failure' | 'manual';\n steps: CompensationStep[];\n}\n\nexport interface WorkflowDefinition {\n steps: Step[];\n transitions: Transition[];\n /** Optional explicit entry step. Defaults to the first step when omitted. */\n entryStepId?: string;\n sla?: SLA;\n compensation?: CompensationStrategy;\n}\n\nexport interface WorkflowMeta extends OwnerShipMeta {\n /** Fully-qualified workflow name (e.g., `sigil.onboarding.basic`). */\n name: string;\n /** Version of the workflow. Increment on breaking changes. */\n version: number;\n}\n\nexport interface WorkflowSpec {\n meta: WorkflowMeta;\n definition: WorkflowDefinition;\n policy?: { flags?: string[] };\n experiments?: ExperimentRef[];\n}\n\nfunction workflowKey(meta: WorkflowMeta) {\n return `${meta.name}.v${meta.version}`;\n}\n\nexport class WorkflowRegistry {\n private readonly items = new Map<string, WorkflowSpec>();\n\n register(spec: WorkflowSpec): this {\n const key = workflowKey(spec.meta);\n if (this.items.has(key)) throw new Error(`Duplicate workflow ${key}`);\n this.items.set(key, spec);\n return this;\n }\n\n list(): WorkflowSpec[] {\n return [...this.items.values()];\n }\n\n get(name: string, version?: number): WorkflowSpec | undefined {\n if (version != null) return this.items.get(`${name}.v${version}`);\n let candidate: WorkflowSpec | undefined;\n let max = -Infinity;\n for (const spec of this.items.values()) {\n if (spec.meta.name !== name) continue;\n if (spec.meta.version > max) {\n max = spec.meta.version;\n candidate = spec;\n }\n }\n return candidate;\n }\n}\n"],"mappings":"AA2GA,SAAS,EAAY,EAAoB,CACvC,MAAO,GAAG,EAAK,KAAK,IAAI,EAAK,UAG/B,IAAa,EAAb,KAA8B,CAC5B,MAAyB,IAAI,IAE7B,SAAS,EAA0B,CACjC,IAAM,EAAM,EAAY,EAAK,KAAK,CAClC,GAAI,KAAK,MAAM,IAAI,EAAI,CAAE,MAAU,MAAM,sBAAsB,IAAM,CAErE,OADA,KAAK,MAAM,IAAI,EAAK,EAAK,CAClB,KAGT,MAAuB,CACrB,MAAO,CAAC,GAAG,KAAK,MAAM,QAAQ,CAAC,CAGjC,IAAI,EAAc,EAA4C,CAC5D,GAAI,GAAW,KAAM,OAAO,KAAK,MAAM,IAAI,GAAG,EAAK,IAAI,IAAU,CACjE,IAAIA,EACA,EAAM,KACV,IAAK,IAAM,KAAQ,KAAK,MAAM,QAAQ,CAChC,EAAK,KAAK,OAAS,GACnB,EAAK,KAAK,QAAU,IACtB,EAAM,EAAK,KAAK,QAChB,EAAY,GAGhB,OAAO"}
|
package/dist/workflow/state.d.ts
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { WorkflowStatus } from "./spec.js";
|
|
2
|
-
|
|
3
|
-
//#region src/workflow/state.d.ts
|
|
4
|
-
interface StepExecution {
|
|
5
|
-
stepId: string;
|
|
6
|
-
startedAt: Date;
|
|
7
|
-
completedAt?: Date;
|
|
8
|
-
status: 'pending' | 'running' | 'completed' | 'failed';
|
|
9
|
-
input?: unknown;
|
|
10
|
-
output?: unknown;
|
|
11
|
-
error?: string;
|
|
12
|
-
}
|
|
13
|
-
interface WorkflowState {
|
|
14
|
-
workflowId: string;
|
|
15
|
-
workflowName: string;
|
|
16
|
-
workflowVersion: number;
|
|
17
|
-
currentStep: string;
|
|
18
|
-
data: Record<string, unknown>;
|
|
19
|
-
retryCounts?: Record<string, number>;
|
|
20
|
-
history: StepExecution[];
|
|
21
|
-
status: WorkflowStatus;
|
|
22
|
-
createdAt: Date;
|
|
23
|
-
updatedAt: Date;
|
|
24
|
-
}
|
|
25
|
-
interface WorkflowStateFilters {
|
|
26
|
-
status?: WorkflowStatus;
|
|
27
|
-
}
|
|
28
|
-
interface StateStore {
|
|
29
|
-
create(state: WorkflowState): Promise<void>;
|
|
30
|
-
get(workflowId: string): Promise<WorkflowState | undefined>;
|
|
31
|
-
update(workflowId: string, updater: (current: WorkflowState) => WorkflowState): Promise<WorkflowState>;
|
|
32
|
-
list(filters?: WorkflowStateFilters): Promise<WorkflowState[]>;
|
|
33
|
-
}
|
|
34
|
-
//#endregion
|
|
35
|
-
export { StateStore, StepExecution, WorkflowState, WorkflowStateFilters };
|
|
36
|
-
//# sourceMappingURL=state.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"state.d.ts","names":[],"sources":["../../src/workflow/state.ts"],"sourcesContent":[],"mappings":";;;UAEiB,aAAA;;EAAA,SAAA,EAEJ,IAFI;EAUA,WAAA,CAAA,EAPD,IAOc;EAKtB,MAAA,EAAA,SAAA,GAAA,SAAA,GAAA,WAAA,GAAA,QAAA;EACQ,KAAA,CAAA,EAAA,OAAA;EACL,MAAA,CAAA,EAAA,OAAA;EACD,KAAA,CAAA,EAAA,MAAA;;AAEG,UAVI,aAAA,CAUJ;EAAI,UAAA,EAAA,MAAA;EAGA,YAAA,EAAA,MAAA;EAIA,eAAU,EAAA,MAAA;EACX,WAAA,EAAA,MAAA;EAAgB,IAAA,EAbxB,MAawB,CAAA,MAAA,EAAA,OAAA,CAAA;EACG,WAAA,CAAA,EAbnB,MAamB,CAAA,MAAA,EAAA,MAAA,CAAA;EAAR,OAAA,EAZhB,aAYgB,EAAA;EAGJ,MAAA,EAdb,cAca;EAAkB,SAAA,EAb5B,IAa4B;EAC5B,SAAA,EAbA,IAaA;;AACI,UAXA,oBAAA,CAWA;EAA+B,MAAA,CAAA,EAVrC,cAUqC;;AAAD,UAP9B,UAAA,CAO8B;gBAN/B,gBAAgB;2BACL,QAAQ;gDAGZ,kBAAkB,gBACpC,QAAQ;iBACI,uBAAuB,QAAQ"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { WorkflowSpec } from "./spec.js";
|
|
2
|
-
import { SpecRegistry } from "../registry.js";
|
|
3
|
-
import { FormRegistry } from "../forms.js";
|
|
4
|
-
|
|
5
|
-
//#region src/workflow/validation.d.ts
|
|
6
|
-
type WorkflowValidationLevel = 'error' | 'warning';
|
|
7
|
-
interface WorkflowValidationIssue {
|
|
8
|
-
level: WorkflowValidationLevel;
|
|
9
|
-
message: string;
|
|
10
|
-
context?: Record<string, unknown>;
|
|
11
|
-
}
|
|
12
|
-
interface ValidateWorkflowSpecOptions {
|
|
13
|
-
operations?: SpecRegistry;
|
|
14
|
-
forms?: FormRegistry;
|
|
15
|
-
}
|
|
16
|
-
declare class WorkflowValidationError extends Error {
|
|
17
|
-
readonly issues: WorkflowValidationIssue[];
|
|
18
|
-
constructor(message: string, issues: WorkflowValidationIssue[]);
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Validate workflow structure, references, and reachability.
|
|
22
|
-
* Returns the collected issues. Consumers may call {@link assertWorkflowSpecValid}
|
|
23
|
-
* to throw on validation errors.
|
|
24
|
-
*/
|
|
25
|
-
declare function validateWorkflowSpec(spec: WorkflowSpec, options?: ValidateWorkflowSpecOptions): WorkflowValidationIssue[];
|
|
26
|
-
declare function assertWorkflowSpecValid(spec: WorkflowSpec, options?: ValidateWorkflowSpecOptions): void;
|
|
27
|
-
//#endregion
|
|
28
|
-
export { ValidateWorkflowSpecOptions, WorkflowValidationError, WorkflowValidationIssue, WorkflowValidationLevel, assertWorkflowSpecValid, validateWorkflowSpec };
|
|
29
|
-
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validation.d.ts","names":[],"sources":["../../src/workflow/validation.ts"],"sourcesContent":[],"mappings":";;;;;KASY,uBAAA;UAEK,uBAAA;EAFL,KAAA,EAGH,uBAH0B;EAElB,OAAA,EAAA,MAAA;EAMA,OAAA,CAAA,EAHL,MAGK,CAAA,MAAA,EAAA,OAA2B,CAAA;AAK5C;AAG4B,UARX,2BAAA,CAQW;EAAA,UAAA,CAAA,EAPb,YAOa;EAHiB,KAAA,CAAA,EAHnC,YAGmC;;AAe7B,cAfH,uBAAA,SAAgC,KAAA,CAeT;EAC5B,SAAA,MAAA,EAboB,uBAapB,EAAA;EACG,WAAA,CAAA,OAAA,EAAA,MAAA,EAAA,MAAA,EAdiB,uBAcjB,EAAA;;;AAqCX;;;;iBAvCgB,oBAAA,OACR,wBACG,8BACR;iBAoCa,uBAAA,OACR,wBACG"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validation.js","names":["issues: WorkflowValidationIssue[]"],"sources":["../../src/workflow/validation.ts"],"sourcesContent":["import type { FormRegistry } from '../forms';\nimport type { SpecRegistry } from '../registry';\nimport type {\n Step,\n Transition,\n WorkflowDefinition,\n WorkflowSpec,\n} from './spec';\n\nexport type WorkflowValidationLevel = 'error' | 'warning';\n\nexport interface WorkflowValidationIssue {\n level: WorkflowValidationLevel;\n message: string;\n context?: Record<string, unknown>;\n}\n\nexport interface ValidateWorkflowSpecOptions {\n operations?: SpecRegistry;\n forms?: FormRegistry;\n}\n\nexport class WorkflowValidationError extends Error {\n constructor(\n message: string,\n public readonly issues: WorkflowValidationIssue[]\n ) {\n super(message);\n this.name = 'WorkflowValidationError';\n }\n}\n\n/**\n * Validate workflow structure, references, and reachability.\n * Returns the collected issues. Consumers may call {@link assertWorkflowSpecValid}\n * to throw on validation errors.\n */\nexport function validateWorkflowSpec(\n spec: WorkflowSpec,\n options: ValidateWorkflowSpecOptions = {}\n): WorkflowValidationIssue[] {\n const issues: WorkflowValidationIssue[] = [];\n const { definition } = spec;\n\n if (!definition.steps.length) {\n issues.push({\n level: 'error',\n message: 'Workflow must declare at least one step.',\n });\n return issues;\n }\n\n const stepsById = indexSteps(definition, issues);\n const entryStepId = definition.entryStepId ?? definition.steps[0]?.id ?? null;\n\n if (!entryStepId) {\n issues.push({\n level: 'error',\n message: 'Workflow requires an entry step (definition.entryStepId).',\n });\n } else if (!stepsById.has(entryStepId)) {\n issues.push({\n level: 'error',\n message: `Entry step \"${entryStepId}\" is not defined in steps.`,\n });\n }\n\n const adjacency = buildAdjacency(definition, stepsById, issues);\n\n validateStepActions(definition.steps, options, issues);\n validateReachability(entryStepId, stepsById, adjacency, issues);\n detectCycles(adjacency, issues);\n\n return issues;\n}\n\nexport function assertWorkflowSpecValid(\n spec: WorkflowSpec,\n options: ValidateWorkflowSpecOptions = {}\n): void {\n const issues = validateWorkflowSpec(spec, options);\n const errors = issues.filter((issue) => issue.level === 'error');\n if (errors.length) {\n throw new WorkflowValidationError(\n `Workflow ${spec.meta.name}.v${spec.meta.version} is invalid`,\n issues\n );\n }\n}\n\nfunction indexSteps(\n definition: WorkflowDefinition,\n issues: WorkflowValidationIssue[]\n) {\n const stepsById = new Map<string, Step>();\n for (const step of definition.steps) {\n if (stepsById.has(step.id)) {\n issues.push({\n level: 'error',\n message: `Duplicate step id \"${step.id}\" detected.`,\n });\n continue;\n }\n stepsById.set(step.id, step);\n if (step.type === 'automation' && !step.action?.operation) {\n issues.push({\n level: 'warning',\n message: `Automation step \"${step.id}\" does not declare an operation.`,\n });\n }\n if (step.type === 'human' && !step.action?.form) {\n issues.push({\n level: 'warning',\n message: `Human step \"${step.id}\" does not declare a form.`,\n });\n }\n if (step.guard && !step.guard.value.trim()) {\n issues.push({\n level: 'error',\n message: `Guard for step \"${step.id}\" must have a non-empty value.`,\n });\n }\n }\n return stepsById;\n}\n\nfunction buildAdjacency(\n definition: WorkflowDefinition,\n stepsById: Map<string, Step>,\n issues: WorkflowValidationIssue[]\n) {\n const adjacency = new Map<string, Set<string>>();\n const incoming = new Map<string, number>();\n\n for (const stepId of stepsById.keys()) {\n adjacency.set(stepId, new Set());\n incoming.set(stepId, 0);\n }\n\n for (const transition of definition.transitions) {\n const from = stepsById.get(transition.from);\n const to = stepsById.get(transition.to);\n\n if (!from) {\n issues.push({\n level: 'error',\n message: `Transition refers to unknown \"from\" step \"${transition.from}\".`,\n });\n continue;\n }\n if (!to) {\n issues.push({\n level: 'error',\n message: `Transition refers to unknown \"to\" step \"${transition.to}\".`,\n });\n continue;\n }\n\n adjacency.get(transition.from)?.add(transition.to);\n incoming.set(transition.to, (incoming.get(transition.to) ?? 0) + 1);\n\n validateTransition(transition, issues);\n }\n\n const roots = [...incoming.entries()]\n .filter(([, count]) => count === 0)\n .map(([id]) => id);\n if (roots.length > 1) {\n issues.push({\n level: 'warning',\n message: `Workflow has multiple potential entry steps: ${roots.join(', ')}`,\n });\n }\n\n return adjacency;\n}\n\nfunction validateTransition(\n transition: Transition,\n issues: WorkflowValidationIssue[]\n) {\n if (transition.condition && !transition.condition.trim()) {\n issues.push({\n level: 'error',\n message: `Transition ${transition.from} -> ${transition.to} declares an empty condition.`,\n });\n }\n}\n\nfunction validateStepActions(\n steps: Step[],\n options: ValidateWorkflowSpecOptions,\n issues: WorkflowValidationIssue[]\n) {\n for (const step of steps) {\n const action = step.action;\n if (!action) continue;\n if (action.operation && options.operations) {\n const op = options.operations.getSpec(\n action.operation.name,\n action.operation.version\n );\n if (!op) {\n issues.push({\n level: 'error',\n message: `Step \"${step.id}\" references unknown operation ${action.operation.name}.v${action.operation.version}.`,\n });\n }\n }\n if (action.form && options.forms) {\n const form = options.forms.get(action.form.key, action.form.version);\n if (!form) {\n issues.push({\n level: 'error',\n message: `Step \"${step.id}\" references unknown form ${action.form.key}.v${action.form.version}.`,\n });\n }\n }\n }\n}\n\nfunction validateReachability(\n entryStepId: string | null,\n stepsById: Map<string, Step>,\n adjacency: Map<string, Set<string>>,\n issues: WorkflowValidationIssue[]\n) {\n if (!entryStepId || !stepsById.has(entryStepId)) return;\n const visited = new Set<string>();\n const queue = [entryStepId];\n visited.add(entryStepId);\n\n while (queue.length) {\n const current = queue.shift()!;\n const neighbours = adjacency.get(current);\n if (!neighbours) continue;\n for (const next of neighbours) {\n if (visited.has(next)) continue;\n visited.add(next);\n queue.push(next);\n }\n }\n\n for (const stepId of stepsById.keys()) {\n if (!visited.has(stepId)) {\n issues.push({\n level: 'error',\n message: `Step \"${stepId}\" is unreachable from entry step \"${entryStepId}\".`,\n });\n }\n }\n}\n\nfunction detectCycles(\n adjacency: Map<string, Set<string>>,\n issues: WorkflowValidationIssue[]\n) {\n const visited = new Set<string>();\n const stack = new Set<string>();\n let cycleReported = false;\n\n const dfs = (node: string) => {\n if (stack.has(node)) {\n if (!cycleReported) {\n issues.push({\n level: 'error',\n message: `Workflow contains a cycle involving step \"${node}\".`,\n });\n cycleReported = true;\n }\n return;\n }\n if (visited.has(node)) return;\n\n stack.add(node);\n const neighbours = adjacency.get(node);\n if (neighbours) {\n for (const next of neighbours) dfs(next);\n }\n stack.delete(node);\n visited.add(node);\n };\n\n for (const node of adjacency.keys()) dfs(node);\n}\n"],"mappings":"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"}
|