@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.
Files changed (199) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +490 -0
  3. package/dist/client/client.d.ts +34 -0
  4. package/dist/client/client.d.ts.map +1 -0
  5. package/dist/client/client.js +427 -0
  6. package/dist/client/client.js.map +1 -0
  7. package/dist/client/index.d.ts +4 -0
  8. package/dist/client/index.d.ts.map +1 -0
  9. package/dist/client/index.js +4 -0
  10. package/dist/client/index.js.map +1 -0
  11. package/dist/client/response.d.ts +99 -0
  12. package/dist/client/response.d.ts.map +1 -0
  13. package/dist/client/response.js +92 -0
  14. package/dist/client/response.js.map +1 -0
  15. package/dist/client/types.d.ts +242 -0
  16. package/dist/client/types.d.ts.map +1 -0
  17. package/dist/client/types.js +3 -0
  18. package/dist/client/types.js.map +1 -0
  19. package/dist/definitions/continuous.d.ts +110 -0
  20. package/dist/definitions/continuous.d.ts.map +1 -0
  21. package/dist/definitions/continuous.js +79 -0
  22. package/dist/definitions/continuous.js.map +1 -0
  23. package/dist/definitions/debounce.d.ts +67 -0
  24. package/dist/definitions/debounce.d.ts.map +1 -0
  25. package/dist/definitions/debounce.js +28 -0
  26. package/dist/definitions/debounce.js.map +1 -0
  27. package/dist/definitions/index.d.ts +4 -0
  28. package/dist/definitions/index.d.ts.map +1 -0
  29. package/dist/definitions/index.js +5 -0
  30. package/dist/definitions/index.js.map +1 -0
  31. package/dist/definitions/task.d.ts +234 -0
  32. package/dist/definitions/task.d.ts.map +1 -0
  33. package/dist/definitions/task.js +106 -0
  34. package/dist/definitions/task.js.map +1 -0
  35. package/dist/engine/engine.d.ts +60 -0
  36. package/dist/engine/engine.d.ts.map +1 -0
  37. package/dist/engine/engine.js +89 -0
  38. package/dist/engine/engine.js.map +1 -0
  39. package/dist/engine/index.d.ts +3 -0
  40. package/dist/engine/index.d.ts.map +1 -0
  41. package/dist/engine/index.js +3 -0
  42. package/dist/engine/index.js.map +1 -0
  43. package/dist/engine/types.d.ts +53 -0
  44. package/dist/engine/types.d.ts.map +1 -0
  45. package/dist/engine/types.js +3 -0
  46. package/dist/engine/types.js.map +1 -0
  47. package/dist/errors.d.ts +119 -0
  48. package/dist/errors.d.ts.map +1 -0
  49. package/dist/errors.js +80 -0
  50. package/dist/errors.js.map +1 -0
  51. package/dist/factory.d.ts +97 -0
  52. package/dist/factory.d.ts.map +1 -0
  53. package/dist/factory.js +94 -0
  54. package/dist/factory.js.map +1 -0
  55. package/dist/handlers/continuous/context.d.ts +25 -0
  56. package/dist/handlers/continuous/context.d.ts.map +1 -0
  57. package/dist/handlers/continuous/context.js +38 -0
  58. package/dist/handlers/continuous/context.js.map +1 -0
  59. package/dist/handlers/continuous/executor.d.ts +10 -0
  60. package/dist/handlers/continuous/executor.d.ts.map +1 -0
  61. package/dist/handlers/continuous/executor.js +83 -0
  62. package/dist/handlers/continuous/executor.js.map +1 -0
  63. package/dist/handlers/continuous/handler.d.ts +14 -0
  64. package/dist/handlers/continuous/handler.d.ts.map +1 -0
  65. package/dist/handlers/continuous/handler.js +283 -0
  66. package/dist/handlers/continuous/handler.js.map +1 -0
  67. package/dist/handlers/continuous/index.d.ts +4 -0
  68. package/dist/handlers/continuous/index.d.ts.map +1 -0
  69. package/dist/handlers/continuous/index.js +4 -0
  70. package/dist/handlers/continuous/index.js.map +1 -0
  71. package/dist/handlers/continuous/types.d.ts +36 -0
  72. package/dist/handlers/continuous/types.d.ts.map +1 -0
  73. package/dist/handlers/continuous/types.js +3 -0
  74. package/dist/handlers/continuous/types.js.map +1 -0
  75. package/dist/handlers/debounce/handler.d.ts +14 -0
  76. package/dist/handlers/debounce/handler.d.ts.map +1 -0
  77. package/dist/handlers/debounce/handler.js +261 -0
  78. package/dist/handlers/debounce/handler.js.map +1 -0
  79. package/dist/handlers/debounce/index.d.ts +3 -0
  80. package/dist/handlers/debounce/index.d.ts.map +1 -0
  81. package/dist/handlers/debounce/index.js +3 -0
  82. package/dist/handlers/debounce/index.js.map +1 -0
  83. package/dist/handlers/debounce/types.d.ts +10 -0
  84. package/dist/handlers/debounce/types.d.ts.map +1 -0
  85. package/dist/handlers/debounce/types.js +3 -0
  86. package/dist/handlers/debounce/types.js.map +1 -0
  87. package/dist/handlers/index.d.ts +14 -0
  88. package/dist/handlers/index.d.ts.map +1 -0
  89. package/dist/handlers/index.js +25 -0
  90. package/dist/handlers/index.js.map +1 -0
  91. package/dist/handlers/task/context.d.ts +35 -0
  92. package/dist/handlers/task/context.d.ts.map +1 -0
  93. package/dist/handlers/task/context.js +156 -0
  94. package/dist/handlers/task/context.js.map +1 -0
  95. package/dist/handlers/task/handler.d.ts +13 -0
  96. package/dist/handlers/task/handler.d.ts.map +1 -0
  97. package/dist/handlers/task/handler.js +280 -0
  98. package/dist/handlers/task/handler.js.map +1 -0
  99. package/dist/handlers/task/index.d.ts +3 -0
  100. package/dist/handlers/task/index.d.ts.map +1 -0
  101. package/dist/handlers/task/index.js +2 -0
  102. package/dist/handlers/task/index.js.map +1 -0
  103. package/dist/handlers/task/types.d.ts +10 -0
  104. package/dist/handlers/task/types.d.ts.map +1 -0
  105. package/dist/handlers/task/types.js +3 -0
  106. package/dist/handlers/task/types.js.map +1 -0
  107. package/dist/index.d.ts +28 -0
  108. package/dist/index.d.ts.map +1 -0
  109. package/dist/index.js +79 -0
  110. package/dist/index.js.map +1 -0
  111. package/dist/registry/index.d.ts +5 -0
  112. package/dist/registry/index.d.ts.map +1 -0
  113. package/dist/registry/index.js +4 -0
  114. package/dist/registry/index.js.map +1 -0
  115. package/dist/registry/registry.d.ts +74 -0
  116. package/dist/registry/registry.d.ts.map +1 -0
  117. package/dist/registry/registry.js +159 -0
  118. package/dist/registry/registry.js.map +1 -0
  119. package/dist/registry/typed.d.ts +146 -0
  120. package/dist/registry/typed.d.ts.map +1 -0
  121. package/dist/registry/typed.js +29 -0
  122. package/dist/registry/typed.js.map +1 -0
  123. package/dist/registry/types.d.ts +497 -0
  124. package/dist/registry/types.d.ts.map +1 -0
  125. package/dist/registry/types.js +3 -0
  126. package/dist/registry/types.js.map +1 -0
  127. package/dist/retry/errors.d.ts +31 -0
  128. package/dist/retry/errors.d.ts.map +1 -0
  129. package/dist/retry/errors.js +22 -0
  130. package/dist/retry/errors.js.map +1 -0
  131. package/dist/retry/executor.d.ts +53 -0
  132. package/dist/retry/executor.d.ts.map +1 -0
  133. package/dist/retry/executor.js +112 -0
  134. package/dist/retry/executor.js.map +1 -0
  135. package/dist/retry/index.d.ts +4 -0
  136. package/dist/retry/index.d.ts.map +1 -0
  137. package/dist/retry/index.js +4 -0
  138. package/dist/retry/index.js.map +1 -0
  139. package/dist/retry/types.d.ts +29 -0
  140. package/dist/retry/types.d.ts.map +1 -0
  141. package/dist/retry/types.js +3 -0
  142. package/dist/retry/types.js.map +1 -0
  143. package/dist/runtime/dispatcher.d.ts +39 -0
  144. package/dist/runtime/dispatcher.d.ts.map +1 -0
  145. package/dist/runtime/dispatcher.js +76 -0
  146. package/dist/runtime/dispatcher.js.map +1 -0
  147. package/dist/runtime/index.d.ts +4 -0
  148. package/dist/runtime/index.d.ts.map +1 -0
  149. package/dist/runtime/index.js +6 -0
  150. package/dist/runtime/index.js.map +1 -0
  151. package/dist/runtime/runtime.d.ts +88 -0
  152. package/dist/runtime/runtime.d.ts.map +1 -0
  153. package/dist/runtime/runtime.js +116 -0
  154. package/dist/runtime/runtime.js.map +1 -0
  155. package/dist/runtime/types.d.ts +182 -0
  156. package/dist/runtime/types.d.ts.map +1 -0
  157. package/dist/runtime/types.js +3 -0
  158. package/dist/runtime/types.js.map +1 -0
  159. package/dist/services/alarm.d.ts +37 -0
  160. package/dist/services/alarm.d.ts.map +1 -0
  161. package/dist/services/alarm.js +39 -0
  162. package/dist/services/alarm.js.map +1 -0
  163. package/dist/services/cleanup.d.ts +27 -0
  164. package/dist/services/cleanup.d.ts.map +1 -0
  165. package/dist/services/cleanup.js +25 -0
  166. package/dist/services/cleanup.js.map +1 -0
  167. package/dist/services/entity-state.d.ts +49 -0
  168. package/dist/services/entity-state.d.ts.map +1 -0
  169. package/dist/services/entity-state.js +72 -0
  170. package/dist/services/entity-state.js.map +1 -0
  171. package/dist/services/execution.d.ts +70 -0
  172. package/dist/services/execution.d.ts.map +1 -0
  173. package/dist/services/execution.js +159 -0
  174. package/dist/services/execution.js.map +1 -0
  175. package/dist/services/execution_test.d.ts +13 -0
  176. package/dist/services/execution_test.d.ts.map +1 -0
  177. package/dist/services/execution_test.js +11 -0
  178. package/dist/services/execution_test.js.map +1 -0
  179. package/dist/services/idempotency.d.ts +36 -0
  180. package/dist/services/idempotency.d.ts.map +1 -0
  181. package/dist/services/idempotency.js +48 -0
  182. package/dist/services/idempotency.js.map +1 -0
  183. package/dist/services/index.d.ts +19 -0
  184. package/dist/services/index.d.ts.map +1 -0
  185. package/dist/services/index.js +33 -0
  186. package/dist/services/index.js.map +1 -0
  187. package/dist/services/metadata.d.ts +64 -0
  188. package/dist/services/metadata.d.ts.map +1 -0
  189. package/dist/services/metadata.js +56 -0
  190. package/dist/services/metadata.js.map +1 -0
  191. package/dist/services/registry.d.ts +19 -0
  192. package/dist/services/registry.d.ts.map +1 -0
  193. package/dist/services/registry.js +17 -0
  194. package/dist/services/registry.js.map +1 -0
  195. package/dist/storage-keys.d.ts +38 -0
  196. package/dist/storage-keys.d.ts.map +1 -0
  197. package/dist/storage-keys.js +47 -0
  198. package/dist/storage-keys.js.map +1 -0
  199. 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,3 @@
1
+ export { DebounceHandler, DebounceHandlerLayer, } from "./handler";
2
+ export type { DebounceHandlerI, DebounceResponse } from "./types";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ // packages/jobs/src/handlers/debounce/index.ts
2
+ export { DebounceHandler, DebounceHandlerLayer, } from "./handler";
3
+ //# sourceMappingURL=index.js.map
@@ -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,3 @@
1
+ // packages/jobs/src/handlers/debounce/types.ts
2
+ export {};
3
+ //# sourceMappingURL=types.js.map
@@ -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