@durable-effect/jobs 0.0.1-next.1
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 +490 -0
- package/dist/client/client.d.ts +34 -0
- package/dist/client/client.d.ts.map +1 -0
- package/dist/client/client.js +427 -0
- package/dist/client/client.js.map +1 -0
- package/dist/client/index.d.ts +4 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +4 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/response.d.ts +99 -0
- package/dist/client/response.d.ts.map +1 -0
- package/dist/client/response.js +92 -0
- package/dist/client/response.js.map +1 -0
- package/dist/client/types.d.ts +242 -0
- package/dist/client/types.d.ts.map +1 -0
- package/dist/client/types.js +3 -0
- package/dist/client/types.js.map +1 -0
- package/dist/definitions/continuous.d.ts +110 -0
- package/dist/definitions/continuous.d.ts.map +1 -0
- package/dist/definitions/continuous.js +79 -0
- package/dist/definitions/continuous.js.map +1 -0
- package/dist/definitions/debounce.d.ts +67 -0
- package/dist/definitions/debounce.d.ts.map +1 -0
- package/dist/definitions/debounce.js +28 -0
- package/dist/definitions/debounce.js.map +1 -0
- package/dist/definitions/index.d.ts +4 -0
- package/dist/definitions/index.d.ts.map +1 -0
- package/dist/definitions/index.js +5 -0
- package/dist/definitions/index.js.map +1 -0
- package/dist/definitions/task.d.ts +234 -0
- package/dist/definitions/task.d.ts.map +1 -0
- package/dist/definitions/task.js +106 -0
- package/dist/definitions/task.js.map +1 -0
- package/dist/engine/engine.d.ts +60 -0
- package/dist/engine/engine.d.ts.map +1 -0
- package/dist/engine/engine.js +89 -0
- package/dist/engine/engine.js.map +1 -0
- package/dist/engine/index.d.ts +3 -0
- package/dist/engine/index.d.ts.map +1 -0
- package/dist/engine/index.js +3 -0
- package/dist/engine/index.js.map +1 -0
- package/dist/engine/types.d.ts +53 -0
- package/dist/engine/types.d.ts.map +1 -0
- package/dist/engine/types.js +3 -0
- package/dist/engine/types.js.map +1 -0
- package/dist/errors.d.ts +119 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +80 -0
- package/dist/errors.js.map +1 -0
- package/dist/factory.d.ts +97 -0
- package/dist/factory.d.ts.map +1 -0
- package/dist/factory.js +94 -0
- package/dist/factory.js.map +1 -0
- package/dist/handlers/continuous/context.d.ts +25 -0
- package/dist/handlers/continuous/context.d.ts.map +1 -0
- package/dist/handlers/continuous/context.js +38 -0
- package/dist/handlers/continuous/context.js.map +1 -0
- package/dist/handlers/continuous/executor.d.ts +10 -0
- package/dist/handlers/continuous/executor.d.ts.map +1 -0
- package/dist/handlers/continuous/executor.js +83 -0
- package/dist/handlers/continuous/executor.js.map +1 -0
- package/dist/handlers/continuous/handler.d.ts +14 -0
- package/dist/handlers/continuous/handler.d.ts.map +1 -0
- package/dist/handlers/continuous/handler.js +283 -0
- package/dist/handlers/continuous/handler.js.map +1 -0
- package/dist/handlers/continuous/index.d.ts +4 -0
- package/dist/handlers/continuous/index.d.ts.map +1 -0
- package/dist/handlers/continuous/index.js +4 -0
- package/dist/handlers/continuous/index.js.map +1 -0
- package/dist/handlers/continuous/types.d.ts +36 -0
- package/dist/handlers/continuous/types.d.ts.map +1 -0
- package/dist/handlers/continuous/types.js +3 -0
- package/dist/handlers/continuous/types.js.map +1 -0
- package/dist/handlers/debounce/handler.d.ts +14 -0
- package/dist/handlers/debounce/handler.d.ts.map +1 -0
- package/dist/handlers/debounce/handler.js +261 -0
- package/dist/handlers/debounce/handler.js.map +1 -0
- package/dist/handlers/debounce/index.d.ts +3 -0
- package/dist/handlers/debounce/index.d.ts.map +1 -0
- package/dist/handlers/debounce/index.js +3 -0
- package/dist/handlers/debounce/index.js.map +1 -0
- package/dist/handlers/debounce/types.d.ts +10 -0
- package/dist/handlers/debounce/types.d.ts.map +1 -0
- package/dist/handlers/debounce/types.js +3 -0
- package/dist/handlers/debounce/types.js.map +1 -0
- package/dist/handlers/index.d.ts +14 -0
- package/dist/handlers/index.d.ts.map +1 -0
- package/dist/handlers/index.js +25 -0
- package/dist/handlers/index.js.map +1 -0
- package/dist/handlers/task/context.d.ts +35 -0
- package/dist/handlers/task/context.d.ts.map +1 -0
- package/dist/handlers/task/context.js +156 -0
- package/dist/handlers/task/context.js.map +1 -0
- package/dist/handlers/task/handler.d.ts +13 -0
- package/dist/handlers/task/handler.d.ts.map +1 -0
- package/dist/handlers/task/handler.js +280 -0
- package/dist/handlers/task/handler.js.map +1 -0
- package/dist/handlers/task/index.d.ts +3 -0
- package/dist/handlers/task/index.d.ts.map +1 -0
- package/dist/handlers/task/index.js +2 -0
- package/dist/handlers/task/index.js.map +1 -0
- package/dist/handlers/task/types.d.ts +10 -0
- package/dist/handlers/task/types.d.ts.map +1 -0
- package/dist/handlers/task/types.js +3 -0
- package/dist/handlers/task/types.js.map +1 -0
- package/dist/index.d.ts +28 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +79 -0
- package/dist/index.js.map +1 -0
- package/dist/registry/index.d.ts +5 -0
- package/dist/registry/index.d.ts.map +1 -0
- package/dist/registry/index.js +4 -0
- package/dist/registry/index.js.map +1 -0
- package/dist/registry/registry.d.ts +74 -0
- package/dist/registry/registry.d.ts.map +1 -0
- package/dist/registry/registry.js +159 -0
- package/dist/registry/registry.js.map +1 -0
- package/dist/registry/typed.d.ts +146 -0
- package/dist/registry/typed.d.ts.map +1 -0
- package/dist/registry/typed.js +29 -0
- package/dist/registry/typed.js.map +1 -0
- package/dist/registry/types.d.ts +497 -0
- package/dist/registry/types.d.ts.map +1 -0
- package/dist/registry/types.js +3 -0
- package/dist/registry/types.js.map +1 -0
- package/dist/retry/errors.d.ts +31 -0
- package/dist/retry/errors.d.ts.map +1 -0
- package/dist/retry/errors.js +22 -0
- package/dist/retry/errors.js.map +1 -0
- package/dist/retry/executor.d.ts +53 -0
- package/dist/retry/executor.d.ts.map +1 -0
- package/dist/retry/executor.js +112 -0
- package/dist/retry/executor.js.map +1 -0
- package/dist/retry/index.d.ts +4 -0
- package/dist/retry/index.d.ts.map +1 -0
- package/dist/retry/index.js +4 -0
- package/dist/retry/index.js.map +1 -0
- package/dist/retry/types.d.ts +29 -0
- package/dist/retry/types.d.ts.map +1 -0
- package/dist/retry/types.js +3 -0
- package/dist/retry/types.js.map +1 -0
- package/dist/runtime/dispatcher.d.ts +39 -0
- package/dist/runtime/dispatcher.d.ts.map +1 -0
- package/dist/runtime/dispatcher.js +76 -0
- package/dist/runtime/dispatcher.js.map +1 -0
- package/dist/runtime/index.d.ts +4 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +6 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/runtime.d.ts +88 -0
- package/dist/runtime/runtime.d.ts.map +1 -0
- package/dist/runtime/runtime.js +116 -0
- package/dist/runtime/runtime.js.map +1 -0
- package/dist/runtime/types.d.ts +182 -0
- package/dist/runtime/types.d.ts.map +1 -0
- package/dist/runtime/types.js +3 -0
- package/dist/runtime/types.js.map +1 -0
- package/dist/services/alarm.d.ts +37 -0
- package/dist/services/alarm.d.ts.map +1 -0
- package/dist/services/alarm.js +39 -0
- package/dist/services/alarm.js.map +1 -0
- package/dist/services/cleanup.d.ts +27 -0
- package/dist/services/cleanup.d.ts.map +1 -0
- package/dist/services/cleanup.js +25 -0
- package/dist/services/cleanup.js.map +1 -0
- package/dist/services/entity-state.d.ts +49 -0
- package/dist/services/entity-state.d.ts.map +1 -0
- package/dist/services/entity-state.js +72 -0
- package/dist/services/entity-state.js.map +1 -0
- package/dist/services/execution.d.ts +70 -0
- package/dist/services/execution.d.ts.map +1 -0
- package/dist/services/execution.js +159 -0
- package/dist/services/execution.js.map +1 -0
- package/dist/services/execution_test.d.ts +13 -0
- package/dist/services/execution_test.d.ts.map +1 -0
- package/dist/services/execution_test.js +11 -0
- package/dist/services/execution_test.js.map +1 -0
- package/dist/services/idempotency.d.ts +36 -0
- package/dist/services/idempotency.d.ts.map +1 -0
- package/dist/services/idempotency.js +48 -0
- package/dist/services/idempotency.js.map +1 -0
- package/dist/services/index.d.ts +19 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +33 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/metadata.d.ts +64 -0
- package/dist/services/metadata.d.ts.map +1 -0
- package/dist/services/metadata.js +56 -0
- package/dist/services/metadata.js.map +1 -0
- package/dist/services/registry.d.ts +19 -0
- package/dist/services/registry.d.ts.map +1 -0
- package/dist/services/registry.js +17 -0
- package/dist/services/registry.js.map +1 -0
- package/dist/storage-keys.d.ts +38 -0
- package/dist/storage-keys.d.ts.map +1 -0
- package/dist/storage-keys.js +47 -0
- package/dist/storage-keys.js.map +1 -0
- package/package.json +35 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/handlers/debounce/handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/handlers/debounce/index.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,eAAe,EACf,oBAAoB,GACrB,MAAM,WAAW,CAAC;AACnB,YAAY,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/handlers/debounce/index.ts"],"names":[],"mappings":"AAAA,+CAA+C;AAE/C,OAAO,EACL,eAAe,EACf,oBAAoB,GACrB,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Effect } from "effect";
|
|
2
|
+
import type { DebounceRequest } from "../../runtime/types";
|
|
3
|
+
import type { DebounceAddResponse, DebounceFlushResponse, DebounceClearResponse, DebounceStatusResponse, DebounceGetStateResponse } from "../../runtime/types";
|
|
4
|
+
import type { JobError } from "../../errors";
|
|
5
|
+
export type DebounceResponse = DebounceAddResponse | DebounceFlushResponse | DebounceClearResponse | DebounceStatusResponse | DebounceGetStateResponse;
|
|
6
|
+
export interface DebounceHandlerI {
|
|
7
|
+
handle(request: DebounceRequest): Effect.Effect<DebounceResponse, JobError>;
|
|
8
|
+
handleAlarm(): Effect.Effect<void, JobError>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/handlers/debounce/types.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,KAAK,EACV,mBAAmB,EACnB,qBAAqB,EACrB,qBAAqB,EACrB,sBAAsB,EACtB,wBAAwB,EACzB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,MAAM,gBAAgB,GACxB,mBAAmB,GACnB,qBAAqB,GACrB,qBAAqB,GACrB,sBAAsB,GACtB,wBAAwB,CAAC;AAE7B,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,OAAO,EAAE,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC;IAC5E,WAAW,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;CAC9C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/handlers/debounce/types.ts"],"names":[],"mappings":"AAAA,+CAA+C"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Layer } from "effect";
|
|
2
|
+
export { ContinuousHandler, ContinuousHandlerLayer, createContinuousContext, type ContinuousHandlerI, type ContinuousResponse, type StateHolder, } from "./continuous";
|
|
3
|
+
export { DebounceHandler, DebounceHandlerLayer, type DebounceHandlerI, type DebounceResponse, } from "./debounce";
|
|
4
|
+
export { TaskHandler, TaskHandlerLayer, type TaskHandlerI, type TaskResponse, } from "./task";
|
|
5
|
+
export { RetryExecutorLayer } from "../retry";
|
|
6
|
+
/**
|
|
7
|
+
* Combined layer for all job handlers.
|
|
8
|
+
*
|
|
9
|
+
* Note: RetryExecutorLayer is NOT included here because it depends on
|
|
10
|
+
* AlarmService which is provided by RuntimeServicesLayer. The runtime
|
|
11
|
+
* must compose the layers in the correct order.
|
|
12
|
+
*/
|
|
13
|
+
export declare const JobHandlersLayer: Layer.Layer<import("./continuous").ContinuousHandler | import("./debounce").DebounceHandler | import("./task").TaskHandler, never, import("..").MetadataService | import("@durable-effect/core").RuntimeAdapter | import("@durable-effect/core").StorageAdapter | import("..").AlarmService | import("../services").RegistryService | import("../retry").RetryExecutor | import("../services").JobExecutionService>;
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAC;AAM/B,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EACtB,uBAAuB,EACvB,KAAK,kBAAkB,EACvB,KAAK,kBAAkB,EACvB,KAAK,WAAW,GACjB,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,eAAe,EACf,oBAAoB,EACpB,KAAK,gBAAgB,EACrB,KAAK,gBAAgB,GACtB,MAAM,YAAY,CAAC;AACpB,OAAO,EACL,WAAW,EACX,gBAAgB,EAChB,KAAK,YAAY,EACjB,KAAK,YAAY,GAClB,MAAM,QAAQ,CAAC;AAGhB,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAM9C;;;;;;GAMG;AACH,eAAO,MAAM,gBAAgB,qZAK5B,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
// packages/jobs/src/handlers/index.ts
|
|
2
|
+
import { Layer } from "effect";
|
|
3
|
+
import { ContinuousHandlerLayer } from "./continuous";
|
|
4
|
+
import { DebounceHandlerLayer } from "./debounce";
|
|
5
|
+
import { TaskHandlerLayer } from "./task";
|
|
6
|
+
// Re-export handlers
|
|
7
|
+
export { ContinuousHandler, ContinuousHandlerLayer, createContinuousContext, } from "./continuous";
|
|
8
|
+
export { DebounceHandler, DebounceHandlerLayer, } from "./debounce";
|
|
9
|
+
export { TaskHandler, TaskHandlerLayer, } from "./task";
|
|
10
|
+
// Re-export RetryExecutorLayer for runtime composition
|
|
11
|
+
export { RetryExecutorLayer } from "../retry";
|
|
12
|
+
// =============================================================================
|
|
13
|
+
// Combined Handlers Layer
|
|
14
|
+
// =============================================================================
|
|
15
|
+
/**
|
|
16
|
+
* Combined layer for all job handlers.
|
|
17
|
+
*
|
|
18
|
+
* Note: RetryExecutorLayer is NOT included here because it depends on
|
|
19
|
+
* AlarmService which is provided by RuntimeServicesLayer. The runtime
|
|
20
|
+
* must compose the layers in the correct order.
|
|
21
|
+
*/
|
|
22
|
+
export const JobHandlersLayer = Layer.mergeAll(ContinuousHandlerLayer, DebounceHandlerLayer, TaskHandlerLayer
|
|
23
|
+
// TODO: Add WorkerPoolHandlerLayer in Phase 5
|
|
24
|
+
);
|
|
25
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAAA,sCAAsC;AAEtC,OAAO,EAAE,KAAK,EAAE,MAAM,QAAQ,CAAC;AAC/B,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAE1C,qBAAqB;AACrB,OAAO,EACL,iBAAiB,EACjB,sBAAsB,EACtB,uBAAuB,GAIxB,MAAM,cAAc,CAAC;AACtB,OAAO,EACL,eAAe,EACf,oBAAoB,GAGrB,MAAM,YAAY,CAAC;AACpB,OAAO,EACL,WAAW,EACX,gBAAgB,GAGjB,MAAM,QAAQ,CAAC;AAEhB,uDAAuD;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAE9C,gFAAgF;AAChF,0BAA0B;AAC1B,gFAAgF;AAEhF;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,CAAC,QAAQ,CAC5C,sBAAsB,EACtB,oBAAoB,EACpB,gBAAgB;AAChB,8CAA8C;CAC/C,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Effect } from "effect";
|
|
2
|
+
import type { TaskEventContext, TaskExecuteContext, TaskIdleContext, TaskErrorContext } from "../../registry/types";
|
|
3
|
+
/**
|
|
4
|
+
* State holder for mutable state updates during execution.
|
|
5
|
+
*/
|
|
6
|
+
export interface TaskStateHolder<S> {
|
|
7
|
+
current: S | null;
|
|
8
|
+
dirty: boolean;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Scheduling holder for tracking schedule operations during execution.
|
|
12
|
+
*/
|
|
13
|
+
export interface TaskScheduleHolder {
|
|
14
|
+
scheduledAt: number | null;
|
|
15
|
+
cancelled: boolean;
|
|
16
|
+
dirty: boolean;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Create TaskEventContext for onEvent handler.
|
|
20
|
+
* Note: event is passed separately to onEvent, not via context.
|
|
21
|
+
*/
|
|
22
|
+
export declare function createTaskEventContext<S>(stateHolder: TaskStateHolder<S>, scheduleHolder: TaskScheduleHolder, instanceId: string, jobName: string, executionStartedAt: number, getEventCount: () => Effect.Effect<number, never, never>, getCreatedAt: () => Effect.Effect<number, never, never>, getScheduledFromStorage: () => Effect.Effect<number | null, never, never>): TaskEventContext<S>;
|
|
23
|
+
/**
|
|
24
|
+
* Create TaskExecuteContext for execute handler.
|
|
25
|
+
*/
|
|
26
|
+
export declare function createTaskExecuteContext<S>(stateHolder: TaskStateHolder<S>, scheduleHolder: TaskScheduleHolder, instanceId: string, jobName: string, executionStartedAt: number, getState: () => Effect.Effect<S | null, never, never>, getEventCount: () => Effect.Effect<number, never, never>, getCreatedAt: () => Effect.Effect<number, never, never>, getExecuteCount: () => Effect.Effect<number, never, never>, getScheduledFromStorage: () => Effect.Effect<number | null, never, never>): TaskExecuteContext<S>;
|
|
27
|
+
/**
|
|
28
|
+
* Create TaskIdleContext for onIdle handler.
|
|
29
|
+
*/
|
|
30
|
+
export declare function createTaskIdleContext<S>(stateHolder: TaskStateHolder<S>, scheduleHolder: TaskScheduleHolder, instanceId: string, jobName: string, idleReason: "onEvent" | "execute", getState: () => Effect.Effect<S | null, never, never>, getScheduledFromStorage: () => Effect.Effect<number | null, never, never>): TaskIdleContext<S>;
|
|
31
|
+
/**
|
|
32
|
+
* Create TaskErrorContext for onError handler.
|
|
33
|
+
*/
|
|
34
|
+
export declare function createTaskErrorContext<S>(stateHolder: TaskStateHolder<S>, scheduleHolder: TaskScheduleHolder, instanceId: string, jobName: string, errorSource: "onEvent" | "execute", getState: () => Effect.Effect<S | null, never, never>, getScheduledFromStorage: () => Effect.Effect<number | null, never, never>): TaskErrorContext<S>;
|
|
35
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/handlers/task/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
// packages/jobs/src/handlers/task/context.ts
|
|
2
|
+
import { Effect, Duration } from "effect";
|
|
3
|
+
import { TerminateSignal } from "../../errors";
|
|
4
|
+
// =============================================================================
|
|
5
|
+
// Effect Factories
|
|
6
|
+
// =============================================================================
|
|
7
|
+
/**
|
|
8
|
+
* Create the common scheduling effects.
|
|
9
|
+
* Shared between onEvent and execute contexts.
|
|
10
|
+
*/
|
|
11
|
+
function createSchedulingEffects(scheduleHolder, getScheduledFromStorage) {
|
|
12
|
+
return {
|
|
13
|
+
schedule: (when) => Effect.sync(() => {
|
|
14
|
+
let timestamp;
|
|
15
|
+
if (when instanceof Date) {
|
|
16
|
+
timestamp = when.getTime();
|
|
17
|
+
}
|
|
18
|
+
else if (typeof when === "number") {
|
|
19
|
+
timestamp = when;
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
timestamp = Date.now() + Duration.toMillis(Duration.decode(when));
|
|
23
|
+
}
|
|
24
|
+
scheduleHolder.scheduledAt = timestamp;
|
|
25
|
+
scheduleHolder.cancelled = false;
|
|
26
|
+
scheduleHolder.dirty = true;
|
|
27
|
+
}),
|
|
28
|
+
cancelSchedule: () => Effect.sync(() => {
|
|
29
|
+
scheduleHolder.scheduledAt = null;
|
|
30
|
+
scheduleHolder.cancelled = true;
|
|
31
|
+
scheduleHolder.dirty = true;
|
|
32
|
+
}),
|
|
33
|
+
getScheduledTime: () => scheduleHolder.dirty
|
|
34
|
+
? Effect.succeed(scheduleHolder.scheduledAt)
|
|
35
|
+
: getScheduledFromStorage(),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
// =============================================================================
|
|
39
|
+
// Context Factories
|
|
40
|
+
// =============================================================================
|
|
41
|
+
/**
|
|
42
|
+
* Create TaskEventContext for onEvent handler.
|
|
43
|
+
* Note: event is passed separately to onEvent, not via context.
|
|
44
|
+
*/
|
|
45
|
+
export function createTaskEventContext(stateHolder, scheduleHolder, instanceId, jobName, executionStartedAt, getEventCount, getCreatedAt, getScheduledFromStorage) {
|
|
46
|
+
const scheduling = createSchedulingEffects(scheduleHolder, getScheduledFromStorage);
|
|
47
|
+
// Capture isFirstEvent at context creation time (before state might change)
|
|
48
|
+
const isFirstEvent = stateHolder.current === null;
|
|
49
|
+
return {
|
|
50
|
+
// State access (Effect-based)
|
|
51
|
+
state: Effect.sync(() => stateHolder.current),
|
|
52
|
+
// State mutations
|
|
53
|
+
setState: (state) => Effect.sync(() => {
|
|
54
|
+
stateHolder.current = state;
|
|
55
|
+
stateHolder.dirty = true;
|
|
56
|
+
}),
|
|
57
|
+
updateState: (fn) => Effect.sync(() => {
|
|
58
|
+
if (stateHolder.current !== null) {
|
|
59
|
+
stateHolder.current = fn(stateHolder.current);
|
|
60
|
+
stateHolder.dirty = true;
|
|
61
|
+
}
|
|
62
|
+
}),
|
|
63
|
+
// Scheduling
|
|
64
|
+
...scheduling,
|
|
65
|
+
// Cleanup
|
|
66
|
+
terminate: () => Effect.fail(new TerminateSignal({ reason: "terminate", purgeState: true })),
|
|
67
|
+
// Metadata
|
|
68
|
+
instanceId,
|
|
69
|
+
jobName,
|
|
70
|
+
executionStartedAt,
|
|
71
|
+
isFirstEvent,
|
|
72
|
+
// Metadata (Effects)
|
|
73
|
+
eventCount: getEventCount(),
|
|
74
|
+
createdAt: getCreatedAt(),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Create TaskExecuteContext for execute handler.
|
|
79
|
+
*/
|
|
80
|
+
export function createTaskExecuteContext(stateHolder, scheduleHolder, instanceId, jobName, executionStartedAt, getState, getEventCount, getCreatedAt, getExecuteCount, getScheduledFromStorage) {
|
|
81
|
+
const scheduling = createSchedulingEffects(scheduleHolder, getScheduledFromStorage);
|
|
82
|
+
return {
|
|
83
|
+
// State access (Effect - loaded on demand, but uses holder if dirty)
|
|
84
|
+
state: stateHolder.dirty
|
|
85
|
+
? Effect.succeed(stateHolder.current)
|
|
86
|
+
: getState(),
|
|
87
|
+
// State mutations
|
|
88
|
+
setState: (state) => Effect.sync(() => {
|
|
89
|
+
stateHolder.current = state;
|
|
90
|
+
stateHolder.dirty = true;
|
|
91
|
+
}),
|
|
92
|
+
updateState: (fn) => Effect.gen(function* () {
|
|
93
|
+
const current = stateHolder.dirty
|
|
94
|
+
? stateHolder.current
|
|
95
|
+
: yield* getState();
|
|
96
|
+
if (current !== null) {
|
|
97
|
+
stateHolder.current = fn(current);
|
|
98
|
+
stateHolder.dirty = true;
|
|
99
|
+
}
|
|
100
|
+
}),
|
|
101
|
+
// Scheduling
|
|
102
|
+
...scheduling,
|
|
103
|
+
// Cleanup
|
|
104
|
+
terminate: () => Effect.fail(new TerminateSignal({ reason: "terminate", purgeState: true })),
|
|
105
|
+
// Metadata
|
|
106
|
+
instanceId,
|
|
107
|
+
jobName,
|
|
108
|
+
executionStartedAt,
|
|
109
|
+
// Metadata (Effects)
|
|
110
|
+
eventCount: getEventCount(),
|
|
111
|
+
createdAt: getCreatedAt(),
|
|
112
|
+
executeCount: getExecuteCount(),
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Create TaskIdleContext for onIdle handler.
|
|
117
|
+
*/
|
|
118
|
+
export function createTaskIdleContext(stateHolder, scheduleHolder, instanceId, jobName, idleReason, getState, getScheduledFromStorage) {
|
|
119
|
+
const scheduling = createSchedulingEffects(scheduleHolder, getScheduledFromStorage);
|
|
120
|
+
return {
|
|
121
|
+
state: stateHolder.dirty
|
|
122
|
+
? Effect.succeed(stateHolder.current)
|
|
123
|
+
: getState(),
|
|
124
|
+
schedule: scheduling.schedule,
|
|
125
|
+
terminate: () => Effect.fail(new TerminateSignal({ reason: "terminate", purgeState: true })),
|
|
126
|
+
instanceId,
|
|
127
|
+
jobName,
|
|
128
|
+
idleReason,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Create TaskErrorContext for onError handler.
|
|
133
|
+
*/
|
|
134
|
+
export function createTaskErrorContext(stateHolder, scheduleHolder, instanceId, jobName, errorSource, getState, getScheduledFromStorage) {
|
|
135
|
+
const scheduling = createSchedulingEffects(scheduleHolder, getScheduledFromStorage);
|
|
136
|
+
return {
|
|
137
|
+
state: stateHolder.dirty
|
|
138
|
+
? Effect.succeed(stateHolder.current)
|
|
139
|
+
: getState(),
|
|
140
|
+
updateState: (fn) => Effect.gen(function* () {
|
|
141
|
+
const current = stateHolder.dirty
|
|
142
|
+
? stateHolder.current
|
|
143
|
+
: yield* getState();
|
|
144
|
+
if (current !== null) {
|
|
145
|
+
stateHolder.current = fn(current);
|
|
146
|
+
stateHolder.dirty = true;
|
|
147
|
+
}
|
|
148
|
+
}),
|
|
149
|
+
schedule: scheduling.schedule,
|
|
150
|
+
terminate: () => Effect.fail(new TerminateSignal({ reason: "terminate", purgeState: true })),
|
|
151
|
+
instanceId,
|
|
152
|
+
jobName,
|
|
153
|
+
errorSource,
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../src/handlers/task/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Context, Layer } from "effect";
|
|
2
|
+
import { RuntimeAdapter, StorageAdapter } from "@durable-effect/core";
|
|
3
|
+
import { MetadataService } from "../../services/metadata";
|
|
4
|
+
import { AlarmService } from "../../services/alarm";
|
|
5
|
+
import { RegistryService } from "../../services/registry";
|
|
6
|
+
import { JobExecutionService } from "../../services/execution";
|
|
7
|
+
import type { TaskHandlerI } from "./types";
|
|
8
|
+
declare const TaskHandler_base: Context.TagClass<TaskHandler, "@durable-effect/jobs/TaskHandler", TaskHandlerI>;
|
|
9
|
+
export declare class TaskHandler extends TaskHandler_base {
|
|
10
|
+
}
|
|
11
|
+
export declare const TaskHandlerLayer: Layer.Layer<TaskHandler, never, MetadataService | RuntimeAdapter | StorageAdapter | AlarmService | RegistryService | JobExecutionService>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../src/handlers/task/handler.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAU,KAAK,EAAU,MAAM,QAAQ,CAAC;AACxD,OAAO,EACL,cAAc,EACd,cAAc,EAGf,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAW/D,OAAO,KAAK,EAAE,YAAY,EAAgB,MAAM,SAAS,CAAC;;AAU1D,qBAAa,WAAY,SAAQ,gBAEH;CAAG;AAIjC,eAAO,MAAM,gBAAgB,2IA2Z5B,CAAC"}
|
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
// packages/jobs/src/handlers/task/handler.ts
|
|
2
|
+
import { Context, Effect, Layer, Schema } from "effect";
|
|
3
|
+
import { RuntimeAdapter, StorageAdapter, } from "@durable-effect/core";
|
|
4
|
+
import { MetadataService } from "../../services/metadata";
|
|
5
|
+
import { AlarmService } from "../../services/alarm";
|
|
6
|
+
import { createEntityStateService } from "../../services/entity-state";
|
|
7
|
+
import { RegistryService } from "../../services/registry";
|
|
8
|
+
import { JobExecutionService } from "../../services/execution";
|
|
9
|
+
import { KEYS } from "../../storage-keys";
|
|
10
|
+
import { JobNotFoundError, ExecutionError, TerminateSignal, } from "../../errors";
|
|
11
|
+
import { createTaskEventContext, createTaskExecuteContext, createTaskIdleContext, createTaskErrorContext, } from "./context";
|
|
12
|
+
export class TaskHandler extends Context.Tag("@durable-effect/jobs/TaskHandler")() {
|
|
13
|
+
}
|
|
14
|
+
export const TaskHandlerLayer = Layer.effect(TaskHandler, Effect.gen(function* () {
|
|
15
|
+
const registryService = yield* RegistryService;
|
|
16
|
+
const metadata = yield* MetadataService;
|
|
17
|
+
const alarm = yield* AlarmService;
|
|
18
|
+
const runtime = yield* RuntimeAdapter;
|
|
19
|
+
const storage = yield* StorageAdapter;
|
|
20
|
+
const execution = yield* JobExecutionService;
|
|
21
|
+
const withStorage = (effect) => Effect.provideService(effect, StorageAdapter, storage);
|
|
22
|
+
const getDefinition = (name) => {
|
|
23
|
+
const def = registryService.registry.task[name];
|
|
24
|
+
if (!def) {
|
|
25
|
+
return Effect.fail(new JobNotFoundError({ type: "task", name }));
|
|
26
|
+
}
|
|
27
|
+
return Effect.succeed(def);
|
|
28
|
+
};
|
|
29
|
+
const getEventCount = () => storage
|
|
30
|
+
.get(KEYS.TASK.EVENT_COUNT)
|
|
31
|
+
.pipe(Effect.map((n) => n ?? 0));
|
|
32
|
+
const incrementEventCount = () => Effect.gen(function* () {
|
|
33
|
+
const current = yield* getEventCount();
|
|
34
|
+
const next = current + 1;
|
|
35
|
+
yield* storage.put(KEYS.TASK.EVENT_COUNT, next);
|
|
36
|
+
return next;
|
|
37
|
+
});
|
|
38
|
+
const getExecuteCount = () => storage
|
|
39
|
+
.get(KEYS.TASK.EXECUTE_COUNT)
|
|
40
|
+
.pipe(Effect.map((n) => n ?? 0));
|
|
41
|
+
const incrementExecuteCount = () => Effect.gen(function* () {
|
|
42
|
+
const current = yield* getExecuteCount();
|
|
43
|
+
const next = current + 1;
|
|
44
|
+
yield* storage.put(KEYS.TASK.EXECUTE_COUNT, next);
|
|
45
|
+
return next;
|
|
46
|
+
});
|
|
47
|
+
const getCreatedAt = () => storage.get(KEYS.TASK.CREATED_AT);
|
|
48
|
+
const setCreatedAt = (timestamp) => storage.put(KEYS.TASK.CREATED_AT, timestamp);
|
|
49
|
+
const getScheduledAt = () => storage
|
|
50
|
+
.get(KEYS.TASK.SCHEDULED_AT)
|
|
51
|
+
.pipe(Effect.map((t) => t ?? null));
|
|
52
|
+
const setScheduledAt = (timestamp) => timestamp === null
|
|
53
|
+
? storage.delete(KEYS.TASK.SCHEDULED_AT).pipe(Effect.asVoid)
|
|
54
|
+
: storage.put(KEYS.TASK.SCHEDULED_AT, timestamp);
|
|
55
|
+
const purge = () => Effect.gen(function* () {
|
|
56
|
+
yield* alarm.cancel();
|
|
57
|
+
yield* storage.deleteAll();
|
|
58
|
+
});
|
|
59
|
+
const applyScheduleChanges = (holder) => Effect.gen(function* () {
|
|
60
|
+
if (!holder.dirty)
|
|
61
|
+
return;
|
|
62
|
+
if (holder.cancelled) {
|
|
63
|
+
yield* alarm.cancel();
|
|
64
|
+
yield* setScheduledAt(null);
|
|
65
|
+
}
|
|
66
|
+
else if (holder.scheduledAt !== null) {
|
|
67
|
+
yield* alarm.schedule(holder.scheduledAt);
|
|
68
|
+
yield* setScheduledAt(holder.scheduledAt);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
const runExecution = (def, runCount, triggerType, event) => execution.execute({
|
|
72
|
+
jobType: "task",
|
|
73
|
+
jobName: def.name,
|
|
74
|
+
schema: def.stateSchema,
|
|
75
|
+
retryConfig: undefined,
|
|
76
|
+
runCount,
|
|
77
|
+
allowNullState: true,
|
|
78
|
+
createContext: (base) => {
|
|
79
|
+
const scheduleHolder = {
|
|
80
|
+
scheduledAt: null,
|
|
81
|
+
cancelled: false,
|
|
82
|
+
dirty: false
|
|
83
|
+
};
|
|
84
|
+
// Proxy state holder for the legacy context factories
|
|
85
|
+
const proxyStateHolder = {
|
|
86
|
+
get current() { return base.getState(); },
|
|
87
|
+
set current(val) { base.setState(val); },
|
|
88
|
+
get dirty() { return true; }, // Handled by service
|
|
89
|
+
set dirty(_) { }
|
|
90
|
+
};
|
|
91
|
+
return { base, scheduleHolder, proxyStateHolder };
|
|
92
|
+
},
|
|
93
|
+
run: (metaCtx) => Effect.gen(function* () {
|
|
94
|
+
const { base, scheduleHolder, proxyStateHolder } = metaCtx;
|
|
95
|
+
// Define error handler for this scope
|
|
96
|
+
const runWithErrorHandling = (effect, errorSource) => effect.pipe(Effect.catchAll(error => {
|
|
97
|
+
// Let TerminateSignal propagate to JobExecutionService
|
|
98
|
+
if (error instanceof TerminateSignal)
|
|
99
|
+
return Effect.fail(error);
|
|
100
|
+
if (def.onError) {
|
|
101
|
+
const errorCtx = createTaskErrorContext(proxyStateHolder, scheduleHolder, base.instanceId, def.name, errorSource, () => Effect.succeed(base.getState()), () => getScheduledAt().pipe(Effect.catchAll(() => Effect.succeed(null))));
|
|
102
|
+
return def.onError(error, errorCtx);
|
|
103
|
+
}
|
|
104
|
+
return Effect.fail(error);
|
|
105
|
+
}));
|
|
106
|
+
if (triggerType === "onEvent") {
|
|
107
|
+
const ctx = createTaskEventContext(proxyStateHolder, scheduleHolder, base.instanceId, def.name, Date.now(), () => getEventCount().pipe(Effect.catchAll(() => Effect.succeed(0))), () => getCreatedAt().pipe(Effect.map(t => t ?? Date.now()), Effect.catchAll(() => Effect.succeed(Date.now()))), () => getScheduledAt().pipe(Effect.catchAll(() => Effect.succeed(null))));
|
|
108
|
+
// Pass event as first argument to make it clear it's a direct value
|
|
109
|
+
yield* runWithErrorHandling(def.onEvent(event, ctx), "onEvent");
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
const ctx = createTaskExecuteContext(proxyStateHolder, scheduleHolder, base.instanceId, def.name, Date.now(), () => Effect.succeed(base.getState()), () => getEventCount().pipe(Effect.catchAll(() => Effect.succeed(0))), () => getCreatedAt().pipe(Effect.map(t => t ?? Date.now()), Effect.catchAll(() => Effect.succeed(Date.now()))), () => getExecuteCount().pipe(Effect.catchAll(() => Effect.succeed(0))), () => getScheduledAt().pipe(Effect.catchAll(() => Effect.succeed(null))));
|
|
113
|
+
yield* runWithErrorHandling(def.execute(ctx), "execute");
|
|
114
|
+
}
|
|
115
|
+
// Apply schedule changes
|
|
116
|
+
yield* applyScheduleChanges(scheduleHolder);
|
|
117
|
+
// Maybe run onIdle
|
|
118
|
+
if (def.onIdle) {
|
|
119
|
+
// Check if scheduled
|
|
120
|
+
const scheduled = scheduleHolder.dirty
|
|
121
|
+
? scheduleHolder.scheduledAt
|
|
122
|
+
: (yield* getScheduledAt());
|
|
123
|
+
if (scheduled === null) {
|
|
124
|
+
const idleCtx = createTaskIdleContext(proxyStateHolder, scheduleHolder, base.instanceId, def.name, triggerType, () => Effect.succeed(base.getState()), () => getScheduledAt().pipe(Effect.catchAll(() => Effect.succeed(null))));
|
|
125
|
+
// onIdle doesn't have standard error handling in definition, it returns Effect<void, never, R>
|
|
126
|
+
// But let's wrap it just in case
|
|
127
|
+
yield* def.onIdle(idleCtx);
|
|
128
|
+
// Re-apply schedule changes
|
|
129
|
+
yield* applyScheduleChanges(scheduleHolder);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
})
|
|
133
|
+
});
|
|
134
|
+
const handleSend = (def, request) => Effect.gen(function* () {
|
|
135
|
+
const meta = yield* metadata.get();
|
|
136
|
+
const created = !meta;
|
|
137
|
+
const now = yield* runtime.now();
|
|
138
|
+
if (created) {
|
|
139
|
+
yield* metadata.initialize("task", request.name);
|
|
140
|
+
yield* metadata.updateStatus("running");
|
|
141
|
+
yield* setCreatedAt(now);
|
|
142
|
+
yield* storage.put(KEYS.TASK.EVENT_COUNT, 0);
|
|
143
|
+
yield* storage.put(KEYS.TASK.EXECUTE_COUNT, 0);
|
|
144
|
+
}
|
|
145
|
+
yield* incrementEventCount();
|
|
146
|
+
const decodeEvent = Schema.decodeUnknown(def.eventSchema);
|
|
147
|
+
const validatedEvent = yield* decodeEvent(request.event).pipe(Effect.mapError(e => new ExecutionError({
|
|
148
|
+
jobType: "task",
|
|
149
|
+
jobName: def.name,
|
|
150
|
+
instanceId: runtime.instanceId,
|
|
151
|
+
cause: e
|
|
152
|
+
})));
|
|
153
|
+
yield* runExecution(def, 0, "onEvent", validatedEvent);
|
|
154
|
+
const scheduledAt = yield* getScheduledAt();
|
|
155
|
+
return {
|
|
156
|
+
_type: "task.send",
|
|
157
|
+
instanceId: runtime.instanceId,
|
|
158
|
+
created,
|
|
159
|
+
scheduledAt,
|
|
160
|
+
};
|
|
161
|
+
});
|
|
162
|
+
const handleTrigger = (def) => Effect.gen(function* () {
|
|
163
|
+
const meta = yield* metadata.get();
|
|
164
|
+
if (!meta) {
|
|
165
|
+
return {
|
|
166
|
+
_type: "task.trigger",
|
|
167
|
+
instanceId: runtime.instanceId,
|
|
168
|
+
triggered: false,
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
yield* incrementExecuteCount();
|
|
172
|
+
yield* runExecution(def, 0, "execute");
|
|
173
|
+
return {
|
|
174
|
+
_type: "task.trigger",
|
|
175
|
+
instanceId: runtime.instanceId,
|
|
176
|
+
triggered: true,
|
|
177
|
+
};
|
|
178
|
+
});
|
|
179
|
+
const handleTerminate = () => Effect.gen(function* () {
|
|
180
|
+
const meta = yield* metadata.get();
|
|
181
|
+
if (!meta) {
|
|
182
|
+
return {
|
|
183
|
+
_type: "task.terminate",
|
|
184
|
+
instanceId: runtime.instanceId,
|
|
185
|
+
terminated: false,
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
yield* purge();
|
|
189
|
+
return {
|
|
190
|
+
_type: "task.terminate",
|
|
191
|
+
instanceId: runtime.instanceId,
|
|
192
|
+
terminated: true,
|
|
193
|
+
};
|
|
194
|
+
});
|
|
195
|
+
const handleStatus = () => Effect.gen(function* () {
|
|
196
|
+
const meta = yield* metadata.get();
|
|
197
|
+
if (!meta) {
|
|
198
|
+
return {
|
|
199
|
+
_type: "task.status",
|
|
200
|
+
status: "not_found",
|
|
201
|
+
scheduledAt: null,
|
|
202
|
+
createdAt: undefined,
|
|
203
|
+
eventCount: undefined,
|
|
204
|
+
executeCount: undefined,
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
const scheduledAt = yield* getScheduledAt();
|
|
208
|
+
const createdAt = yield* getCreatedAt();
|
|
209
|
+
const eventCount = yield* getEventCount();
|
|
210
|
+
const executeCount = yield* getExecuteCount();
|
|
211
|
+
return {
|
|
212
|
+
_type: "task.status",
|
|
213
|
+
status: scheduledAt !== null ? "active" : "idle",
|
|
214
|
+
scheduledAt,
|
|
215
|
+
createdAt,
|
|
216
|
+
eventCount,
|
|
217
|
+
executeCount,
|
|
218
|
+
};
|
|
219
|
+
});
|
|
220
|
+
const handleGetState = (def) => Effect.gen(function* () {
|
|
221
|
+
const meta = yield* metadata.get();
|
|
222
|
+
if (!meta) {
|
|
223
|
+
return {
|
|
224
|
+
_type: "task.getState",
|
|
225
|
+
instanceId: runtime.instanceId,
|
|
226
|
+
state: undefined,
|
|
227
|
+
scheduledAt: null,
|
|
228
|
+
createdAt: undefined,
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
const stateService = yield* withStorage(createEntityStateService(def.stateSchema));
|
|
232
|
+
const state = yield* stateService.get();
|
|
233
|
+
const scheduledAt = yield* getScheduledAt();
|
|
234
|
+
const createdAt = yield* getCreatedAt();
|
|
235
|
+
return {
|
|
236
|
+
_type: "task.getState",
|
|
237
|
+
instanceId: runtime.instanceId,
|
|
238
|
+
state,
|
|
239
|
+
scheduledAt,
|
|
240
|
+
createdAt,
|
|
241
|
+
};
|
|
242
|
+
});
|
|
243
|
+
return {
|
|
244
|
+
handle: (request) => Effect.gen(function* () {
|
|
245
|
+
const def = yield* getDefinition(request.name);
|
|
246
|
+
switch (request.action) {
|
|
247
|
+
case "send":
|
|
248
|
+
return yield* handleSend(def, request);
|
|
249
|
+
case "trigger":
|
|
250
|
+
return yield* handleTrigger(def);
|
|
251
|
+
case "terminate":
|
|
252
|
+
return yield* handleTerminate();
|
|
253
|
+
case "status":
|
|
254
|
+
return yield* handleStatus();
|
|
255
|
+
case "getState":
|
|
256
|
+
return yield* handleGetState(def);
|
|
257
|
+
}
|
|
258
|
+
}).pipe(Effect.catchTag("StorageError", (e) => Effect.fail(new ExecutionError({
|
|
259
|
+
jobType: "task",
|
|
260
|
+
jobName: request.name,
|
|
261
|
+
instanceId: runtime.instanceId,
|
|
262
|
+
cause: e,
|
|
263
|
+
})))),
|
|
264
|
+
handleAlarm: () => Effect.gen(function* () {
|
|
265
|
+
const meta = yield* metadata.get();
|
|
266
|
+
if (!meta || meta.type !== "task") {
|
|
267
|
+
return;
|
|
268
|
+
}
|
|
269
|
+
const def = yield* getDefinition(meta.name);
|
|
270
|
+
yield* incrementExecuteCount();
|
|
271
|
+
yield* runExecution(def, 0, "execute");
|
|
272
|
+
}).pipe(Effect.catchTag("StorageError", (e) => Effect.fail(new ExecutionError({
|
|
273
|
+
jobType: "task",
|
|
274
|
+
jobName: "unknown",
|
|
275
|
+
instanceId: runtime.instanceId,
|
|
276
|
+
cause: e,
|
|
277
|
+
})))),
|
|
278
|
+
};
|
|
279
|
+
}));
|
|
280
|
+
//# sourceMappingURL=handler.js.map
|