@lostgradient/weft 0.2.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/LICENSE +21 -0
- package/README.md +493 -0
- package/dist/alerting/alert-manager.d.ts +42 -0
- package/dist/alerting/alert-manager.js +167 -0
- package/dist/alerting/index.d.ts +2 -0
- package/dist/alerting/index.js +1 -0
- package/dist/alerting/sliding-window.d.ts +26 -0
- package/dist/alerting/sliding-window.js +97 -0
- package/dist/alerting/types.d.ts +157 -0
- package/dist/alerting/types.js +0 -0
- package/dist/cli/api-arguments.d.ts +2 -0
- package/dist/cli/api-arguments.js +48 -0
- package/dist/cli/api.d.ts +13 -0
- package/dist/cli/api.js +191 -0
- package/dist/cli/codegen-arguments.d.ts +10 -0
- package/dist/cli/codegen-arguments.js +50 -0
- package/dist/cli/codegen-emit-keywords.d.ts +28 -0
- package/dist/cli/codegen-emit-keywords.js +48 -0
- package/dist/cli/codegen-emit.d.ts +50 -0
- package/dist/cli/codegen-emit.js +280 -0
- package/dist/cli/codegen.d.ts +38 -0
- package/dist/cli/codegen.js +268 -0
- package/dist/cli/command-suggestions.d.ts +9 -0
- package/dist/cli/command-suggestions.js +27 -0
- package/dist/cli/completions.d.ts +17 -0
- package/dist/cli/completions.js +112 -0
- package/dist/cli/conformance.d.ts +9 -0
- package/dist/cli/conformance.js +226 -0
- package/dist/cli/doctor.d.ts +6 -0
- package/dist/cli/doctor.js +9 -0
- package/dist/cli/generated/operation-client.generated.d.ts +605 -0
- package/dist/cli/generated/operation-client.generated.js +60 -0
- package/dist/cli/help-text.d.ts +13 -0
- package/dist/cli/help-text.js +269 -0
- package/dist/cli/index.d.ts +23 -0
- package/dist/cli/index.js +34 -0
- package/dist/cli/json-rpc-client.d.ts +15 -0
- package/dist/cli/json-rpc-client.js +37 -0
- package/dist/cli/noun-verb-arguments.d.ts +15 -0
- package/dist/cli/noun-verb-arguments.js +190 -0
- package/dist/cli/operation-catalog-snapshot.d.ts +38 -0
- package/dist/cli/operation-catalog-snapshot.js +48 -0
- package/dist/cli/operation-client-runtime.d.ts +47 -0
- package/dist/cli/operation-client-runtime.js +33 -0
- package/dist/cli/output.d.ts +66 -0
- package/dist/cli/output.js +83 -0
- package/dist/cli/parse-arguments.d.ts +3 -0
- package/dist/cli/parse-arguments.js +214 -0
- package/dist/cli/parse-schedule-arguments.d.ts +9 -0
- package/dist/cli/parse-schedule-arguments.js +132 -0
- package/dist/cli/schedule.d.ts +3 -0
- package/dist/cli/schedule.js +128 -0
- package/dist/cli/serve-registrations.d.ts +15 -0
- package/dist/cli/serve-registrations.js +23 -0
- package/dist/cli/server-client.d.ts +45 -0
- package/dist/cli/server-client.js +33 -0
- package/dist/cli/server-commands.d.ts +19 -0
- package/dist/cli/server-commands.js +151 -0
- package/dist/cli/storage-backend-arguments.d.ts +15 -0
- package/dist/cli/storage-backend-arguments.js +16 -0
- package/dist/cli/storage-factory.d.ts +8 -0
- package/dist/cli/storage-factory.js +18 -0
- package/dist/cli/subcommand-detection.d.ts +2 -0
- package/dist/cli/subcommand-detection.js +38 -0
- package/dist/cli/tail.d.ts +50 -0
- package/dist/cli/tail.js +161 -0
- package/dist/cli/timeline.d.ts +9 -0
- package/dist/cli/timeline.js +78 -0
- package/dist/cli/types.d.ts +224 -0
- package/dist/cli/types.js +0 -0
- package/dist/cli/utilities.d.ts +9 -0
- package/dist/cli/utilities.js +120 -0
- package/dist/cli/validate.d.ts +6 -0
- package/dist/cli/validate.js +70 -0
- package/dist/cli/version-check.d.ts +7 -0
- package/dist/cli/version-check.js +16 -0
- package/dist/cli/version.d.ts +7 -0
- package/dist/cli/version.js +4 -0
- package/dist/cli/workflow-commands.d.ts +15 -0
- package/dist/cli/workflow-commands.js +195 -0
- package/dist/cli-main.d.ts +2 -0
- package/dist/cli-main.js +402 -0
- package/dist/client/event-stream-transport.d.ts +73 -0
- package/dist/client/event-stream-transport.js +59 -0
- package/dist/client/event-stream.d.ts +90 -0
- package/dist/client/event-stream.js +221 -0
- package/dist/client/event-tail.d.ts +50 -0
- package/dist/client/event-tail.js +0 -0
- package/dist/client/handle-delegation.d.ts +73 -0
- package/dist/client/handle-delegation.js +66 -0
- package/dist/client/http-client-requests.d.ts +65 -0
- package/dist/client/http-client-requests.js +178 -0
- package/dist/client/http-client.d.ts +130 -0
- package/dist/client/http-client.js +217 -0
- package/dist/client/http-handle.d.ts +27 -0
- package/dist/client/http-handle.js +43 -0
- package/dist/client/http-operations.d.ts +29 -0
- package/dist/client/http-operations.js +36 -0
- package/dist/client/http-request.d.ts +101 -0
- package/dist/client/http-request.js +73 -0
- package/dist/client/http-schedule-handle.d.ts +5 -0
- package/dist/client/http-schedule-handle.js +5 -0
- package/dist/client/in-process-operations.d.ts +30 -0
- package/dist/client/in-process-operations.js +17 -0
- package/dist/client/index.d.ts +15 -0
- package/dist/client/index.js +2 -0
- package/dist/client/interface.d.ts +333 -0
- package/dist/client/interface.js +0 -0
- package/dist/client/local-event-tail.d.ts +30 -0
- package/dist/client/local-event-tail.js +131 -0
- package/dist/client/local.d.ts +115 -0
- package/dist/client/local.js +178 -0
- package/dist/client/open-event-subscription.d.ts +33 -0
- package/dist/client/open-event-subscription.js +5 -0
- package/dist/client/schedule-list-search-params.d.ts +3 -0
- package/dist/client/schedule-list-search-params.js +18 -0
- package/dist/client/search-params.d.ts +3 -0
- package/dist/client/search-params.js +54 -0
- package/dist/client/start-body.d.ts +9 -0
- package/dist/client/start-body.js +23 -0
- package/dist/client/workflow-name-typing.d.ts +33 -0
- package/dist/client/workflow-name-typing.js +0 -0
- package/dist/connection.d.ts +121 -0
- package/dist/connection.js +161 -0
- package/dist/core/activity-registry.d.ts +135 -0
- package/dist/core/activity-registry.js +174 -0
- package/dist/core/activity.d.ts +2 -0
- package/dist/core/activity.js +1 -0
- package/dist/core/aggregate-validation.d.ts +85 -0
- package/dist/core/aggregate-validation.js +48 -0
- package/dist/core/atomic-state-events.d.ts +214 -0
- package/dist/core/atomic-state-events.js +39 -0
- package/dist/core/atomic-state.d.ts +79 -0
- package/dist/core/atomic-state.js +231 -0
- package/dist/core/bulk-workflow-filter.d.ts +23 -0
- package/dist/core/bulk-workflow-filter.js +38 -0
- package/dist/core/checkpoint/comparison.d.ts +2 -0
- package/dist/core/checkpoint/comparison.js +137 -0
- package/dist/core/checkpoint/index.d.ts +4 -0
- package/dist/core/checkpoint/index.js +3 -0
- package/dist/core/checkpoint/interfaces.d.ts +11 -0
- package/dist/core/checkpoint/interfaces.js +0 -0
- package/dist/core/checkpoint/lifecycle.d.ts +49 -0
- package/dist/core/checkpoint/lifecycle.js +36 -0
- package/dist/core/checkpoint/serialization.d.ts +31 -0
- package/dist/core/checkpoint/serialization.js +155 -0
- package/dist/core/checkpoint/validation.d.ts +4 -0
- package/dist/core/checkpoint/validation.js +26 -0
- package/dist/core/checkpoint.d.ts +1 -0
- package/dist/core/checkpoint.js +1 -0
- package/dist/core/codec/api.d.ts +32 -0
- package/dist/core/codec/api.js +9 -0
- package/dist/core/codec/extension-codec.d.ts +7 -0
- package/dist/core/codec/extension-codec.js +145 -0
- package/dist/core/codec/index.d.ts +3 -0
- package/dist/core/codec/index.js +2 -0
- package/dist/core/codec/validation.d.ts +28 -0
- package/dist/core/codec/validation.js +139 -0
- package/dist/core/codec-helpers.d.ts +8 -0
- package/dist/core/codec-helpers.js +19 -0
- package/dist/core/codec.d.ts +1 -0
- package/dist/core/codec.js +1 -0
- package/dist/core/compression.d.ts +127 -0
- package/dist/core/compression.js +88 -0
- package/dist/core/concurrency-lock-record.d.ts +122 -0
- package/dist/core/concurrency-lock-record.js +53 -0
- package/dist/core/concurrency.d.ts +221 -0
- package/dist/core/concurrency.js +93 -0
- package/dist/core/constraint.d.ts +144 -0
- package/dist/core/constraint.js +3 -0
- package/dist/core/context/attributes.d.ts +7 -0
- package/dist/core/context/attributes.js +29 -0
- package/dist/core/context/child-workflow-pipe.d.ts +18 -0
- package/dist/core/context/child-workflow-pipe.js +111 -0
- package/dist/core/context/durable-operations.d.ts +29 -0
- package/dist/core/context/durable-operations.js +166 -0
- package/dist/core/context/index.d.ts +114 -0
- package/dist/core/context/index.js +224 -0
- package/dist/core/context/internals.d.ts +30 -0
- package/dist/core/context/internals.js +36 -0
- package/dist/core/context/operation-request.d.ts +160 -0
- package/dist/core/context/operation-request.js +0 -0
- package/dist/core/context/parallel-cache-entry.d.ts +91 -0
- package/dist/core/context/parallel-cache-entry.js +92 -0
- package/dist/core/context/parallel-operations.d.ts +9 -0
- package/dist/core/context/parallel-operations.js +202 -0
- package/dist/core/context/run-operation.d.ts +21 -0
- package/dist/core/context/run-operation.js +231 -0
- package/dist/core/context/saga.d.ts +4 -0
- package/dist/core/context/saga.js +65 -0
- package/dist/core/context/session-state.d.ts +22 -0
- package/dist/core/context/session-state.js +154 -0
- package/dist/core/context/speculate-operations.d.ts +4 -0
- package/dist/core/context/speculate-operations.js +14 -0
- package/dist/core/context/speculative-child.d.ts +6 -0
- package/dist/core/context/speculative-child.js +67 -0
- package/dist/core/context/state-namespace.d.ts +27 -0
- package/dist/core/context/state-namespace.js +138 -0
- package/dist/core/context/types.d.ts +181 -0
- package/dist/core/context/types.js +0 -0
- package/dist/core/context/updates.d.ts +46 -0
- package/dist/core/context/updates.js +21 -0
- package/dist/core/context/validation.d.ts +2 -0
- package/dist/core/context/validation.js +12 -0
- package/dist/core/context.d.ts +1 -0
- package/dist/core/context.js +1 -0
- package/dist/core/debug-output.d.ts +3 -0
- package/dist/core/debug-output.js +112 -0
- package/dist/core/effect-log/index.d.ts +194 -0
- package/dist/core/effect-log/index.js +104 -0
- package/dist/core/engine/activity-reconciliation.d.ts +108 -0
- package/dist/core/engine/activity-reconciliation.js +182 -0
- package/dist/core/engine/aggregate.d.ts +47 -0
- package/dist/core/engine/aggregate.js +132 -0
- package/dist/core/engine/anonymous-signal-sequence.d.ts +4 -0
- package/dist/core/engine/anonymous-signal-sequence.js +101 -0
- package/dist/core/engine/async-activity-completion.d.ts +141 -0
- package/dist/core/engine/async-activity-completion.js +131 -0
- package/dist/core/engine/attributes-tags.d.ts +31 -0
- package/dist/core/engine/attributes-tags.js +178 -0
- package/dist/core/engine/broadcast.d.ts +8 -0
- package/dist/core/engine/broadcast.js +26 -0
- package/dist/core/engine/bulk-operations-purge.d.ts +11 -0
- package/dist/core/engine/bulk-operations-purge.js +246 -0
- package/dist/core/engine/bulk-operations-shared.d.ts +28 -0
- package/dist/core/engine/bulk-operations-shared.js +198 -0
- package/dist/core/engine/bulk-operations.d.ts +21 -0
- package/dist/core/engine/bulk-operations.js +128 -0
- package/dist/core/engine/callback-creators-bundles.d.ts +25 -0
- package/dist/core/engine/callback-creators-bundles.js +154 -0
- package/dist/core/engine/callback-creators-core.d.ts +39 -0
- package/dist/core/engine/callback-creators-core.js +136 -0
- package/dist/core/engine/callback-creators-router-registry.d.ts +4 -0
- package/dist/core/engine/callback-creators-router-registry.js +9 -0
- package/dist/core/engine/callback-creators-router.d.ts +3 -0
- package/dist/core/engine/callback-creators-router.js +68 -0
- package/dist/core/engine/callback-creators-schedule.d.ts +13 -0
- package/dist/core/engine/callback-creators-schedule.js +65 -0
- package/dist/core/engine/callback-creators.d.ts +9 -0
- package/dist/core/engine/callback-creators.js +87 -0
- package/dist/core/engine/cancel-handlers.d.ts +6 -0
- package/dist/core/engine/cancel-handlers.js +32 -0
- package/dist/core/engine/checkpoint-commit-snapshots.d.ts +4 -0
- package/dist/core/engine/checkpoint-commit-snapshots.js +16 -0
- package/dist/core/engine/checkpoint-io.d.ts +34 -0
- package/dist/core/engine/checkpoint-io.js +183 -0
- package/dist/core/engine/checkpoint-reads.d.ts +22 -0
- package/dist/core/engine/checkpoint-reads.js +98 -0
- package/dist/core/engine/child-workflow.d.ts +20 -0
- package/dist/core/engine/child-workflow.js +72 -0
- package/dist/core/engine/completed-review-storage.d.ts +14 -0
- package/dist/core/engine/completed-review-storage.js +61 -0
- package/dist/core/engine/constraints.d.ts +24 -0
- package/dist/core/engine/constraints.js +57 -0
- package/dist/core/engine/construction.d.ts +60 -0
- package/dist/core/engine/construction.js +213 -0
- package/dist/core/engine/disposal.d.ts +9 -0
- package/dist/core/engine/disposal.js +58 -0
- package/dist/core/engine/engine-create-types.d.ts +70 -0
- package/dist/core/engine/engine-create-types.js +0 -0
- package/dist/core/engine/engine-internal-types.d.ts +59 -0
- package/dist/core/engine/engine-internal-types.js +0 -0
- package/dist/core/engine/engine-leak-warnings.d.ts +26 -0
- package/dist/core/engine/engine-leak-warnings.js +42 -0
- package/dist/core/engine/engine-runtime-helpers.d.ts +8 -0
- package/dist/core/engine/engine-runtime-helpers.js +52 -0
- package/dist/core/engine/engine-state-namespace.d.ts +20 -0
- package/dist/core/engine/engine-state-namespace.js +0 -0
- package/dist/core/engine/errors.d.ts +215 -0
- package/dist/core/engine/errors.js +90 -0
- package/dist/core/engine/event-log-compaction.d.ts +102 -0
- package/dist/core/engine/event-log-compaction.js +76 -0
- package/dist/core/engine/guards.d.ts +17 -0
- package/dist/core/engine/guards.js +43 -0
- package/dist/core/engine/handle-iteration.d.ts +2 -0
- package/dist/core/engine/handle-iteration.js +59 -0
- package/dist/core/engine/handle-result.d.ts +8 -0
- package/dist/core/engine/handle-result.js +74 -0
- package/dist/core/engine/handles.d.ts +137 -0
- package/dist/core/engine/handles.js +173 -0
- package/dist/core/engine/index.d.ts +311 -0
- package/dist/core/engine/index.js +595 -0
- package/dist/core/engine/inline-launch-queue.d.ts +17 -0
- package/dist/core/engine/inline-launch-queue.js +93 -0
- package/dist/core/engine/inline-parking.d.ts +26 -0
- package/dist/core/engine/inline-parking.js +86 -0
- package/dist/core/engine/internals.d.ts +167 -0
- package/dist/core/engine/internals.js +11 -0
- package/dist/core/engine/lifecycle/fork-helpers.d.ts +9 -0
- package/dist/core/engine/lifecycle/fork-helpers.js +66 -0
- package/dist/core/engine/lifecycle/persist.d.ts +22 -0
- package/dist/core/engine/lifecycle/persist.js +80 -0
- package/dist/core/engine/lifecycle/resume.d.ts +4 -0
- package/dist/core/engine/lifecycle/resume.js +136 -0
- package/dist/core/engine/lifecycle/shared.d.ts +79 -0
- package/dist/core/engine/lifecycle/shared.js +49 -0
- package/dist/core/engine/lifecycle/start-batch.d.ts +7 -0
- package/dist/core/engine/lifecycle/start-batch.js +70 -0
- package/dist/core/engine/lifecycle/start-exec.d.ts +5 -0
- package/dist/core/engine/lifecycle/start-exec.js +39 -0
- package/dist/core/engine/lifecycle/start.d.ts +13 -0
- package/dist/core/engine/lifecycle/start.js +163 -0
- package/dist/core/engine/lifecycle/transition.d.ts +8 -0
- package/dist/core/engine/lifecycle/transition.js +183 -0
- package/dist/core/engine/lifecycle.d.ts +8 -0
- package/dist/core/engine/lifecycle.js +40 -0
- package/dist/core/engine/list-candidate-resolution.d.ts +15 -0
- package/dist/core/engine/list-candidate-resolution.js +88 -0
- package/dist/core/engine/listing.d.ts +17 -0
- package/dist/core/engine/listing.js +186 -0
- package/dist/core/engine/operations-activity.d.ts +40 -0
- package/dist/core/engine/operations-activity.js +194 -0
- package/dist/core/engine/operations-coordination.d.ts +39 -0
- package/dist/core/engine/operations-coordination.js +162 -0
- package/dist/core/engine/operations-data.d.ts +23 -0
- package/dist/core/engine/operations-data.js +38 -0
- package/dist/core/engine/operations-router.d.ts +75 -0
- package/dist/core/engine/operations-router.js +90 -0
- package/dist/core/engine/operations-speculate.d.ts +16 -0
- package/dist/core/engine/operations-speculate.js +40 -0
- package/dist/core/engine/operations-state.d.ts +16 -0
- package/dist/core/engine/operations-state.js +27 -0
- package/dist/core/engine/operations-stream.d.ts +20 -0
- package/dist/core/engine/operations-stream.js +54 -0
- package/dist/core/engine/operations-time.d.ts +28 -0
- package/dist/core/engine/operations-time.js +167 -0
- package/dist/core/engine/parallel-dispatch.d.ts +92 -0
- package/dist/core/engine/parallel-dispatch.js +45 -0
- package/dist/core/engine/pending-updates.d.ts +18 -0
- package/dist/core/engine/pending-updates.js +109 -0
- package/dist/core/engine/persisted-data-version.d.ts +24 -0
- package/dist/core/engine/persisted-data-version.js +25 -0
- package/dist/core/engine/queries.d.ts +3 -0
- package/dist/core/engine/queries.js +17 -0
- package/dist/core/engine/registration.d.ts +6 -0
- package/dist/core/engine/registration.js +107 -0
- package/dist/core/engine/retention.d.ts +15 -0
- package/dist/core/engine/retention.js +76 -0
- package/dist/core/engine/review-list-entries.d.ts +6 -0
- package/dist/core/engine/review-list-entries.js +117 -0
- package/dist/core/engine/reviews.d.ts +34 -0
- package/dist/core/engine/reviews.js +242 -0
- package/dist/core/engine/schedule-occurrence.d.ts +35 -0
- package/dist/core/engine/schedule-occurrence.js +26 -0
- package/dist/core/engine/schedule-timer.d.ts +4 -0
- package/dist/core/engine/schedule-timer.js +77 -0
- package/dist/core/engine/schedules.d.ts +34 -0
- package/dist/core/engine/schedules.js +204 -0
- package/dist/core/engine/signals.d.ts +40 -0
- package/dist/core/engine/signals.js +185 -0
- package/dist/core/engine/speculative-execution-state.d.ts +8 -0
- package/dist/core/engine/speculative-execution-state.js +26 -0
- package/dist/core/engine/state-utilities.d.ts +62 -0
- package/dist/core/engine/state-utilities.js +306 -0
- package/dist/core/engine/storage-io.d.ts +21 -0
- package/dist/core/engine/storage-io.js +82 -0
- package/dist/core/engine/strategy-helpers.d.ts +27 -0
- package/dist/core/engine/strategy-helpers.js +47 -0
- package/dist/core/engine/stream-chunk-loading.d.ts +5 -0
- package/dist/core/engine/stream-chunk-loading.js +22 -0
- package/dist/core/engine/sub-operation.d.ts +24 -0
- package/dist/core/engine/sub-operation.js +78 -0
- package/dist/core/engine/termination/cleanup.d.ts +67 -0
- package/dist/core/engine/termination/cleanup.js +167 -0
- package/dist/core/engine/termination/complete.d.ts +13 -0
- package/dist/core/engine/termination/complete.js +249 -0
- package/dist/core/engine/termination.d.ts +7 -0
- package/dist/core/engine/termination.js +23 -0
- package/dist/core/engine/updates.d.ts +56 -0
- package/dist/core/engine/updates.js +230 -0
- package/dist/core/engine/validation/schedule.d.ts +38 -0
- package/dist/core/engine/validation/schedule.js +258 -0
- package/dist/core/engine/validation.d.ts +40 -0
- package/dist/core/engine/validation.js +144 -0
- package/dist/core/engine/workflow-feed.d.ts +82 -0
- package/dist/core/engine/workflow-feed.js +96 -0
- package/dist/core/engine/workflow-indexes.d.ts +103 -0
- package/dist/core/engine/workflow-indexes.js +93 -0
- package/dist/core/engine/workflow-state-stream.d.ts +9 -0
- package/dist/core/engine/workflow-state-stream.js +126 -0
- package/dist/core/engine/workflow-visibility-queries.d.ts +40 -0
- package/dist/core/engine/workflow-visibility-queries.js +56 -0
- package/dist/core/engine-helpers.d.ts +56 -0
- package/dist/core/engine-helpers.js +52 -0
- package/dist/core/engine.d.ts +1 -0
- package/dist/core/engine.js +1 -0
- package/dist/core/event-log-shared.d.ts +65 -0
- package/dist/core/event-log-shared.js +31 -0
- package/dist/core/event-log-verify.d.ts +51 -0
- package/dist/core/event-log-verify.js +64 -0
- package/dist/core/event-log.d.ts +112 -0
- package/dist/core/event-log.js +81 -0
- package/dist/core/events/activity-events.d.ts +104 -0
- package/dist/core/events/activity-events.js +63 -0
- package/dist/core/events/attribute-events.d.ts +22 -0
- package/dist/core/events/attribute-events.js +10 -0
- package/dist/core/events/event-map.d.ts +80 -0
- package/dist/core/events/event-map.js +0 -0
- package/dist/core/events/index.d.ts +7 -0
- package/dist/core/events/index.js +7 -0
- package/dist/core/events/signal-events.d.ts +45 -0
- package/dist/core/events/signal-events.js +23 -0
- package/dist/core/events/system-events.d.ts +149 -0
- package/dist/core/events/system-events.js +92 -0
- package/dist/core/events/update-events.d.ts +53 -0
- package/dist/core/events/update-events.js +31 -0
- package/dist/core/events/workflow-events.d.ts +198 -0
- package/dist/core/events/workflow-events.js +91 -0
- package/dist/core/events.d.ts +1 -0
- package/dist/core/events.js +1 -0
- package/dist/core/execution-strategy.d.ts +107 -0
- package/dist/core/execution-strategy.js +0 -0
- package/dist/core/failure-categories.d.ts +18 -0
- package/dist/core/failure-categories.js +70 -0
- package/dist/core/fault-code.d.ts +92 -0
- package/dist/core/fault-code.js +21 -0
- package/dist/core/inline-execution-strategy.d.ts +76 -0
- package/dist/core/inline-execution-strategy.js +264 -0
- package/dist/core/interceptor/activity-composition.d.ts +20 -0
- package/dist/core/interceptor/activity-composition.js +17 -0
- package/dist/core/interceptor/index.d.ts +25 -0
- package/dist/core/interceptor/index.js +8 -0
- package/dist/core/interceptor/interception-contexts.d.ts +200 -0
- package/dist/core/interceptor/interception-contexts.js +0 -0
- package/dist/core/interceptor/interceptor-interfaces.d.ts +149 -0
- package/dist/core/interceptor/interceptor-interfaces.js +9 -0
- package/dist/core/interceptor/split.d.ts +11 -0
- package/dist/core/interceptor/split.js +14 -0
- package/dist/core/interceptor/workflow-composition.d.ts +21 -0
- package/dist/core/interceptor/workflow-composition.js +116 -0
- package/dist/core/interceptor.d.ts +1 -0
- package/dist/core/interceptor.js +1 -0
- package/dist/core/json.d.ts +56 -0
- package/dist/core/json.js +77 -0
- package/dist/core/list-filter-validation.d.ts +78 -0
- package/dist/core/list-filter-validation.js +75 -0
- package/dist/core/payload-size.d.ts +78 -0
- package/dist/core/payload-size.js +27 -0
- package/dist/core/persisted-data-incompatible-error.d.ts +48 -0
- package/dist/core/persisted-data-incompatible-error.js +12 -0
- package/dist/core/registry-snapshot.d.ts +69 -0
- package/dist/core/registry-snapshot.js +70 -0
- package/dist/core/review/events.d.ts +73 -0
- package/dist/core/review/events.js +31 -0
- package/dist/core/review/index.d.ts +265 -0
- package/dist/core/review/index.js +96 -0
- package/dist/core/runtime-workflow-engine.d.ts +16 -0
- package/dist/core/runtime-workflow-engine.js +6 -0
- package/dist/core/schedule/cron-formatter.d.ts +10 -0
- package/dist/core/schedule/cron-formatter.js +103 -0
- package/dist/core/schedule/cron-occurrence.d.ts +3 -0
- package/dist/core/schedule/cron-occurrence.js +129 -0
- package/dist/core/schedule/cron-parser.d.ts +2 -0
- package/dist/core/schedule/cron-parser.js +93 -0
- package/dist/core/schedule/cron-types.d.ts +35 -0
- package/dist/core/schedule/cron-types.js +0 -0
- package/dist/core/schedule/index.d.ts +3 -0
- package/dist/core/schedule/index.js +2 -0
- package/dist/core/schedule/interval-occurrence.d.ts +31 -0
- package/dist/core/schedule/interval-occurrence.js +26 -0
- package/dist/core/schedule.d.ts +1 -0
- package/dist/core/schedule.js +1 -0
- package/dist/core/scheduler/duration.d.ts +44 -0
- package/dist/core/scheduler/duration.js +48 -0
- package/dist/core/scheduler/index.d.ts +4 -0
- package/dist/core/scheduler/index.js +3 -0
- package/dist/core/scheduler/scheduler-class.d.ts +52 -0
- package/dist/core/scheduler/scheduler-class.js +167 -0
- package/dist/core/scheduler/timer-batch.d.ts +10 -0
- package/dist/core/scheduler/timer-batch.js +42 -0
- package/dist/core/scheduler/timer-sources.d.ts +17 -0
- package/dist/core/scheduler/timer-sources.js +61 -0
- package/dist/core/scheduler.d.ts +1 -0
- package/dist/core/scheduler.js +1 -0
- package/dist/core/search-attributes.d.ts +67 -0
- package/dist/core/search-attributes.js +196 -0
- package/dist/core/session-state.d.ts +18 -0
- package/dist/core/session-state.js +71 -0
- package/dist/core/signal-id.d.ts +2 -0
- package/dist/core/signal-id.js +10 -0
- package/dist/core/start-workflow-validation.d.ts +14 -0
- package/dist/core/start-workflow-validation.js +63 -0
- package/dist/core/step-context.d.ts +97 -0
- package/dist/core/step-context.js +113 -0
- package/dist/core/timeouts.d.ts +98 -0
- package/dist/core/timeouts.js +38 -0
- package/dist/core/types/activity.d.ts +316 -0
- package/dist/core/types/activity.js +15 -0
- package/dist/core/types/archive-adapter.d.ts +49 -0
- package/dist/core/types/archive-adapter.js +0 -0
- package/dist/core/types/bulk.d.ts +312 -0
- package/dist/core/types/bulk.js +1 -0
- package/dist/core/types/checkpoint.d.ts +237 -0
- package/dist/core/types/checkpoint.js +12 -0
- package/dist/core/types/clone-plain.d.ts +17 -0
- package/dist/core/types/clone-plain.js +25 -0
- package/dist/core/types/constants.d.ts +54 -0
- package/dist/core/types/constants.js +1 -0
- package/dist/core/types/deep-freeze.d.ts +31 -0
- package/dist/core/types/deep-freeze.js +31 -0
- package/dist/core/types/definition-schema-to-json.d.ts +41 -0
- package/dist/core/types/definition-schema-to-json.js +56 -0
- package/dist/core/types/definition-schema.d.ts +341 -0
- package/dist/core/types/definition-schema.js +45 -0
- package/dist/core/types/history-policy.d.ts +92 -0
- package/dist/core/types/history-policy.js +1 -0
- package/dist/core/types/identity.d.ts +55 -0
- package/dist/core/types/identity.js +0 -0
- package/dist/core/types/message-handles.d.ts +229 -0
- package/dist/core/types/message-handles.js +36 -0
- package/dist/core/types/name-grammar.d.ts +30 -0
- package/dist/core/types/name-grammar.js +9 -0
- package/dist/core/types/options.d.ts +360 -0
- package/dist/core/types/options.js +0 -0
- package/dist/core/types/payload-size-policy.d.ts +47 -0
- package/dist/core/types/payload-size-policy.js +0 -0
- package/dist/core/types/registry-type-helpers.d.ts +1 -0
- package/dist/core/types/registry-type-helpers.js +0 -0
- package/dist/core/types/retry-retention.d.ts +163 -0
- package/dist/core/types/retry-retention.js +6 -0
- package/dist/core/types/reviews.d.ts +170 -0
- package/dist/core/types/reviews.js +0 -0
- package/dist/core/types/schedules.d.ts +176 -0
- package/dist/core/types/schedules.js +3 -0
- package/dist/core/types/search-attributes.d.ts +127 -0
- package/dist/core/types/search-attributes.js +8 -0
- package/dist/core/types/serializer.d.ts +30 -0
- package/dist/core/types/serializer.js +0 -0
- package/dist/core/types/standard-schema-validate.d.ts +113 -0
- package/dist/core/types/standard-schema-validate.js +60 -0
- package/dist/core/types/state.d.ts +261 -0
- package/dist/core/types/state.js +0 -0
- package/dist/core/types/workflow-builder-helpers.d.ts +310 -0
- package/dist/core/types/workflow-builder-helpers.js +0 -0
- package/dist/core/types/workflow-builder-runtime.d.ts +97 -0
- package/dist/core/types/workflow-builder-runtime.js +137 -0
- package/dist/core/types/workflow-builder.d.ts +343 -0
- package/dist/core/types/workflow-builder.js +0 -0
- package/dist/core/types/workflow-context.d.ts +168 -0
- package/dist/core/types/workflow-context.js +0 -0
- package/dist/core/types/workflow-definition.d.ts +61 -0
- package/dist/core/types/workflow-definition.js +0 -0
- package/dist/core/types/workflow-function.d.ts +330 -0
- package/dist/core/types/workflow-function.js +9 -0
- package/dist/core/types/workflow-registries.d.ts +203 -0
- package/dist/core/types/workflow-registries.js +0 -0
- package/dist/core/types/workflow-registry.d.ts +31 -0
- package/dist/core/types/workflow-registry.js +0 -0
- package/dist/core/types.d.ts +26 -0
- package/dist/core/types.js +26 -0
- package/dist/core/updates.d.ts +183 -0
- package/dist/core/updates.js +141 -0
- package/dist/core/versioning.d.ts +153 -0
- package/dist/core/versioning.js +94 -0
- package/dist/core/weft-error.d.ts +82 -0
- package/dist/core/weft-error.js +43 -0
- package/dist/core/worker-checkpoint-resume-state.d.ts +11 -0
- package/dist/core/worker-checkpoint-resume-state.js +40 -0
- package/dist/core/worker-execution-dispatcher.d.ts +42 -0
- package/dist/core/worker-execution-dispatcher.js +95 -0
- package/dist/core/worker-execution-ownership.d.ts +20 -0
- package/dist/core/worker-execution-ownership.js +91 -0
- package/dist/core/worker-execution-strategy-options.d.ts +7 -0
- package/dist/core/worker-execution-strategy-options.js +0 -0
- package/dist/core/worker-execution-strategy.d.ts +29 -0
- package/dist/core/worker-execution-strategy.js +356 -0
- package/dist/core/worker-listener-registry.d.ts +11 -0
- package/dist/core/worker-listener-registry.js +35 -0
- package/dist/core/worker-message-helpers.d.ts +5 -0
- package/dist/core/worker-message-helpers.js +14 -0
- package/dist/core/worker-protocol-guard.d.ts +20 -0
- package/dist/core/worker-protocol-guard.js +69 -0
- package/dist/core/worker-protocol.d.ts +27 -0
- package/dist/core/worker-protocol.js +346 -0
- package/dist/core/worker-turn-watchdog.d.ts +14 -0
- package/dist/core/worker-turn-watchdog.js +40 -0
- package/dist/core/workflow-identifiers.d.ts +1 -0
- package/dist/core/workflow-identifiers.js +19 -0
- package/dist/core/workflow-tags.d.ts +9 -0
- package/dist/core/workflow-tags.js +37 -0
- package/dist/core/workflow-version-tuple.d.ts +67 -0
- package/dist/core/workflow-version-tuple.js +77 -0
- package/dist/diagnostics/doctor.d.ts +30 -0
- package/dist/diagnostics/doctor.js +173 -0
- package/dist/diagnostics/format.d.ts +77 -0
- package/dist/diagnostics/format.js +115 -0
- package/dist/diagnostics/index.d.ts +15 -0
- package/dist/diagnostics/index.js +10 -0
- package/dist/diagnostics/memory-profiler.d.ts +136 -0
- package/dist/diagnostics/memory-profiler.js +93 -0
- package/dist/diagnostics/recommendations.d.ts +37 -0
- package/dist/diagnostics/recommendations.js +116 -0
- package/dist/diagnostics/types.d.ts +178 -0
- package/dist/diagnostics/types.js +9 -0
- package/dist/diagnostics/validate.d.ts +79 -0
- package/dist/diagnostics/validate.js +88 -0
- package/dist/diagnostics/version-check.d.ts +34 -0
- package/dist/diagnostics/version-check.js +61 -0
- package/dist/index.d.ts +109 -0
- package/dist/index.js +182 -0
- package/dist/json-schema.d.ts +55 -0
- package/dist/json-schema.js +4 -0
- package/dist/mcp/access.d.ts +21 -0
- package/dist/mcp/access.js +22 -0
- package/dist/mcp/cli.d.ts +2 -0
- package/dist/mcp/cli.js +72 -0
- package/dist/mcp/dispatcher.d.ts +13 -0
- package/dist/mcp/dispatcher.js +198 -0
- package/dist/mcp/http.d.ts +64 -0
- package/dist/mcp/http.js +272 -0
- package/dist/mcp/index.d.ts +17 -0
- package/dist/mcp/index.js +26 -0
- package/dist/mcp/list-filter.d.ts +10 -0
- package/dist/mcp/list-filter.js +116 -0
- package/dist/mcp/protocol.d.ts +89 -0
- package/dist/mcp/protocol.js +64 -0
- package/dist/mcp/resources.d.ts +40 -0
- package/dist/mcp/resources.js +141 -0
- package/dist/mcp/session.d.ts +138 -0
- package/dist/mcp/session.js +204 -0
- package/dist/mcp/stdio.d.ts +89 -0
- package/dist/mcp/stdio.js +204 -0
- package/dist/mcp/tools.d.ts +27 -0
- package/dist/mcp/tools.js +262 -0
- package/dist/observability/activity-interceptor.d.ts +3 -0
- package/dist/observability/activity-interceptor.js +34 -0
- package/dist/observability/index.d.ts +60 -0
- package/dist/observability/index.js +4 -0
- package/dist/observability/metrics-catalog.d.ts +128 -0
- package/dist/observability/metrics-catalog.js +110 -0
- package/dist/observability/metrics-snapshot.d.ts +106 -0
- package/dist/observability/metrics-snapshot.js +0 -0
- package/dist/observability/metrics.d.ts +156 -0
- package/dist/observability/metrics.js +152 -0
- package/dist/observability/no-op-telemetry.d.ts +168 -0
- package/dist/observability/no-op-telemetry.js +96 -0
- package/dist/observability/propagation.d.ts +121 -0
- package/dist/observability/propagation.js +41 -0
- package/dist/observability/span-helpers.d.ts +50 -0
- package/dist/observability/span-helpers.js +83 -0
- package/dist/observability/types.d.ts +92 -0
- package/dist/observability/types.js +0 -0
- package/dist/observability/workflow-interceptor.d.ts +3 -0
- package/dist/observability/workflow-interceptor.js +106 -0
- package/dist/observability/workflow-lifecycle.d.ts +8 -0
- package/dist/observability/workflow-lifecycle.js +103 -0
- package/dist/runtime/portable.d.ts +119 -0
- package/dist/runtime/portable.js +90 -0
- package/dist/server/api-catalog.d.ts +85 -0
- package/dist/server/api-catalog.js +47 -0
- package/dist/server/asyncapi-channels.d.ts +40 -0
- package/dist/server/asyncapi-channels.js +264 -0
- package/dist/server/asyncapi.d.ts +25 -0
- package/dist/server/asyncapi.js +110 -0
- package/dist/server/attribute-filters.d.ts +37 -0
- package/dist/server/attribute-filters.js +39 -0
- package/dist/server/authentication/api-key.d.ts +3 -0
- package/dist/server/authentication/api-key.js +80 -0
- package/dist/server/authentication/audit.d.ts +116 -0
- package/dist/server/authentication/audit.js +25 -0
- package/dist/server/authentication/crypto.d.ts +7 -0
- package/dist/server/authentication/crypto.js +99 -0
- package/dist/server/authentication/index.d.ts +68 -0
- package/dist/server/authentication/index.js +144 -0
- package/dist/server/authentication/rate-limiter.d.ts +126 -0
- package/dist/server/authentication/rate-limiter.js +61 -0
- package/dist/server/authentication/redaction.d.ts +72 -0
- package/dist/server/authentication/redaction.js +30 -0
- package/dist/server/authentication/rotating-api-key-store.d.ts +107 -0
- package/dist/server/authentication/rotating-api-key-store.js +43 -0
- package/dist/server/authentication/types.d.ts +290 -0
- package/dist/server/authentication/types.js +13 -0
- package/dist/server/authentication.d.ts +1 -0
- package/dist/server/authentication.js +1 -0
- package/dist/server/authorization-scope.d.ts +43 -0
- package/dist/server/authorization-scope.js +53 -0
- package/dist/server/authorization.d.ts +55 -0
- package/dist/server/authorization.js +87 -0
- package/dist/server/deadline-tracker.d.ts +47 -0
- package/dist/server/deadline-tracker.js +106 -0
- package/dist/server/discovery-filter.d.ts +13 -0
- package/dist/server/discovery-filter.js +5 -0
- package/dist/server/discovery-info.d.ts +69 -0
- package/dist/server/discovery-info.js +12 -0
- package/dist/server/engine-event-feed-backend.d.ts +31 -0
- package/dist/server/engine-event-feed-backend.js +36 -0
- package/dist/server/fault-to-http.d.ts +14 -0
- package/dist/server/fault-to-http.js +29 -0
- package/dist/server/fault-to-json-rpc.d.ts +23 -0
- package/dist/server/fault-to-json-rpc.js +60 -0
- package/dist/server/handler/binding-dispatch.d.ts +11 -0
- package/dist/server/handler/binding-dispatch.js +13 -0
- package/dist/server/handler/index.d.ts +31 -0
- package/dist/server/handler/index.js +78 -0
- package/dist/server/handler/response-helpers.d.ts +5 -0
- package/dist/server/handler/response-helpers.js +28 -0
- package/dist/server/handler/route-dispatch.d.ts +144 -0
- package/dist/server/handler/route-dispatch.js +192 -0
- package/dist/server/handler/route-matching.d.ts +55 -0
- package/dist/server/handler/route-matching.js +45 -0
- package/dist/server/handler.d.ts +1 -0
- package/dist/server/handler.js +56 -0
- package/dist/server/index.d.ts +346 -0
- package/dist/server/index.js +64 -0
- package/dist/server/interactive-operations.d.ts +18 -0
- package/dist/server/interactive-operations.js +28 -0
- package/dist/server/json-rpc-dispatch.d.ts +49 -0
- package/dist/server/json-rpc-dispatch.js +92 -0
- package/dist/server/json-rpc-framing.d.ts +42 -0
- package/dist/server/json-rpc-framing.js +15 -0
- package/dist/server/json-rpc-http.d.ts +33 -0
- package/dist/server/json-rpc-http.js +112 -0
- package/dist/server/json-rpc-parse.d.ts +69 -0
- package/dist/server/json-rpc-parse.js +139 -0
- package/dist/server/json-rpc-protocol.d.ts +76 -0
- package/dist/server/json-rpc-protocol.js +27 -0
- package/dist/server/json-rpc-transport-helpers.d.ts +17 -0
- package/dist/server/json-rpc-transport-helpers.js +26 -0
- package/dist/server/json-rpc-websocket-runtime.d.ts +37 -0
- package/dist/server/json-rpc-websocket-runtime.js +51 -0
- package/dist/server/json-rpc-websocket-validation.d.ts +38 -0
- package/dist/server/json-rpc-websocket-validation.js +96 -0
- package/dist/server/json-rpc-websocket.d.ts +60 -0
- package/dist/server/json-rpc-websocket.js +268 -0
- package/dist/server/json-schema-utilities.d.ts +4 -0
- package/dist/server/json-schema-utilities.js +16 -0
- package/dist/server/mcp-discovery.d.ts +57 -0
- package/dist/server/mcp-discovery.js +50 -0
- package/dist/server/openapi-canonical-json.d.ts +10 -0
- package/dist/server/openapi-canonical-json.js +13 -0
- package/dist/server/openapi-error-responses.d.ts +15 -0
- package/dist/server/openapi-error-responses.js +36 -0
- package/dist/server/openapi-schemas.d.ts +17 -0
- package/dist/server/openapi-schemas.js +69 -0
- package/dist/server/openapi.d.ts +48 -0
- package/dist/server/openapi.js +290 -0
- package/dist/server/openrpc-document-schema.d.ts +112 -0
- package/dist/server/openrpc-document-schema.js +65 -0
- package/dist/server/openrpc-errors.d.ts +73 -0
- package/dist/server/openrpc-errors.js +57 -0
- package/dist/server/openrpc.d.ts +53 -0
- package/dist/server/openrpc.js +179 -0
- package/dist/server/operation-catalog/activity-adapter.d.ts +11 -0
- package/dist/server/operation-catalog/activity-adapter.js +9 -0
- package/dist/server/operation-catalog/dispatch-allowlist.d.ts +4 -0
- package/dist/server/operation-catalog/dispatch-allowlist.js +4 -0
- package/dist/server/operation-catalog/dispatch-preparation.d.ts +39 -0
- package/dist/server/operation-catalog/dispatch-preparation.js +52 -0
- package/dist/server/operation-catalog/index.d.ts +22 -0
- package/dist/server/operation-catalog/index.js +17 -0
- package/dist/server/operation-catalog/pipeline-helpers.d.ts +66 -0
- package/dist/server/operation-catalog/pipeline-helpers.js +179 -0
- package/dist/server/operation-catalog/pipeline-stages.d.ts +23 -0
- package/dist/server/operation-catalog/pipeline-stages.js +189 -0
- package/dist/server/operation-catalog/pipeline.d.ts +7 -0
- package/dist/server/operation-catalog/pipeline.js +32 -0
- package/dist/server/operation-catalog/raise-fault.d.ts +32 -0
- package/dist/server/operation-catalog/raise-fault.js +18 -0
- package/dist/server/operation-catalog/registry.d.ts +6 -0
- package/dist/server/operation-catalog/registry.js +93 -0
- package/dist/server/operation-catalog/stream-pipeline.d.ts +25 -0
- package/dist/server/operation-catalog/stream-pipeline.js +122 -0
- package/dist/server/operation-catalog/types.d.ts +246 -0
- package/dist/server/operation-catalog/types.js +9 -0
- package/dist/server/operation-catalog/workflow-adapter.d.ts +55 -0
- package/dist/server/operation-catalog/workflow-adapter.js +85 -0
- package/dist/server/operation-catalog.d.ts +1 -0
- package/dist/server/operation-catalog.js +1 -0
- package/dist/server/operation-fault.d.ts +153 -0
- package/dist/server/operation-fault.js +50 -0
- package/dist/server/operation-registry.d.ts +100 -0
- package/dist/server/operation-registry.js +56 -0
- package/dist/server/operations/add-workflow-tags.d.ts +15 -0
- package/dist/server/operations/add-workflow-tags.js +13 -0
- package/dist/server/operations/aggregate-workflows.d.ts +81 -0
- package/dist/server/operations/aggregate-workflows.js +110 -0
- package/dist/server/operations/async-activity.d.ts +44 -0
- package/dist/server/operations/async-activity.js +134 -0
- package/dist/server/operations/bulk-cancel-workflows.d.ts +7 -0
- package/dist/server/operations/bulk-cancel-workflows.js +64 -0
- package/dist/server/operations/bulk-delete-workflows.d.ts +7 -0
- package/dist/server/operations/bulk-delete-workflows.js +71 -0
- package/dist/server/operations/bulk-filter-helpers.d.ts +62 -0
- package/dist/server/operations/bulk-filter-helpers.js +334 -0
- package/dist/server/operations/bulk-mutate-workflow-tags.d.ts +94 -0
- package/dist/server/operations/bulk-mutate-workflow-tags.js +100 -0
- package/dist/server/operations/bulk-operation-helpers.d.ts +27 -0
- package/dist/server/operations/bulk-operation-helpers.js +29 -0
- package/dist/server/operations/bulk-signal-workflows.d.ts +87 -0
- package/dist/server/operations/bulk-signal-workflows.js +80 -0
- package/dist/server/operations/cancel-schedule.d.ts +13 -0
- package/dist/server/operations/cancel-schedule.js +43 -0
- package/dist/server/operations/cancel-workflow.d.ts +13 -0
- package/dist/server/operations/cancel-workflow.js +34 -0
- package/dist/server/operations/create-schedule.d.ts +29 -0
- package/dist/server/operations/create-schedule.js +116 -0
- package/dist/server/operations/failure-category-filter.d.ts +2 -0
- package/dist/server/operations/failure-category-filter.js +19 -0
- package/dist/server/operations/fork-workflow.d.ts +29 -0
- package/dist/server/operations/fork-workflow.js +88 -0
- package/dist/server/operations/get-checkpoint-at.d.ts +15 -0
- package/dist/server/operations/get-checkpoint-at.js +74 -0
- package/dist/server/operations/get-registry.d.ts +26 -0
- package/dist/server/operations/get-registry.js +56 -0
- package/dist/server/operations/get-retention-overview.d.ts +9 -0
- package/dist/server/operations/get-retention-overview.js +39 -0
- package/dist/server/operations/get-review.d.ts +15 -0
- package/dist/server/operations/get-review.js +57 -0
- package/dist/server/operations/get-schedule.d.ts +20 -0
- package/dist/server/operations/get-schedule.js +48 -0
- package/dist/server/operations/get-stream-chunks.d.ts +19 -0
- package/dist/server/operations/get-stream-chunks.js +71 -0
- package/dist/server/operations/get-system-metrics.d.ts +42 -0
- package/dist/server/operations/get-system-metrics.js +43 -0
- package/dist/server/operations/get-task-diagnostics.d.ts +184 -0
- package/dist/server/operations/get-task-diagnostics.js +340 -0
- package/dist/server/operations/get-update-result.d.ts +18 -0
- package/dist/server/operations/get-update-result.js +55 -0
- package/dist/server/operations/get-workflow-attributes.d.ts +13 -0
- package/dist/server/operations/get-workflow-attributes.js +51 -0
- package/dist/server/operations/get-workflow-events.d.ts +15 -0
- package/dist/server/operations/get-workflow-events.js +51 -0
- package/dist/server/operations/get-workflow-result.d.ts +14 -0
- package/dist/server/operations/get-workflow-result.js +93 -0
- package/dist/server/operations/get-workflow-timeline.d.ts +13 -0
- package/dist/server/operations/get-workflow-timeline.js +51 -0
- package/dist/server/operations/get-workflow.d.ts +36 -0
- package/dist/server/operations/get-workflow.js +49 -0
- package/dist/server/operations/list-checkpoints.d.ts +13 -0
- package/dist/server/operations/list-checkpoints.js +43 -0
- package/dist/server/operations/list-filter-query-extractor.d.ts +23 -0
- package/dist/server/operations/list-filter-query-extractor.js +87 -0
- package/dist/server/operations/list-reviews.d.ts +19 -0
- package/dist/server/operations/list-reviews.js +77 -0
- package/dist/server/operations/list-schedules.d.ts +28 -0
- package/dist/server/operations/list-schedules.js +108 -0
- package/dist/server/operations/list-task-queues.d.ts +71 -0
- package/dist/server/operations/list-task-queues.js +105 -0
- package/dist/server/operations/list-workers.d.ts +56 -0
- package/dist/server/operations/list-workers.js +92 -0
- package/dist/server/operations/list-workflows.d.ts +79 -0
- package/dist/server/operations/list-workflows.js +136 -0
- package/dist/server/operations/operation-helpers.d.ts +21 -0
- package/dist/server/operations/operation-helpers.js +22 -0
- package/dist/server/operations/pause-schedule.d.ts +13 -0
- package/dist/server/operations/pause-schedule.js +43 -0
- package/dist/server/operations/purge-workflows.d.ts +41 -0
- package/dist/server/operations/purge-workflows.js +57 -0
- package/dist/server/operations/query-workflow.d.ts +19 -0
- package/dist/server/operations/query-workflow.js +99 -0
- package/dist/server/operations/recover-all.d.ts +13 -0
- package/dist/server/operations/recover-all.js +65 -0
- package/dist/server/operations/remove-workflow-tags.d.ts +15 -0
- package/dist/server/operations/remove-workflow-tags.js +13 -0
- package/dist/server/operations/replay-workflow.d.ts +28 -0
- package/dist/server/operations/replay-workflow.js +69 -0
- package/dist/server/operations/resume-schedule.d.ts +13 -0
- package/dist/server/operations/resume-schedule.js +43 -0
- package/dist/server/operations/resume-workflow.d.ts +17 -0
- package/dist/server/operations/resume-workflow.js +40 -0
- package/dist/server/operations/schedule-faults.d.ts +14 -0
- package/dist/server/operations/schedule-faults.js +41 -0
- package/dist/server/operations/set-workflow-attributes.d.ts +19 -0
- package/dist/server/operations/set-workflow-attributes.js +67 -0
- package/dist/server/operations/signal-workflow.d.ts +23 -0
- package/dist/server/operations/signal-workflow.js +58 -0
- package/dist/server/operations/single-workflow-control-operation.d.ts +32 -0
- package/dist/server/operations/single-workflow-control-operation.js +44 -0
- package/dist/server/operations/single-workflow-tag-mutation.d.ts +27 -0
- package/dist/server/operations/single-workflow-tag-mutation.js +108 -0
- package/dist/server/operations/sse-stream.d.ts +13 -0
- package/dist/server/operations/sse-stream.js +42 -0
- package/dist/server/operations/start-workflow.d.ts +33 -0
- package/dist/server/operations/start-workflow.js +181 -0
- package/dist/server/operations/storage.d.ts +112 -0
- package/dist/server/operations/storage.js +358 -0
- package/dist/server/operations/stream-workflow-sse.d.ts +17 -0
- package/dist/server/operations/stream-workflow-sse.js +94 -0
- package/dist/server/operations/submit-review-decision.d.ts +25 -0
- package/dist/server/operations/submit-review-decision.js +113 -0
- package/dist/server/operations/timeout-workflow.d.ts +11 -0
- package/dist/server/operations/timeout-workflow.js +34 -0
- package/dist/server/operations/update-schedule.d.ts +15 -0
- package/dist/server/operations/update-schedule.js +60 -0
- package/dist/server/operations/update-workflow.d.ts +27 -0
- package/dist/server/operations/update-workflow.js +109 -0
- package/dist/server/operations/worker-drain.d.ts +69 -0
- package/dist/server/operations/worker-drain.js +214 -0
- package/dist/server/operations/workflow-events-subscription.d.ts +47 -0
- package/dist/server/operations/workflow-events-subscription.js +51 -0
- package/dist/server/principal.d.ts +176 -0
- package/dist/server/principal.js +59 -0
- package/dist/server/rest-binding.d.ts +158 -0
- package/dist/server/rest-binding.js +35 -0
- package/dist/server/rest-bindings.d.ts +76 -0
- package/dist/server/rest-bindings.js +376 -0
- package/dist/server/route-model.d.ts +268 -0
- package/dist/server/route-model.js +166 -0
- package/dist/server/runtime/authentication-bridge.d.ts +22 -0
- package/dist/server/runtime/authentication-bridge.js +194 -0
- package/dist/server/runtime/context.d.ts +73 -0
- package/dist/server/runtime/context.js +0 -0
- package/dist/server/runtime/cors.d.ts +149 -0
- package/dist/server/runtime/cors.js +123 -0
- package/dist/server/runtime/event-broadcasting.d.ts +71 -0
- package/dist/server/runtime/event-broadcasting.js +205 -0
- package/dist/server/runtime/request-gate.d.ts +54 -0
- package/dist/server/runtime/request-gate.js +71 -0
- package/dist/server/runtime/shutdown.d.ts +10 -0
- package/dist/server/runtime/shutdown.js +18 -0
- package/dist/server/runtime/stop-server.d.ts +3 -0
- package/dist/server/runtime/stop-server.js +19 -0
- package/dist/server/runtime/task-dispatch.d.ts +8 -0
- package/dist/server/runtime/task-dispatch.js +157 -0
- package/dist/server/runtime/task-metrics.d.ts +12 -0
- package/dist/server/runtime/task-metrics.js +36 -0
- package/dist/server/runtime/task-polling.d.ts +9 -0
- package/dist/server/runtime/task-polling.js +132 -0
- package/dist/server/runtime/task-reconciliation.d.ts +17 -0
- package/dist/server/runtime/task-reconciliation.js +163 -0
- package/dist/server/runtime/websocket-stream.d.ts +15 -0
- package/dist/server/runtime/websocket-stream.js +79 -0
- package/dist/server/runtime/websocket-upgrade.d.ts +8 -0
- package/dist/server/runtime/websocket-upgrade.js +76 -0
- package/dist/server/runtime/websocket-worker.d.ts +7 -0
- package/dist/server/runtime/websocket-worker.js +224 -0
- package/dist/server/runtime-helpers.d.ts +18 -0
- package/dist/server/runtime-helpers.js +23 -0
- package/dist/server/sequence-cursor.d.ts +5 -0
- package/dist/server/sequence-cursor.js +19 -0
- package/dist/server/serve-internals.d.ts +83 -0
- package/dist/server/serve-internals.js +203 -0
- package/dist/server/stdio-session.d.ts +51 -0
- package/dist/server/stdio-session.js +245 -0
- package/dist/server/task-queue-summary.d.ts +27 -0
- package/dist/server/task-queue-summary.js +34 -0
- package/dist/server/task-queue-types.d.ts +95 -0
- package/dist/server/task-queue-types.js +0 -0
- package/dist/server/task-queue.d.ts +90 -0
- package/dist/server/task-queue.js +247 -0
- package/dist/server/task-resolved-record.d.ts +12 -0
- package/dist/server/task-resolved-record.js +35 -0
- package/dist/server/task-state.d.ts +152 -0
- package/dist/server/task-state.js +178 -0
- package/dist/server/workflow-event-feed.d.ts +166 -0
- package/dist/server/workflow-event-feed.js +193 -0
- package/dist/service-worker/index.d.ts +123 -0
- package/dist/service-worker/index.js +56 -0
- package/dist/service-worker/scheduler.d.ts +37 -0
- package/dist/service-worker/scheduler.js +117 -0
- package/dist/service-worker/setup.d.ts +127 -0
- package/dist/service-worker/setup.js +129 -0
- package/dist/service-worker/shared.d.ts +94 -0
- package/dist/service-worker/shared.js +15 -0
- package/dist/storage/auto.d.ts +45 -0
- package/dist/storage/auto.js +2 -0
- package/dist/storage/bun-sql.d.ts +64 -0
- package/dist/storage/bun-sql.js +575 -0
- package/dist/storage/byte-encoding.d.ts +6 -0
- package/dist/storage/byte-encoding.js +16 -0
- package/dist/storage/capabilities.d.ts +187 -0
- package/dist/storage/capabilities.js +19 -0
- package/dist/storage/compressed-storage.d.ts +45 -0
- package/dist/storage/compressed-storage.js +2 -0
- package/dist/storage/default-scope.d.ts +17 -0
- package/dist/storage/default-scope.js +1 -0
- package/dist/storage/delete-range.d.ts +109 -0
- package/dist/storage/delete-range.js +64 -0
- package/dist/storage/derived-operations.d.ts +53 -0
- package/dist/storage/derived-operations.js +31 -0
- package/dist/storage/http.d.ts +67 -0
- package/dist/storage/http.js +2 -0
- package/dist/storage/index.d.ts +292 -0
- package/dist/storage/index.js +51 -0
- package/dist/storage/indexeddb.d.ts +49 -0
- package/dist/storage/indexeddb.js +1 -0
- package/dist/storage/interface.d.ts +340 -0
- package/dist/storage/interface.js +2 -0
- package/dist/storage/key-prefixes.d.ts +19 -0
- package/dist/storage/key-prefixes.js +35 -0
- package/dist/storage/lmdb.d.ts +40 -0
- package/dist/storage/lmdb.js +2 -0
- package/dist/storage/memory.d.ts +46 -0
- package/dist/storage/memory.js +2 -0
- package/dist/storage/node-sqlite.d.ts +85 -0
- package/dist/storage/node-sqlite.js +323 -0
- package/dist/storage/read-only-query.d.ts +2 -0
- package/dist/storage/read-only-query.js +19 -0
- package/dist/storage/resolve.d.ts +180 -0
- package/dist/storage/resolve.js +2 -0
- package/dist/storage/scoped-storage.d.ts +68 -0
- package/dist/storage/scoped-storage.js +2 -0
- package/dist/storage/sqlite-key-value-queries.d.ts +40 -0
- package/dist/storage/sqlite-key-value-queries.js +64 -0
- package/dist/storage/sqlite.d.ts +31 -0
- package/dist/storage/sqlite.js +0 -0
- package/dist/storage/text-value-import.d.ts +87 -0
- package/dist/storage/text-value-import.js +50 -0
- package/dist/storage/text-value-store.d.ts +171 -0
- package/dist/storage/text-value-store.js +55 -0
- package/dist/storage/turso.d.ts +60 -0
- package/dist/storage/turso.js +5 -0
- package/dist/storage/typed-storage.d.ts +258 -0
- package/dist/storage/typed-storage.js +2 -0
- package/dist/storage/web-extension.d.ts +55 -0
- package/dist/storage/web-extension.js +1 -0
- package/dist/testing/chaos.d.ts +157 -0
- package/dist/testing/chaos.js +69 -0
- package/dist/testing/event-loop.d.ts +4 -0
- package/dist/testing/event-loop.js +21 -0
- package/dist/testing/index.d.ts +126 -0
- package/dist/testing/index.js +61 -0
- package/dist/testing/mocks.d.ts +145 -0
- package/dist/testing/mocks.js +136 -0
- package/dist/testing/subprocess-engine.d.ts +100 -0
- package/dist/testing/subprocess-engine.js +291 -0
- package/dist/testing/test-engine.d.ts +145 -0
- package/dist/testing/test-engine.js +147 -0
- package/dist/testing/time-control.d.ts +59 -0
- package/dist/testing/time-control.js +68 -0
- package/dist/version.d.ts +12 -0
- package/dist/version.js +1 -0
- package/dist/worker/activity-table.d.ts +33 -0
- package/dist/worker/activity-table.js +20 -0
- package/dist/worker/execute-with-interceptors.d.ts +28 -0
- package/dist/worker/execute-with-interceptors.js +21 -0
- package/dist/worker/heartbeat.d.ts +34 -0
- package/dist/worker/heartbeat.js +31 -0
- package/dist/worker/index.d.ts +57 -0
- package/dist/worker/index.js +334 -0
- package/dist/worker/long-poll.d.ts +54 -0
- package/dist/worker/long-poll.js +134 -0
- package/dist/worker/options.d.ts +66 -0
- package/dist/worker/options.js +19 -0
- package/dist/worker/protocol-internals.d.ts +82 -0
- package/dist/worker/protocol-internals.js +56 -0
- package/dist/worker/protocol-messages.d.ts +264 -0
- package/dist/worker/protocol-messages.js +0 -0
- package/dist/worker/protocol-schemas.d.ts +559 -0
- package/dist/worker/protocol-schemas.js +180 -0
- package/dist/worker/protocol-version.d.ts +71 -0
- package/dist/worker/protocol-version.js +1 -0
- package/dist/worker/protocol.d.ts +72 -0
- package/dist/worker/protocol.js +2 -0
- package/dist/worker/registry/fair-share.d.ts +59 -0
- package/dist/worker/registry/fair-share.js +15 -0
- package/dist/worker/registry/routing.d.ts +17 -0
- package/dist/worker/registry/routing.js +16 -0
- package/dist/worker/registry/summary.d.ts +87 -0
- package/dist/worker/registry/summary.js +81 -0
- package/dist/worker/registry/types.d.ts +123 -0
- package/dist/worker/registry/types.js +0 -0
- package/dist/worker/registry.d.ts +94 -0
- package/dist/worker/registry.js +305 -0
- package/dist/worker/remote-activity-context.d.ts +15 -0
- package/dist/worker/remote-activity-context.js +0 -0
- package/dist/worker/task-result-outbox.d.ts +40 -0
- package/dist/worker/task-result-outbox.js +42 -0
- package/dist/worker/worker-protocol-incompatible-error.d.ts +52 -0
- package/dist/worker/worker-protocol-incompatible-error.js +15 -0
- package/dist/worker/workflow-activity-binding.d.ts +96 -0
- package/dist/worker/workflow-activity-binding.js +22 -0
- package/dist/workers/activity-runner.d.ts +87 -0
- package/dist/workers/activity-runner.js +29 -0
- package/dist/workers/activity-worker-dispatcher.d.ts +85 -0
- package/dist/workers/activity-worker-dispatcher.js +68 -0
- package/dist/workers/activity-worker-entry.d.ts +99 -0
- package/dist/workers/activity-worker-entry.js +59 -0
- package/dist/workers/pool.d.ts +83 -0
- package/dist/workers/pool.js +174 -0
- package/dist/workers/workflow-runner.d.ts +79 -0
- package/dist/workers/workflow-runner.js +245 -0
- package/dist/workers/workflow-worker-entry.d.ts +24 -0
- package/dist/workers/workflow-worker-entry.js +70 -0
- package/package.json +297 -0
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { decode } from "../../core/codec.js";
|
|
2
|
+
import { ActivityFailedEvent } from "../../core/events.js";
|
|
3
|
+
import { calculateBackoff } from "../../core/scheduler.js";
|
|
4
|
+
import { KEYS } from "../../storage/interface.js";
|
|
5
|
+
import { restoreExtendedDeadlineIfStillActive } from "../runtime-helpers.js";
|
|
6
|
+
import { transitionInflightToQueued, transitionInflightToResolved } from "../task-state.js";
|
|
7
|
+
import { dispatchTaskImpl, scheduleDelayedDispatch } from "./task-dispatch.js";
|
|
8
|
+
import {
|
|
9
|
+
isTaskHeartbeatStaleForMetrics,
|
|
10
|
+
recordTaskRequeueMetric,
|
|
11
|
+
recordTaskRetryMetric,
|
|
12
|
+
recordTaskStaleHeartbeatMetric,
|
|
13
|
+
recordWorkerCapacitySaturationMetric
|
|
14
|
+
} from "./task-metrics.js";
|
|
15
|
+
import { isInflightRecord } from "./websocket-worker.js";
|
|
16
|
+
export async function reassignOrExpireTask(context, options, operationId, record, reason = "visibility-timeout") {
|
|
17
|
+
const nextAttempt = (record.attempt ?? 1) + 1, policy = record.retryPolicy, nextRetryCount = Math.max(record.retryCount ?? 0, nextAttempt - 1);
|
|
18
|
+
if (hasExceededMaxAttempts(policy, nextAttempt)) {
|
|
19
|
+
await expireTaskAfterMaxAttempts(context, options, operationId, record, policy);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const queuedRecord = createRequeuedRecord(record, nextAttempt, nextRetryCount, reason);
|
|
23
|
+
await transitionInflightToQueued(options.engine.storage, operationId, queuedRecord);
|
|
24
|
+
recordTaskRetryMetric(context.metricsCollector);
|
|
25
|
+
recordTaskRequeueMetric(context.metricsCollector);
|
|
26
|
+
recordWorkerCapacitySaturationMetric(context.metricsCollector, context.registry);
|
|
27
|
+
scheduleTaskRedispatch(context, options, createRequeuedTaskDispatch(record, nextAttempt), policy);
|
|
28
|
+
}
|
|
29
|
+
function hasExceededMaxAttempts(policy, nextAttempt) {
|
|
30
|
+
return policy !== void 0 && nextAttempt > policy.maxAttempts;
|
|
31
|
+
}
|
|
32
|
+
async function expireTaskAfterMaxAttempts(context, options, operationId, record, policy) {
|
|
33
|
+
await transitionInflightToResolved(options.engine.storage, operationId, "failed", {
|
|
34
|
+
record,
|
|
35
|
+
resolutionReason: "max-attempts-exceeded"
|
|
36
|
+
});
|
|
37
|
+
recordWorkerCapacitySaturationMetric(context.metricsCollector, context.registry);
|
|
38
|
+
options.engine.dispatchEvent(new ActivityFailedEvent(record.operationId, record.workflowId ?? "", record.activityName, Error(`Activity "${record.activityName}" exhausted all ${policy.maxAttempts} retry attempts`), record.attempt ?? 1));
|
|
39
|
+
}
|
|
40
|
+
function createRequeuedRecord(record, nextAttempt, nextRetryCount, reason) {
|
|
41
|
+
return {
|
|
42
|
+
operationId: record.operationId,
|
|
43
|
+
activityName: record.activityName,
|
|
44
|
+
input: record.input,
|
|
45
|
+
queue: record.queue,
|
|
46
|
+
attempt: nextAttempt,
|
|
47
|
+
visibilityTimeout: record.visibilityTimeout,
|
|
48
|
+
retryPolicy: record.retryPolicy,
|
|
49
|
+
queuedAt: Date.now(),
|
|
50
|
+
workflowId: record.workflowId,
|
|
51
|
+
firstQueuedAt: record.firstQueuedAt,
|
|
52
|
+
lastDispatchedAt: record.lastDispatchedAt,
|
|
53
|
+
startedAt: record.startedAt,
|
|
54
|
+
retryCount: nextRetryCount,
|
|
55
|
+
requeueCount: (record.requeueCount ?? 0) + 1,
|
|
56
|
+
lastRequeueReason: reason
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
function createRequeuedTaskDispatch(record, nextAttempt) {
|
|
60
|
+
const taskDispatch = {
|
|
61
|
+
operationId: record.operationId,
|
|
62
|
+
activityName: record.activityName,
|
|
63
|
+
input: record.input,
|
|
64
|
+
queue: record.queue,
|
|
65
|
+
attempt: nextAttempt,
|
|
66
|
+
visibilityTimeout: record.visibilityTimeout,
|
|
67
|
+
workflowId: record.workflowId
|
|
68
|
+
};
|
|
69
|
+
if (record.retryPolicy !== void 0)
|
|
70
|
+
taskDispatch.retryPolicy = record.retryPolicy;
|
|
71
|
+
return taskDispatch;
|
|
72
|
+
}
|
|
73
|
+
function scheduleTaskRedispatch(context, options, taskDispatch, policy) {
|
|
74
|
+
if (policy) {
|
|
75
|
+
const delay = calculateBackoff((taskDispatch.attempt ?? 1) - 1, policy);
|
|
76
|
+
scheduleDelayedDispatch(context, options, taskDispatch, delay);
|
|
77
|
+
} else
|
|
78
|
+
dispatchTaskImpl(context, options, taskDispatch).catch((err) => console.error(`[weft] Redispatch failed for "${taskDispatch.operationId}":`, err));
|
|
79
|
+
}
|
|
80
|
+
export async function scanExpiredTasks(context, options, cleanupWorkflowIndex) {
|
|
81
|
+
if (context.scanRunning)
|
|
82
|
+
return;
|
|
83
|
+
context.scanRunning = !0;
|
|
84
|
+
try {
|
|
85
|
+
const now = Date.now(), expired = context.deadlineTracker.drainExpired(now);
|
|
86
|
+
for (const { operationId, deadline } of expired) {
|
|
87
|
+
if (context.processingOperations.has(operationId)) {
|
|
88
|
+
context.deadlineTracker.add({ operationId, deadline });
|
|
89
|
+
continue;
|
|
90
|
+
}
|
|
91
|
+
context.processingOperations.add(operationId);
|
|
92
|
+
try {
|
|
93
|
+
const inflightKey = KEYS.operationInflight(operationId), existing = await options.engine.storage.get(inflightKey);
|
|
94
|
+
if (!existing)
|
|
95
|
+
continue;
|
|
96
|
+
const decoded = decode(existing);
|
|
97
|
+
if (!isInflightRecord(decoded)) {
|
|
98
|
+
console.error(`[weft] Corrupt inflight record for task "${operationId}" \u2014 skipping`);
|
|
99
|
+
continue;
|
|
100
|
+
}
|
|
101
|
+
if (restoreExtendedDeadlineIfStillActive(context.deadlineTracker, operationId, decoded.deadline, now))
|
|
102
|
+
continue;
|
|
103
|
+
context.registry.completeTask(decoded.operationId);
|
|
104
|
+
cleanupWorkflowIndex(decoded.operationId);
|
|
105
|
+
await reassignOrExpireTask(context, options, decoded.operationId, decoded);
|
|
106
|
+
} catch (error) {
|
|
107
|
+
context.deadlineTracker.add({ operationId, deadline });
|
|
108
|
+
console.error(`[weft] Failed to process expired task "${operationId}" \u2014 will retry:`, error);
|
|
109
|
+
} finally {
|
|
110
|
+
context.processingOperations.delete(operationId);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
} catch (error) {
|
|
114
|
+
console.error("[weft] Visibility timeout scanner error:", error);
|
|
115
|
+
} finally {
|
|
116
|
+
context.scanRunning = !1;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
export async function reconcileOrphanedRecords(context, options, cleanupWorkflowIndex) {
|
|
120
|
+
if (context.reconciliationRunning)
|
|
121
|
+
return;
|
|
122
|
+
context.reconciliationRunning = !0;
|
|
123
|
+
try {
|
|
124
|
+
const now = Date.now();
|
|
125
|
+
let staleHeartbeatCount = 0;
|
|
126
|
+
for await (const [, value] of options.engine.storage.scan("op:inflight:"))
|
|
127
|
+
try {
|
|
128
|
+
const decoded = decode(value);
|
|
129
|
+
if (!isInflightRecord(decoded))
|
|
130
|
+
continue;
|
|
131
|
+
if (isTaskHeartbeatStaleForMetrics(decoded, now))
|
|
132
|
+
staleHeartbeatCount += 1;
|
|
133
|
+
if (decoded.deadline > now) {
|
|
134
|
+
if (context.processingOperations.has(decoded.operationId))
|
|
135
|
+
continue;
|
|
136
|
+
context.deadlineTracker.remove(decoded.operationId);
|
|
137
|
+
context.deadlineTracker.add({
|
|
138
|
+
operationId: decoded.operationId,
|
|
139
|
+
deadline: decoded.deadline
|
|
140
|
+
});
|
|
141
|
+
continue;
|
|
142
|
+
}
|
|
143
|
+
if (context.processingOperations.has(decoded.operationId))
|
|
144
|
+
continue;
|
|
145
|
+
context.processingOperations.add(decoded.operationId);
|
|
146
|
+
try {
|
|
147
|
+
context.deadlineTracker.remove(decoded.operationId);
|
|
148
|
+
context.registry.completeTask(decoded.operationId);
|
|
149
|
+
cleanupWorkflowIndex(decoded.operationId);
|
|
150
|
+
await reassignOrExpireTask(context, options, decoded.operationId, decoded);
|
|
151
|
+
} finally {
|
|
152
|
+
context.processingOperations.delete(decoded.operationId);
|
|
153
|
+
}
|
|
154
|
+
} catch (error) {
|
|
155
|
+
console.error("[weft] Failed to reconcile inflight record \u2014 skipping:", error);
|
|
156
|
+
}
|
|
157
|
+
recordTaskStaleHeartbeatMetric(context.metricsCollector, staleHeartbeatCount);
|
|
158
|
+
} catch (error) {
|
|
159
|
+
console.error("[weft] Reconciliation scanner error:", error);
|
|
160
|
+
} finally {
|
|
161
|
+
context.reconciliationRunning = !1;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ServerWebSocket } from 'bun';
|
|
2
|
+
import type { Engine } from '../../core/engine.ts';
|
|
3
|
+
import type { WebSocketData } from '../json-rpc-websocket-runtime.ts';
|
|
4
|
+
import type { ServerContext } from './context.ts';
|
|
5
|
+
export declare function sendStreamMessage(ws: ServerWebSocket<WebSocketData>, sequence: number, message: string): void;
|
|
6
|
+
export declare function getHighestStoredStreamSequence(engine: Engine, workflowId: string, key: string): Promise<number>;
|
|
7
|
+
export declare function addStreamSocket(context: ServerContext, workflowId: string, ws: ServerWebSocket<WebSocketData>): void;
|
|
8
|
+
export declare function removeStreamSocket(context: ServerContext, ws: ServerWebSocket<WebSocketData>): void;
|
|
9
|
+
export declare function flushPendingStreamMessages(_context: ServerContext, ws: ServerWebSocket<WebSocketData>): void;
|
|
10
|
+
export declare function publishTokenMessage(context: ServerContext, workflowId: string, sequence: number, message: string): void;
|
|
11
|
+
/**
|
|
12
|
+
* Send existing token chunks from storage to a newly connected stream client,
|
|
13
|
+
* so it can catch up on tokens emitted before the connection was established.
|
|
14
|
+
*/
|
|
15
|
+
export declare function replayTokenStream(context: ServerContext, engine: Engine, ws: ServerWebSocket<WebSocketData>, workflowId: string): Promise<void>;
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { KEYS } from "../../storage/interface.js";
|
|
2
|
+
const TOKEN_EVENT_TYPE = "stream:token";
|
|
3
|
+
export function sendStreamMessage(ws, sequence, message) {
|
|
4
|
+
if (sequence <= (ws.data.lastDeliveredSequence ?? -1))
|
|
5
|
+
return;
|
|
6
|
+
ws.send(message);
|
|
7
|
+
ws.data.lastDeliveredSequence = sequence;
|
|
8
|
+
}
|
|
9
|
+
export async function getHighestStoredStreamSequence(engine, workflowId, key) {
|
|
10
|
+
const prefix = KEYS.streamChunkPrefix(workflowId, key);
|
|
11
|
+
for await (const [storageKey] of engine.storage.scan(prefix, { reverse: !0, limit: 1 })) {
|
|
12
|
+
const sequenceText = storageKey.slice(prefix.length), sequence = Number.parseInt(sequenceText, 10);
|
|
13
|
+
if (Number.isSafeInteger(sequence) && sequence >= 0)
|
|
14
|
+
return sequence;
|
|
15
|
+
}
|
|
16
|
+
return -1;
|
|
17
|
+
}
|
|
18
|
+
export function addStreamSocket(context, workflowId, ws) {
|
|
19
|
+
let sockets = context.streamSockets.get(workflowId);
|
|
20
|
+
if (!sockets) {
|
|
21
|
+
sockets = new Set;
|
|
22
|
+
context.streamSockets.set(workflowId, sockets);
|
|
23
|
+
}
|
|
24
|
+
sockets.add(ws);
|
|
25
|
+
}
|
|
26
|
+
export function removeStreamSocket(context, ws) {
|
|
27
|
+
const workflowId = ws.data.workflowId;
|
|
28
|
+
if (!workflowId)
|
|
29
|
+
return;
|
|
30
|
+
const sockets = context.streamSockets.get(workflowId);
|
|
31
|
+
if (!sockets)
|
|
32
|
+
return;
|
|
33
|
+
sockets.delete(ws);
|
|
34
|
+
if (sockets.size === 0)
|
|
35
|
+
context.streamSockets.delete(workflowId);
|
|
36
|
+
}
|
|
37
|
+
export function flushPendingStreamMessages(_context, ws) {
|
|
38
|
+
const pendingMessages = ws.data.pendingStreamMessages ?? [];
|
|
39
|
+
pendingMessages.sort((left, right) => left.sequence - right.sequence);
|
|
40
|
+
for (const pending of pendingMessages)
|
|
41
|
+
sendStreamMessage(ws, pending.sequence, pending.message);
|
|
42
|
+
ws.data.pendingStreamMessages = [];
|
|
43
|
+
}
|
|
44
|
+
export function publishTokenMessage(context, workflowId, sequence, message) {
|
|
45
|
+
const sockets = context.streamSockets.get(workflowId);
|
|
46
|
+
if (!sockets)
|
|
47
|
+
return;
|
|
48
|
+
for (const ws of sockets) {
|
|
49
|
+
if (ws.data.replayInProgress) {
|
|
50
|
+
ws.data.pendingStreamMessages ??= [];
|
|
51
|
+
ws.data.pendingStreamMessages.push({ sequence, message });
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
sendStreamMessage(ws, sequence, message);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
export async function replayTokenStream(context, engine, ws, workflowId) {
|
|
58
|
+
ws.data.lastDeliveredSequence = -1;
|
|
59
|
+
try {
|
|
60
|
+
const requestedResumeFrom = ws.data.resumeFrom, after = requestedResumeFrom === void 0 ? -1 : Math.min(requestedResumeFrom, await getHighestStoredStreamSequence(engine, workflowId, "tokens"));
|
|
61
|
+
ws.data.lastDeliveredSequence = after;
|
|
62
|
+
const chunks = after >= 0 ? await engine.getStreamChunks(workflowId, "tokens", { after }) : await engine.getStreamChunks(workflowId, "tokens");
|
|
63
|
+
for (const chunk of chunks) {
|
|
64
|
+
if (typeof chunk.value !== "object" || chunk.value === null)
|
|
65
|
+
continue;
|
|
66
|
+
sendStreamMessage(ws, chunk.sequence, JSON.stringify({
|
|
67
|
+
type: TOKEN_EVENT_TYPE,
|
|
68
|
+
timestamp: Date.now(),
|
|
69
|
+
sequence: chunk.sequence,
|
|
70
|
+
data: chunk.value
|
|
71
|
+
}));
|
|
72
|
+
}
|
|
73
|
+
} catch (error) {
|
|
74
|
+
console.error(`[weft] Failed to replay token stream for workflow "${workflowId}":`, error);
|
|
75
|
+
} finally {
|
|
76
|
+
ws.data.replayInProgress = !1;
|
|
77
|
+
flushPendingStreamMessages(context, ws);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { AuthContext } from '../authentication.ts';
|
|
2
|
+
import type { ServeOptions } from '../index.ts';
|
|
3
|
+
import type { WebSocketData } from '../json-rpc-websocket-runtime.ts';
|
|
4
|
+
import type { ServerContext } from './context.ts';
|
|
5
|
+
export declare const WORKER_STREAM_RE: RegExp;
|
|
6
|
+
/** Classify a WebSocket request URL and extract relevant parameters. */
|
|
7
|
+
export declare function classifyConnection(url: URL): Pick<WebSocketData, 'connectionType' | 'workflowId' | 'queue'> | null;
|
|
8
|
+
export declare function handleWebSocketUpgrade(server: ReturnType<typeof Bun.serve>, context: ServerContext, options: ServeOptions, request: Request, url: URL, authContext?: AuthContext): Response | undefined | null;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { authContextToPrincipal } from "../handler.js";
|
|
2
|
+
import { finalizeWebSocketUpgrade } from "../json-rpc-transport-helpers.js";
|
|
3
|
+
import { isAuthenticated } from "../principal.js";
|
|
4
|
+
import { parseOptionalSequenceCursor } from "../sequence-cursor.js";
|
|
5
|
+
import { isOriginAllowed } from "./cors.js";
|
|
6
|
+
export const WORKER_STREAM_RE = /^\/v1\/tasks\/([\w-]+)\/stream$/;
|
|
7
|
+
const WORKFLOW_STREAM_RE = /^\/v1\/workflows\/([^/]+)\/stream$/, WORKFLOW_WATCH_RE = /^\/v1\/workflows\/([^/]+)\/watch$/;
|
|
8
|
+
function tryDecodePathComponent(value) {
|
|
9
|
+
try {
|
|
10
|
+
return decodeURIComponent(value);
|
|
11
|
+
} catch {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function matchUpgradePath(pathname, pattern) {
|
|
16
|
+
const match = pattern.exec(pathname);
|
|
17
|
+
if (!match?.[1])
|
|
18
|
+
return;
|
|
19
|
+
return tryDecodePathComponent(match[1]);
|
|
20
|
+
}
|
|
21
|
+
export function classifyConnection(url) {
|
|
22
|
+
const { pathname } = url, workflowStreamId = matchUpgradePath(pathname, WORKFLOW_STREAM_RE);
|
|
23
|
+
if (workflowStreamId !== void 0)
|
|
24
|
+
return workflowStreamId === null ? null : { connectionType: "stream", workflowId: workflowStreamId };
|
|
25
|
+
const workflowWatchId = matchUpgradePath(pathname, WORKFLOW_WATCH_RE);
|
|
26
|
+
if (workflowWatchId !== void 0)
|
|
27
|
+
return workflowWatchId === null ? null : { connectionType: "watch", workflowId: workflowWatchId };
|
|
28
|
+
const queue = matchUpgradePath(pathname, WORKER_STREAM_RE);
|
|
29
|
+
if (queue !== void 0)
|
|
30
|
+
return queue === null ? null : { connectionType: "worker", queue };
|
|
31
|
+
if (pathname === "/jsonrpc")
|
|
32
|
+
return { connectionType: "jsonrpc" };
|
|
33
|
+
return { connectionType: "generic" };
|
|
34
|
+
}
|
|
35
|
+
function rejectsCrossOriginUpgrade(context, request) {
|
|
36
|
+
const origin = request.headers.get("origin");
|
|
37
|
+
return context.corsPolicy !== null && origin !== null && !isOriginAllowed(context.corsPolicy, origin);
|
|
38
|
+
}
|
|
39
|
+
function resolvePrincipalForUpgrade(connectionType, authContext) {
|
|
40
|
+
if (connectionType !== "jsonrpc" && connectionType !== "worker")
|
|
41
|
+
return { ok: !0, principal: void 0 };
|
|
42
|
+
if (authContext === void 0)
|
|
43
|
+
return { ok: !0, principal: void 0 };
|
|
44
|
+
let principal;
|
|
45
|
+
try {
|
|
46
|
+
principal = authContextToPrincipal(authContext);
|
|
47
|
+
} catch (error) {
|
|
48
|
+
console.error("[weft] WebSocket upgrade principal resolution failed", error);
|
|
49
|
+
return { ok: !1, response: new Response("Authentication context invalid", { status: 401 }) };
|
|
50
|
+
}
|
|
51
|
+
if (connectionType === "worker" && isAuthenticated(principal) && !principal.hasScope("workers:write"))
|
|
52
|
+
return { ok: !1, response: new Response("Insufficient scope", { status: 403 }) };
|
|
53
|
+
return { ok: !0, principal };
|
|
54
|
+
}
|
|
55
|
+
export function handleWebSocketUpgrade(server, context, options, request, url, authContext) {
|
|
56
|
+
if (request.headers.get("upgrade") !== "websocket")
|
|
57
|
+
return null;
|
|
58
|
+
if (rejectsCrossOriginUpgrade(context, request))
|
|
59
|
+
return new Response("Cross-origin WebSocket upgrade not allowed", { status: 403 });
|
|
60
|
+
const classification = classifyConnection(url);
|
|
61
|
+
if (classification === null)
|
|
62
|
+
return new Response("Invalid encoded WebSocket path", { status: 400 });
|
|
63
|
+
const resolution = resolvePrincipalForUpgrade(classification.connectionType, authContext);
|
|
64
|
+
if (!resolution.ok)
|
|
65
|
+
return resolution.response;
|
|
66
|
+
const { principal } = resolution, resumeFromParam = url.searchParams.get("resumeFrom"), resumeFromResult = parseOptionalSequenceCursor(resumeFromParam, "resumeFrom query parameter");
|
|
67
|
+
if (resumeFromResult.error)
|
|
68
|
+
return new Response(resumeFromResult.error, { status: 400 });
|
|
69
|
+
const resumeFrom = resumeFromResult.value;
|
|
70
|
+
return finalizeWebSocketUpgrade(server, request, {
|
|
71
|
+
pathname: url.pathname,
|
|
72
|
+
...classification,
|
|
73
|
+
...principal ? { principal } : {},
|
|
74
|
+
...resumeFrom !== void 0 ? { resumeFrom } : {}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ServerWebSocket } from 'bun';
|
|
2
|
+
import type { ServeOptions } from '../index.ts';
|
|
3
|
+
import type { WebSocketData } from '../json-rpc-websocket-runtime.ts';
|
|
4
|
+
import type { ServerContext } from './context.ts';
|
|
5
|
+
export { isInflightRecord } from '../task-state.ts';
|
|
6
|
+
export declare function withRetry<T>(operation: () => Promise<T>, label: string, maxAttempts?: number): Promise<T>;
|
|
7
|
+
export declare function handleWorkerWebSocketMessage(context: ServerContext, options: ServeOptions, ws: ServerWebSocket<WebSocketData>, rawMessage: string | Buffer, cleanupWorkflowIndex: (operationId: string) => void): void;
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { decode, encode } from "../../core/codec.js";
|
|
2
|
+
import { KEYS } from "../../storage/interface.js";
|
|
3
|
+
import {
|
|
4
|
+
REMOTE_WORKER_PROTOCOL_VERSION,
|
|
5
|
+
REMOTE_WORKER_SUPPORTED_PROTOCOL_VERSIONS,
|
|
6
|
+
parseWorkerToServerMessage
|
|
7
|
+
} from "../../worker/protocol.js";
|
|
8
|
+
import { workerProtocolIncompatibleMessage } from "../../worker/worker-protocol-incompatible-error.js";
|
|
9
|
+
import { isAuthenticated } from "../principal.js";
|
|
10
|
+
import {
|
|
11
|
+
isInflightRecord,
|
|
12
|
+
readInflightRecord,
|
|
13
|
+
transitionInflightToResolved
|
|
14
|
+
} from "../task-state.js";
|
|
15
|
+
import {
|
|
16
|
+
recordTaskExecutionLatencyMetric,
|
|
17
|
+
recordWorkerCapacitySaturationMetric
|
|
18
|
+
} from "./task-metrics.js";
|
|
19
|
+
import { WORKER_STREAM_RE } from "./websocket-upgrade.js";
|
|
20
|
+
const MAX_WORKER_CONCURRENCY = 1000, DEFAULT_WORKER_CONCURRENCY = 10, WORKER_PROTOCOL_CLOSE_CODE = 1002, WORKER_REGISTRATION_CLOSE_CODE = 1008;
|
|
21
|
+
function isWorkerConnection(pathname) {
|
|
22
|
+
return WORKER_STREAM_RE.test(pathname);
|
|
23
|
+
}
|
|
24
|
+
export { isInflightRecord } from "../task-state.js";
|
|
25
|
+
export async function withRetry(operation, label, maxAttempts = 2) {
|
|
26
|
+
let lastError;
|
|
27
|
+
for (let attempt = 1;attempt <= maxAttempts; attempt++)
|
|
28
|
+
try {
|
|
29
|
+
return await operation();
|
|
30
|
+
} catch (error) {
|
|
31
|
+
lastError = error;
|
|
32
|
+
if (attempt < maxAttempts) {
|
|
33
|
+
console.warn(`[weft] Retrying "${label}" (attempt ${attempt + 1}/${maxAttempts})`);
|
|
34
|
+
await Bun.sleep(100 * attempt);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
throw lastError;
|
|
38
|
+
}
|
|
39
|
+
function sendWorkerProtocolMessage(ws, message) {
|
|
40
|
+
ws.send(JSON.stringify(message));
|
|
41
|
+
}
|
|
42
|
+
function closeWorkerSocket(ws, code, reason) {
|
|
43
|
+
try {
|
|
44
|
+
ws.unsubscribe(ws.data.pathname);
|
|
45
|
+
} catch {}
|
|
46
|
+
ws.close(code, reason);
|
|
47
|
+
setTimeout(() => {
|
|
48
|
+
try {
|
|
49
|
+
ws.terminate();
|
|
50
|
+
} catch {}
|
|
51
|
+
}, 10);
|
|
52
|
+
}
|
|
53
|
+
function rejectRegistration(ws, code, message, requestedProtocolVersion) {
|
|
54
|
+
sendWorkerProtocolMessage(ws, {
|
|
55
|
+
type: "registerError",
|
|
56
|
+
code,
|
|
57
|
+
message,
|
|
58
|
+
supportedProtocolVersions: REMOTE_WORKER_SUPPORTED_PROTOCOL_VERSIONS,
|
|
59
|
+
...requestedProtocolVersion !== void 0 ? { requestedProtocolVersion } : {}
|
|
60
|
+
});
|
|
61
|
+
closeWorkerSocket(ws, WORKER_REGISTRATION_CLOSE_CODE, code);
|
|
62
|
+
}
|
|
63
|
+
function rejectProtocolMessage(ws, code, message) {
|
|
64
|
+
sendWorkerProtocolMessage(ws, { type: "protocolError", code, message });
|
|
65
|
+
closeWorkerSocket(ws, WORKER_PROTOCOL_CLOSE_CODE, code);
|
|
66
|
+
}
|
|
67
|
+
function principalMayRegisterWorker(principal) {
|
|
68
|
+
if (principal === void 0)
|
|
69
|
+
return !0;
|
|
70
|
+
return isAuthenticated(principal) && principal.hasScope("workers:write");
|
|
71
|
+
}
|
|
72
|
+
function buildWorkerRegistrationInfo(message, queue, concurrency) {
|
|
73
|
+
return {
|
|
74
|
+
id: message.workerId,
|
|
75
|
+
queue,
|
|
76
|
+
activities: [...message.activities],
|
|
77
|
+
concurrency,
|
|
78
|
+
...message.deploymentName !== void 0 ? { deploymentName: message.deploymentName } : {},
|
|
79
|
+
...message.buildId !== void 0 ? { buildId: message.buildId } : {},
|
|
80
|
+
...message.runtimeVersion !== void 0 ? { runtimeVersion: message.runtimeVersion } : {},
|
|
81
|
+
...message.gitSha !== void 0 ? { gitSha: message.gitSha } : {},
|
|
82
|
+
...message.startedAt !== void 0 ? { startedAt: message.startedAt } : {},
|
|
83
|
+
...message.capabilities !== void 0 ? { capabilities: message.capabilities } : {}
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
function registerWorker(context, ws, message) {
|
|
87
|
+
if (!principalMayRegisterWorker(ws.data.principal)) {
|
|
88
|
+
rejectRegistration(ws, "invalid_registration", "Worker registration requires the workers:write scope", message.protocolVersion);
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
const rawConcurrency = message.concurrency ?? DEFAULT_WORKER_CONCURRENCY, clampedConcurrency = Math.min(Math.max(1, Math.floor(rawConcurrency)), MAX_WORKER_CONCURRENCY), queue = ws.data.queue ?? "default", pendingRequeue = context.pendingWorkerRequeues.get(message.workerId);
|
|
92
|
+
if (pendingRequeue !== void 0) {
|
|
93
|
+
clearTimeout(pendingRequeue);
|
|
94
|
+
context.pendingWorkerRequeues.delete(message.workerId);
|
|
95
|
+
}
|
|
96
|
+
ws.data.workerId = message.workerId;
|
|
97
|
+
ws.data.workerRegistered = !0;
|
|
98
|
+
ws.data.workerProtocolVersion = message.protocolVersion;
|
|
99
|
+
context.registry.register(buildWorkerRegistrationInfo(message, queue, clampedConcurrency));
|
|
100
|
+
context.workerSockets.set(message.workerId, ws);
|
|
101
|
+
sendWorkerProtocolMessage(ws, {
|
|
102
|
+
type: "registerAck",
|
|
103
|
+
protocolVersion: REMOTE_WORKER_PROTOCOL_VERSION,
|
|
104
|
+
workerId: message.workerId,
|
|
105
|
+
queue,
|
|
106
|
+
activities: [...message.activities],
|
|
107
|
+
concurrency: clampedConcurrency
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
function resolveTaskResultStatus(message) {
|
|
111
|
+
return message.status === "completed" ? "completed" : "failed";
|
|
112
|
+
}
|
|
113
|
+
function onTaskResultMessage(context, options, ws, message, cleanupWorkflowIndex) {
|
|
114
|
+
const operationId = message.operationId, workerId = ws.data.workerId;
|
|
115
|
+
if (workerId === void 0 || !context.registry.isAssignedToWorker(operationId, workerId)) {
|
|
116
|
+
sendWorkerProtocolMessage(ws, {
|
|
117
|
+
type: "protocolError",
|
|
118
|
+
code: "invalid_message",
|
|
119
|
+
message: `taskResult for operation "${operationId}" rejected \u2014 task not assigned to worker "${workerId ?? ""}"`
|
|
120
|
+
});
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
context.registry.completeTask(operationId);
|
|
124
|
+
context.deadlineTracker.remove(operationId);
|
|
125
|
+
cleanupWorkflowIndex(operationId);
|
|
126
|
+
recordWorkerCapacitySaturationMetric(context.metricsCollector, context.registry);
|
|
127
|
+
(async () => {
|
|
128
|
+
const inflightRecord = await readInflightRecord(options.engine.storage, operationId), resolvedAt = Date.now(), resolvedStatus = resolveTaskResultStatus(message);
|
|
129
|
+
await transitionInflightToResolved(options.engine.storage, operationId, resolvedStatus, {
|
|
130
|
+
...inflightRecord === null ? {} : { record: inflightRecord },
|
|
131
|
+
resolvedAt,
|
|
132
|
+
resolutionReason: resolvedStatus,
|
|
133
|
+
...message.status === "completed" ? { value: message.value } : { error: message.error }
|
|
134
|
+
});
|
|
135
|
+
if (inflightRecord !== null)
|
|
136
|
+
recordTaskExecutionLatencyMetric(context.metricsCollector, inflightRecord, resolvedAt);
|
|
137
|
+
})().catch((error) => {
|
|
138
|
+
console.error(`[weft] Failed to transition task "${operationId}" to resolved \u2014 inflight record may leak:`, error);
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
function onHeartbeatMessage(context, options, ws, _message) {
|
|
142
|
+
const workerId = ws.data.workerId;
|
|
143
|
+
if (!workerId)
|
|
144
|
+
return;
|
|
145
|
+
context.registry.heartbeat(workerId);
|
|
146
|
+
for (const task of context.registry.getWorkerTasks(workerId)) {
|
|
147
|
+
const newDeadline = context.registry.extendVisibility(task.operationId, task.visibilityTimeout);
|
|
148
|
+
if (newDeadline !== void 0) {
|
|
149
|
+
context.deadlineTracker.remove(task.operationId);
|
|
150
|
+
context.deadlineTracker.add({ operationId: task.operationId, deadline: newDeadline });
|
|
151
|
+
const opId = task.operationId, heartbeatWorkerId = ws.data.workerId;
|
|
152
|
+
withRetry(async () => {
|
|
153
|
+
if (!context.registry.isAssigned(opId))
|
|
154
|
+
return;
|
|
155
|
+
if (!context.registry.getWorkerTasks(heartbeatWorkerId ?? "").find((trackedTask) => trackedTask.operationId === opId))
|
|
156
|
+
return;
|
|
157
|
+
const inflightKey = KEYS.operationInflight(opId), existing = await options.engine.storage.get(inflightKey);
|
|
158
|
+
if (existing) {
|
|
159
|
+
const decoded = decode(existing);
|
|
160
|
+
if (!isInflightRecord(decoded)) {
|
|
161
|
+
console.error(`[weft] Corrupt inflight record for task "${opId}" during heartbeat \u2014 skipping visibility extension`);
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
const updated = { ...decoded, deadline: newDeadline, lastHeartbeatAt: Date.now() };
|
|
165
|
+
await options.engine.storage.put(inflightKey, encode(updated));
|
|
166
|
+
}
|
|
167
|
+
}, `extend visibility for task "${opId}"`).catch((error) => {
|
|
168
|
+
console.error(`[weft] Failed to extend visibility for task "${opId}":`, error);
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
function parseAndValidateWorkerFrame(ws, rawMessage) {
|
|
174
|
+
const text = typeof rawMessage === "string" ? rawMessage : new TextDecoder().decode(rawMessage);
|
|
175
|
+
let parsed;
|
|
176
|
+
try {
|
|
177
|
+
parsed = JSON.parse(text);
|
|
178
|
+
} catch {
|
|
179
|
+
rejectProtocolMessage(ws, "invalid_json", "Worker protocol messages must be valid JSON");
|
|
180
|
+
return { ok: !1 };
|
|
181
|
+
}
|
|
182
|
+
const result = parseWorkerToServerMessage(parsed);
|
|
183
|
+
if (!result.ok) {
|
|
184
|
+
if (result.error.code === "invalid_registration" || result.error.code === "unsupported_protocol_version") {
|
|
185
|
+
const message = result.error.code === "unsupported_protocol_version" ? workerProtocolIncompatibleMessage({
|
|
186
|
+
expected: REMOTE_WORKER_PROTOCOL_VERSION,
|
|
187
|
+
received: result.error.requestedProtocolVersion
|
|
188
|
+
}) : result.error.message;
|
|
189
|
+
rejectRegistration(ws, result.error.code, message, result.error.requestedProtocolVersion);
|
|
190
|
+
return { ok: !1 };
|
|
191
|
+
}
|
|
192
|
+
rejectProtocolMessage(ws, result.error.code, result.error.message);
|
|
193
|
+
return { ok: !1 };
|
|
194
|
+
}
|
|
195
|
+
return { ok: !0, message: result.message };
|
|
196
|
+
}
|
|
197
|
+
export function handleWorkerWebSocketMessage(context, options, ws, rawMessage, cleanupWorkflowIndex) {
|
|
198
|
+
if (!isWorkerConnection(ws.data.pathname))
|
|
199
|
+
return;
|
|
200
|
+
const parsed = parseAndValidateWorkerFrame(ws, rawMessage);
|
|
201
|
+
if (!parsed.ok)
|
|
202
|
+
return;
|
|
203
|
+
const { message } = parsed;
|
|
204
|
+
if (message.type !== "register" && ws.data.workerRegistered !== !0) {
|
|
205
|
+
rejectProtocolMessage(ws, "registration_required", "Worker must register before sending heartbeat or taskResult messages");
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
switch (message.type) {
|
|
209
|
+
case "register": {
|
|
210
|
+
registerWorker(context, ws, message);
|
|
211
|
+
break;
|
|
212
|
+
}
|
|
213
|
+
case "taskResult": {
|
|
214
|
+
onTaskResultMessage(context, options, ws, message, cleanupWorkflowIndex);
|
|
215
|
+
break;
|
|
216
|
+
}
|
|
217
|
+
case "heartbeat": {
|
|
218
|
+
onHeartbeatMessage(context, options, ws, message);
|
|
219
|
+
break;
|
|
220
|
+
}
|
|
221
|
+
default:
|
|
222
|
+
return message;
|
|
223
|
+
}
|
|
224
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/** Claim the next event sequence number for a workflow. */
|
|
2
|
+
export declare function claimNextSequence(sequenceCounters: Map<string, number>, workflowId: string): number;
|
|
3
|
+
/** Evict the oldest workflow affinity entry when the cache grows beyond its cap. */
|
|
4
|
+
export declare function evictOldestAffinityEntries(workerAffinity: Map<string, string>, maxEntries: number): void;
|
|
5
|
+
/** Restore an extended deadline back into the tracker when a stale heap entry expires. */
|
|
6
|
+
export declare function restoreExtendedDeadline(deadlineTracker: {
|
|
7
|
+
add(entry: {
|
|
8
|
+
operationId: string;
|
|
9
|
+
deadline: number;
|
|
10
|
+
}): void;
|
|
11
|
+
}, operationId: string, deadline: number): void;
|
|
12
|
+
/** Restore a stale heap entry when the recorded deadline is still in the future. */
|
|
13
|
+
export declare function restoreExtendedDeadlineIfStillActive(deadlineTracker: {
|
|
14
|
+
add(entry: {
|
|
15
|
+
operationId: string;
|
|
16
|
+
deadline: number;
|
|
17
|
+
}): void;
|
|
18
|
+
}, operationId: string, deadline: number, now: number): boolean;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export function claimNextSequence(sequenceCounters, workflowId) {
|
|
2
|
+
const current = sequenceCounters.get(workflowId);
|
|
3
|
+
if (current === void 0)
|
|
4
|
+
throw Error(`Sequence counter for workflow "${workflowId}" accessed before initialization`);
|
|
5
|
+
sequenceCounters.set(workflowId, current + 1);
|
|
6
|
+
return current;
|
|
7
|
+
}
|
|
8
|
+
export function evictOldestAffinityEntries(workerAffinity, maxEntries) {
|
|
9
|
+
if (workerAffinity.size > maxEntries) {
|
|
10
|
+
const firstKey = workerAffinity.keys().next().value;
|
|
11
|
+
if (firstKey !== void 0)
|
|
12
|
+
workerAffinity.delete(firstKey);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
export function restoreExtendedDeadline(deadlineTracker, operationId, deadline) {
|
|
16
|
+
deadlineTracker.add({ operationId, deadline });
|
|
17
|
+
}
|
|
18
|
+
export function restoreExtendedDeadlineIfStillActive(deadlineTracker, operationId, deadline, now) {
|
|
19
|
+
if (deadline <= now)
|
|
20
|
+
return !1;
|
|
21
|
+
restoreExtendedDeadline(deadlineTracker, operationId, deadline);
|
|
22
|
+
return !0;
|
|
23
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
const DECIMAL_INTEGER_PATTERN = /^-?\d+$/;
|
|
2
|
+
export function parseOptionalSequenceCursor(rawValue, parameterName) {
|
|
3
|
+
if (rawValue === null || rawValue === void 0)
|
|
4
|
+
return {};
|
|
5
|
+
if (rawValue.trim().length === 0)
|
|
6
|
+
return {
|
|
7
|
+
error: `Invalid ${parameterName}: ${rawValue}`
|
|
8
|
+
};
|
|
9
|
+
if (!DECIMAL_INTEGER_PATTERN.test(rawValue))
|
|
10
|
+
return {
|
|
11
|
+
error: `Invalid ${parameterName}: ${rawValue}`
|
|
12
|
+
};
|
|
13
|
+
const value = Number(rawValue);
|
|
14
|
+
if (!Number.isSafeInteger(value) || value < -1)
|
|
15
|
+
return {
|
|
16
|
+
error: `Invalid ${parameterName}: ${rawValue}`
|
|
17
|
+
};
|
|
18
|
+
return { value };
|
|
19
|
+
}
|