dotdo 0.0.1 → 0.0.2

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 (727) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +446 -315
  3. package/dist/ai/index.js +19 -0
  4. package/dist/ai/index.js.map +1 -0
  5. package/dist/ai/template-literals.js +852 -0
  6. package/dist/ai/template-literals.js.map +1 -0
  7. package/dist/api/analytics/router.js +601 -0
  8. package/dist/api/analytics/router.js.map +1 -0
  9. package/dist/api/index.js +158 -0
  10. package/dist/api/index.js.map +1 -0
  11. package/dist/api/middleware/auth-federation.js +573 -0
  12. package/dist/api/middleware/auth-federation.js.map +1 -0
  13. package/dist/api/middleware/auth.js +544 -0
  14. package/dist/api/middleware/auth.js.map +1 -0
  15. package/dist/api/middleware/error-handling.js +176 -0
  16. package/dist/api/middleware/error-handling.js.map +1 -0
  17. package/dist/api/middleware/request-id.js +21 -0
  18. package/dist/api/middleware/request-id.js.map +1 -0
  19. package/dist/api/pages.js +1180 -0
  20. package/dist/api/pages.js.map +1 -0
  21. package/dist/api/routes/api.js +612 -0
  22. package/dist/api/routes/api.js.map +1 -0
  23. package/dist/api/routes/browsers.js +471 -0
  24. package/dist/api/routes/browsers.js.map +1 -0
  25. package/dist/api/routes/do.js +188 -0
  26. package/dist/api/routes/do.js.map +1 -0
  27. package/dist/api/routes/mcp.js +459 -0
  28. package/dist/api/routes/mcp.js.map +1 -0
  29. package/dist/api/routes/obs.js +445 -0
  30. package/dist/api/routes/obs.js.map +1 -0
  31. package/dist/api/routes/openapi.js +794 -0
  32. package/dist/api/routes/openapi.js.map +1 -0
  33. package/dist/api/routes/rpc.js +1103 -0
  34. package/dist/api/routes/rpc.js.map +1 -0
  35. package/dist/api/routes/sandboxes.js +389 -0
  36. package/dist/api/routes/sandboxes.js.map +1 -0
  37. package/dist/api/test-do.js +38 -0
  38. package/dist/api/test-do.js.map +1 -0
  39. package/dist/api/types.js +11 -0
  40. package/dist/api/types.js.map +1 -0
  41. package/dist/cli/bin.js +2 -0
  42. package/dist/cli/main.js +52342 -0
  43. package/dist/db/actions.js +212 -0
  44. package/dist/db/actions.js.map +1 -0
  45. package/dist/db/auth.js +506 -0
  46. package/dist/db/auth.js.map +1 -0
  47. package/dist/db/branches.js +65 -0
  48. package/dist/db/branches.js.map +1 -0
  49. package/dist/db/clickhouse.js +1074 -0
  50. package/dist/db/clickhouse.js.map +1 -0
  51. package/dist/db/dlq.js +39 -0
  52. package/dist/db/dlq.js.map +1 -0
  53. package/dist/db/events.js +28 -0
  54. package/dist/db/events.js.map +1 -0
  55. package/dist/db/exec.js +64 -0
  56. package/dist/db/exec.js.map +1 -0
  57. package/dist/db/files.js +85 -0
  58. package/dist/db/files.js.map +1 -0
  59. package/dist/db/flags.js +24 -0
  60. package/dist/db/flags.js.map +1 -0
  61. package/dist/db/git.js +116 -0
  62. package/dist/db/git.js.map +1 -0
  63. package/dist/db/iceberg/inverted-index.js +862 -0
  64. package/dist/db/iceberg/inverted-index.js.map +1 -0
  65. package/dist/db/iceberg/puffin.js +878 -0
  66. package/dist/db/iceberg/puffin.js.map +1 -0
  67. package/dist/db/iceberg/search-manifest.js +422 -0
  68. package/dist/db/iceberg/search-manifest.js.map +1 -0
  69. package/dist/db/iceberg/types.js +8 -0
  70. package/dist/db/iceberg/types.js.map +1 -0
  71. package/dist/db/index.js +121 -0
  72. package/dist/db/index.js.map +1 -0
  73. package/dist/db/integrations.js +368 -0
  74. package/dist/db/integrations.js.map +1 -0
  75. package/dist/db/json-indexes.js +332 -0
  76. package/dist/db/json-indexes.js.map +1 -0
  77. package/dist/db/linked-accounts.js +287 -0
  78. package/dist/db/linked-accounts.js.map +1 -0
  79. package/dist/db/nouns.js +183 -0
  80. package/dist/db/nouns.js.map +1 -0
  81. package/dist/db/objects.js +170 -0
  82. package/dist/db/objects.js.map +1 -0
  83. package/dist/db/primitives/dag-scheduler/index.js +869 -0
  84. package/dist/db/primitives/dag-scheduler/index.js.map +1 -0
  85. package/dist/db/primitives/exactly-once-context.js +237 -0
  86. package/dist/db/primitives/exactly-once-context.js.map +1 -0
  87. package/dist/db/primitives/index.js +62 -0
  88. package/dist/db/primitives/index.js.map +1 -0
  89. package/dist/db/primitives/keyed-router.js +145 -0
  90. package/dist/db/primitives/keyed-router.js.map +1 -0
  91. package/dist/db/primitives/observability.js +162 -0
  92. package/dist/db/primitives/observability.js.map +1 -0
  93. package/dist/db/primitives/schema-evolution.js +643 -0
  94. package/dist/db/primitives/schema-evolution.js.map +1 -0
  95. package/dist/db/primitives/stateful-operator/index.js +770 -0
  96. package/dist/db/primitives/stateful-operator/index.js.map +1 -0
  97. package/dist/db/primitives/temporal-store.js +306 -0
  98. package/dist/db/primitives/temporal-store.js.map +1 -0
  99. package/dist/db/primitives/typed-column-store.js +1229 -0
  100. package/dist/db/primitives/typed-column-store.js.map +1 -0
  101. package/dist/db/primitives/utils/duration.js +162 -0
  102. package/dist/db/primitives/utils/duration.js.map +1 -0
  103. package/dist/db/primitives/utils/murmur3.js +118 -0
  104. package/dist/db/primitives/utils/murmur3.js.map +1 -0
  105. package/dist/db/primitives/watermark-service.js +136 -0
  106. package/dist/db/primitives/watermark-service.js.map +1 -0
  107. package/dist/db/primitives/window-manager.js +764 -0
  108. package/dist/db/primitives/window-manager.js.map +1 -0
  109. package/dist/db/relationships.js +66 -0
  110. package/dist/db/relationships.js.map +1 -0
  111. package/dist/db/schema-minimal.js +61 -0
  112. package/dist/db/schema-minimal.js.map +1 -0
  113. package/dist/db/search.js +28 -0
  114. package/dist/db/search.js.map +1 -0
  115. package/dist/db/stores.js +1665 -0
  116. package/dist/db/stores.js.map +1 -0
  117. package/dist/db/things.js +297 -0
  118. package/dist/db/things.js.map +1 -0
  119. package/dist/db/vault.js +171 -0
  120. package/dist/db/vault.js.map +1 -0
  121. package/dist/db/verbs.js +102 -0
  122. package/dist/db/verbs.js.map +1 -0
  123. package/dist/do/base.js +48 -0
  124. package/dist/do/base.js.map +1 -0
  125. package/dist/do/bash.js +35 -0
  126. package/dist/do/bash.js.map +1 -0
  127. package/dist/do/fs.js +25 -0
  128. package/dist/do/fs.js.map +1 -0
  129. package/dist/do/full.js +61 -0
  130. package/dist/do/full.js.map +1 -0
  131. package/dist/do/git.js +28 -0
  132. package/dist/do/git.js.map +1 -0
  133. package/dist/do/index.js +52 -0
  134. package/dist/do/index.js.map +1 -0
  135. package/dist/do/tiny.js +31 -0
  136. package/dist/do/tiny.js.map +1 -0
  137. package/dist/lib/DOAuth.js +261 -0
  138. package/dist/lib/DOAuth.js.map +1 -0
  139. package/dist/lib/DODispatcher.js +72 -0
  140. package/dist/lib/DODispatcher.js.map +1 -0
  141. package/dist/lib/Modifier.js +189 -0
  142. package/dist/lib/Modifier.js.map +1 -0
  143. package/dist/lib/StateStorage.js +403 -0
  144. package/dist/lib/StateStorage.js.map +1 -0
  145. package/dist/lib/TypeRegistry.js +122 -0
  146. package/dist/lib/TypeRegistry.js.map +1 -0
  147. package/dist/lib/agent/tools/bash.js +336 -0
  148. package/dist/lib/agent/tools/bash.js.map +1 -0
  149. package/dist/lib/agent/tools/edit.js +157 -0
  150. package/dist/lib/agent/tools/edit.js.map +1 -0
  151. package/dist/lib/agent/tools/glob.js +137 -0
  152. package/dist/lib/agent/tools/glob.js.map +1 -0
  153. package/dist/lib/agent/tools/grep.js +315 -0
  154. package/dist/lib/agent/tools/grep.js.map +1 -0
  155. package/dist/lib/agent/tools/index.js +71 -0
  156. package/dist/lib/agent/tools/index.js.map +1 -0
  157. package/dist/lib/agent/tools/read.js +212 -0
  158. package/dist/lib/agent/tools/read.js.map +1 -0
  159. package/dist/lib/agent/tools/types.js +197 -0
  160. package/dist/lib/agent/tools/types.js.map +1 -0
  161. package/dist/lib/agent/tools/write.js +159 -0
  162. package/dist/lib/agent/tools/write.js.map +1 -0
  163. package/dist/lib/ai/gateway.js +247 -0
  164. package/dist/lib/ai/gateway.js.map +1 -0
  165. package/dist/lib/ai/tool-loop-agent.js +591 -0
  166. package/dist/lib/ai/tool-loop-agent.js.map +1 -0
  167. package/dist/lib/auto-wiring.js +439 -0
  168. package/dist/lib/auto-wiring.js.map +1 -0
  169. package/dist/lib/browse/browserbase.js +163 -0
  170. package/dist/lib/browse/browserbase.js.map +1 -0
  171. package/dist/lib/browse/cloudflare.js +144 -0
  172. package/dist/lib/browse/cloudflare.js.map +1 -0
  173. package/dist/lib/browse/index.js +62 -0
  174. package/dist/lib/browse/index.js.map +1 -0
  175. package/dist/lib/browse/types.js +13 -0
  176. package/dist/lib/browse/types.js.map +1 -0
  177. package/dist/lib/cache/index.js +37 -0
  178. package/dist/lib/cache/index.js.map +1 -0
  179. package/dist/lib/cache/visibility.js +638 -0
  180. package/dist/lib/cache/visibility.js.map +1 -0
  181. package/dist/lib/capabilities.js +268 -0
  182. package/dist/lib/capabilities.js.map +1 -0
  183. package/dist/lib/channels/base.js +106 -0
  184. package/dist/lib/channels/base.js.map +1 -0
  185. package/dist/lib/channels/discord.js +94 -0
  186. package/dist/lib/channels/discord.js.map +1 -0
  187. package/dist/lib/channels/email.js +204 -0
  188. package/dist/lib/channels/email.js.map +1 -0
  189. package/dist/lib/channels/index.js +90 -0
  190. package/dist/lib/channels/index.js.map +1 -0
  191. package/dist/lib/channels/mdxui-chat.js +95 -0
  192. package/dist/lib/channels/mdxui-chat.js.map +1 -0
  193. package/dist/lib/channels/slack-blockkit.js +121 -0
  194. package/dist/lib/channels/slack-blockkit.js.map +1 -0
  195. package/dist/lib/channels/types.js +7 -0
  196. package/dist/lib/channels/types.js.map +1 -0
  197. package/dist/lib/cloudflare/ai.js +654 -0
  198. package/dist/lib/cloudflare/ai.js.map +1 -0
  199. package/dist/lib/cloudflare/index.js +88 -0
  200. package/dist/lib/cloudflare/index.js.map +1 -0
  201. package/dist/lib/cloudflare/kv.js +342 -0
  202. package/dist/lib/cloudflare/kv.js.map +1 -0
  203. package/dist/lib/cloudflare/queues.js +434 -0
  204. package/dist/lib/cloudflare/queues.js.map +1 -0
  205. package/dist/lib/cloudflare/r2.js +604 -0
  206. package/dist/lib/cloudflare/r2.js.map +1 -0
  207. package/dist/lib/cloudflare/vectorize.js +494 -0
  208. package/dist/lib/cloudflare/vectorize.js.map +1 -0
  209. package/dist/lib/cloudflare/workflows.js +569 -0
  210. package/dist/lib/cloudflare/workflows.js.map +1 -0
  211. package/dist/lib/colo/caching.js +196 -0
  212. package/dist/lib/colo/caching.js.map +1 -0
  213. package/dist/lib/colo/detection.js +194 -0
  214. package/dist/lib/colo/detection.js.map +1 -0
  215. package/dist/lib/colo/external-data.js +219 -0
  216. package/dist/lib/colo/external-data.js.map +1 -0
  217. package/dist/lib/colo/globe-data.js +179 -0
  218. package/dist/lib/colo/globe-data.js.map +1 -0
  219. package/dist/lib/colo/index.js +16 -0
  220. package/dist/lib/colo/index.js.map +1 -0
  221. package/dist/lib/decorators.js +37 -0
  222. package/dist/lib/decorators.js.map +1 -0
  223. package/dist/lib/discovery.js +81 -0
  224. package/dist/lib/discovery.js.map +1 -0
  225. package/dist/lib/executors/AgenticFunctionExecutor.js +619 -0
  226. package/dist/lib/executors/AgenticFunctionExecutor.js.map +1 -0
  227. package/dist/lib/executors/BaseFunctionExecutor.js +328 -0
  228. package/dist/lib/executors/BaseFunctionExecutor.js.map +1 -0
  229. package/dist/lib/executors/CascadeExecutor.js +418 -0
  230. package/dist/lib/executors/CascadeExecutor.js.map +1 -0
  231. package/dist/lib/executors/CodeFunctionExecutor.js +904 -0
  232. package/dist/lib/executors/CodeFunctionExecutor.js.map +1 -0
  233. package/dist/lib/executors/GenerativeFunctionExecutor.js +904 -0
  234. package/dist/lib/executors/GenerativeFunctionExecutor.js.map +1 -0
  235. package/dist/lib/executors/HumanFunctionExecutor.js +884 -0
  236. package/dist/lib/executors/HumanFunctionExecutor.js.map +1 -0
  237. package/dist/lib/executors/ParallelStepExecutor.js +308 -0
  238. package/dist/lib/executors/ParallelStepExecutor.js.map +1 -0
  239. package/dist/lib/executors/types.js +12 -0
  240. package/dist/lib/executors/types.js.map +1 -0
  241. package/dist/lib/experiments.js +89 -0
  242. package/dist/lib/experiments.js.map +1 -0
  243. package/dist/lib/flags/store.js +262 -0
  244. package/dist/lib/flags/store.js.map +1 -0
  245. package/dist/lib/functions/FunctionComposition.js +467 -0
  246. package/dist/lib/functions/FunctionComposition.js.map +1 -0
  247. package/dist/lib/functions/FunctionMiddleware.js +457 -0
  248. package/dist/lib/functions/FunctionMiddleware.js.map +1 -0
  249. package/dist/lib/functions/FunctionRegistry.js +426 -0
  250. package/dist/lib/functions/FunctionRegistry.js.map +1 -0
  251. package/dist/lib/functions/createFunction.js +1048 -0
  252. package/dist/lib/functions/createFunction.js.map +1 -0
  253. package/dist/lib/humans/index.js +68 -0
  254. package/dist/lib/humans/index.js.map +1 -0
  255. package/dist/lib/humans/templates.js +117 -0
  256. package/dist/lib/humans/templates.js.map +1 -0
  257. package/dist/lib/identity.js +98 -0
  258. package/dist/lib/identity.js.map +1 -0
  259. package/dist/lib/index.js +9 -0
  260. package/dist/lib/index.js.map +1 -0
  261. package/dist/lib/logging/error-logger.js +163 -0
  262. package/dist/lib/logging/error-logger.js.map +1 -0
  263. package/dist/lib/logging/index.js +160 -0
  264. package/dist/lib/logging/index.js.map +1 -0
  265. package/dist/lib/mixins/bash.js +825 -0
  266. package/dist/lib/mixins/bash.js.map +1 -0
  267. package/dist/lib/mixins/fs.js +648 -0
  268. package/dist/lib/mixins/fs.js.map +1 -0
  269. package/dist/lib/mixins/git.js +1011 -0
  270. package/dist/lib/mixins/git.js.map +1 -0
  271. package/dist/lib/mixins/index.js +29 -0
  272. package/dist/lib/mixins/index.js.map +1 -0
  273. package/dist/lib/mixins/npm.js +662 -0
  274. package/dist/lib/mixins/npm.js.map +1 -0
  275. package/dist/lib/noun-id.js +278 -0
  276. package/dist/lib/noun-id.js.map +1 -0
  277. package/dist/lib/rate-limit/sliding-window.js +148 -0
  278. package/dist/lib/rate-limit/sliding-window.js.map +1 -0
  279. package/dist/lib/rate-limit.js +110 -0
  280. package/dist/lib/rate-limit.js.map +1 -0
  281. package/dist/lib/rpc/bindings.js +548 -0
  282. package/dist/lib/rpc/bindings.js.map +1 -0
  283. package/dist/lib/rpc/index.js +64 -0
  284. package/dist/lib/rpc/index.js.map +1 -0
  285. package/dist/lib/safe-stringify.js +223 -0
  286. package/dist/lib/safe-stringify.js.map +1 -0
  287. package/dist/lib/sandbox/miniflare-sandbox.js +1007 -0
  288. package/dist/lib/sandbox/miniflare-sandbox.js.map +1 -0
  289. package/dist/lib/sqids.js +110 -0
  290. package/dist/lib/sqids.js.map +1 -0
  291. package/dist/lib/sql/adapters/index.js +10 -0
  292. package/dist/lib/sql/adapters/index.js.map +1 -0
  293. package/dist/lib/sql/adapters/node-sql-parser.js +552 -0
  294. package/dist/lib/sql/adapters/node-sql-parser.js.map +1 -0
  295. package/dist/lib/sql/adapters/pgsql-parser.js +1189 -0
  296. package/dist/lib/sql/adapters/pgsql-parser.js.map +1 -0
  297. package/dist/lib/sql/index.js +277 -0
  298. package/dist/lib/sql/index.js.map +1 -0
  299. package/dist/lib/sql/types.js +56 -0
  300. package/dist/lib/sql/types.js.map +1 -0
  301. package/dist/lib/type-classifier.js +126 -0
  302. package/dist/lib/type-classifier.js.map +1 -0
  303. package/dist/lib/utils/html.js +47 -0
  304. package/dist/lib/utils/html.js.map +1 -0
  305. package/dist/lib/validation.js +48 -0
  306. package/dist/lib/validation.js.map +1 -0
  307. package/dist/lib/vault/store.js +411 -0
  308. package/dist/lib/vault/store.js.map +1 -0
  309. package/dist/metrics/hunch.js +739 -0
  310. package/dist/metrics/hunch.js.map +1 -0
  311. package/dist/objects/API.js +302 -0
  312. package/dist/objects/API.js.map +1 -0
  313. package/dist/objects/Agent.js +179 -0
  314. package/dist/objects/Agent.js.map +1 -0
  315. package/dist/objects/AgenticFunctionExecutor.js +8 -0
  316. package/dist/objects/AgenticFunctionExecutor.js.map +1 -0
  317. package/dist/objects/App.js +83 -0
  318. package/dist/objects/App.js.map +1 -0
  319. package/dist/objects/Browser.js +884 -0
  320. package/dist/objects/Browser.js.map +1 -0
  321. package/dist/objects/Business.js +107 -0
  322. package/dist/objects/Business.js.map +1 -0
  323. package/dist/objects/CLI.js +221 -0
  324. package/dist/objects/CLI.js.map +1 -0
  325. package/dist/objects/CodeFunctionExecutor.js +8 -0
  326. package/dist/objects/CodeFunctionExecutor.js.map +1 -0
  327. package/dist/objects/Collection.js +161 -0
  328. package/dist/objects/Collection.js.map +1 -0
  329. package/dist/objects/DO.js +41 -0
  330. package/dist/objects/DO.js.map +1 -0
  331. package/dist/objects/DOBase.js +2309 -0
  332. package/dist/objects/DOBase.js.map +1 -0
  333. package/dist/objects/DOFull.js +1676 -0
  334. package/dist/objects/DOFull.js.map +1 -0
  335. package/dist/objects/DOTiny.js +207 -0
  336. package/dist/objects/DOTiny.js.map +1 -0
  337. package/dist/objects/Directory.js +199 -0
  338. package/dist/objects/Directory.js.map +1 -0
  339. package/dist/objects/Entity.js +413 -0
  340. package/dist/objects/Entity.js.map +1 -0
  341. package/dist/objects/Function.js +116 -0
  342. package/dist/objects/Function.js.map +1 -0
  343. package/dist/objects/Human.js +231 -0
  344. package/dist/objects/Human.js.map +1 -0
  345. package/dist/objects/HumanFunctionExecutor.js +8 -0
  346. package/dist/objects/HumanFunctionExecutor.js.map +1 -0
  347. package/dist/objects/IcebergMetadataDO.js +938 -0
  348. package/dist/objects/IcebergMetadataDO.js.map +1 -0
  349. package/dist/objects/IntegrationsDO.js +1174 -0
  350. package/dist/objects/IntegrationsDO.js.map +1 -0
  351. package/dist/objects/ObservabilityBroadcaster.js +149 -0
  352. package/dist/objects/ObservabilityBroadcaster.js.map +1 -0
  353. package/dist/objects/Package.js +154 -0
  354. package/dist/objects/Package.js.map +1 -0
  355. package/dist/objects/Product.js +193 -0
  356. package/dist/objects/Product.js.map +1 -0
  357. package/dist/objects/SDK.js +152 -0
  358. package/dist/objects/SDK.js.map +1 -0
  359. package/dist/objects/SaaS.js +235 -0
  360. package/dist/objects/SaaS.js.map +1 -0
  361. package/dist/objects/SandboxDO.js +759 -0
  362. package/dist/objects/SandboxDO.js.map +1 -0
  363. package/dist/objects/Service.js +337 -0
  364. package/dist/objects/Service.js.map +1 -0
  365. package/dist/objects/Site.js +80 -0
  366. package/dist/objects/Site.js.map +1 -0
  367. package/dist/objects/Startup.js +479 -0
  368. package/dist/objects/Startup.js.map +1 -0
  369. package/dist/objects/ThingsDO.js +170 -0
  370. package/dist/objects/ThingsDO.js.map +1 -0
  371. package/dist/objects/VectorShardDO.js +648 -0
  372. package/dist/objects/VectorShardDO.js.map +1 -0
  373. package/dist/objects/Worker.js +144 -0
  374. package/dist/objects/Worker.js.map +1 -0
  375. package/dist/objects/Workflow.js +196 -0
  376. package/dist/objects/Workflow.js.map +1 -0
  377. package/dist/objects/WorkflowFactory.js +313 -0
  378. package/dist/objects/WorkflowFactory.js.map +1 -0
  379. package/dist/objects/WorkflowRuntime.js +863 -0
  380. package/dist/objects/WorkflowRuntime.js.map +1 -0
  381. package/dist/objects/circuit-breaker-bulkhead.js +178 -0
  382. package/dist/objects/circuit-breaker-bulkhead.js.map +1 -0
  383. package/dist/objects/createFunction.js +934 -0
  384. package/dist/objects/createFunction.js.map +1 -0
  385. package/dist/objects/index.js +80 -0
  386. package/dist/objects/index.js.map +1 -0
  387. package/dist/objects/lifecycle/Branch.js +275 -0
  388. package/dist/objects/lifecycle/Branch.js.map +1 -0
  389. package/dist/objects/lifecycle/Clone.js +1499 -0
  390. package/dist/objects/lifecycle/Clone.js.map +1 -0
  391. package/dist/objects/lifecycle/Compact.js +237 -0
  392. package/dist/objects/lifecycle/Compact.js.map +1 -0
  393. package/dist/objects/lifecycle/Promote.js +476 -0
  394. package/dist/objects/lifecycle/Promote.js.map +1 -0
  395. package/dist/objects/lifecycle/Shard.js +560 -0
  396. package/dist/objects/lifecycle/Shard.js.map +1 -0
  397. package/dist/objects/lifecycle/index.js +15 -0
  398. package/dist/objects/lifecycle/index.js.map +1 -0
  399. package/dist/objects/lifecycle/types.js +33 -0
  400. package/dist/objects/lifecycle/types.js.map +1 -0
  401. package/dist/objects/mixins/infrastructure.js +171 -0
  402. package/dist/objects/mixins/infrastructure.js.map +1 -0
  403. package/dist/objects/modules/StoresModule.js +153 -0
  404. package/dist/objects/modules/StoresModule.js.map +1 -0
  405. package/dist/objects/persistence/checkpoint-manager.js +606 -0
  406. package/dist/objects/persistence/checkpoint-manager.js.map +1 -0
  407. package/dist/objects/persistence/index.js +72 -0
  408. package/dist/objects/persistence/index.js.map +1 -0
  409. package/dist/objects/persistence/migration-runner.js +562 -0
  410. package/dist/objects/persistence/migration-runner.js.map +1 -0
  411. package/dist/objects/persistence/replication-manager.js +501 -0
  412. package/dist/objects/persistence/replication-manager.js.map +1 -0
  413. package/dist/objects/persistence/tiered-storage-manager.js +595 -0
  414. package/dist/objects/persistence/tiered-storage-manager.js.map +1 -0
  415. package/dist/objects/persistence/types.js +14 -0
  416. package/dist/objects/persistence/types.js.map +1 -0
  417. package/dist/objects/persistence/wal-manager.js +653 -0
  418. package/dist/objects/persistence/wal-manager.js.map +1 -0
  419. package/dist/objects/presets/index.js +20 -0
  420. package/dist/objects/presets/index.js.map +1 -0
  421. package/dist/objects/presets/primitives.js +188 -0
  422. package/dist/objects/presets/primitives.js.map +1 -0
  423. package/dist/objects/primitives/alarm-adapter.js +141 -0
  424. package/dist/objects/primitives/alarm-adapter.js.map +1 -0
  425. package/dist/objects/primitives/index.js +337 -0
  426. package/dist/objects/primitives/index.js.map +1 -0
  427. package/dist/objects/primitives/storage-adapter.js +182 -0
  428. package/dist/objects/primitives/storage-adapter.js.map +1 -0
  429. package/dist/objects/primitives/with-primitives.js +102 -0
  430. package/dist/objects/primitives/with-primitives.js.map +1 -0
  431. package/dist/objects/services/StoreManager.js +227 -0
  432. package/dist/objects/services/StoreManager.js.map +1 -0
  433. package/dist/objects/services/index.js +13 -0
  434. package/dist/objects/services/index.js.map +1 -0
  435. package/dist/objects/transport/auth-layer.js +1451 -0
  436. package/dist/objects/transport/auth-layer.js.map +1 -0
  437. package/dist/objects/transport/capnweb-target.js +355 -0
  438. package/dist/objects/transport/capnweb-target.js.map +1 -0
  439. package/dist/objects/transport/chain.js +441 -0
  440. package/dist/objects/transport/chain.js.map +1 -0
  441. package/dist/objects/transport/handler.js +58 -0
  442. package/dist/objects/transport/handler.js.map +1 -0
  443. package/dist/objects/transport/index.js +53 -0
  444. package/dist/objects/transport/index.js.map +1 -0
  445. package/dist/objects/transport/mcp-server.js +690 -0
  446. package/dist/objects/transport/mcp-server.js.map +1 -0
  447. package/dist/objects/transport/rest-autowire.js +1507 -0
  448. package/dist/objects/transport/rest-autowire.js.map +1 -0
  449. package/dist/objects/transport/rest-router.js +440 -0
  450. package/dist/objects/transport/rest-router.js.map +1 -0
  451. package/dist/objects/transport/rpc-server.js +1536 -0
  452. package/dist/objects/transport/rpc-server.js.map +1 -0
  453. package/dist/objects/transport/shared.js +575 -0
  454. package/dist/objects/transport/shared.js.map +1 -0
  455. package/dist/objects/transport/sync-engine.js +291 -0
  456. package/dist/objects/transport/sync-engine.js.map +1 -0
  457. package/dist/objects/transport/types.js +8 -0
  458. package/dist/objects/transport/types.js.map +1 -0
  459. package/dist/primitives/bashx/src/ast/analyze.js +1472 -0
  460. package/dist/primitives/bashx/src/ast/analyze.js.map +1 -0
  461. package/dist/primitives/bashx/src/ast/parser.js +1488 -0
  462. package/dist/primitives/bashx/src/ast/parser.js.map +1 -0
  463. package/dist/primitives/bashx/src/do/commands/crypto.js +1954 -0
  464. package/dist/primitives/bashx/src/do/commands/crypto.js.map +1 -0
  465. package/dist/primitives/bashx/src/do/commands/data-processing.js +1812 -0
  466. package/dist/primitives/bashx/src/do/commands/data-processing.js.map +1 -0
  467. package/dist/primitives/bashx/src/do/commands/extended-utils.js +804 -0
  468. package/dist/primitives/bashx/src/do/commands/extended-utils.js.map +1 -0
  469. package/dist/primitives/bashx/src/do/commands/math-control.js +1122 -0
  470. package/dist/primitives/bashx/src/do/commands/math-control.js.map +1 -0
  471. package/dist/primitives/bashx/src/do/commands/posix-utils.js +1015 -0
  472. package/dist/primitives/bashx/src/do/commands/posix-utils.js.map +1 -0
  473. package/dist/primitives/bashx/src/do/commands/system-utils.js +687 -0
  474. package/dist/primitives/bashx/src/do/commands/system-utils.js.map +1 -0
  475. package/dist/primitives/bashx/src/do/commands/test-command.js +523 -0
  476. package/dist/primitives/bashx/src/do/commands/test-command.js.map +1 -0
  477. package/dist/primitives/bashx/src/do/commands/text-processing.js +1550 -0
  478. package/dist/primitives/bashx/src/do/commands/text-processing.js.map +1 -0
  479. package/dist/primitives/bashx/src/do/container-executor.js +429 -0
  480. package/dist/primitives/bashx/src/do/container-executor.js.map +1 -0
  481. package/dist/primitives/bashx/src/do/index.js +668 -0
  482. package/dist/primitives/bashx/src/do/index.js.map +1 -0
  483. package/dist/primitives/bashx/src/do/tiered-executor.js +2647 -0
  484. package/dist/primitives/bashx/src/do/tiered-executor.js.map +1 -0
  485. package/dist/primitives/bashx/src/do/worker.js +352 -0
  486. package/dist/primitives/bashx/src/do/worker.js.map +1 -0
  487. package/dist/primitives/bashx/src/types.js +10 -0
  488. package/dist/primitives/bashx/src/types.js.map +1 -0
  489. package/dist/primitives/fsx/core/backend.js +480 -0
  490. package/dist/primitives/fsx/core/backend.js.map +1 -0
  491. package/dist/primitives/fsx/core/constants.js +140 -0
  492. package/dist/primitives/fsx/core/constants.js.map +1 -0
  493. package/dist/primitives/fsx/core/fsx.js +1184 -0
  494. package/dist/primitives/fsx/core/fsx.js.map +1 -0
  495. package/dist/primitives/fsx/core/glob/glob.js +438 -0
  496. package/dist/primitives/fsx/core/glob/glob.js.map +1 -0
  497. package/dist/primitives/fsx/core/glob/index.js +8 -0
  498. package/dist/primitives/fsx/core/glob/index.js.map +1 -0
  499. package/dist/primitives/fsx/core/glob/match.js +392 -0
  500. package/dist/primitives/fsx/core/glob/match.js.map +1 -0
  501. package/dist/primitives/fsx/core/types.js +307 -0
  502. package/dist/primitives/fsx/core/types.js.map +1 -0
  503. package/dist/sandbox/index.js +258 -0
  504. package/dist/sandbox/index.js.map +1 -0
  505. package/dist/sdk/capnweb-compat.js +42 -0
  506. package/dist/sdk/capnweb-compat.js.map +1 -0
  507. package/dist/sdk/client.js +20 -0
  508. package/dist/sdk/client.js.map +1 -0
  509. package/dist/sdk/index.js +17 -0
  510. package/dist/sdk/index.js.map +1 -0
  511. package/dist/snippets/artifacts-config.js +241 -0
  512. package/dist/snippets/artifacts-config.js.map +1 -0
  513. package/dist/snippets/artifacts-ingest.js +832 -0
  514. package/dist/snippets/artifacts-ingest.js.map +1 -0
  515. package/dist/snippets/artifacts-serve.js +1035 -0
  516. package/dist/snippets/artifacts-serve.js.map +1 -0
  517. package/dist/snippets/artifacts-types.js +161 -0
  518. package/dist/snippets/artifacts-types.js.map +1 -0
  519. package/dist/snippets/cache-probe.js +376 -0
  520. package/dist/snippets/cache-probe.js.map +1 -0
  521. package/dist/snippets/cache.js +10 -0
  522. package/dist/snippets/cache.js.map +1 -0
  523. package/dist/snippets/events.js +469 -0
  524. package/dist/snippets/events.js.map +1 -0
  525. package/dist/snippets/index.js +7 -0
  526. package/dist/snippets/index.js.map +1 -0
  527. package/dist/snippets/proxy.js +495 -0
  528. package/dist/snippets/proxy.js.map +1 -0
  529. package/dist/snippets/search.js +1759 -0
  530. package/dist/snippets/search.js.map +1 -0
  531. package/dist/streams/index.js +30 -0
  532. package/dist/streams/index.js.map +1 -0
  533. package/dist/streams/observability.js +68 -0
  534. package/dist/streams/observability.js.map +1 -0
  535. package/dist/types/AI.js +92 -0
  536. package/dist/types/AI.js.map +1 -0
  537. package/dist/types/AIFunction.js +171 -0
  538. package/dist/types/AIFunction.js.map +1 -0
  539. package/dist/types/BrowseVerb.js +89 -0
  540. package/dist/types/BrowseVerb.js.map +1 -0
  541. package/dist/types/Browser.js +31 -0
  542. package/dist/types/Browser.js.map +1 -0
  543. package/dist/types/Chaos.js +15 -0
  544. package/dist/types/Chaos.js.map +1 -0
  545. package/dist/types/CloudflareBindings.js +109 -0
  546. package/dist/types/CloudflareBindings.js.map +1 -0
  547. package/dist/types/Collection.js +50 -0
  548. package/dist/types/Collection.js.map +1 -0
  549. package/dist/types/DO.js +2 -0
  550. package/dist/types/DO.js.map +1 -0
  551. package/dist/types/DOLocation.js +63 -0
  552. package/dist/types/DOLocation.js.map +1 -0
  553. package/dist/types/EventHandler.js +57 -0
  554. package/dist/types/EventHandler.js.map +1 -0
  555. package/dist/types/Experiment.js +33 -0
  556. package/dist/types/Experiment.js.map +1 -0
  557. package/dist/types/Flag.js +57 -0
  558. package/dist/types/Flag.js.map +1 -0
  559. package/dist/types/Lifecycle.js +13 -0
  560. package/dist/types/Lifecycle.js.map +1 -0
  561. package/dist/types/Location.js +169 -0
  562. package/dist/types/Location.js.map +1 -0
  563. package/dist/types/Noun.js +66 -0
  564. package/dist/types/Noun.js.map +1 -0
  565. package/dist/types/SessionEvent.js +194 -0
  566. package/dist/types/SessionEvent.js.map +1 -0
  567. package/dist/types/Thing.js +55 -0
  568. package/dist/types/Thing.js.map +1 -0
  569. package/dist/types/ThingDO.js +153 -0
  570. package/dist/types/ThingDO.js.map +1 -0
  571. package/dist/types/Things.js +2 -0
  572. package/dist/types/Things.js.map +1 -0
  573. package/dist/types/Verb.js +119 -0
  574. package/dist/types/Verb.js.map +1 -0
  575. package/dist/types/WorkflowContext.js +70 -0
  576. package/dist/types/WorkflowContext.js.map +1 -0
  577. package/dist/types/analytics-api.js +13 -0
  578. package/dist/types/analytics-api.js.map +1 -0
  579. package/dist/types/capabilities.js +135 -0
  580. package/dist/types/capabilities.js.map +1 -0
  581. package/dist/types/drizzle.js +12 -0
  582. package/dist/types/drizzle.js.map +1 -0
  583. package/dist/types/event.js +201 -0
  584. package/dist/types/event.js.map +1 -0
  585. package/dist/types/fn.js +12 -0
  586. package/dist/types/fn.js.map +1 -0
  587. package/dist/types/iceberg.js +48 -0
  588. package/dist/types/iceberg.js.map +1 -0
  589. package/dist/types/ids.js +170 -0
  590. package/dist/types/ids.js.map +1 -0
  591. package/dist/types/index.js +41 -0
  592. package/dist/types/index.js.map +1 -0
  593. package/dist/types/introspect.js +54 -0
  594. package/dist/types/introspect.js.map +1 -0
  595. package/dist/types/observability.js +124 -0
  596. package/dist/types/observability.js.map +1 -0
  597. package/dist/types/sync-protocol.js +175 -0
  598. package/dist/types/sync-protocol.js.map +1 -0
  599. package/dist/types/vector.js +13 -0
  600. package/dist/types/vector.js.map +1 -0
  601. package/dist/workflows/ScheduleManager.js +473 -0
  602. package/dist/workflows/ScheduleManager.js.map +1 -0
  603. package/dist/workflows/StepDOBridge.js +149 -0
  604. package/dist/workflows/StepDOBridge.js.map +1 -0
  605. package/dist/workflows/StepResultStorage.js +232 -0
  606. package/dist/workflows/StepResultStorage.js.map +1 -0
  607. package/dist/workflows/WaitForEventManager.js +461 -0
  608. package/dist/workflows/WaitForEventManager.js.map +1 -0
  609. package/dist/workflows/analyzer.js +332 -0
  610. package/dist/workflows/analyzer.js.map +1 -0
  611. package/dist/workflows/compat/activity-router.js +484 -0
  612. package/dist/workflows/compat/activity-router.js.map +1 -0
  613. package/dist/workflows/compat/backends/cloudflare-workflows.js +431 -0
  614. package/dist/workflows/compat/backends/cloudflare-workflows.js.map +1 -0
  615. package/dist/workflows/compat/backends/index.js +14 -0
  616. package/dist/workflows/compat/backends/index.js.map +1 -0
  617. package/dist/workflows/compat/errors/index.js +375 -0
  618. package/dist/workflows/compat/errors/index.js.map +1 -0
  619. package/dist/workflows/compat/index.js +79 -0
  620. package/dist/workflows/compat/index.js.map +1 -0
  621. package/dist/workflows/compat/inngest/index.js +989 -0
  622. package/dist/workflows/compat/inngest/index.js.map +1 -0
  623. package/dist/workflows/compat/qstash/index.js +1263 -0
  624. package/dist/workflows/compat/qstash/index.js.map +1 -0
  625. package/dist/workflows/compat/temporal/activities.js +739 -0
  626. package/dist/workflows/compat/temporal/activities.js.map +1 -0
  627. package/dist/workflows/compat/temporal/child-workflows.js +154 -0
  628. package/dist/workflows/compat/temporal/child-workflows.js.map +1 -0
  629. package/dist/workflows/compat/temporal/client.js +381 -0
  630. package/dist/workflows/compat/temporal/client.js.map +1 -0
  631. package/dist/workflows/compat/temporal/context.js +309 -0
  632. package/dist/workflows/compat/temporal/context.js.map +1 -0
  633. package/dist/workflows/compat/temporal/determinism.js +216 -0
  634. package/dist/workflows/compat/temporal/determinism.js.map +1 -0
  635. package/dist/workflows/compat/temporal/errors.js +128 -0
  636. package/dist/workflows/compat/temporal/errors.js.map +1 -0
  637. package/dist/workflows/compat/temporal/index.js +2464 -0
  638. package/dist/workflows/compat/temporal/index.js.map +1 -0
  639. package/dist/workflows/compat/temporal/saga.js +504 -0
  640. package/dist/workflows/compat/temporal/saga.js.map +1 -0
  641. package/dist/workflows/compat/temporal/signals.js +364 -0
  642. package/dist/workflows/compat/temporal/signals.js.map +1 -0
  643. package/dist/workflows/compat/temporal/storage.js +271 -0
  644. package/dist/workflows/compat/temporal/storage.js.map +1 -0
  645. package/dist/workflows/compat/temporal/timers.js +347 -0
  646. package/dist/workflows/compat/temporal/timers.js.map +1 -0
  647. package/dist/workflows/compat/temporal/types.js +7 -0
  648. package/dist/workflows/compat/temporal/types.js.map +1 -0
  649. package/dist/workflows/compat/temporal/unified-primitives.js +339 -0
  650. package/dist/workflows/compat/temporal/unified-primitives.js.map +1 -0
  651. package/dist/workflows/compat/trigger/index.js +468 -0
  652. package/dist/workflows/compat/trigger/index.js.map +1 -0
  653. package/dist/workflows/compat/utils/index.js +69 -0
  654. package/dist/workflows/compat/utils/index.js.map +1 -0
  655. package/dist/workflows/context/correlation-capability.js +266 -0
  656. package/dist/workflows/context/correlation-capability.js.map +1 -0
  657. package/dist/workflows/context/correlation.js +484 -0
  658. package/dist/workflows/context/correlation.js.map +1 -0
  659. package/dist/workflows/context/experiment.js +289 -0
  660. package/dist/workflows/context/experiment.js.map +1 -0
  661. package/dist/workflows/context/flag.js +244 -0
  662. package/dist/workflows/context/flag.js.map +1 -0
  663. package/dist/workflows/context/foundation.js +648 -0
  664. package/dist/workflows/context/foundation.js.map +1 -0
  665. package/dist/workflows/context/human-base.js +106 -0
  666. package/dist/workflows/context/human-base.js.map +1 -0
  667. package/dist/workflows/context/human.js +368 -0
  668. package/dist/workflows/context/human.js.map +1 -0
  669. package/dist/workflows/context/measure.js +354 -0
  670. package/dist/workflows/context/measure.js.map +1 -0
  671. package/dist/workflows/context/rate-limit.js +358 -0
  672. package/dist/workflows/context/rate-limit.js.map +1 -0
  673. package/dist/workflows/context/user.js +117 -0
  674. package/dist/workflows/context/user.js.map +1 -0
  675. package/dist/workflows/context/vault.js +360 -0
  676. package/dist/workflows/context/vault.js.map +1 -0
  677. package/dist/workflows/data/entity-events/entity-events.js +489 -0
  678. package/dist/workflows/data/entity-events/entity-events.js.map +1 -0
  679. package/dist/workflows/data/experiment/index.js +599 -0
  680. package/dist/workflows/data/experiment/index.js.map +1 -0
  681. package/dist/workflows/data/goal/context.js +558 -0
  682. package/dist/workflows/data/goal/context.js.map +1 -0
  683. package/dist/workflows/data/goal/index.js +32 -0
  684. package/dist/workflows/data/goal/index.js.map +1 -0
  685. package/dist/workflows/data/measure/index.js +840 -0
  686. package/dist/workflows/data/measure/index.js.map +1 -0
  687. package/dist/workflows/data/stream/index.js +1215 -0
  688. package/dist/workflows/data/stream/index.js.map +1 -0
  689. package/dist/workflows/data/track/context.js +883 -0
  690. package/dist/workflows/data/track/context.js.map +1 -0
  691. package/dist/workflows/data/track/index.js +15 -0
  692. package/dist/workflows/data/track/index.js.map +1 -0
  693. package/dist/workflows/data/view/context.js +864 -0
  694. package/dist/workflows/data/view/context.js.map +1 -0
  695. package/dist/workflows/domain.js +93 -0
  696. package/dist/workflows/domain.js.map +1 -0
  697. package/dist/workflows/flag.js +176 -0
  698. package/dist/workflows/flag.js.map +1 -0
  699. package/dist/workflows/flags.js +217 -0
  700. package/dist/workflows/flags.js.map +1 -0
  701. package/dist/workflows/hash.js +209 -0
  702. package/dist/workflows/hash.js.map +1 -0
  703. package/dist/workflows/index.js +50 -0
  704. package/dist/workflows/index.js.map +1 -0
  705. package/dist/workflows/on.js +378 -0
  706. package/dist/workflows/on.js.map +1 -0
  707. package/dist/workflows/pipeline-promise.js +481 -0
  708. package/dist/workflows/pipeline-promise.js.map +1 -0
  709. package/dist/workflows/pipeline-types.js +20 -0
  710. package/dist/workflows/pipeline-types.js.map +1 -0
  711. package/dist/workflows/proxy.js +76 -0
  712. package/dist/workflows/proxy.js.map +1 -0
  713. package/dist/workflows/runtime.js +310 -0
  714. package/dist/workflows/runtime.js.map +1 -0
  715. package/dist/workflows/schedule-builder.js +327 -0
  716. package/dist/workflows/schedule-builder.js.map +1 -0
  717. package/dist/workflows/visibility/index.js +148 -0
  718. package/dist/workflows/visibility/index.js.map +1 -0
  719. package/dist/workflows/visibility/query-parser.js +150 -0
  720. package/dist/workflows/visibility/query-parser.js.map +1 -0
  721. package/dist/workflows/visibility/store.js +223 -0
  722. package/dist/workflows/visibility/store.js.map +1 -0
  723. package/dist/workflows/visibility/types.js +30 -0
  724. package/dist/workflows/visibility/types.js.map +1 -0
  725. package/dist/workflows/workflow.js +53 -0
  726. package/dist/workflows/workflow.js.map +1 -0
  727. package/package.json +279 -46
