@bluelibs/runner 5.4.0 → 5.5.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.
Files changed (170) hide show
  1. package/README.md +23 -22
  2. package/dist/browser/index.cjs +5426 -2403
  3. package/dist/browser/index.cjs.map +1 -1
  4. package/dist/browser/index.mjs +5426 -2400
  5. package/dist/browser/index.mjs.map +1 -1
  6. package/dist/edge/index.cjs +5426 -2403
  7. package/dist/edge/index.cjs.map +1 -1
  8. package/dist/edge/index.mjs +5426 -2400
  9. package/dist/edge/index.mjs.map +1 -1
  10. package/dist/node/node.cjs +7208 -6935
  11. package/dist/node/node.cjs.map +1 -1
  12. package/dist/node/node.mjs +7167 -6936
  13. package/dist/node/node.mjs.map +1 -1
  14. package/dist/types/definers/builders/asyncContext/fluent-builder.interface.d.ts +4 -0
  15. package/dist/types/definers/builders/error/fluent-builder.interface.d.ts +8 -1
  16. package/dist/types/definers/builders/error/index.d.ts +1 -0
  17. package/dist/types/definers/builders/error/types.d.ts +2 -1
  18. package/dist/types/definers/builders/error/utils.d.ts +1 -0
  19. package/dist/types/definers/builders/event/fluent-builder.interface.d.ts +10 -0
  20. package/dist/types/definers/builders/hook/fluent-builder.interface.d.ts +3 -0
  21. package/dist/types/definers/builders/hook/types.d.ts +3 -0
  22. package/dist/types/definers/builders/middleware/index.d.ts +4 -2
  23. package/dist/types/definers/builders/middleware/resource.interface.d.ts +7 -0
  24. package/dist/types/definers/builders/middleware/task.interface.d.ts +7 -0
  25. package/dist/types/definers/builders/middleware/types.d.ts +22 -3
  26. package/dist/types/definers/builders/middleware/utils.d.ts +2 -0
  27. package/dist/types/definers/builders/override/hook.d.ts +3 -0
  28. package/dist/types/definers/builders/override/index.d.ts +5 -0
  29. package/dist/types/definers/builders/resource/fluent-builder.interface.d.ts +15 -0
  30. package/dist/types/definers/builders/resource/index.d.ts +0 -1
  31. package/dist/types/definers/builders/resource/types.d.ts +1 -0
  32. package/dist/types/definers/builders/tag/fluent-builder.interface.d.ts +4 -0
  33. package/dist/types/definers/builders/tag/utils.d.ts +1 -0
  34. package/dist/types/definers/builders/task/fluent-builder.interface.d.ts +4 -0
  35. package/dist/types/definers/builders/task/index.d.ts +2 -2
  36. package/dist/types/definers/builders/utils.d.ts +6 -1
  37. package/dist/types/definers/defineError.d.ts +12 -2
  38. package/dist/types/definers/resourceFork.d.ts +3 -1
  39. package/dist/types/definers/tools.d.ts +12 -12
  40. package/dist/types/errors/domain-error-ids.d.ts +44 -0
  41. package/dist/types/errors/domain-runtime.errors.d.ts +136 -0
  42. package/dist/types/errors/foundation.errors.d.ts +125 -0
  43. package/dist/types/errors/generic.errors.d.ts +1 -0
  44. package/dist/types/errors/model-runtime.errors.d.ts +20 -0
  45. package/dist/types/errors.d.ts +5 -73
  46. package/dist/types/globals/cron/cron-parser.d.ts +4 -0
  47. package/dist/types/globals/cron/cron.errors.d.ts +8 -0
  48. package/dist/types/globals/cron/cron.resource.d.ts +12 -0
  49. package/dist/types/globals/cron/cron.tag.d.ts +2 -0
  50. package/dist/types/globals/cron/types.d.ts +25 -0
  51. package/dist/types/globals/globalMiddleware.d.ts +87 -13
  52. package/dist/types/globals/globalResources.d.ts +110 -24
  53. package/dist/types/globals/globalTags.d.ts +10 -2
  54. package/dist/types/globals/middleware/cache.middleware.d.ts +173 -13
  55. package/dist/types/globals/middleware/circuitBreaker.middleware.d.ts +5 -1
  56. package/dist/types/globals/middleware/concurrency.middleware.d.ts +3 -0
  57. package/dist/types/globals/middleware/fallback.middleware.d.ts +8 -1
  58. package/dist/types/globals/middleware/rateLimit.middleware.d.ts +4 -1
  59. package/dist/types/globals/middleware/retry.middleware.d.ts +5 -0
  60. package/dist/types/globals/middleware/temporal.middleware.d.ts +19 -19
  61. package/dist/types/globals/middleware/timeout.middleware.d.ts +4 -1
  62. package/dist/types/globals/resources/eventManager.resource.d.ts +2 -0
  63. package/dist/types/globals/resources/logger.resource.d.ts +2 -0
  64. package/dist/types/globals/resources/middlewareManager.resource.d.ts +2 -0
  65. package/dist/types/globals/resources/queue.resource.d.ts +2 -0
  66. package/dist/types/globals/resources/runtime.resource.d.ts +2 -0
  67. package/dist/types/globals/resources/serializer.resource.d.ts +2 -0
  68. package/dist/types/globals/resources/store.resource.d.ts +2 -0
  69. package/dist/types/globals/resources/taskRunner.resource.d.ts +2 -0
  70. package/dist/types/globals/resources/tunnel/plan.d.ts +6 -3
  71. package/dist/types/globals/resources/tunnel/tunnel.policy.tag.d.ts +2 -0
  72. package/dist/types/globals/resources/tunnel/types.d.ts +7 -2
  73. package/dist/types/globals/types.d.ts +6 -1
  74. package/dist/types/models/BuiltinsRegistry.d.ts +2 -0
  75. package/dist/types/models/DependencyProcessor.d.ts +26 -5
  76. package/dist/types/models/EventManager.d.ts +9 -9
  77. package/dist/types/models/LogPrinter.d.ts +5 -5
  78. package/dist/types/models/Logger.d.ts +16 -16
  79. package/dist/types/models/MiddlewareManager.d.ts +18 -0
  80. package/dist/types/models/OverrideManager.d.ts +4 -1
  81. package/dist/types/models/Queue.d.ts +2 -0
  82. package/dist/types/models/RunResult.d.ts +290 -26
  83. package/dist/types/models/Store.d.ts +20 -3
  84. package/dist/types/models/StoreRegistry.d.ts +2 -0
  85. package/dist/types/models/StoreValidator.d.ts +2 -0
  86. package/dist/types/models/TaskRunner.d.ts +3 -1
  87. package/dist/types/models/VisibilityTracker.d.ts +75 -0
  88. package/dist/types/models/dependency-processor/DependencyExtractor.d.ts +23 -0
  89. package/dist/types/models/dependency-processor/HookEventBuffer.d.ts +15 -0
  90. package/dist/types/models/dependency-processor/ResourceScheduler.d.ts +10 -0
  91. package/dist/types/models/event/EmissionExecutor.d.ts +5 -4
  92. package/dist/types/models/event/ListenerRegistry.d.ts +2 -0
  93. package/dist/types/models/index.d.ts +1 -3
  94. package/dist/types/models/middleware/InterceptorRegistry.d.ts +13 -4
  95. package/dist/types/models/middleware/ResourceMiddlewareComposer.d.ts +1 -0
  96. package/dist/types/models/middleware/ValidationHelper.d.ts +3 -6
  97. package/dist/types/models/utils/disposeOrder.d.ts +5 -1
  98. package/dist/types/models/utils/resourceDependencyIds.d.ts +1 -0
  99. package/dist/types/node/durable/bus/MemoryEventBus.d.ts +10 -1
  100. package/dist/types/node/durable/bus/NoopEventBus.d.ts +1 -1
  101. package/dist/types/node/durable/bus/RedisEventBus.d.ts +8 -2
  102. package/dist/types/node/durable/core/CronParser.d.ts +2 -13
  103. package/dist/types/node/durable/core/DurableResource.d.ts +14 -32
  104. package/dist/types/node/durable/core/DurableService.d.ts +1 -0
  105. package/dist/types/node/durable/core/DurableWorker.d.ts +4 -2
  106. package/dist/types/node/durable/core/createRunnerDurableRuntime.d.ts +2 -0
  107. package/dist/types/node/durable/core/interfaces/bus.d.ts +1 -1
  108. package/dist/types/node/durable/core/interfaces/resource.d.ts +61 -0
  109. package/dist/types/node/durable/core/interfaces/service.d.ts +2 -0
  110. package/dist/types/node/durable/core/interfaces/store.d.ts +5 -0
  111. package/dist/types/node/durable/core/managers/ExecutionManager.d.ts +1 -0
  112. package/dist/types/node/durable/core/managers/PollingManager.d.ts +3 -1
  113. package/dist/types/node/durable/core/resource.d.ts +4 -3
  114. package/dist/types/node/durable/core/utils.d.ts +11 -1
  115. package/dist/types/node/durable/queue/RabbitMQQueue.d.ts +4 -0
  116. package/dist/types/node/durable/resources/memoryDurableResource.d.ts +5 -3
  117. package/dist/types/node/durable/resources/redisDurableResource.d.ts +5 -3
  118. package/dist/types/node/durable/store/MemoryStore.d.ts +2 -0
  119. package/dist/types/node/durable/store/RedisStore.d.ts +1 -0
  120. package/dist/types/node/exposure/allowList.d.ts +2 -1
  121. package/dist/types/node/exposure/handlers/contextWrapper.d.ts +6 -2
  122. package/dist/types/node/exposure/handlers/errorHandlers.d.ts +1 -0
  123. package/dist/types/node/exposure/handlers/eventHandler.d.ts +1 -0
  124. package/dist/types/node/exposure/handlers/taskHandler.d.ts +3 -1
  125. package/dist/types/node/exposure/logging.d.ts +1 -0
  126. package/dist/types/node/exposure/requestHandlers.d.ts +3 -1
  127. package/dist/types/node/exposure/requestIdentity.d.ts +3 -0
  128. package/dist/types/node/exposure/resource.d.ts +4 -4
  129. package/dist/types/node/exposure/resourceTypes.d.ts +6 -0
  130. package/dist/types/node/exposure/serverLifecycle.d.ts +2 -0
  131. package/dist/types/node/node.d.ts +1 -1
  132. package/dist/types/node/tunnel/allowlist.d.ts +10 -1
  133. package/dist/types/platform/adapters/browser.d.ts +1 -1
  134. package/dist/types/platform/adapters/node-als.d.ts +1 -1
  135. package/dist/types/platform/adapters/node.d.ts +1 -1
  136. package/dist/types/platform/adapters/universal-generic.d.ts +2 -2
  137. package/dist/types/platform/adapters/universal.d.ts +1 -1
  138. package/dist/types/platform/index.d.ts +2 -2
  139. package/dist/types/platform/types.d.ts +1 -1
  140. package/dist/types/public.d.ts +374 -20
  141. package/dist/types/run.d.ts +17 -1
  142. package/dist/types/serializer/Serializer.d.ts +1 -41
  143. package/dist/types/serializer/errors.d.ts +8 -0
  144. package/dist/types/serializer/marker-key-escapes.d.ts +2 -0
  145. package/dist/types/serializer/serialize-utils.d.ts +1 -1
  146. package/dist/types/serializer/type-registry.d.ts +0 -1
  147. package/dist/types/serializer/types.d.ts +7 -6
  148. package/dist/types/testing.d.ts +1 -0
  149. package/dist/types/tools/getAllThrows.d.ts +13 -0
  150. package/dist/types/tools/throws.d.ts +1 -1
  151. package/dist/types/types/error.d.ts +25 -2
  152. package/dist/types/types/event.d.ts +35 -0
  153. package/dist/types/types/hook.d.ts +8 -0
  154. package/dist/types/types/resource.d.ts +13 -1
  155. package/dist/types/types/resourceMiddleware.d.ts +8 -0
  156. package/dist/types/types/runner.d.ts +56 -0
  157. package/dist/types/types/storeTypes.d.ts +5 -1
  158. package/dist/types/types/tag.d.ts +1 -0
  159. package/dist/types/types/tagged.d.ts +2 -2
  160. package/dist/types/types/task.d.ts +2 -2
  161. package/dist/types/types/taskMiddleware.d.ts +8 -0
  162. package/dist/types/types/utilities.d.ts +25 -3
  163. package/dist/ui/assets/{index-Bo7Gi6Vq.js → index-B4lZaXFJ.js} +48 -48
  164. package/dist/ui/index.html +1 -1
  165. package/dist/universal/index.cjs +5426 -2403
  166. package/dist/universal/index.cjs.map +1 -1
  167. package/dist/universal/index.mjs +5426 -2400
  168. package/dist/universal/index.mjs.map +1 -1
  169. package/package.json +18 -14
  170. package/readmes/AI.md +147 -42