@@ -0,0 +1,764 @@
1
+ /**
2
+ * Window Manager - Unified windowing primitive inspired by Apache Flink
3
+ *
4
+ * Provides stream windowing capabilities including:
5
+ * - Tumbling windows (non-overlapping, fixed-size)
6
+ * - Sliding windows (overlapping, fixed-size with slide interval)
7
+ * - Session windows (gap-based, dynamic size)
8
+ * - Global windows (single window for all elements)
9
+ * - Various triggers (event-time, count-based, processing-time)
10
+ * - Late data handling and side outputs
11
+ *
12
+ * @see https://nightlies.apache.org/flink/flink-docs-stable/docs/dev/datastream/operators/windows/
13
+ */
14
+ import { noopMetrics, MetricNames } from './observability';
15
+ export { hours, minutes, seconds, milliseconds } from './utils/duration';
16
+ // ============================================================================
17
+ // Tumbling Window Assigner
18
+ // ============================================================================
19
+ class TumblingWindowAssigner {
20
+ size;
21
+ type = 'tumbling';
22
+ constructor(size) {
23
+ this.size = size;
24
+ }
25
+ assignWindows(element, timestamp) {
26
+ const sizeMs = this.size.toMillis();
27
+ const windowStart = Math.floor(timestamp / sizeMs) * sizeMs;
28
+ return [
29
+ {
30
+ start: windowStart,
31
+ end: windowStart + sizeMs,
32
+ },
33
+ ];
34
+ }
35
+ }
36
+ // ============================================================================
37
+ // Sliding Window Assigner
38
+ // ============================================================================
39
+ class SlidingWindowAssigner {
40
+ size;
41
+ slide;
42
+ type = 'sliding';
43
+ constructor(size, slide) {
44
+ this.size = size;
45
+ this.slide = slide;
46
+ const slideMs = slide.toMillis();
47
+ const sizeMs = size.toMillis();
48
+ if (slideMs <= 0) {
49
+ throw new Error('Slide must be positive');
50
+ }
51
+ if (slideMs > sizeMs) {
52
+ throw new Error('Slide cannot be larger than size');
53
+ }
54
+ }
55
+ assignWindows(element, timestamp) {
56
+ const sizeMs = this.size.toMillis();
57
+ const slideMs = this.slide.toMillis();
58
+ const windows = [];
59
+ // Find all windows that contain this timestamp
60
+ // A window contains timestamp if: start <= timestamp < end
61
+ // where end = start + size
62
+ // So: start <= timestamp < start + size
63
+ // Which means: timestamp - size < start <= timestamp
64
+ // The last window start that contains this element
65
+ const lastWindowStart = Math.floor(timestamp / slideMs) * slideMs;
66
+ // Count backwards to find all windows
67
+ const numWindows = Math.ceil(sizeMs / slideMs);
68
+ for (let i = 0; i < numWindows; i++) {
69
+ const windowStart = lastWindowStart - i * slideMs;
70
+ const windowEnd = windowStart + sizeMs;
71
+ // Check if this window actually contains the timestamp
72
+ if (windowStart <= timestamp && timestamp < windowEnd) {
73
+ windows.push({ start: windowStart, end: windowEnd });
74
+ }
75
+ }
76
+ return windows.sort((a, b) => a.start - b.start);
77
+ }
78
+ }
79
+ // ============================================================================
80
+ // Session Window Assigner
81
+ // ============================================================================
82
+ class SessionWindowAssigner {
83
+ gap;
84
+ type = 'session';
85
+ constructor(gap) {
86
+ this.gap = gap;
87
+ }
88
+ assignWindows(element, timestamp, key, existingWindows) {
89
+ const gapMs = this.gap.toMillis();
90
+ // For session windows, we need to find or create a session
91
+ // The initial window is [timestamp, timestamp + gap)
92
+ const newWindow = {
93
+ start: timestamp,
94
+ end: timestamp + gapMs,
95
+ key,
96
+ };
97
+ if (!existingWindows) {
98
+ return [newWindow];
99
+ }
100
+ // Find overlapping or adjacent sessions to merge
101
+ const windowsToMerge = [newWindow];
102
+ for (const [windowKey, windowData] of existingWindows) {
103
+ const w = windowData.window;
104
+ if (key !== undefined && w.key !== key)
105
+ continue;
106
+ // Check if windows overlap or are adjacent (within gap)
107
+ // Two sessions should merge if the gap between them is less than the session gap
108
+ // Session windows: [start1, end1) and [start2, end2) merge if they overlap or touch
109
+ if ((newWindow.start <= w.end && newWindow.end >= w.start) || // Overlap
110
+ Math.abs(newWindow.start - w.end) <= gapMs || // New starts within gap of existing end
111
+ Math.abs(w.start - newWindow.end) <= gapMs // Existing starts within gap of new end
112
+ ) {
113
+ windowsToMerge.push(w);
114
+ }
115
+ }
116
+ // Merge all overlapping windows
117
+ if (windowsToMerge.length === 1) {
118
+ return [newWindow];
119
+ }
120
+ const mergedStart = Math.min(...windowsToMerge.map((w) => w.start));
121
+ const mergedEnd = Math.max(...windowsToMerge.map((w) => w.end));
122
+ return [{ start: mergedStart, end: mergedEnd, key }];
123
+ }
124
+ }
125
+ // ============================================================================
126
+ // Global Window Assigner
127
+ // ============================================================================
128
+ class GlobalWindowAssigner {
129
+ type = 'global';
130
+ assignWindows() {
131
+ return [
132
+ {
133
+ start: Number.MIN_SAFE_INTEGER,
134
+ end: Number.MAX_SAFE_INTEGER,
135
+ },
136
+ ];
137
+ }
138
+ }
139
+ // ============================================================================
140
+ // Trigger Types
141
+ // ============================================================================
142
+ export var TriggerResult;
143
+ (function (TriggerResult) {
144
+ TriggerResult["CONTINUE"] = "CONTINUE";
145
+ TriggerResult["FIRE"] = "FIRE";
146
+ TriggerResult["FIRE_AND_PURGE"] = "FIRE_AND_PURGE";
147
+ TriggerResult["PURGE"] = "PURGE";
148
+ })(TriggerResult || (TriggerResult = {}));
149
+ export class Trigger {
150
+ /**
151
+ * Clean up any resources held by this trigger.
152
+ * Subclasses should override if they hold timers or other resources.
153
+ */
154
+ dispose() {
155
+ // Default implementation does nothing
156
+ }
157
+ static or(...triggers) {
158
+ return new OrTrigger(triggers);
159
+ }
160
+ static and(...triggers) {
161
+ return new AndTrigger(triggers);
162
+ }
163
+ }
164
+ // ============================================================================
165
+ // Event Time Trigger
166
+ // ============================================================================
167
+ export class EventTimeTrigger extends Trigger {
168
+ onElement(_ctx) {
169
+ return TriggerResult.CONTINUE;
170
+ }
171
+ onWatermark(ctx) {
172
+ if (ctx.watermark >= ctx.window.end) {
173
+ return TriggerResult.FIRE;
174
+ }
175
+ return TriggerResult.CONTINUE;
176
+ }
177
+ onProcessingTime(_ctx) {
178
+ return TriggerResult.CONTINUE;
179
+ }
180
+ }
181
+ // ============================================================================
182
+ // Count Trigger
183
+ // ============================================================================
184
+ export class CountTrigger extends Trigger {
185
+ count;
186
+ constructor(count) {
187
+ super();
188
+ this.count = count;
189
+ }
190
+ onElement(ctx) {
191
+ if (ctx.countSinceLastTrigger >= this.count) {
192
+ return TriggerResult.FIRE_AND_PURGE;
193
+ }
194
+ return TriggerResult.CONTINUE;
195
+ }
196
+ onWatermark(_ctx) {
197
+ return TriggerResult.CONTINUE;
198
+ }
199
+ onProcessingTime(_ctx) {
200
+ return TriggerResult.CONTINUE;
201
+ }
202
+ }
203
+ // ============================================================================
204
+ // Processing Time Trigger
205
+ // ============================================================================
206
+ export class ProcessingTimeTrigger extends Trigger {
207
+ interval;
208
+ timerId = null;
209
+ callback = null;
210
+ constructor(interval) {
211
+ super();
212
+ this.interval = interval;
213
+ }
214
+ setCallback(callback) {
215
+ this.callback = callback;
216
+ if (this.timerId) {
217
+ clearInterval(this.timerId);
218
+ }
219
+ this.timerId = setInterval(() => {
220
+ if (this.callback) {
221
+ this.callback();
222
+ }
223
+ }, this.interval.toMillis());
224
+ }
225
+ clearTimer() {
226
+ if (this.timerId) {
227
+ clearInterval(this.timerId);
228
+ this.timerId = null;
229
+ }
230
+ }
231
+ /**
232
+ * Clean up the interval timer to prevent memory leaks.
233
+ */
234
+ dispose() {
235
+ this.clearTimer();
236
+ this.callback = null;
237
+ }
238
+ onElement(_ctx) {
239
+ return TriggerResult.CONTINUE;
240
+ }
241
+ onWatermark(_ctx) {
242
+ return TriggerResult.CONTINUE;
243
+ }
244
+ onProcessingTime(_ctx) {
245
+ return TriggerResult.FIRE;
246
+ }
247
+ }
248
+ // ============================================================================
249
+ // Purging Trigger
250
+ // ============================================================================
251
+ export class PurgingTrigger extends Trigger {
252
+ innerTrigger;
253
+ constructor(innerTrigger) {
254
+ super();
255
+ this.innerTrigger = innerTrigger;
256
+ }
257
+ onElement(ctx) {
258
+ const result = this.innerTrigger.onElement(ctx);
259
+ if (result === TriggerResult.FIRE) {
260
+ return TriggerResult.FIRE_AND_PURGE;
261
+ }
262
+ return result;
263
+ }
264
+ onWatermark(ctx) {
265
+ const result = this.innerTrigger.onWatermark(ctx);
266
+ if (result === TriggerResult.FIRE) {
267
+ return TriggerResult.FIRE_AND_PURGE;
268
+ }
269
+ return result;
270
+ }
271
+ onProcessingTime(ctx) {
272
+ const result = this.innerTrigger.onProcessingTime(ctx);
273
+ if (result === TriggerResult.FIRE) {
274
+ return TriggerResult.FIRE_AND_PURGE;
275
+ }
276
+ return result;
277
+ }
278
+ dispose() {
279
+ this.innerTrigger.dispose();
280
+ }
281
+ }
282
+ // ============================================================================
283
+ // Composite Triggers
284
+ // ============================================================================
285
+ class OrTrigger extends Trigger {
286
+ triggers;
287
+ firedTriggers = new Set();
288
+ constructor(triggers) {
289
+ super();
290
+ this.triggers = triggers;
291
+ }
292
+ onElement(ctx) {
293
+ for (let i = 0; i < this.triggers.length; i++) {
294
+ const result = this.triggers[i].onElement(ctx);
295
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
296
+ this.firedTriggers.add(i);
297
+ return result;
298
+ }
299
+ }
300
+ return TriggerResult.CONTINUE;
301
+ }
302
+ onWatermark(ctx) {
303
+ for (let i = 0; i < this.triggers.length; i++) {
304
+ const result = this.triggers[i].onWatermark(ctx);
305
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
306
+ this.firedTriggers.add(i);
307
+ return result;
308
+ }
309
+ }
310
+ return TriggerResult.CONTINUE;
311
+ }
312
+ onProcessingTime(ctx) {
313
+ for (let i = 0; i < this.triggers.length; i++) {
314
+ const result = this.triggers[i].onProcessingTime(ctx);
315
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
316
+ this.firedTriggers.add(i);
317
+ return result;
318
+ }
319
+ }
320
+ return TriggerResult.CONTINUE;
321
+ }
322
+ dispose() {
323
+ for (const trigger of this.triggers) {
324
+ trigger.dispose();
325
+ }
326
+ this.firedTriggers.clear();
327
+ }
328
+ }
329
+ class AndTrigger extends Trigger {
330
+ triggers;
331
+ satisfiedTriggers = new Map();
332
+ constructor(triggers) {
333
+ super();
334
+ this.triggers = triggers;
335
+ }
336
+ getWindowKey(window) {
337
+ return `${window.start}-${window.end}-${window.key || ''}`;
338
+ }
339
+ checkAndFire(windowKey) {
340
+ const satisfied = this.satisfiedTriggers.get(windowKey);
341
+ if (satisfied && satisfied.size === this.triggers.length) {
342
+ this.satisfiedTriggers.delete(windowKey);
343
+ return TriggerResult.FIRE;
344
+ }
345
+ return TriggerResult.CONTINUE;
346
+ }
347
+ onElement(ctx) {
348
+ const windowKey = this.getWindowKey(ctx.window);
349
+ if (!this.satisfiedTriggers.has(windowKey)) {
350
+ this.satisfiedTriggers.set(windowKey, new Set());
351
+ }
352
+ const satisfied = this.satisfiedTriggers.get(windowKey);
353
+ for (let i = 0; i < this.triggers.length; i++) {
354
+ const result = this.triggers[i].onElement(ctx);
355
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
356
+ satisfied.add(i);
357
+ }
358
+ }
359
+ return this.checkAndFire(windowKey);
360
+ }
361
+ onWatermark(ctx) {
362
+ const windowKey = this.getWindowKey(ctx.window);
363
+ if (!this.satisfiedTriggers.has(windowKey)) {
364
+ this.satisfiedTriggers.set(windowKey, new Set());
365
+ }
366
+ const satisfied = this.satisfiedTriggers.get(windowKey);
367
+ for (let i = 0; i < this.triggers.length; i++) {
368
+ const result = this.triggers[i].onWatermark(ctx);
369
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
370
+ satisfied.add(i);
371
+ }
372
+ }
373
+ return this.checkAndFire(windowKey);
374
+ }
375
+ onProcessingTime(ctx) {
376
+ const windowKey = this.getWindowKey(ctx.window);
377
+ if (!this.satisfiedTriggers.has(windowKey)) {
378
+ this.satisfiedTriggers.set(windowKey, new Set());
379
+ }
380
+ const satisfied = this.satisfiedTriggers.get(windowKey);
381
+ for (let i = 0; i < this.triggers.length; i++) {
382
+ const result = this.triggers[i].onProcessingTime(ctx);
383
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
384
+ satisfied.add(i);
385
+ }
386
+ }
387
+ return this.checkAndFire(windowKey);
388
+ }
389
+ dispose() {
390
+ for (const trigger of this.triggers) {
391
+ trigger.dispose();
392
+ }
393
+ this.satisfiedTriggers.clear();
394
+ }
395
+ }
396
+ // ============================================================================
397
+ // Window Manager
398
+ // ============================================================================
399
+ export class WindowManager {
400
+ assigner;
401
+ windows = new Map();
402
+ watermark = Number.MIN_SAFE_INTEGER;
403
+ trigger = null;
404
+ lateDataHandler = null;
405
+ allowedLateness = 0;
406
+ triggerCallback = null;
407
+ keyExtractor = null;
408
+ metrics;
409
+ constructor(assigner, options) {
410
+ this.assigner = assigner;
411
+ this.metrics = options?.metrics ?? noopMetrics;
412
+ }
413
+ // -------------------------------------------------------------------------
414
+ // Static Factory Methods
415
+ // -------------------------------------------------------------------------
416
+ static tumbling(size) {
417
+ return new TumblingWindowAssigner(size);
418
+ }
419
+ static sliding(size, slide) {
420
+ return new SlidingWindowAssigner(size, slide);
421
+ }
422
+ static session(gap) {
423
+ return new SessionWindowAssigner(gap);
424
+ }
425
+ static global() {
426
+ return new GlobalWindowAssigner();
427
+ }
428
+ // -------------------------------------------------------------------------
429
+ // Configuration Methods
430
+ // -------------------------------------------------------------------------
431
+ withTrigger(trigger) {
432
+ this.trigger = trigger;
433
+ // Set up processing time trigger if applicable
434
+ if (trigger instanceof ProcessingTimeTrigger) {
435
+ trigger.setCallback(() => {
436
+ this.fireProcessingTimeTrigger();
437
+ });
438
+ }
439
+ return this;
440
+ }
441
+ withKeyExtractor(fn) {
442
+ this.keyExtractor = fn;
443
+ return this;
444
+ }
445
+ allowLateness(duration) {
446
+ this.allowedLateness = duration.toMillis();
447
+ return this;
448
+ }
449
+ sideOutputLate(handler) {
450
+ this.lateDataHandler = handler;
451
+ return this;
452
+ }
453
+ onTrigger(callback) {
454
+ this.triggerCallback = callback;
455
+ }
456
+ // -------------------------------------------------------------------------
457
+ // Core Methods
458
+ // -------------------------------------------------------------------------
459
+ getWindowKey(window) {
460
+ return `${window.start}-${window.end}-${window.key || ''}`;
461
+ }
462
+ assign(element, timestamp) {
463
+ const key = this.keyExtractor ? this.keyExtractor(element) : undefined;
464
+ if (this.assigner.type === 'session') {
465
+ return this.assigner.assignWindows(element, timestamp, key, this.windows);
466
+ }
467
+ const windows = this.assigner.assignWindows(element, timestamp, key);
468
+ if (key !== undefined) {
469
+ return windows.map((w) => ({ ...w, key }));
470
+ }
471
+ return windows;
472
+ }
473
+ process(element, timestamp) {
474
+ const start = performance.now();
475
+ try {
476
+ const key = this.keyExtractor ? this.keyExtractor(element) : undefined;
477
+ // Check if data is late (beyond watermark + allowed lateness)
478
+ if (this.assigner.type !== 'global' && this.assigner.type !== 'session') {
479
+ const windows = this.assign(element, timestamp);
480
+ for (const window of windows) {
481
+ if (window.end <= this.watermark - this.allowedLateness) {
482
+ // Data is too late
483
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_LATE_DATA);
484
+ if (this.lateDataHandler) {
485
+ this.lateDataHandler(element, window);
486
+ }
487
+ return;
488
+ }
489
+ }
490
+ }
491
+ // For session windows, we need special handling
492
+ if (this.assigner.type === 'session') {
493
+ this.processSessionElement(element, timestamp, key);
494
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_ELEMENTS_PROCESSED);
495
+ return;
496
+ }
497
+ const windows = this.assign(element, timestamp);
498
+ for (const window of windows) {
499
+ const windowKey = this.getWindowKey(window);
500
+ // Check if window is still accepting data (within allowed lateness)
501
+ if (window.end <= this.watermark) {
502
+ // Window has been triggered, check if within allowed lateness
503
+ if (window.end > this.watermark - this.allowedLateness) {
504
+ // Re-trigger the window with the late element
505
+ const existing = this.windows.get(windowKey);
506
+ if (existing) {
507
+ existing.elements.push(element);
508
+ this.fireTrigger(existing);
509
+ }
510
+ else if (this.lateDataHandler) {
511
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_LATE_DATA);
512
+ this.lateDataHandler(element, window);
513
+ }
514
+ }
515
+ else if (this.lateDataHandler) {
516
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_LATE_DATA);
517
+ this.lateDataHandler(element, window);
518
+ }
519
+ continue;
520
+ }
521
+ let windowData = this.windows.get(windowKey);
522
+ const isNewWindow = !windowData;
523
+ if (!windowData) {
524
+ windowData = {
525
+ window,
526
+ elements: [],
527
+ triggered: false,
528
+ countSinceLastTrigger: 0,
529
+ };
530
+ this.windows.set(windowKey, windowData);
531
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_WINDOW_CREATED);
532
+ }
533
+ windowData.elements.push(element);
534
+ windowData.countSinceLastTrigger++;
535
+ // Check element trigger
536
+ if (this.trigger) {
537
+ const ctx = {
538
+ window: windowData.window,
539
+ elements: windowData.elements,
540
+ watermark: this.watermark,
541
+ countSinceLastTrigger: windowData.countSinceLastTrigger,
542
+ };
543
+ const result = this.trigger.onElement(ctx);
544
+ this.handleTriggerResult(result, windowData);
545
+ }
546
+ }
547
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_ELEMENTS_PROCESSED);
548
+ this.metrics.recordGauge(MetricNames.WINDOW_MANAGER_ACTIVE_WINDOWS, this.windows.size);
549
+ }
550
+ finally {
551
+ this.metrics.recordLatency(MetricNames.WINDOW_MANAGER_PROCESS_LATENCY, performance.now() - start);
552
+ }
553
+ }
554
+ processSessionElement(element, timestamp, key) {
555
+ const gapMs = this.assigner.gap.toMillis();
556
+ // Find all windows that should be merged with this element
557
+ const windowsToMerge = [];
558
+ const newWindow = { start: timestamp, end: timestamp + gapMs, key };
559
+ for (const [windowKey, windowData] of this.windows) {
560
+ const w = windowData.window;
561
+ if (key !== undefined && w.key !== key)
562
+ continue;
563
+ // Check if windows should merge
564
+ if ((newWindow.start <= w.end && newWindow.end >= w.start) ||
565
+ Math.abs(newWindow.start - w.end) <= 0 ||
566
+ Math.abs(w.start - newWindow.end) <= 0) {
567
+ windowsToMerge.push(windowData);
568
+ }
569
+ }
570
+ if (windowsToMerge.length === 0) {
571
+ // Create new session window
572
+ const windowKey = this.getWindowKey(newWindow);
573
+ this.windows.set(windowKey, {
574
+ window: newWindow,
575
+ elements: [element],
576
+ triggered: false,
577
+ countSinceLastTrigger: 1,
578
+ });
579
+ }
580
+ else {
581
+ // Merge windows
582
+ const allElements = [element];
583
+ let mergedStart = timestamp;
584
+ let mergedEnd = timestamp + gapMs;
585
+ for (const wd of windowsToMerge) {
586
+ allElements.push(...wd.elements);
587
+ mergedStart = Math.min(mergedStart, wd.window.start);
588
+ mergedEnd = Math.max(mergedEnd, wd.window.end);
589
+ // Remove old window
590
+ this.windows.delete(this.getWindowKey(wd.window));
591
+ }
592
+ // Update merged end to be max timestamp + gap
593
+ const maxTimestamp = Math.max(timestamp, ...windowsToMerge.flatMap((wd) =>
594
+ // For simplicity, use window end - gap as approximate max timestamp
595
+ [wd.window.end - gapMs]));
596
+ mergedEnd = maxTimestamp + gapMs;
597
+ const mergedWindow = { start: mergedStart, end: mergedEnd, key };
598
+ const windowKey = this.getWindowKey(mergedWindow);
599
+ this.windows.set(windowKey, {
600
+ window: mergedWindow,
601
+ elements: allElements,
602
+ triggered: false,
603
+ countSinceLastTrigger: allElements.length,
604
+ });
605
+ }
606
+ }
607
+ advanceWatermark(timestamp) {
608
+ const start = performance.now();
609
+ try {
610
+ if (timestamp < this.watermark) {
611
+ throw new Error('Watermark cannot go backwards');
612
+ }
613
+ this.watermark = timestamp;
614
+ const triggeredWindows = [];
615
+ // Check watermark trigger for all windows
616
+ for (const [windowKey, windowData] of this.windows) {
617
+ if (windowData.triggered && this.assigner.type !== 'session')
618
+ continue;
619
+ // For session windows, automatically trigger when watermark passes window end
620
+ if (this.assigner.type === 'session' && !windowData.triggered) {
621
+ if (this.watermark >= windowData.window.end) {
622
+ this.fireTrigger(windowData);
623
+ windowData.triggered = true;
624
+ triggeredWindows.push(windowData.window);
625
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_WINDOW_TRIGGERED);
626
+ continue;
627
+ }
628
+ }
629
+ if (this.trigger) {
630
+ const ctx = {
631
+ window: windowData.window,
632
+ elements: windowData.elements,
633
+ watermark: this.watermark,
634
+ countSinceLastTrigger: windowData.countSinceLastTrigger,
635
+ };
636
+ const result = this.trigger.onWatermark(ctx);
637
+ if (result === TriggerResult.FIRE || result === TriggerResult.FIRE_AND_PURGE) {
638
+ this.fireTrigger(windowData);
639
+ windowData.triggered = true;
640
+ triggeredWindows.push(windowData.window);
641
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_WINDOW_TRIGGERED);
642
+ if (result === TriggerResult.FIRE_AND_PURGE) {
643
+ windowData.elements = [];
644
+ windowData.countSinceLastTrigger = 0;
645
+ }
646
+ }
647
+ }
648
+ }
649
+ // Clean up old windows beyond allowed lateness
650
+ const windowCountBefore = this.windows.size;
651
+ this.cleanupOldWindows();
652
+ const windowsRemoved = windowCountBefore - this.windows.size;
653
+ if (windowsRemoved > 0) {
654
+ this.metrics.incrementCounter(MetricNames.WINDOW_MANAGER_WINDOW_CLOSED, undefined, windowsRemoved);
655
+ }
656
+ this.metrics.recordGauge(MetricNames.WINDOW_MANAGER_ACTIVE_WINDOWS, this.windows.size);
657
+ return triggeredWindows;
658
+ }
659
+ finally {
660
+ this.metrics.recordLatency(MetricNames.WINDOW_MANAGER_ADVANCE_WATERMARK_LATENCY, performance.now() - start);
661
+ }
662
+ }
663
+ cleanupOldWindows() {
664
+ const windowsToRemove = [];
665
+ for (const [windowKey, windowData] of this.windows) {
666
+ // Don't clean up global windows
667
+ if (this.assigner.type === 'global')
668
+ continue;
669
+ // Remove windows that are beyond watermark + allowed lateness
670
+ if (windowData.triggered &&
671
+ windowData.window.end <= this.watermark - this.allowedLateness) {
672
+ windowsToRemove.push(windowKey);
673
+ }
674
+ }
675
+ for (const key of windowsToRemove) {
676
+ this.windows.delete(key);
677
+ }
678
+ }
679
+ getCurrentWatermark() {
680
+ return this.watermark;
681
+ }
682
+ getWindowState(window) {
683
+ const windowKey = this.getWindowKey(window);
684
+ const windowData = this.windows.get(windowKey);
685
+ if (!windowData) {
686
+ return [];
687
+ }
688
+ // Return a copy
689
+ return [...windowData.elements];
690
+ }
691
+ clearWindow(window) {
692
+ const windowKey = this.getWindowKey(window);
693
+ const windowData = this.windows.get(windowKey);
694
+ if (windowData) {
695
+ windowData.elements = [];
696
+ windowData.countSinceLastTrigger = 0;
697
+ }
698
+ }
699
+ getActiveWindowCount() {
700
+ return this.windows.size;
701
+ }
702
+ /**
703
+ * Dispose of all resources held by this WindowManager.
704
+ * This MUST be called when the WindowManager is no longer needed to prevent
705
+ * memory leaks from interval timers (especially ProcessingTimeTrigger).
706
+ *
707
+ * After calling dispose():
708
+ * - All timers are cleared
709
+ * - All window state is cleared
710
+ * - The trigger callback is removed
711
+ * - The WindowManager should not be used again
712
+ */
713
+ dispose() {
714
+ // Clean up trigger (especially important for ProcessingTimeTrigger)
715
+ if (this.trigger) {
716
+ this.trigger.dispose();
717
+ this.trigger = null;
718
+ }
719
+ // Clear all window state
720
+ this.windows.clear();
721
+ // Clear callbacks
722
+ this.triggerCallback = null;
723
+ this.lateDataHandler = null;
724
+ this.keyExtractor = null;
725
+ }
726
+ // -------------------------------------------------------------------------
727
+ // Private Helpers
728
+ // -------------------------------------------------------------------------
729
+ fireTrigger(windowData) {
730
+ if (this.triggerCallback && windowData.elements.length > 0) {
731
+ this.triggerCallback(windowData.window, [...windowData.elements]);
732
+ }
733
+ }
734
+ handleTriggerResult(result, windowData) {
735
+ if (result === TriggerResult.FIRE) {
736
+ this.fireTrigger(windowData);
737
+ windowData.countSinceLastTrigger = 0;
738
+ }
739
+ else if (result === TriggerResult.FIRE_AND_PURGE) {
740
+ this.fireTrigger(windowData);
741
+ windowData.elements = [];
742
+ windowData.countSinceLastTrigger = 0;
743
+ }
744
+ else if (result === TriggerResult.PURGE) {
745
+ windowData.elements = [];
746
+ windowData.countSinceLastTrigger = 0;
747
+ }
748
+ }
749
+ fireProcessingTimeTrigger() {
750
+ for (const [_, windowData] of this.windows) {
751
+ if (this.trigger) {
752
+ const ctx = {
753
+ window: windowData.window,
754
+ elements: windowData.elements,
755
+ watermark: this.watermark,
756
+ countSinceLastTrigger: windowData.countSinceLastTrigger,
757
+ };
758
+ const result = this.trigger.onProcessingTime(ctx);
759
+ this.handleTriggerResult(result, windowData);
760
+ }
761
+ }
762
+ }
763
+ }
764
+ //# sourceMappingURL=window-manager.js.map