@@ -13,23 +13,114 @@ declare const globals: {
13
13
  readonly eventManager: import("./defs").IResource<void, Promise<import("./models").EventManager>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
14
14
  readonly taskRunner: import("./defs").IResource<void, Promise<import("./models").TaskRunner>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
15
15
  readonly logger: import("./defs").IResource<void, Promise<import("./models").Logger>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
16
+ readonly debug: import("./defs").IResource<import("./public").DebugFriendlyConfig, Promise<any>, {}, any, {
17
+ title: string;
18
+ description: string;
19
+ }, import("./defs").ITag<{
20
+ metadata?: Record<string, any>;
21
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
16
22
  readonly serializer: import("./defs").IResource<void, Promise<import("./serializer").SerializerLike>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
17
23
  readonly cache: import("./defs").IResource<import("./public").CacheResourceConfig, Promise<{
18
24
  map: Map<string, import("./defs").ICacheInstance>;
19
- cacheFactoryTask: import("./defs").TaskDependencyWithIntercept<import("lru-cache").LRUCache.Options<any, any, any>, Promise<import("./defs").ICacheInstance>>;
20
- defaultOptions: any;
25
+ pendingCreates: Map<string, Promise<import("./defs").ICacheInstance>>;
26
+ cacheFactoryTask: import("./defs").TaskDependencyWithIntercept<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>>;
27
+ defaultOptions: {
28
+ ttl: number;
29
+ max: number;
30
+ ttlAutopurge: boolean;
31
+ } | {
32
+ max: import("lru-cache/raw").LRUCache.Count;
33
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
34
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
35
+ ttlAutopurge: boolean;
36
+ updateAgeOnGet?: boolean | undefined;
37
+ updateAgeOnHas?: boolean | undefined;
38
+ allowStale?: boolean | undefined;
39
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
40
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
41
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
42
+ noDisposeOnSet?: boolean | undefined;
43
+ noUpdateTTL?: boolean | undefined;
44
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
45
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
46
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
47
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
48
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
49
+ noDeleteOnFetchRejection?: boolean | undefined;
50
+ noDeleteOnStaleGet?: boolean | undefined;
51
+ allowStaleOnFetchRejection?: boolean | undefined;
52
+ allowStaleOnFetchAbort?: boolean | undefined;
53
+ ignoreFetchAbort?: boolean | undefined;
54
+ perf?: import("lru-cache/raw").Perf | undefined;
55
+ } | {
56
+ maxSize?: number | undefined;
57
+ max: import("lru-cache/raw").LRUCache.Count;
58
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
59
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
60
+ ttlAutopurge: boolean;
61
+ updateAgeOnGet?: boolean | undefined;
62
+ updateAgeOnHas?: boolean | undefined;
63
+ allowStale?: boolean | undefined;
64
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
65
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
66
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
67
+ noDisposeOnSet?: boolean | undefined;
68
+ noUpdateTTL?: boolean | undefined;
69
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
70
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
71
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
72
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
73
+ noDeleteOnFetchRejection?: boolean | undefined;
74
+ noDeleteOnStaleGet?: boolean | undefined;
75
+ allowStaleOnFetchRejection?: boolean | undefined;
76
+ allowStaleOnFetchAbort?: boolean | undefined;
77
+ ignoreFetchAbort?: boolean | undefined;
78
+ perf?: import("lru-cache/raw").Perf | undefined;
79
+ } | {
80
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
81
+ ttlAutopurge: boolean;
82
+ max: import("lru-cache/raw").LRUCache.Count;
83
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
84
+ updateAgeOnGet?: boolean | undefined;
85
+ updateAgeOnHas?: boolean | undefined;
86
+ allowStale?: boolean | undefined;
87
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
88
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
89
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
90
+ noDisposeOnSet?: boolean | undefined;
91
+ noUpdateTTL?: boolean | undefined;
92
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
93
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
94
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
95
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
96
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
97
+ noDeleteOnFetchRejection?: boolean | undefined;
98
+ noDeleteOnStaleGet?: boolean | undefined;
99
+ allowStaleOnFetchRejection?: boolean | undefined;
100
+ allowStaleOnFetchAbort?: boolean | undefined;
101
+ ignoreFetchAbort?: boolean | undefined;
102
+ perf?: import("lru-cache/raw").Perf | undefined;
103
+ };
21
104
  }>, {
22
- cacheFactoryTask: import("./defs").ITask<import("lru-cache").LRUCache.Options<any, any, any>, Promise<import("./defs").ICacheInstance>, any, any, import("./defs").TagType[], import("./defs").TaskMiddlewareAttachmentType[]>;
105
+ cacheFactoryTask: import("./defs").ITask<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>, any, any, import("./defs").TagType[], import("./defs").TaskMiddlewareAttachmentType[]>;
106
+ }, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
107
+ readonly cron: import("./defs").IResource<void, Promise<import("./public").CronResourceValue>, import("./defs").DependencyMapType & {
108
+ store: typeof import("./globals/globalResources").store;
109
+ logger: typeof import("./globals/resources/logger.resource").loggerResource;
110
+ taskRunner: typeof import("./globals/resources/taskRunner.resource").taskRunnerResource;
23
111
  }, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
24
112
  readonly queue: import("./defs").IResource<void, Promise<{
25
113
  map: Map<string, import("./models").Queue>;
26
114
  run: <T>(id: string, task: (signal: AbortSignal) => Promise<T>) => Promise<T>;
27
115
  }>, {}, {
116
+ disposed: boolean;
28
117
  map: Map<string, import("./models").Queue>;
118
+ cleanupTimers: Map<string, NodeJS.Timeout>;
29
119
  }, {
30
120
  title: string;
31
121
  description: string;
32
122
  }, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
123
+ readonly runtime: import("./defs").IResource<void, Promise<import("./models").RunResult<unknown>>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
33
124
  readonly httpClientFactory: import("./defs").IResource<void, Promise<import("./public").HttpClientFactory>, {
34
125
  serializer: import("./defs").IResource<void, Promise<import("./serializer").SerializerLike>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
35
126
  store: import("./defs").IResource<void, Promise<import("./models").Store>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
@@ -47,10 +138,7 @@ declare const globals: {
47
138
  }>, {}, any, any, import("./defs").ITag<{
48
139
  metadata?: Record<string, any>;
49
140
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
50
- readonly temporal: import("./defs").IResource<void, Promise<{
51
- debounceStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").DebounceState>;
52
- throttleStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").ThrottleState>;
53
- }>, {}, any, any, import("./defs").ITag<{
141
+ readonly temporal: import("./defs").IResource<void, Promise<import("./globals/middleware/temporal.middleware").TemporalResourceState>, {}, any, any, import("./defs").ITag<{
54
142
  metadata?: Record<string, any>;
55
143
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
56
144
  readonly concurrency: import("./defs").IResource<void, Promise<{
@@ -59,6 +147,7 @@ declare const globals: {
59
147
  semaphore: import("./models").Semaphore;
60
148
  limit: number;
61
149
  }>;
150
+ semaphores: Set<import("./models").Semaphore>;
62
151
  }>, {}, any, any, import("./defs").ITag<{
63
152
  metadata?: Record<string, any>;
64
153
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
@@ -67,13 +156,92 @@ declare const globals: {
67
156
  requireContext: import("./defs").ITaskMiddleware<import("./public").RequireContextMiddlewareConfig, void, void, any>;
68
157
  task: {
69
158
  requireContext: import("./defs").ITaskMiddleware<import("./public").RequireContextMiddlewareConfig, void, void, any>;
70
- cache: import("./defs").ITaskMiddleware<any, void, void, {
159
+ cache: import("./defs").ITaskMiddleware<(Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>) & {
160
+ keyBuilder?: (taskId: string, input: unknown) => string;
161
+ }, void, void, {
71
162
  cache: import("./defs").IResource<import("./public").CacheResourceConfig, Promise<{
72
163
  map: Map<string, import("./defs").ICacheInstance>;
73
- cacheFactoryTask: import("./defs").TaskDependencyWithIntercept<import("lru-cache").LRUCache.Options<any, any, any>, Promise<import("./defs").ICacheInstance>>;
74
- defaultOptions: any;
164
+ pendingCreates: Map<string, Promise<import("./defs").ICacheInstance>>;
165
+ cacheFactoryTask: import("./defs").TaskDependencyWithIntercept<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>>;
166
+ defaultOptions: {
167
+ ttl: number;
168
+ max: number;
169
+ ttlAutopurge: boolean;
170
+ } | {
171
+ max: import("lru-cache/raw").LRUCache.Count;
172
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
173
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
174
+ ttlAutopurge: boolean;
175
+ updateAgeOnGet?: boolean | undefined;
176
+ updateAgeOnHas?: boolean | undefined;
177
+ allowStale?: boolean | undefined;
178
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
179
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
180
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
181
+ noDisposeOnSet?: boolean | undefined;
182
+ noUpdateTTL?: boolean | undefined;
183
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
184
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
185
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
186
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
187
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
188
+ noDeleteOnFetchRejection?: boolean | undefined;
189
+ noDeleteOnStaleGet?: boolean | undefined;
190
+ allowStaleOnFetchRejection?: boolean | undefined;
191
+ allowStaleOnFetchAbort?: boolean | undefined;
192
+ ignoreFetchAbort?: boolean | undefined;
193
+ perf?: import("lru-cache/raw").Perf | undefined;
194
+ } | {
195
+ maxSize?: number | undefined;
196
+ max: import("lru-cache/raw").LRUCache.Count;
197
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
198
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
199
+ ttlAutopurge: boolean;
200
+ updateAgeOnGet?: boolean | undefined;
201
+ updateAgeOnHas?: boolean | undefined;
202
+ allowStale?: boolean | undefined;
203
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
204
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
205
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
206
+ noDisposeOnSet?: boolean | undefined;
207
+ noUpdateTTL?: boolean | undefined;
208
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
209
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
210
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
211
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
212
+ noDeleteOnFetchRejection?: boolean | undefined;
213
+ noDeleteOnStaleGet?: boolean | undefined;
214
+ allowStaleOnFetchRejection?: boolean | undefined;
215
+ allowStaleOnFetchAbort?: boolean | undefined;
216
+ ignoreFetchAbort?: boolean | undefined;
217
+ perf?: import("lru-cache/raw").Perf | undefined;
218
+ } | {
219
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
220
+ ttlAutopurge: boolean;
221
+ max: import("lru-cache/raw").LRUCache.Count;
222
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
223
+ updateAgeOnGet?: boolean | undefined;
224
+ updateAgeOnHas?: boolean | undefined;
225
+ allowStale?: boolean | undefined;
226
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
227
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
228
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
229
+ noDisposeOnSet?: boolean | undefined;
230
+ noUpdateTTL?: boolean | undefined;
231
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
232
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
233
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
234
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
235
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
236
+ noDeleteOnFetchRejection?: boolean | undefined;
237
+ noDeleteOnStaleGet?: boolean | undefined;
238
+ allowStaleOnFetchRejection?: boolean | undefined;
239
+ allowStaleOnFetchAbort?: boolean | undefined;
240
+ ignoreFetchAbort?: boolean | undefined;
241
+ perf?: import("lru-cache/raw").Perf | undefined;
242
+ };
75
243
  }>, {
76
- cacheFactoryTask: import("./defs").ITask<import("lru-cache").LRUCache.Options<any, any, any>, Promise<import("./defs").ICacheInstance>, any, any, import("./defs").TagType[], import("./defs").TaskMiddlewareAttachmentType[]>;
244
+ cacheFactoryTask: import("./defs").ITask<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>, any, any, import("./defs").TagType[], import("./defs").TaskMiddlewareAttachmentType[]>;
77
245
  }, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
78
246
  }> & {
79
247
  journalKeys: {
@@ -87,25 +255,188 @@ declare const globals: {
87
255
  semaphore: import("./models").Semaphore;
88
256
  limit: number;
89
257
  }>;
258
+ semaphores: Set<import("./models").Semaphore>;
90
259
  }>, {}, any, any, import("./defs").ITag<{
91
260
  metadata?: Record<string, any>;
92
261
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
93
262
  }>;
94
263
  debounce: import("./defs").ITaskMiddleware<import("./public").TemporalMiddlewareConfig, void, void, {
95
- state: import("./defs").IResource<void, Promise<{
96
- debounceStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").DebounceState>;
97
- throttleStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").ThrottleState>;
98
- }>, {}, any, any, import("./defs").ITag<{
264
+ state: import("./defs").IResource<void, Promise<import("./globals/middleware/temporal.middleware").TemporalResourceState>, {}, any, any, import("./defs").ITag<{
99
265
  metadata?: Record<string, any>;
100
266
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
101
267
  }>;
102
268
  throttle: import("./defs").ITaskMiddleware<import("./public").TemporalMiddlewareConfig, void, void, {
269
+ state: import("./defs").IResource<void, Promise<import("./globals/middleware/temporal.middleware").TemporalResourceState>, {}, any, any, import("./defs").ITag<{
270
+ metadata?: Record<string, any>;
271
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
272
+ }>;
273
+ fallback: import("./defs").ITaskMiddleware<import("./public").FallbackMiddlewareConfig, void, void, {
274
+ taskRunner: import("./defs").IResource<void, Promise<import("./models").TaskRunner>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
275
+ }> & {
276
+ journalKeys: {
277
+ readonly active: import("./public-types").JournalKey<boolean>;
278
+ readonly error: import("./public-types").JournalKey<Error>;
279
+ };
280
+ };
281
+ rateLimit: import("./defs").ITaskMiddleware<import("./public").RateLimitMiddlewareConfig, void, void, {
103
282
  state: import("./defs").IResource<void, Promise<{
104
- debounceStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").DebounceState>;
105
- throttleStates: WeakMap<import("./public").TemporalMiddlewareConfig, import("./public").ThrottleState>;
283
+ states: WeakMap<import("./public").RateLimitMiddlewareConfig, import("./public").RateLimitState>;
106
284
  }>, {}, any, any, import("./defs").ITag<{
107
285
  metadata?: Record<string, any>;
108
286
  }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
287
+ }> & {
288
+ journalKeys: {
289
+ readonly remaining: import("./public-types").JournalKey<number>;
290
+ readonly resetTime: import("./public-types").JournalKey<number>;
291
+ readonly limit: import("./public-types").JournalKey<number>;
292
+ };
293
+ };
294
+ retry: import("./defs").ITaskMiddleware<import("./public").RetryMiddlewareConfig, void, void, any> & {
295
+ journalKeys: {
296
+ readonly attempt: import("./public-types").JournalKey<number>;
297
+ readonly lastError: import("./public-types").JournalKey<Error>;
298
+ };
299
+ };
300
+ timeout: import("./defs").ITaskMiddleware<import("./public").TimeoutMiddlewareConfig, void, void, any> & {
301
+ journalKeys: {
302
+ readonly abortController: import("./public-types").JournalKey<AbortController>;
303
+ };
304
+ };
305
+ circuitBreaker: import("./defs").ITaskMiddleware<import("./public").CircuitBreakerMiddlewareConfig, void, void, {
306
+ state: import("./defs").IResource<void, Promise<{
307
+ statusMap: Map<string, import("./public").CircuitBreakerStatus>;
308
+ }>, {}, any, any, import("./defs").ITag<{
309
+ metadata?: Record<string, any>;
310
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
311
+ }> & {
312
+ journalKeys: {
313
+ readonly state: import("./public-types").JournalKey<import("./public").CircuitBreakerState>;
314
+ readonly failures: import("./public-types").JournalKey<number>;
315
+ };
316
+ };
317
+ };
318
+ resource: {
319
+ retry: import("./defs").IResourceMiddleware<import("./public").RetryMiddlewareConfig, void, void, any>;
320
+ timeout: import("./defs").IResourceMiddleware<import("./public").TimeoutMiddlewareConfig, void, void, any>;
321
+ };
322
+ };
323
+ middlewares: {
324
+ requireContext: import("./defs").ITaskMiddleware<import("./public").RequireContextMiddlewareConfig, void, void, any>;
325
+ task: {
326
+ requireContext: import("./defs").ITaskMiddleware<import("./public").RequireContextMiddlewareConfig, void, void, any>;
327
+ cache: import("./defs").ITaskMiddleware<(Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>) & {
328
+ keyBuilder?: (taskId: string, input: unknown) => string;
329
+ }, void, void, {
330
+ cache: import("./defs").IResource<import("./public").CacheResourceConfig, Promise<{
331
+ map: Map<string, import("./defs").ICacheInstance>;
332
+ pendingCreates: Map<string, Promise<import("./defs").ICacheInstance>>;
333
+ cacheFactoryTask: import("./defs").TaskDependencyWithIntercept<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>>;
334
+ defaultOptions: {
335
+ ttl: number;
336
+ max: number;
337
+ ttlAutopurge: boolean;
338
+ } | {
339
+ max: import("lru-cache/raw").LRUCache.Count;
340
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
341
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
342
+ ttlAutopurge: boolean;
343
+ updateAgeOnGet?: boolean | undefined;
344
+ updateAgeOnHas?: boolean | undefined;
345
+ allowStale?: boolean | undefined;
346
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
347
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
348
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
349
+ noDisposeOnSet?: boolean | undefined;
350
+ noUpdateTTL?: boolean | undefined;
351
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
352
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
353
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
354
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
355
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
356
+ noDeleteOnFetchRejection?: boolean | undefined;
357
+ noDeleteOnStaleGet?: boolean | undefined;
358
+ allowStaleOnFetchRejection?: boolean | undefined;
359
+ allowStaleOnFetchAbort?: boolean | undefined;
360
+ ignoreFetchAbort?: boolean | undefined;
361
+ perf?: import("lru-cache/raw").Perf | undefined;
362
+ } | {
363
+ maxSize?: number | undefined;
364
+ max: import("lru-cache/raw").LRUCache.Count;
365
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
366
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
367
+ ttlAutopurge: boolean;
368
+ updateAgeOnGet?: boolean | undefined;
369
+ updateAgeOnHas?: boolean | undefined;
370
+ allowStale?: boolean | undefined;
371
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
372
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
373
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
374
+ noDisposeOnSet?: boolean | undefined;
375
+ noUpdateTTL?: boolean | undefined;
376
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
377
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
378
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
379
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
380
+ noDeleteOnFetchRejection?: boolean | undefined;
381
+ noDeleteOnStaleGet?: boolean | undefined;
382
+ allowStaleOnFetchRejection?: boolean | undefined;
383
+ allowStaleOnFetchAbort?: boolean | undefined;
384
+ ignoreFetchAbort?: boolean | undefined;
385
+ perf?: import("lru-cache/raw").Perf | undefined;
386
+ } | {
387
+ ttl: import("lru-cache/raw").LRUCache.Milliseconds;
388
+ ttlAutopurge: boolean;
389
+ max: import("lru-cache/raw").LRUCache.Count;
390
+ ttlResolution?: import("lru-cache/raw").LRUCache.Milliseconds | undefined;
391
+ updateAgeOnGet?: boolean | undefined;
392
+ updateAgeOnHas?: boolean | undefined;
393
+ allowStale?: boolean | undefined;
394
+ dispose?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
395
+ onInsert?: import("lru-cache/raw").LRUCache.Inserter<string, {}> | undefined;
396
+ disposeAfter?: import("lru-cache/raw").LRUCache.Disposer<string, {}> | undefined;
397
+ noDisposeOnSet?: boolean | undefined;
398
+ noUpdateTTL?: boolean | undefined;
399
+ maxSize?: import("lru-cache/raw").LRUCache.Size | undefined;
400
+ maxEntrySize?: import("lru-cache/raw").LRUCache.Size | undefined;
401
+ sizeCalculation?: import("lru-cache/raw").LRUCache.SizeCalculator<string, {}> | undefined;
402
+ fetchMethod?: import("lru-cache/raw").LRUCache.Fetcher<string, {}, unknown> | undefined;
403
+ memoMethod?: import("lru-cache/raw").LRUCache.Memoizer<string, {}, unknown> | undefined;
404
+ noDeleteOnFetchRejection?: boolean | undefined;
405
+ noDeleteOnStaleGet?: boolean | undefined;
406
+ allowStaleOnFetchRejection?: boolean | undefined;
407
+ allowStaleOnFetchAbort?: boolean | undefined;
408
+ ignoreFetchAbort?: boolean | undefined;
409
+ perf?: import("lru-cache/raw").Perf | undefined;
410
+ };
411
+ }>, {
412
+ cacheFactoryTask: import("./defs").ITask<Partial<import("lru-cache/raw").LRUCache.OptionsMaxLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsSizeLimit<string, {}, unknown>> | Partial<import("lru-cache/raw").LRUCache.OptionsTTLLimit<string, {}, unknown>>, Promise<import("./defs").ICacheInstance>, any, any, import("./defs").TagType[], import("./defs").TaskMiddlewareAttachmentType[]>;
413
+ }, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
414
+ }> & {
415
+ journalKeys: {
416
+ readonly hit: import("./public-types").JournalKey<boolean>;
417
+ };
418
+ };
419
+ concurrency: import("./defs").ITaskMiddleware<import("./public").ConcurrencyMiddlewareConfig, void, void, {
420
+ state: import("./defs").IResource<void, Promise<{
421
+ semaphoresByConfig: WeakMap<import("./public").ConcurrencyMiddlewareConfig, import("./models").Semaphore>;
422
+ semaphoresByKey: Map<string, {
423
+ semaphore: import("./models").Semaphore;
424
+ limit: number;
425
+ }>;
426
+ semaphores: Set<import("./models").Semaphore>;
427
+ }>, {}, any, any, import("./defs").ITag<{
428
+ metadata?: Record<string, any>;
429
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
430
+ }>;
431
+ debounce: import("./defs").ITaskMiddleware<import("./public").TemporalMiddlewareConfig, void, void, {
432
+ state: import("./defs").IResource<void, Promise<import("./globals/middleware/temporal.middleware").TemporalResourceState>, {}, any, any, import("./defs").ITag<{
433
+ metadata?: Record<string, any>;
434
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
435
+ }>;
436
+ throttle: import("./defs").ITaskMiddleware<import("./public").TemporalMiddlewareConfig, void, void, {
437
+ state: import("./defs").IResource<void, Promise<import("./globals/middleware/temporal.middleware").TemporalResourceState>, {}, any, any, import("./defs").ITag<{
438
+ metadata?: Record<string, any>;
439
+ }, void, void>[], import("./defs").ResourceMiddlewareAttachmentType[]>;
109
440
  }>;
110
441
  fallback: import("./defs").ITaskMiddleware<import("./public").FallbackMiddlewareConfig, void, void, {
111
442
  taskRunner: import("./defs").IResource<void, Promise<import("./models").TaskRunner>, {}, any, any, import("./defs").TagType[], import("./defs").ResourceMiddlewareAttachmentType[]>;
@@ -165,9 +496,12 @@ declare const globals: {
165
496
  metadata?: Record<string, any>;
166
497
  }, void, void>;
167
498
  debug: import("./defs").ITag<import("./public").DebugFriendlyConfig, void, void>;
499
+ cron: import("./defs").ITag<import("./public").CronTagConfig, void, void>;
168
500
  tunnel: import("./defs").ITag<void, void, import("./public").TunnelRunner>;
169
- tunnelPolicy: import("./defs").ITag<import("./public").TunnelTaskMiddlewarePolicyConfig, void, void>;
501
+ tunnelTaskPolicy: import("./defs").ITag<import("./public").TunnelTaskMiddlewarePolicyConfig, void, void>;
170
502
  authValidator: import("./defs").ITag<void, void, void>;
503
+ } & {
504
+ tunnelPolicy: typeof import("./globals/resources/tunnel/tunnel.policy.tag").tunnelTaskPolicyTag;
171
505
  };
172
506
  tunnels: Readonly<{
173
507
  http: Readonly<{
@@ -185,6 +519,24 @@ export { globals };
185
519
  export { defineTask as task, defineResource as resource, defineEvent as event, defineTaskMiddleware as taskMiddleware, defineResourceMiddleware as resourceMiddleware, defineAsyncContext as asyncContext, defineTag as tag, defineOverride as override, defineHook as hook, run, createTestResource, };
186
520
  declare const createContext: typeof oldCreateContext;
187
521
  export { createContext };
522
+ /**
523
+ * The unified fluent builder namespace for creating Runner components.
524
+ *
525
+ * @example
526
+ * ```ts
527
+ * import { r, run } from "@bluelibs/runner";
528
+ *
529
+ * const greet = r.task("app.tasks.greet")
530
+ * .inputSchema<{ name: string }>({ parse: (v) => v })
531
+ * .run(async (input) => `Hello, ${input.name}!`)
532
+ * .build();
533
+ *
534
+ * const app = r.resource("app").register([greet]).build();
535
+ * const runtime = await run(app);
536
+ * const msg = await runtime.runTask(greet, { name: "Ada" });
537
+ * await runtime.dispose();
538
+ * ```
539
+ */
188
540
  export declare const r: Readonly<{
189
541
  resource: typeof import("./definers/builders/resource").resourceBuilder;
190
542
  task: import("./public-types").TaskBuilderWithPhantom;
@@ -194,7 +546,10 @@ export declare const r: Readonly<{
194
546
  override: typeof overrideBuilder;
195
547
  asyncContext: typeof import("./definers/builders/asyncContext").asyncContextBuilder;
196
548
  error: typeof import("./definers/builders/error").errorBuilder & {
197
- is: (error: unknown) => error is import("./public").RunnerError;
549
+ is: {
550
+ (error: unknown): error is import("./public").RunnerError;
551
+ (error: unknown, partialData: Partial<import("./defs").DefaultErrorType>): error is import("./public").RunnerError;
552
+ };
198
553
  };
199
554
  middleware: Readonly<{
200
555
  task: typeof import("./definers/builders/middleware").taskMiddlewareBuilder;
@@ -210,6 +565,5 @@ export { PlatformAdapter, setPlatform } from "./platform";
210
565
  export { RunnerError } from "./definers/defineError";
211
566
  export { LockableMap } from "./tools/LockableMap";
212
567
  export * from "./http-client";
213
- export * from "./http-fetch-tunnel.resource";
214
568
  export { Serializer, SymbolPolicy, SymbolPolicyErrorMessage, } from "./serializer";
215
569
  export { journal } from "./models/ExecutionJournal";
@@ -2,13 +2,29 @@ import { IResource, IResourceWithConfig } from "./defs";
2
2
  import { RunResult } from "./models/RunResult";
3
3
  import { RunOptions } from "./types/runner";
4
4
  /**
5
- * This is the central function that kicks off you runner. You can run as many resources as you want in a single process, they will run in complete isolation.
5
+ * This is the central function that kicks off your runner. You can run as many resources as you want in a single process, they will run in complete isolation.
6
6
  *
7
7
  * @param resourceOrResourceWithConfig - The resource or resource with config to run.
8
8
  * @param options - The options for the run.
9
9
  * @returns A promise that resolves to the result of the run.
10
+ *
11
+ * @example
12
+ * ```ts
13
+ * import { r, run } from "@bluelibs/runner";
14
+ *
15
+ * const app = r.resource("app")
16
+ * .register([myTask, myService])
17
+ * .build();
18
+ *
19
+ * const runtime = await run(app);
20
+ * await runtime.runTask(myTask, { name: "Ada" });
21
+ * await runtime.dispose();
22
+ * ```
10
23
  */
11
24
  export declare function run<C, V extends Promise<any>>(resourceOrResourceWithConfig: IResourceWithConfig<C, V> | IResource<void, V, any, any> | IResource<{
12
25
  [K in any]?: any;
13
26
  }, V, any, any>, // For optional config
14
27
  options?: RunOptions): Promise<RunResult<V extends Promise<infer U> ? U : V>>;
28
+ export declare function __disposeActiveRunResultsForTests(): Promise<void>;
29
+ export declare function __snapshotActiveRunResultsForTests(): ReadonlySet<RunResult<any>>;
30
+ export declare function __disposeActiveRunResultsForTestsExcept(keep?: ReadonlySet<RunResult<any>>): Promise<void>;
@@ -4,7 +4,7 @@
4
4
  *
5
5
  * Internal protocol reference: `readmes/SERIALIZER_PROTOCOL.md`.
6
6
  */
7
- import type { TypeDefinition, SerializationContext, SerializerOptions, DeserializationContext, SerializedValue, SerializedNode } from "./types";
7
+ import type { TypeDefinition, SerializationContext, SerializerOptions } from "./types";
8
8
  export declare class Serializer {
9
9
  /** Type registry for managing custom types */
10
10
  private readonly typeRegistry;
@@ -40,45 +40,5 @@ export declare class Serializer {
40
40
  * Register a custom type for serialization/deserialization.
41
41
  */
42
42
  addType<TInstance, TSerialized>(typeDef: TypeDefinition<TInstance, TSerialized>): void;
43
- addType<TJson = unknown, TInstance = unknown>(name: string, factory: (json: TJson) => TInstance): void;
44
- /**
45
- * @internal - Exposed for testing RegExp safety validation
46
- */
47
- readonly isRegExpPatternSafe: (pattern: string) => boolean;
48
- /**
49
- * @internal - Exposed for testing quantifier detection
50
- */
51
- readonly isQuantifierAt: (pattern: string, index: number) => boolean;
52
- /**
53
- * @internal - Exposed for testing quantifier character detection
54
- */
55
- readonly isQuantifierChar: (char: string, pattern: string, index: number) => boolean;
56
- /**
57
- * @internal - Exposed for testing bounded quantifier detection
58
- */
59
- readonly isBoundedQuantifier: (pattern: string, index: number) => boolean;
60
- /**
61
- * @internal - Exposed for test compatibility
62
- */
63
- toNodeRecord(nodes: Record<string, SerializedNode>): Record<string, SerializedNode>;
64
- /**
65
- * @internal - Exposed for test compatibility
66
- */
67
- deserializeValue(value: SerializedValue, context: DeserializationContext, depth?: number): unknown;
68
- /**
69
- * @internal - Exposed for test compatibility
70
- */
71
- resolveReference(id: string, context: DeserializationContext, depth?: number): unknown;
72
- /**
73
- * @internal - Exposed for test compatibility
74
- */
75
- mergePlaceholder(placeholder: unknown, result: unknown): unknown;
76
- /**
77
- * @internal - Exposed for test compatibility
78
- */
79
- isSerializedTypeRecord(value: unknown): value is {
80
- __type: string;
81
- value: unknown;
82
- };
83
43
  private jsonStringify;
84
44
  }
@@ -0,0 +1,8 @@
1
+ import { SymbolPolicyErrorMessage } from "./types";
2
+ export declare const invalidPayloadError: (message: string) => never;
3
+ export declare const validationError: (message: string) => never;
4
+ export declare const depthExceededError: (maxDepth: number) => never;
5
+ export declare const referenceResolutionError: (message: string) => never;
6
+ export declare const unsupportedFeatureError: (message: string) => never;
7
+ export declare const typeRegistryError: (message: string) => never;
8
+ export declare const symbolPolicyError: (message: SymbolPolicyErrorMessage) => never;
@@ -0,0 +1,2 @@
1
+ export declare const escapeReservedMarkerKey: (key: string) => string;
2
+ export declare const unescapeReservedMarkerKey: (key: string) => string;
@@ -2,7 +2,7 @@ import type { TypeDefinition } from "./types";
2
2
  import type { SerializedTypeRecord, SerializedValue } from "./types";
3
3
  import type { TypeRegistry } from "./type-registry";
4
4
  export declare const serializeArrayItems: <TSerializedValue>(source: readonly unknown[], serializeNested: (value: unknown) => TSerializedValue) => TSerializedValue[];
5
- export declare const serializeRecordEntries: <TSerializedValue>(source: Record<string, unknown>, unsafeKeys: ReadonlySet<string>, serializeNested: (value: unknown) => TSerializedValue) => Record<string, TSerializedValue>;
5
+ export declare const serializeRecordEntries: <TSerializedValue>(source: Record<string, unknown>, unsafeKeys: ReadonlySet<string>, serializeNested: (value: unknown) => TSerializedValue, mapKey?: (key: string) => string) => Record<string, TSerializedValue>;
6
6
  export declare function serializeTypeRecord(typeDef: TypeDefinition<unknown, unknown>, value: unknown, excludedTypeIds: string[], serializeNested: (value: unknown) => SerializedValue): SerializedTypeRecord;
7
7
  export declare function serializeTypeRecord<TSerializedValue>(typeDef: TypeDefinition<unknown, unknown>, value: unknown, excludedTypeIds: string[], serializeNested: (value: unknown) => TSerializedValue): {
8
8
  __type: string;
@@ -33,7 +33,6 @@ export declare class TypeRegistry {
33
33
  * Register a custom type definition.
34
34
  */
35
35
  addType<TInstance, TSerialized>(typeDef: TypeDefinition<TInstance, TSerialized>): void;
36
- addType<TJson = unknown, TInstance = unknown>(name: string, factory: (json: TJson) => TInstance): void;
37
36
  /**
38
37
  * Find a type definition that matches the given value.
39
38
  */