@uploadista/core 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 (359) hide show
  1. package/.turbo/turbo-build.log +5 -0
  2. package/.turbo/turbo-check.log +231 -0
  3. package/.turbo/turbo-format.log +5 -0
  4. package/LICENSE +21 -0
  5. package/README.md +1120 -0
  6. package/dist/chunk-CUT6urMc.cjs +1 -0
  7. package/dist/debounce-C2SeqcxD.js +2 -0
  8. package/dist/debounce-C2SeqcxD.js.map +1 -0
  9. package/dist/debounce-LZK7yS7Z.cjs +1 -0
  10. package/dist/errors/index.cjs +1 -0
  11. package/dist/errors/index.d.cts +3 -0
  12. package/dist/errors/index.d.ts +3 -0
  13. package/dist/errors/index.d.ts.map +1 -0
  14. package/dist/errors/index.js +2 -0
  15. package/dist/errors/uploadista-error.d.ts +209 -0
  16. package/dist/errors/uploadista-error.d.ts.map +1 -0
  17. package/dist/errors/uploadista-error.js +322 -0
  18. package/dist/errors-8i_aMxOE.js +1 -0
  19. package/dist/errors-CRm1FHHT.cjs +0 -0
  20. package/dist/flow/edge.d.ts +47 -0
  21. package/dist/flow/edge.d.ts.map +1 -0
  22. package/dist/flow/edge.js +40 -0
  23. package/dist/flow/event.d.ts +206 -0
  24. package/dist/flow/event.d.ts.map +1 -0
  25. package/dist/flow/event.js +53 -0
  26. package/dist/flow/flow-server.d.ts +223 -0
  27. package/dist/flow/flow-server.d.ts.map +1 -0
  28. package/dist/flow/flow-server.js +614 -0
  29. package/dist/flow/flow.d.ts +238 -0
  30. package/dist/flow/flow.d.ts.map +1 -0
  31. package/dist/flow/flow.js +629 -0
  32. package/dist/flow/index.cjs +1 -0
  33. package/dist/flow/index.d.cts +6 -0
  34. package/dist/flow/index.d.ts +24 -0
  35. package/dist/flow/index.d.ts.map +1 -0
  36. package/dist/flow/index.js +24 -0
  37. package/dist/flow/node.d.ts +136 -0
  38. package/dist/flow/node.d.ts.map +1 -0
  39. package/dist/flow/node.js +153 -0
  40. package/dist/flow/nodes/index.d.ts +8 -0
  41. package/dist/flow/nodes/index.d.ts.map +1 -0
  42. package/dist/flow/nodes/index.js +7 -0
  43. package/dist/flow/nodes/input-node.d.ts +78 -0
  44. package/dist/flow/nodes/input-node.d.ts.map +1 -0
  45. package/dist/flow/nodes/input-node.js +233 -0
  46. package/dist/flow/nodes/storage-node.d.ts +67 -0
  47. package/dist/flow/nodes/storage-node.d.ts.map +1 -0
  48. package/dist/flow/nodes/storage-node.js +94 -0
  49. package/dist/flow/nodes/streaming-input-node.d.ts +69 -0
  50. package/dist/flow/nodes/streaming-input-node.d.ts.map +1 -0
  51. package/dist/flow/nodes/streaming-input-node.js +156 -0
  52. package/dist/flow/nodes/transform-node.d.ts +85 -0
  53. package/dist/flow/nodes/transform-node.d.ts.map +1 -0
  54. package/dist/flow/nodes/transform-node.js +107 -0
  55. package/dist/flow/parallel-scheduler.d.ts +175 -0
  56. package/dist/flow/parallel-scheduler.d.ts.map +1 -0
  57. package/dist/flow/parallel-scheduler.js +193 -0
  58. package/dist/flow/plugins/credential-provider.d.ts +47 -0
  59. package/dist/flow/plugins/credential-provider.d.ts.map +1 -0
  60. package/dist/flow/plugins/credential-provider.js +24 -0
  61. package/dist/flow/plugins/image-ai-plugin.d.ts +61 -0
  62. package/dist/flow/plugins/image-ai-plugin.d.ts.map +1 -0
  63. package/dist/flow/plugins/image-ai-plugin.js +21 -0
  64. package/dist/flow/plugins/image-plugin.d.ts +52 -0
  65. package/dist/flow/plugins/image-plugin.d.ts.map +1 -0
  66. package/dist/flow/plugins/image-plugin.js +22 -0
  67. package/dist/flow/plugins/types/describe-image-node.d.ts +16 -0
  68. package/dist/flow/plugins/types/describe-image-node.d.ts.map +1 -0
  69. package/dist/flow/plugins/types/describe-image-node.js +9 -0
  70. package/dist/flow/plugins/types/index.d.ts +9 -0
  71. package/dist/flow/plugins/types/index.d.ts.map +1 -0
  72. package/dist/flow/plugins/types/index.js +8 -0
  73. package/dist/flow/plugins/types/optimize-node.d.ts +20 -0
  74. package/dist/flow/plugins/types/optimize-node.d.ts.map +1 -0
  75. package/dist/flow/plugins/types/optimize-node.js +11 -0
  76. package/dist/flow/plugins/types/remove-background-node.d.ts +16 -0
  77. package/dist/flow/plugins/types/remove-background-node.d.ts.map +1 -0
  78. package/dist/flow/plugins/types/remove-background-node.js +9 -0
  79. package/dist/flow/plugins/types/resize-node.d.ts +21 -0
  80. package/dist/flow/plugins/types/resize-node.d.ts.map +1 -0
  81. package/dist/flow/plugins/types/resize-node.js +16 -0
  82. package/dist/flow/plugins/zip-plugin.d.ts +62 -0
  83. package/dist/flow/plugins/zip-plugin.d.ts.map +1 -0
  84. package/dist/flow/plugins/zip-plugin.js +21 -0
  85. package/dist/flow/typed-flow.d.ts +90 -0
  86. package/dist/flow/typed-flow.d.ts.map +1 -0
  87. package/dist/flow/typed-flow.js +59 -0
  88. package/dist/flow/types/flow-file.d.ts +45 -0
  89. package/dist/flow/types/flow-file.d.ts.map +1 -0
  90. package/dist/flow/types/flow-file.js +27 -0
  91. package/dist/flow/types/flow-job.d.ts +118 -0
  92. package/dist/flow/types/flow-job.d.ts.map +1 -0
  93. package/dist/flow/types/flow-job.js +11 -0
  94. package/dist/flow/types/flow-types.d.ts +321 -0
  95. package/dist/flow/types/flow-types.d.ts.map +1 -0
  96. package/dist/flow/types/flow-types.js +52 -0
  97. package/dist/flow/types/index.d.ts +4 -0
  98. package/dist/flow/types/index.d.ts.map +1 -0
  99. package/dist/flow/types/index.js +3 -0
  100. package/dist/flow/types/run-args.d.ts +38 -0
  101. package/dist/flow/types/run-args.d.ts.map +1 -0
  102. package/dist/flow/types/run-args.js +30 -0
  103. package/dist/flow/types/type-validator.d.ts +26 -0
  104. package/dist/flow/types/type-validator.d.ts.map +1 -0
  105. package/dist/flow/types/type-validator.js +134 -0
  106. package/dist/flow/utils/resolve-upload-metadata.d.ts +11 -0
  107. package/dist/flow/utils/resolve-upload-metadata.d.ts.map +1 -0
  108. package/dist/flow/utils/resolve-upload-metadata.js +28 -0
  109. package/dist/flow-2zXnEiWL.cjs +1 -0
  110. package/dist/flow-CRaKy7Vj.js +2 -0
  111. package/dist/flow-CRaKy7Vj.js.map +1 -0
  112. package/dist/generate-id-Dm-Vboxq.d.ts +34 -0
  113. package/dist/generate-id-Dm-Vboxq.d.ts.map +1 -0
  114. package/dist/generate-id-LjJRLD6N.d.cts +34 -0
  115. package/dist/generate-id-LjJRLD6N.d.cts.map +1 -0
  116. package/dist/generate-id-xHp_Z7Cl.cjs +1 -0
  117. package/dist/generate-id-yohS1ZDk.js +2 -0
  118. package/dist/generate-id-yohS1ZDk.js.map +1 -0
  119. package/dist/index-BO8GZlbD.d.cts +1040 -0
  120. package/dist/index-BO8GZlbD.d.cts.map +1 -0
  121. package/dist/index-BoGG5KAY.d.ts +1 -0
  122. package/dist/index-BtBZHVmz.d.cts +1 -0
  123. package/dist/index-D-CoVpkZ.d.ts +1004 -0
  124. package/dist/index-D-CoVpkZ.d.ts.map +1 -0
  125. package/dist/index.cjs +1 -0
  126. package/dist/index.d.cts +6 -0
  127. package/dist/index.d.ts +5 -0
  128. package/dist/index.d.ts.map +1 -0
  129. package/dist/index.js +5 -0
  130. package/dist/logger/logger.cjs +1 -0
  131. package/dist/logger/logger.d.cts +8 -0
  132. package/dist/logger/logger.d.cts.map +1 -0
  133. package/dist/logger/logger.d.ts +5 -0
  134. package/dist/logger/logger.d.ts.map +1 -0
  135. package/dist/logger/logger.js +10 -0
  136. package/dist/logger/logger.js.map +1 -0
  137. package/dist/semaphore-0ZwjVpyF.js +2 -0
  138. package/dist/semaphore-0ZwjVpyF.js.map +1 -0
  139. package/dist/semaphore-BHprIjFI.d.cts +37 -0
  140. package/dist/semaphore-BHprIjFI.d.cts.map +1 -0
  141. package/dist/semaphore-DThupBkc.d.ts +37 -0
  142. package/dist/semaphore-DThupBkc.d.ts.map +1 -0
  143. package/dist/semaphore-DVrONiAV.cjs +1 -0
  144. package/dist/stream-limiter-CoWKv39w.js +2 -0
  145. package/dist/stream-limiter-CoWKv39w.js.map +1 -0
  146. package/dist/stream-limiter-JgOwmkMa.cjs +1 -0
  147. package/dist/streams/multi-stream.cjs +1 -0
  148. package/dist/streams/multi-stream.d.cts +91 -0
  149. package/dist/streams/multi-stream.d.cts.map +1 -0
  150. package/dist/streams/multi-stream.d.ts +86 -0
  151. package/dist/streams/multi-stream.d.ts.map +1 -0
  152. package/dist/streams/multi-stream.js +149 -0
  153. package/dist/streams/multi-stream.js.map +1 -0
  154. package/dist/streams/stream-limiter.cjs +1 -0
  155. package/dist/streams/stream-limiter.d.cts +36 -0
  156. package/dist/streams/stream-limiter.d.cts.map +1 -0
  157. package/dist/streams/stream-limiter.d.ts +27 -0
  158. package/dist/streams/stream-limiter.d.ts.map +1 -0
  159. package/dist/streams/stream-limiter.js +49 -0
  160. package/dist/streams/stream-splitter.cjs +1 -0
  161. package/dist/streams/stream-splitter.d.cts +68 -0
  162. package/dist/streams/stream-splitter.d.cts.map +1 -0
  163. package/dist/streams/stream-splitter.d.ts +51 -0
  164. package/dist/streams/stream-splitter.d.ts.map +1 -0
  165. package/dist/streams/stream-splitter.js +175 -0
  166. package/dist/streams/stream-splitter.js.map +1 -0
  167. package/dist/types/data-store-registry.d.ts +13 -0
  168. package/dist/types/data-store-registry.d.ts.map +1 -0
  169. package/dist/types/data-store-registry.js +4 -0
  170. package/dist/types/data-store.d.ts +316 -0
  171. package/dist/types/data-store.d.ts.map +1 -0
  172. package/dist/types/data-store.js +157 -0
  173. package/dist/types/event-broadcaster.d.ts +28 -0
  174. package/dist/types/event-broadcaster.d.ts.map +1 -0
  175. package/dist/types/event-broadcaster.js +6 -0
  176. package/dist/types/event-emitter.d.ts +378 -0
  177. package/dist/types/event-emitter.d.ts.map +1 -0
  178. package/dist/types/event-emitter.js +223 -0
  179. package/dist/types/index.cjs +1 -0
  180. package/dist/types/index.d.cts +6 -0
  181. package/dist/types/index.d.ts +10 -0
  182. package/dist/types/index.d.ts.map +1 -0
  183. package/dist/types/index.js +9 -0
  184. package/dist/types/input-file.d.ts +104 -0
  185. package/dist/types/input-file.d.ts.map +1 -0
  186. package/dist/types/input-file.js +27 -0
  187. package/dist/types/kv-store.d.ts +281 -0
  188. package/dist/types/kv-store.d.ts.map +1 -0
  189. package/dist/types/kv-store.js +234 -0
  190. package/dist/types/middleware.d.ts +17 -0
  191. package/dist/types/middleware.d.ts.map +1 -0
  192. package/dist/types/middleware.js +21 -0
  193. package/dist/types/upload-event.d.ts +105 -0
  194. package/dist/types/upload-event.d.ts.map +1 -0
  195. package/dist/types/upload-event.js +71 -0
  196. package/dist/types/upload-file.d.ts +136 -0
  197. package/dist/types/upload-file.d.ts.map +1 -0
  198. package/dist/types/upload-file.js +34 -0
  199. package/dist/types/websocket.d.ts +144 -0
  200. package/dist/types/websocket.d.ts.map +1 -0
  201. package/dist/types/websocket.js +40 -0
  202. package/dist/types-BT-cvi7T.cjs +1 -0
  203. package/dist/types-DhU2j-XF.js +2 -0
  204. package/dist/types-DhU2j-XF.js.map +1 -0
  205. package/dist/upload/convert-to-stream.d.ts +38 -0
  206. package/dist/upload/convert-to-stream.d.ts.map +1 -0
  207. package/dist/upload/convert-to-stream.js +43 -0
  208. package/dist/upload/convert-upload-to-flow-file.d.ts +14 -0
  209. package/dist/upload/convert-upload-to-flow-file.d.ts.map +1 -0
  210. package/dist/upload/convert-upload-to-flow-file.js +21 -0
  211. package/dist/upload/create-upload.d.ts +68 -0
  212. package/dist/upload/create-upload.d.ts.map +1 -0
  213. package/dist/upload/create-upload.js +157 -0
  214. package/dist/upload/index.cjs +1 -0
  215. package/dist/upload/index.d.cts +6 -0
  216. package/dist/upload/index.d.ts +4 -0
  217. package/dist/upload/index.d.ts.map +1 -0
  218. package/dist/upload/index.js +3 -0
  219. package/dist/upload/mime.d.ts +24 -0
  220. package/dist/upload/mime.d.ts.map +1 -0
  221. package/dist/upload/mime.js +351 -0
  222. package/dist/upload/upload-chunk.d.ts +58 -0
  223. package/dist/upload/upload-chunk.d.ts.map +1 -0
  224. package/dist/upload/upload-chunk.js +277 -0
  225. package/dist/upload/upload-server.d.ts +221 -0
  226. package/dist/upload/upload-server.d.ts.map +1 -0
  227. package/dist/upload/upload-server.js +181 -0
  228. package/dist/upload/upload-strategy-negotiator.d.ts +148 -0
  229. package/dist/upload/upload-strategy-negotiator.d.ts.map +1 -0
  230. package/dist/upload/upload-strategy-negotiator.js +217 -0
  231. package/dist/upload/upload-url.d.ts +68 -0
  232. package/dist/upload/upload-url.d.ts.map +1 -0
  233. package/dist/upload/upload-url.js +142 -0
  234. package/dist/upload/write-to-store.d.ts +77 -0
  235. package/dist/upload/write-to-store.d.ts.map +1 -0
  236. package/dist/upload/write-to-store.js +147 -0
  237. package/dist/upload-DLuICjpP.cjs +1 -0
  238. package/dist/upload-DaXO34dE.js +2 -0
  239. package/dist/upload-DaXO34dE.js.map +1 -0
  240. package/dist/uploadista-error-BB-Wdiz9.cjs +22 -0
  241. package/dist/uploadista-error-BVsVxqvz.js +23 -0
  242. package/dist/uploadista-error-BVsVxqvz.js.map +1 -0
  243. package/dist/uploadista-error-CwxYs4EB.d.ts +52 -0
  244. package/dist/uploadista-error-CwxYs4EB.d.ts.map +1 -0
  245. package/dist/uploadista-error-kKlhLRhY.d.cts +52 -0
  246. package/dist/uploadista-error-kKlhLRhY.d.cts.map +1 -0
  247. package/dist/utils/checksum.d.ts +22 -0
  248. package/dist/utils/checksum.d.ts.map +1 -0
  249. package/dist/utils/checksum.js +49 -0
  250. package/dist/utils/debounce.cjs +1 -0
  251. package/dist/utils/debounce.d.cts +38 -0
  252. package/dist/utils/debounce.d.cts.map +1 -0
  253. package/dist/utils/debounce.d.ts +36 -0
  254. package/dist/utils/debounce.d.ts.map +1 -0
  255. package/dist/utils/debounce.js +73 -0
  256. package/dist/utils/generate-id.cjs +1 -0
  257. package/dist/utils/generate-id.d.cts +2 -0
  258. package/dist/utils/generate-id.d.ts +32 -0
  259. package/dist/utils/generate-id.d.ts.map +1 -0
  260. package/dist/utils/generate-id.js +23 -0
  261. package/dist/utils/md5.cjs +1 -0
  262. package/dist/utils/md5.d.cts +73 -0
  263. package/dist/utils/md5.d.cts.map +1 -0
  264. package/dist/utils/md5.d.ts +71 -0
  265. package/dist/utils/md5.d.ts.map +1 -0
  266. package/dist/utils/md5.js +417 -0
  267. package/dist/utils/md5.js.map +1 -0
  268. package/dist/utils/once.cjs +1 -0
  269. package/dist/utils/once.d.cts +25 -0
  270. package/dist/utils/once.d.cts.map +1 -0
  271. package/dist/utils/once.d.ts +21 -0
  272. package/dist/utils/once.d.ts.map +1 -0
  273. package/dist/utils/once.js +54 -0
  274. package/dist/utils/once.js.map +1 -0
  275. package/dist/utils/semaphore.cjs +1 -0
  276. package/dist/utils/semaphore.d.cts +3 -0
  277. package/dist/utils/semaphore.d.ts +78 -0
  278. package/dist/utils/semaphore.d.ts.map +1 -0
  279. package/dist/utils/semaphore.js +134 -0
  280. package/dist/utils/throttle.cjs +1 -0
  281. package/dist/utils/throttle.d.cts +24 -0
  282. package/dist/utils/throttle.d.cts.map +1 -0
  283. package/dist/utils/throttle.d.ts +18 -0
  284. package/dist/utils/throttle.d.ts.map +1 -0
  285. package/dist/utils/throttle.js +20 -0
  286. package/dist/utils/throttle.js.map +1 -0
  287. package/docs/PARALLEL_EXECUTION.md +206 -0
  288. package/docs/PARALLEL_EXECUTION_QUICKSTART.md +142 -0
  289. package/docs/PARALLEL_EXECUTION_REFACTOR.md +184 -0
  290. package/package.json +80 -0
  291. package/src/errors/__tests__/uploadista-error.test.ts +251 -0
  292. package/src/errors/index.ts +2 -0
  293. package/src/errors/uploadista-error.ts +394 -0
  294. package/src/flow/README.md +352 -0
  295. package/src/flow/edge.test.ts +146 -0
  296. package/src/flow/edge.ts +60 -0
  297. package/src/flow/event.ts +229 -0
  298. package/src/flow/flow-server.ts +1089 -0
  299. package/src/flow/flow.ts +1050 -0
  300. package/src/flow/index.ts +28 -0
  301. package/src/flow/node.ts +249 -0
  302. package/src/flow/nodes/index.ts +8 -0
  303. package/src/flow/nodes/input-node.ts +296 -0
  304. package/src/flow/nodes/storage-node.ts +128 -0
  305. package/src/flow/nodes/transform-node.ts +154 -0
  306. package/src/flow/parallel-scheduler.ts +259 -0
  307. package/src/flow/plugins/credential-provider.ts +48 -0
  308. package/src/flow/plugins/image-ai-plugin.ts +66 -0
  309. package/src/flow/plugins/image-plugin.ts +60 -0
  310. package/src/flow/plugins/types/describe-image-node.ts +16 -0
  311. package/src/flow/plugins/types/index.ts +9 -0
  312. package/src/flow/plugins/types/optimize-node.ts +18 -0
  313. package/src/flow/plugins/types/remove-background-node.ts +18 -0
  314. package/src/flow/plugins/types/resize-node.ts +26 -0
  315. package/src/flow/plugins/zip-plugin.ts +69 -0
  316. package/src/flow/typed-flow.ts +279 -0
  317. package/src/flow/types/flow-file.ts +51 -0
  318. package/src/flow/types/flow-job.ts +138 -0
  319. package/src/flow/types/flow-types.ts +353 -0
  320. package/src/flow/types/index.ts +6 -0
  321. package/src/flow/types/run-args.ts +40 -0
  322. package/src/flow/types/type-validator.ts +204 -0
  323. package/src/flow/utils/resolve-upload-metadata.ts +48 -0
  324. package/src/index.ts +5 -0
  325. package/src/logger/logger.ts +14 -0
  326. package/src/streams/stream-limiter.test.ts +150 -0
  327. package/src/streams/stream-limiter.ts +75 -0
  328. package/src/types/data-store.ts +427 -0
  329. package/src/types/event-broadcaster.ts +39 -0
  330. package/src/types/event-emitter.ts +349 -0
  331. package/src/types/index.ts +9 -0
  332. package/src/types/input-file.ts +107 -0
  333. package/src/types/kv-store.ts +375 -0
  334. package/src/types/middleware.ts +54 -0
  335. package/src/types/upload-event.ts +75 -0
  336. package/src/types/upload-file.ts +139 -0
  337. package/src/types/websocket.ts +65 -0
  338. package/src/upload/convert-to-stream.ts +48 -0
  339. package/src/upload/create-upload.ts +214 -0
  340. package/src/upload/index.ts +3 -0
  341. package/src/upload/mime.ts +436 -0
  342. package/src/upload/upload-chunk.ts +364 -0
  343. package/src/upload/upload-server.ts +390 -0
  344. package/src/upload/upload-strategy-negotiator.ts +316 -0
  345. package/src/upload/upload-url.ts +173 -0
  346. package/src/upload/write-to-store.ts +211 -0
  347. package/src/utils/checksum.ts +61 -0
  348. package/src/utils/debounce.test.ts +126 -0
  349. package/src/utils/debounce.ts +89 -0
  350. package/src/utils/generate-id.ts +35 -0
  351. package/src/utils/md5.ts +475 -0
  352. package/src/utils/once.test.ts +83 -0
  353. package/src/utils/once.ts +63 -0
  354. package/src/utils/throttle.test.ts +101 -0
  355. package/src/utils/throttle.ts +29 -0
  356. package/tsconfig.json +20 -0
  357. package/tsconfig.tsbuildinfo +1 -0
  358. package/tsdown.config.ts +25 -0
  359. package/vitest.config.ts +15 -0
@@ -0,0 +1,1004 @@
1
+ import { UploadistaError as UploadistaError$1 } from "./uploadista-error-CwxYs4EB.js";
2
+ import { GenerateId, GenerateIdShape } from "./generate-id-Dm-Vboxq.js";
3
+ import { Semaphore } from "./semaphore-DThupBkc.js";
4
+ import { Context, Effect, Layer, Stream } from "effect";
5
+ import z$1, { z } from "zod";
6
+ import { UploadistaError } from "@uploadista/core/errors";
7
+
8
+ //#region src/flow/node.d.ts
9
+ declare enum NodeType {
10
+ input = "input",
11
+ process = "process",
12
+ output = "output",
13
+ conditional = "conditional",
14
+ multiplex = "multiplex",
15
+ merge = "merge",
16
+ }
17
+ type ConditionField = "mimeType" | "size" | "width" | "height" | "extension";
18
+ type ConditionOperator = "equals" | "notEquals" | "greaterThan" | "lessThan" | "contains" | "startsWith";
19
+ type ConditionValue = string | number;
20
+ declare function createFlowNode<Input, Output, Requirements = never>({
21
+ id,
22
+ name,
23
+ description,
24
+ type,
25
+ inputSchema,
26
+ outputSchema,
27
+ run,
28
+ condition,
29
+ multiInput,
30
+ multiOutput,
31
+ pausable
32
+ }: {
33
+ id: string;
34
+ name: string;
35
+ description: string;
36
+ type: NodeType;
37
+ inputSchema: z.ZodSchema<Input>;
38
+ outputSchema: z.ZodSchema<Output>;
39
+ run: (args: {
40
+ data: Input;
41
+ runId: string;
42
+ storageId: string;
43
+ flowId: string;
44
+ }) => Effect.Effect<NodeExecutionResult<Output>, UploadistaError$1, Requirements>;
45
+ condition?: {
46
+ field: ConditionField;
47
+ operator: ConditionOperator;
48
+ value: ConditionValue;
49
+ };
50
+ multiInput?: boolean;
51
+ multiOutput?: boolean;
52
+ pausable?: boolean;
53
+ }): Effect.Effect<FlowNode<Input, Output, UploadistaError$1, Requirements>, UploadistaError$1>;
54
+ declare const getNodeData: <Requirements>(node: FlowNode<any, any, UploadistaError$1, Requirements>) => FlowNodeData;
55
+ //#endregion
56
+ //#region src/flow/event.d.ts
57
+ declare enum EventType {
58
+ JobStart = "job-start",
59
+ JobEnd = "job-end",
60
+ FlowStart = "flow-start",
61
+ FlowEnd = "flow-end",
62
+ NodeStart = "node-start",
63
+ NodeEnd = "node-end",
64
+ NodeError = "node-error",
65
+ NodeStream = "node-stream",
66
+ NodeResponse = "node-response",
67
+ }
68
+ type FlowEventJobStart = {
69
+ jobId: string;
70
+ eventType: EventType.JobStart;
71
+ };
72
+ type FlowEventJobEnd = {
73
+ eventId: string;
74
+ jobId: string;
75
+ eventType: EventType.JobEnd;
76
+ };
77
+ type FlowEventFlowStart = {
78
+ jobId: string;
79
+ flowId: string;
80
+ eventType: EventType.FlowStart;
81
+ };
82
+ type FlowEventFlowEnd = {
83
+ eventId: string;
84
+ jobId: string;
85
+ flowId: string;
86
+ eventType: EventType.FlowEnd;
87
+ };
88
+ type FlowEventNodeStart = {
89
+ jobId: string;
90
+ flowId: string;
91
+ nodeId: string;
92
+ eventType: EventType.NodeStart;
93
+ nodeName: string;
94
+ nodeType: NodeType;
95
+ };
96
+ type FlowEventNodeError = {
97
+ eventId: string;
98
+ jobId: string;
99
+ flowId: string;
100
+ nodeId: string;
101
+ nodeName: string;
102
+ eventType: EventType.NodeError;
103
+ error: string;
104
+ };
105
+ type FlowEventNodeEnd = {
106
+ eventId: string;
107
+ jobId: string;
108
+ flowId: string;
109
+ nodeId: string;
110
+ eventType: EventType.NodeEnd;
111
+ nodeName: string;
112
+ };
113
+ type FlowEventNodeResponse = {
114
+ jobId: string;
115
+ flowId: string;
116
+ nodeId: string;
117
+ eventType: EventType.NodeResponse;
118
+ nodeName: string;
119
+ data: unknown;
120
+ };
121
+ type FlowEvent = FlowEventJobStart | FlowEventJobEnd | FlowEventFlowStart | FlowEventFlowEnd | FlowEventNodeStart | FlowEventNodeEnd | FlowEventNodeError;
122
+ //#endregion
123
+ //#region src/flow/types/flow-types.d.ts
124
+ type NodeTypeMap = Record<string, {
125
+ input: unknown;
126
+ output: unknown;
127
+ }>;
128
+ type FlowNodeData = {
129
+ id: string;
130
+ name: string;
131
+ description: string;
132
+ type: NodeType;
133
+ };
134
+ type NodeExecutionResult<TOutput> = {
135
+ type: "complete";
136
+ data: TOutput;
137
+ } | {
138
+ type: "waiting";
139
+ partialData?: unknown;
140
+ };
141
+ declare const completeNodeExecution: <TOutput>(data: TOutput) => {
142
+ type: "complete";
143
+ data: TOutput;
144
+ };
145
+ declare const waitingNodeExecution: (partialData?: unknown) => {
146
+ type: "waiting";
147
+ partialData: unknown;
148
+ };
149
+ type FlowNode<TInput = unknown, TOutput = unknown, TError = UploadistaError$1, TRequirements = never> = FlowNodeData & {
150
+ inputSchema: z.ZodSchema<TInput>;
151
+ outputSchema: z.ZodSchema<TOutput>;
152
+ run: (args: {
153
+ data: TInput;
154
+ runId: string;
155
+ storageId: string;
156
+ flowId: string;
157
+ inputs?: Record<string, unknown>;
158
+ }) => Effect.Effect<NodeExecutionResult<TOutput>, TError, TRequirements>;
159
+ condition?: {
160
+ field: string;
161
+ operator: string;
162
+ value: unknown;
163
+ };
164
+ multiInput?: boolean;
165
+ multiOutput?: boolean;
166
+ pausable?: boolean;
167
+ };
168
+ type FlowEdge$1 = {
169
+ source: string;
170
+ target: string;
171
+ sourcePort?: string;
172
+ targetPort?: string;
173
+ };
174
+ type TypeCompatibilityChecker = (from: z.ZodSchema<any>, to: z.ZodSchema<any>) => boolean;
175
+ type NodeConnectionValidator = {
176
+ validateConnection: (sourceNode: FlowNode<any, any>, targetNode: FlowNode<any, any>, edge: FlowEdge$1) => boolean;
177
+ getCompatibleTypes: (sourceSchema: z.ZodSchema<any>, targetSchema: z.ZodSchema<any>) => boolean;
178
+ };
179
+ type FlowConfig<TFlowInputSchema extends z.ZodSchema<any>, TFlowOutputSchema extends z.ZodSchema<any>, TRequirements> = {
180
+ flowId: string;
181
+ name: string;
182
+ nodes: Array<FlowNode<any, any, UploadistaError$1, TRequirements>>;
183
+ edges: FlowEdge$1[];
184
+ inputSchema: TFlowInputSchema;
185
+ outputSchema: TFlowOutputSchema;
186
+ typeChecker?: TypeCompatibilityChecker;
187
+ onEvent?: (event: FlowEvent) => Effect.Effect<{
188
+ eventId: string | null;
189
+ }, UploadistaError$1>;
190
+ parallelExecution?: {
191
+ enabled?: boolean;
192
+ maxConcurrency?: number;
193
+ };
194
+ };
195
+ type FlowExecutionContext = {
196
+ runId: string;
197
+ flowId: string;
198
+ nodeResults: Map<string, unknown>;
199
+ nodeInputs: Map<string, Record<string, unknown>>;
200
+ };
201
+ //#endregion
202
+ //#region src/flow/edge.d.ts
203
+ type FlowEdge = FlowEdge$1;
204
+ declare function createFlowEdge({
205
+ source,
206
+ target,
207
+ sourcePort,
208
+ targetPort
209
+ }: {
210
+ source: string;
211
+ target: string;
212
+ sourcePort?: string;
213
+ targetPort?: string;
214
+ }): FlowEdge;
215
+ //#endregion
216
+ //#region src/flow/flow.d.ts
217
+ type FlowData = {
218
+ id: string;
219
+ name: string;
220
+ nodes: FlowNodeData[];
221
+ edges: FlowEdge[];
222
+ };
223
+ declare const getFlowData: <TRequirements>(flow: Flow<any, any, TRequirements>) => FlowData;
224
+ type FlowExecutionResult<TOutput> = {
225
+ type: "completed";
226
+ result: TOutput;
227
+ } | {
228
+ type: "paused";
229
+ nodeId: string;
230
+ executionState: {
231
+ nodeResults: Record<string, unknown>;
232
+ executionOrder: string[];
233
+ currentIndex: number;
234
+ inputs: Record<string, unknown>;
235
+ };
236
+ };
237
+ type Flow<TFlowInputSchema extends z.ZodSchema<any>, TFlowOutputSchema extends z.ZodSchema<any>, TRequirements> = {
238
+ id: string;
239
+ name: string;
240
+ nodes: FlowNode<any, any, UploadistaError$1, TRequirements>[];
241
+ edges: FlowEdge[];
242
+ inputSchema: TFlowInputSchema;
243
+ outputSchema: TFlowOutputSchema;
244
+ run: (args: {
245
+ inputs?: Record<string, z.infer<TFlowInputSchema>>;
246
+ storageId: string;
247
+ jobId: string;
248
+ }) => Effect.Effect<FlowExecutionResult<z.infer<TFlowOutputSchema>>, UploadistaError$1, TRequirements>;
249
+ resume: (args: {
250
+ jobId: string;
251
+ storageId: string;
252
+ executionState: {
253
+ nodeResults: Record<string, unknown>;
254
+ executionOrder: string[];
255
+ currentIndex: number;
256
+ inputs: Record<string, z.infer<TFlowInputSchema>>;
257
+ };
258
+ }) => Effect.Effect<FlowExecutionResult<z.infer<TFlowOutputSchema>>, UploadistaError$1, TRequirements>;
259
+ validateTypes: () => {
260
+ isValid: boolean;
261
+ errors: string[];
262
+ };
263
+ validateInputs: (inputs: unknown) => {
264
+ isValid: boolean;
265
+ errors: string[];
266
+ };
267
+ validateOutputs: (outputs: unknown) => {
268
+ isValid: boolean;
269
+ errors: string[];
270
+ };
271
+ };
272
+ declare function createFlow<TFlowInputSchema extends z.ZodSchema<any>, TFlowOutputSchema extends z.ZodSchema<any>, TRequirements>({
273
+ flowId,
274
+ name,
275
+ onEvent,
276
+ edges,
277
+ nodes,
278
+ inputSchema,
279
+ outputSchema,
280
+ typeChecker
281
+ }: FlowConfig<TFlowInputSchema, TFlowOutputSchema, TRequirements>): Flow<TFlowInputSchema, TFlowOutputSchema, TRequirements>;
282
+ //#endregion
283
+ //#region src/types/upload-file.d.ts
284
+ declare const uploadFileSchema: z.ZodObject<{
285
+ id: z.ZodString;
286
+ size: z.ZodOptional<z.ZodNumber>;
287
+ offset: z.ZodNumber;
288
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
289
+ creationDate: z.ZodOptional<z.ZodString>;
290
+ url: z.ZodOptional<z.ZodString>;
291
+ sizeIsDeferred: z.ZodOptional<z.ZodBoolean>;
292
+ storage: z.ZodObject<{
293
+ id: z.ZodString;
294
+ type: z.ZodString;
295
+ path: z.ZodOptional<z.ZodString>;
296
+ uploadId: z.ZodOptional<z.ZodString>;
297
+ bucket: z.ZodOptional<z.ZodString>;
298
+ }, z.core.$strip>;
299
+ }, z.core.$strip>;
300
+ type UploadFile = {
301
+ id: string;
302
+ offset: number;
303
+ storage: {
304
+ id: string;
305
+ isBuffer?: boolean;
306
+ type: string;
307
+ path?: string | undefined;
308
+ uploadId?: string | undefined;
309
+ bucket?: string | undefined;
310
+ };
311
+ size?: number | undefined;
312
+ metadata?: Record<string, string> | undefined;
313
+ creationDate?: string | undefined;
314
+ url?: string | undefined;
315
+ sizeIsDeferred?: boolean | undefined;
316
+ };
317
+ //#endregion
318
+ //#region src/types/data-store.d.ts
319
+ type DataStoreWriteOptions = {
320
+ file_id: string;
321
+ stream: Stream.Stream<Uint8Array, UploadistaError$1>;
322
+ offset: number;
323
+ };
324
+ type UploadStrategy = "single" | "parallel";
325
+ type DataStoreCapabilities = {
326
+ supportsParallelUploads: boolean;
327
+ supportsConcatenation: boolean;
328
+ supportsDeferredLength: boolean;
329
+ supportsResumableUploads: boolean;
330
+ supportsTransactionalUploads: boolean;
331
+ maxConcurrentUploads?: number;
332
+ minChunkSize?: number;
333
+ maxChunkSize?: number;
334
+ maxParts?: number;
335
+ optimalChunkSize?: number;
336
+ requiresOrderedChunks: boolean;
337
+ };
338
+ type DataStore<TData = unknown> = {
339
+ readonly bucket?: string;
340
+ readonly path?: string;
341
+ readonly create: (file: TData) => Effect.Effect<TData, UploadistaError$1>;
342
+ readonly remove: (file_id: string) => Effect.Effect<void, UploadistaError$1>;
343
+ readonly read: (file_id: string) => Effect.Effect<Uint8Array, UploadistaError$1>;
344
+ readonly write: (options: DataStoreWriteOptions, dependencies: {
345
+ onProgress?: (chunkSize: number) => void;
346
+ }) => Effect.Effect<number, UploadistaError$1>;
347
+ readonly deleteExpired?: Effect.Effect<number, UploadistaError$1>;
348
+ readonly getCapabilities: () => DataStoreCapabilities;
349
+ readonly validateUploadStrategy: (strategy: UploadStrategy) => Effect.Effect<boolean, never>;
350
+ };
351
+ declare const UploadFileDataStore_base: Context.TagClass<UploadFileDataStore, "UploadFileDataStore", DataStore<UploadFile>>;
352
+ declare class UploadFileDataStore extends UploadFileDataStore_base {}
353
+ declare const BufferedUploadFileDataStore_base: Context.TagClass<BufferedUploadFileDataStore, "BufferedUploadFileDataStore", DataStore<UploadFile>>;
354
+ declare class BufferedUploadFileDataStore extends BufferedUploadFileDataStore_base {}
355
+ type UploadFileDataStoresShape = {
356
+ getDataStore: (storageId: string, isBuffer?: boolean) => Effect.Effect<DataStore<UploadFile>, UploadistaError$1>;
357
+ };
358
+ declare const UploadFileDataStores_base: Context.TagClass<UploadFileDataStores, "UploadFileDataStores", UploadFileDataStoresShape>;
359
+ declare class UploadFileDataStores extends UploadFileDataStores_base {}
360
+ //#endregion
361
+ //#region src/types/data-store-registry.d.ts
362
+ declare const DataStoreRegistry_base: Context.TagClass<DataStoreRegistry, "DataStoreRegistry", {
363
+ readonly register: <T extends DataStore<UploadFile>>(id: string, store: Effect.Effect<T, UploadistaError$1>) => Effect.Effect<void, never>;
364
+ readonly get: (id: string) => Effect.Effect<DataStore<UploadFile>, UploadistaError$1>;
365
+ readonly list: () => Effect.Effect<Array<string>, never>;
366
+ }>;
367
+ declare class DataStoreRegistry extends DataStoreRegistry_base {}
368
+ //#endregion
369
+ //#region src/types/upload-event.d.ts
370
+ declare enum UploadEventType {
371
+ UPLOAD_STARTED = "upload-started",
372
+ UPLOAD_PROGRESS = "upload-progress",
373
+ UPLOAD_COMPLETE = "upload-complete",
374
+ UPLOAD_FAILED = "upload-failed",
375
+ }
376
+ declare const uploadEventSchema: z.ZodUnion<readonly [z.ZodObject<{
377
+ type: z.ZodUnion<readonly [z.ZodLiteral<UploadEventType.UPLOAD_STARTED>, z.ZodLiteral<UploadEventType.UPLOAD_COMPLETE>]>;
378
+ data: z.ZodObject<{
379
+ id: z.ZodString;
380
+ size: z.ZodOptional<z.ZodNumber>;
381
+ offset: z.ZodNumber;
382
+ metadata: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
383
+ creationDate: z.ZodOptional<z.ZodString>;
384
+ url: z.ZodOptional<z.ZodString>;
385
+ sizeIsDeferred: z.ZodOptional<z.ZodBoolean>;
386
+ storage: z.ZodObject<{
387
+ id: z.ZodString;
388
+ type: z.ZodString;
389
+ path: z.ZodOptional<z.ZodString>;
390
+ uploadId: z.ZodOptional<z.ZodString>;
391
+ bucket: z.ZodOptional<z.ZodString>;
392
+ }, z.core.$strip>;
393
+ }, z.core.$strip>;
394
+ }, z.core.$strip>, z.ZodObject<{
395
+ type: z.ZodLiteral<UploadEventType.UPLOAD_PROGRESS>;
396
+ data: z.ZodObject<{
397
+ id: z.ZodString;
398
+ progress: z.ZodNumber;
399
+ total: z.ZodNumber;
400
+ }, z.core.$strip>;
401
+ }, z.core.$strip>, z.ZodObject<{
402
+ type: z.ZodLiteral<UploadEventType.UPLOAD_FAILED>;
403
+ data: z.ZodObject<{
404
+ id: z.ZodString;
405
+ error: z.ZodString;
406
+ }, z.core.$strip>;
407
+ }, z.core.$strip>]>;
408
+ type UploadEvent = z.infer<typeof uploadEventSchema>;
409
+ //#endregion
410
+ //#region src/types/websocket.d.ts
411
+ /**
412
+ * Platform-agnostic WebSocket connection interface
413
+ */
414
+ interface WebSocketConnection {
415
+ send(data: string): void;
416
+ close(code?: number, reason?: string): void;
417
+ readonly readyState: number;
418
+ readonly id: string;
419
+ }
420
+ /**
421
+ * WebSocket message that can be sent/received
422
+ */
423
+ declare const webSocketMessageSchema: z$1.ZodUnion<readonly [z$1.ZodObject<{
424
+ type: z$1.ZodLiteral<"upload_event">;
425
+ payload: z$1.ZodUnion<readonly [z$1.ZodObject<{
426
+ type: z$1.ZodUnion<readonly [z$1.ZodLiteral<UploadEventType.UPLOAD_STARTED>, z$1.ZodLiteral<UploadEventType.UPLOAD_COMPLETE>]>;
427
+ data: z$1.ZodObject<{
428
+ id: z$1.ZodString;
429
+ size: z$1.ZodOptional<z$1.ZodNumber>;
430
+ offset: z$1.ZodNumber;
431
+ metadata: z$1.ZodOptional<z$1.ZodRecord<z$1.ZodString, z$1.ZodString>>;
432
+ creationDate: z$1.ZodOptional<z$1.ZodString>;
433
+ url: z$1.ZodOptional<z$1.ZodString>;
434
+ sizeIsDeferred: z$1.ZodOptional<z$1.ZodBoolean>;
435
+ storage: z$1.ZodObject<{
436
+ id: z$1.ZodString;
437
+ type: z$1.ZodString;
438
+ path: z$1.ZodOptional<z$1.ZodString>;
439
+ uploadId: z$1.ZodOptional<z$1.ZodString>;
440
+ bucket: z$1.ZodOptional<z$1.ZodString>;
441
+ }, z$1.core.$strip>;
442
+ }, z$1.core.$strip>;
443
+ }, z$1.core.$strip>, z$1.ZodObject<{
444
+ type: z$1.ZodLiteral<UploadEventType.UPLOAD_PROGRESS>;
445
+ data: z$1.ZodObject<{
446
+ id: z$1.ZodString;
447
+ progress: z$1.ZodNumber;
448
+ total: z$1.ZodNumber;
449
+ }, z$1.core.$strip>;
450
+ }, z$1.core.$strip>, z$1.ZodObject<{
451
+ type: z$1.ZodLiteral<UploadEventType.UPLOAD_FAILED>;
452
+ data: z$1.ZodObject<{
453
+ id: z$1.ZodString;
454
+ error: z$1.ZodString;
455
+ }, z$1.core.$strip>;
456
+ }, z$1.core.$strip>]>;
457
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
458
+ }, z$1.core.$strip>, z$1.ZodObject<{
459
+ type: z$1.ZodLiteral<"flow_event">;
460
+ payload: z$1.ZodAny;
461
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
462
+ }, z$1.core.$strip>, z$1.ZodObject<{
463
+ type: z$1.ZodLiteral<"subscribed">;
464
+ payload: z$1.ZodObject<{
465
+ uploadId: z$1.ZodString;
466
+ }, z$1.core.$strip>;
467
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
468
+ }, z$1.core.$strip>, z$1.ZodObject<{
469
+ type: z$1.ZodLiteral<"error">;
470
+ message: z$1.ZodOptional<z$1.ZodString>;
471
+ }, z$1.core.$strip>, z$1.ZodObject<{
472
+ type: z$1.ZodLiteral<"pong">;
473
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
474
+ }, z$1.core.$strip>, z$1.ZodObject<{
475
+ type: z$1.ZodLiteral<"ping">;
476
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
477
+ }, z$1.core.$strip>, z$1.ZodObject<{
478
+ type: z$1.ZodLiteral<"connection">;
479
+ message: z$1.ZodOptional<z$1.ZodString>;
480
+ uploadId: z$1.ZodOptional<z$1.ZodString>;
481
+ timestamp: z$1.ZodOptional<z$1.ZodString>;
482
+ }, z$1.core.$strip>]>;
483
+ type WebSocketMessage<TEvent = unknown> = z$1.infer<typeof webSocketMessageSchema> | {
484
+ type: "upload_event";
485
+ payload: TEvent;
486
+ timestamp?: string;
487
+ } | {
488
+ type: "flow_event";
489
+ payload: TEvent;
490
+ timestamp?: string;
491
+ };
492
+ //#endregion
493
+ //#region src/types/event-emitter.d.ts
494
+ interface BaseEventEmitter {
495
+ readonly subscribe: (key: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1>;
496
+ readonly unsubscribe: (key: string) => Effect.Effect<void, UploadistaError$1>;
497
+ readonly emit: (key: string, event: string) => Effect.Effect<void, UploadistaError$1>;
498
+ }
499
+ type EventEmitter<TEvent> = {
500
+ readonly subscribe: (key: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1>;
501
+ readonly unsubscribe: (key: string) => Effect.Effect<void, UploadistaError$1>;
502
+ readonly emit: (key: string, event: TEvent) => Effect.Effect<void, UploadistaError$1>;
503
+ };
504
+ declare class TypedEventEmitter<TEvent> implements EventEmitter<TEvent> {
505
+ private baseEmitter;
506
+ private eventToMessage;
507
+ constructor(baseEmitter: BaseEventEmitter, eventToMessage: (event: TEvent) => string);
508
+ subscribe: (key: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1>;
509
+ unsubscribe: (key: string) => Effect.Effect<void, UploadistaError$1>;
510
+ emit: (key: string, event: TEvent) => Effect.Effect<void, UploadistaError$1>;
511
+ }
512
+ declare const eventToMessageSerializer: (messageType: "upload_event" | "flow_event") => {
513
+ eventToMessage: <T>(event: T) => string;
514
+ };
515
+ declare const BaseEventEmitterService_base: Context.TagClass<BaseEventEmitterService, "BaseEventEmitter", BaseEventEmitter>;
516
+ declare class BaseEventEmitterService extends BaseEventEmitterService_base {}
517
+ declare const UploadEventEmitter_base: Context.TagClass<UploadEventEmitter, "UploadEventEmitter", EventEmitter<{
518
+ type: UploadEventType.UPLOAD_STARTED | UploadEventType.UPLOAD_COMPLETE;
519
+ data: {
520
+ id: string;
521
+ offset: number;
522
+ storage: {
523
+ id: string;
524
+ type: string;
525
+ path?: string | undefined;
526
+ uploadId?: string | undefined;
527
+ bucket?: string | undefined;
528
+ };
529
+ size?: number | undefined;
530
+ metadata?: Record<string, string> | undefined;
531
+ creationDate?: string | undefined;
532
+ url?: string | undefined;
533
+ sizeIsDeferred?: boolean | undefined;
534
+ };
535
+ } | {
536
+ type: UploadEventType.UPLOAD_PROGRESS;
537
+ data: {
538
+ id: string;
539
+ progress: number;
540
+ total: number;
541
+ };
542
+ } | {
543
+ type: UploadEventType.UPLOAD_FAILED;
544
+ data: {
545
+ id: string;
546
+ error: string;
547
+ };
548
+ }>>;
549
+ declare class UploadEventEmitter extends UploadEventEmitter_base {}
550
+ declare const uploadEventEmitter: Layer.Layer<UploadEventEmitter, never, BaseEventEmitterService>;
551
+ declare const FlowEventEmitter_base: Context.TagClass<FlowEventEmitter, "FlowEventEmitter", EventEmitter<FlowEvent>>;
552
+ declare class FlowEventEmitter extends FlowEventEmitter_base {}
553
+ declare const flowEventEmitter: Layer.Layer<FlowEventEmitter, never, BaseEventEmitterService>;
554
+ //#endregion
555
+ //#region src/types/input-file.d.ts
556
+ declare const inputFileSchema: z.ZodObject<{
557
+ uploadLengthDeferred: z.ZodOptional<z.ZodBoolean>;
558
+ storageId: z.ZodString;
559
+ size: z.ZodNumber;
560
+ type: z.ZodString;
561
+ fileName: z.ZodOptional<z.ZodString>;
562
+ lastModified: z.ZodOptional<z.ZodNumber>;
563
+ metadata: z.ZodOptional<z.ZodString>;
564
+ }, z.core.$strip>;
565
+ type InputFile = z.infer<typeof inputFileSchema>;
566
+ //#endregion
567
+ //#region src/types/kv-store.d.ts
568
+ interface BaseKvStore {
569
+ readonly get: (key: string) => Effect.Effect<string | null, UploadistaError$1>;
570
+ readonly set: (key: string, value: string) => Effect.Effect<void, UploadistaError$1>;
571
+ readonly delete: (key: string) => Effect.Effect<void, UploadistaError$1>;
572
+ readonly list?: () => Effect.Effect<Array<string>, UploadistaError$1>;
573
+ }
574
+ type KvStore<TData> = {
575
+ readonly get: (key: string) => Effect.Effect<TData, UploadistaError$1>;
576
+ readonly set: (key: string, value: TData) => Effect.Effect<void, UploadistaError$1>;
577
+ readonly delete: (key: string) => Effect.Effect<void, UploadistaError$1>;
578
+ readonly list?: () => Effect.Effect<Array<string>, UploadistaError$1>;
579
+ };
580
+ declare class TypedKvStore<TData> implements KvStore<TData> {
581
+ private baseStore;
582
+ private serialize;
583
+ private deserialize;
584
+ constructor(baseStore: BaseKvStore, serialize: (data: TData) => string, deserialize: (str: string) => TData);
585
+ get: (key: string) => Effect.Effect<TData, UploadistaError$1>;
586
+ set: (key: string, value: TData) => Effect.Effect<void, UploadistaError$1>;
587
+ delete: (key: string) => Effect.Effect<void, UploadistaError$1>;
588
+ list: () => Effect.Effect<Array<string>, UploadistaError$1>;
589
+ }
590
+ declare const jsonSerializer: {
591
+ serialize: <T>(data: T) => string;
592
+ deserialize: <T>(str: string) => T;
593
+ };
594
+ declare const BaseKvStoreService_base: Context.TagClass<BaseKvStoreService, "BaseKvStore", BaseKvStore>;
595
+ declare class BaseKvStoreService extends BaseKvStoreService_base {}
596
+ declare const UploadFileKVStore_base: Context.TagClass<UploadFileKVStore, "UploadFileKVStore", KvStore<UploadFile>>;
597
+ declare class UploadFileKVStore extends UploadFileKVStore_base {}
598
+ declare const uploadFileKvStore: Layer.Layer<UploadFileKVStore, never, BaseKvStoreService>;
599
+ declare const FlowJobKVStore_base: Context.TagClass<FlowJobKVStore, "FlowJobKVStore", KvStore<FlowJob>>;
600
+ declare class FlowJobKVStore extends FlowJobKVStore_base {}
601
+ declare const flowJobKvStore: Layer.Layer<FlowJobKVStore, never, BaseKvStoreService>;
602
+ //#endregion
603
+ //#region src/types/middleware.d.ts
604
+ type MiddlewareContext = {
605
+ request: Request;
606
+ uploadId?: string;
607
+ metadata?: Record<string, string>;
608
+ };
609
+ type MiddlewareNext = () => Promise<Response>;
610
+ type Middleware = (context: MiddlewareContext, next: MiddlewareNext) => Promise<Response>;
611
+ declare const MiddlewareService_base: Context.TagClass<MiddlewareService, "MiddlewareService", {
612
+ readonly execute: (middlewares: Middleware[], context: MiddlewareContext, handler: MiddlewareNext) => Effect.Effect<Response, UploadistaError$1>;
613
+ }>;
614
+ declare class MiddlewareService extends MiddlewareService_base {}
615
+ declare const MiddlewareServiceLive: Layer.Layer<MiddlewareService, never, never>;
616
+ //#endregion
617
+ //#region src/flow/types/flow-job.d.ts
618
+ type FlowJobTaskStatus = "started" | "pending" | "running" | "completed" | "failed";
619
+ type FlowJobTask = {
620
+ nodeId: string;
621
+ status: FlowJobTaskStatus;
622
+ createdAt: Date;
623
+ updatedAt: Date;
624
+ };
625
+ type FlowJob = {
626
+ id: string;
627
+ flowId: string;
628
+ storageId: string;
629
+ status: FlowJobStatus;
630
+ createdAt: Date;
631
+ updatedAt: Date;
632
+ tasks: FlowJobTask[];
633
+ error?: string;
634
+ endedAt?: Date;
635
+ pausedAt?: string;
636
+ executionState?: {
637
+ nodeResults: Record<string, unknown>;
638
+ executionOrder: string[];
639
+ currentIndex: number;
640
+ inputs: Record<string, unknown>;
641
+ };
642
+ };
643
+ type FlowJobStatus = "pending" | "running" | "completed" | "failed" | "started" | "paused";
644
+ //#endregion
645
+ //#region src/flow/flow-server.d.ts
646
+ type FlowProviderShape<TRequirements = any> = {
647
+ getFlow: (flowId: string) => Effect.Effect<Flow<any, any, TRequirements>, UploadistaError$1>;
648
+ };
649
+ declare const FlowProvider_base: Context.TagClass<FlowProvider, "FlowProvider", FlowProviderShape<any>>;
650
+ declare class FlowProvider extends FlowProvider_base {}
651
+ type FlowServerShape = {
652
+ getFlow: <TRequirements>(flowId: string) => Effect.Effect<Flow<any, any, TRequirements>, UploadistaError$1>;
653
+ getFlowData: (flowId: string) => Effect.Effect<FlowData, UploadistaError$1>;
654
+ runFlow: <TRequirements>(flowId: string, storageId: string, inputs: any) => Effect.Effect<FlowJob, UploadistaError$1, TRequirements>;
655
+ continueFlow: <TRequirements>(jobId: string, nodeId: string, newData: unknown) => Effect.Effect<FlowJob, UploadistaError$1, TRequirements>;
656
+ getJobStatus: (jobId: string) => Effect.Effect<FlowJob, UploadistaError$1>;
657
+ subscribeToFlowEvents: (jobId: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1>;
658
+ unsubscribeFromFlowEvents: (jobId: string) => Effect.Effect<void, UploadistaError$1>;
659
+ };
660
+ declare const FlowServer_base: Context.TagClass<FlowServer, "FlowServer", FlowServerShape>;
661
+ declare class FlowServer extends FlowServer_base {}
662
+ type FlowServerOptions = {
663
+ getFlow: <TRequirements>({
664
+ flowId,
665
+ storageId
666
+ }: {
667
+ flowId: string;
668
+ storageId: string;
669
+ }) => Promise<Flow<any, any, TRequirements>>;
670
+ kvStore: KvStore<FlowJob>;
671
+ };
672
+ declare function createFlowServer(): Effect.Effect<{
673
+ getFlow: <TRequirements>(flowId: string) => Effect.Effect<Flow<any, any, any>, UploadistaError$1, never>;
674
+ getFlowData: (flowId: string) => Effect.Effect<FlowData, UploadistaError$1, never>;
675
+ runFlow: (flowId: string, storageId: string, inputs: unknown) => Effect.Effect<FlowJob, UploadistaError$1, any>;
676
+ getJobStatus: (jobId: string) => Effect.Effect<FlowJob, UploadistaError$1, never>;
677
+ continueFlow: (jobId: string, nodeId: string, newData: unknown) => Effect.Effect<FlowJob, UploadistaError$1, any>;
678
+ subscribeToFlowEvents: (jobId: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1, never>;
679
+ unsubscribeFromFlowEvents: (jobId: string) => Effect.Effect<void, UploadistaError$1, never>;
680
+ }, never, FlowProvider | FlowJobKVStore | FlowEventEmitter>;
681
+ declare const flowServer: Layer.Layer<FlowServer, never, FlowProvider | FlowJobKVStore | FlowEventEmitter>;
682
+ type FlowServerLayer = typeof flowServer;
683
+ //#endregion
684
+ //#region src/flow/nodes/input-node.d.ts
685
+ declare function createInputNode(id: string, prepareFile?: (fileId: string) => Effect.Effect<string>): Effect.Effect<FlowNode<{
686
+ fileId: string;
687
+ }, {
688
+ path: string;
689
+ inputBytes: Uint8Array<ArrayBufferLike>;
690
+ metadata: {
691
+ mimeType: string;
692
+ size: number;
693
+ width?: number | undefined;
694
+ height?: number | undefined;
695
+ format?: string | undefined;
696
+ originalName?: string | undefined;
697
+ extension?: string | undefined;
698
+ };
699
+ }, UploadistaError$1, never>, UploadistaError$1, never>;
700
+ //#endregion
701
+ //#region src/upload/mime.d.ts
702
+ declare const detectMimeType: (buffer: Uint8Array, filename?: string) => string;
703
+ //#endregion
704
+ //#region src/upload/upload-server.d.ts
705
+ type UploadServerOptions = {
706
+ dataStore: ((storageId: string) => Promise<DataStore<UploadFile>>) | DataStore<UploadFile>;
707
+ kvStore: KvStore<UploadFile>;
708
+ eventEmitter: EventEmitter<UploadEvent>;
709
+ generateId?: GenerateIdShape;
710
+ middlewares?: Middleware[];
711
+ withTracing?: boolean;
712
+ };
713
+ type UploadServerShape = {
714
+ createUpload: (inputFile: InputFile, isBuffer?: boolean) => Effect.Effect<UploadFile, UploadistaError$1>;
715
+ uploadChunk: (uploadId: string, chunk: ReadableStream, isBuffer?: boolean) => Effect.Effect<UploadFile, UploadistaError$1>;
716
+ getCapabilities: (storageId: string) => Effect.Effect<DataStoreCapabilities, UploadistaError$1>;
717
+ upload: (file: InputFile, stream: ReadableStream) => Effect.Effect<UploadFile, UploadistaError$1>;
718
+ getUpload: (uploadId: string) => Effect.Effect<UploadFile, UploadistaError$1>;
719
+ read: (uploadId: string) => Effect.Effect<Uint8Array, UploadistaError$1>;
720
+ subscribeToUploadEvents: (uploadId: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1>;
721
+ unsubscribeFromUploadEvents: (uploadId: string) => Effect.Effect<void, UploadistaError$1>;
722
+ };
723
+ declare const UploadServer_base: Context.TagClass<UploadServer, "UploadServer", UploadServerShape>;
724
+ declare class UploadServer extends UploadServer_base {}
725
+ declare function createUploadServer(): Effect.Effect<{
726
+ upload: (inputFile: InputFile, stream: ReadableStream) => Effect.Effect<UploadFile, UploadistaError$1, never>;
727
+ createUpload: (inputFile: InputFile) => Effect.Effect<UploadFile, UploadistaError$1, never>;
728
+ uploadChunk: (uploadId: string, chunk: ReadableStream) => Effect.Effect<UploadFile, UploadistaError$1, never>;
729
+ getUpload: (uploadId: string) => Effect.Effect<UploadFile, UploadistaError$1, never>;
730
+ read: (uploadId: string) => Effect.Effect<Uint8Array<ArrayBufferLike>, UploadistaError$1, never>;
731
+ getCapabilities: (storageId: string) => Effect.Effect<DataStoreCapabilities, UploadistaError$1, never>;
732
+ subscribeToUploadEvents: (uploadId: string, connection: WebSocketConnection) => Effect.Effect<void, UploadistaError$1, never>;
733
+ unsubscribeFromUploadEvents: (uploadId: string) => Effect.Effect<void, UploadistaError$1, never>;
734
+ }, never, GenerateId | UploadFileDataStores | UploadFileKVStore | UploadEventEmitter>;
735
+ declare const uploadServer: Layer.Layer<UploadServer, never, GenerateId | UploadFileDataStores | UploadFileKVStore | UploadEventEmitter>;
736
+ //#endregion
737
+ //#region src/upload/upload-strategy-negotiator.d.ts
738
+ type UploadStrategyOptions = {
739
+ fileSize: number;
740
+ preferredStrategy?: UploadStrategy;
741
+ preferredChunkSize?: number;
742
+ parallelUploads?: number;
743
+ minChunkSizeForParallel?: number;
744
+ };
745
+ type NegotiatedStrategy = {
746
+ strategy: UploadStrategy;
747
+ chunkSize: number;
748
+ parallelUploads: number;
749
+ reasoning: string[];
750
+ warnings: string[];
751
+ };
752
+ declare class UploadStrategyNegotiator {
753
+ private capabilities;
754
+ private validateUploadStrategy;
755
+ constructor(capabilities: DataStoreCapabilities, validateUploadStrategy: (strategy: UploadStrategy) => boolean);
756
+ negotiateStrategy(options: UploadStrategyOptions): NegotiatedStrategy;
757
+ getDataStoreCapabilities(): DataStoreCapabilities;
758
+ validateConfiguration(options: UploadStrategyOptions): {
759
+ valid: boolean;
760
+ errors: string[];
761
+ };
762
+ }
763
+ //#endregion
764
+ //#region src/flow/nodes/storage-node.d.ts
765
+ declare const storageParamsSchema: z.ZodObject<{}, z.core.$strip>;
766
+ type StorageParams = z.infer<typeof storageParamsSchema>;
767
+ declare function createStorageNode(id: string): Effect.Effect<FlowNode<{
768
+ id: string;
769
+ offset: number;
770
+ storage: {
771
+ id: string;
772
+ type: string;
773
+ path?: string | undefined;
774
+ uploadId?: string | undefined;
775
+ bucket?: string | undefined;
776
+ };
777
+ size?: number | undefined;
778
+ metadata?: Record<string, string> | undefined;
779
+ creationDate?: string | undefined;
780
+ url?: string | undefined;
781
+ sizeIsDeferred?: boolean | undefined;
782
+ }, {
783
+ id: string;
784
+ offset: number;
785
+ storage: {
786
+ id: string;
787
+ type: string;
788
+ path?: string | undefined;
789
+ uploadId?: string | undefined;
790
+ bucket?: string | undefined;
791
+ };
792
+ size?: number | undefined;
793
+ metadata?: Record<string, string> | undefined;
794
+ creationDate?: string | undefined;
795
+ url?: string | undefined;
796
+ sizeIsDeferred?: boolean | undefined;
797
+ }, UploadistaError$1, never>, UploadistaError$1, UploadServer>;
798
+ //#endregion
799
+ //#region src/flow/nodes/streaming-input-node.d.ts
800
+ declare function createStreamingInputNode(id: string): Effect.Effect<FlowNode<{
801
+ operation: "init";
802
+ storageId: string;
803
+ metadata?: {
804
+ originalName?: string | undefined;
805
+ mimeType?: string | undefined;
806
+ size?: number | undefined;
807
+ extension?: string | undefined;
808
+ } | undefined;
809
+ } | {
810
+ operation: "finalize";
811
+ uploadId: string;
812
+ }, {
813
+ id: string;
814
+ offset: number;
815
+ storage: {
816
+ id: string;
817
+ type: string;
818
+ path?: string | undefined;
819
+ uploadId?: string | undefined;
820
+ bucket?: string | undefined;
821
+ };
822
+ size?: number | undefined;
823
+ metadata?: Record<string, string> | undefined;
824
+ creationDate?: string | undefined;
825
+ url?: string | undefined;
826
+ sizeIsDeferred?: boolean | undefined;
827
+ }, UploadistaError$1, never>, UploadistaError$1, UploadServer>;
828
+ //#endregion
829
+ //#region src/flow/parallel-scheduler.d.ts
830
+ interface ExecutionLevel {
831
+ level: number;
832
+ nodes: string[];
833
+ }
834
+ interface ParallelSchedulerConfig {
835
+ maxConcurrency?: number;
836
+ resourceSemaphore?: Semaphore;
837
+ }
838
+ declare class ParallelScheduler {
839
+ private maxConcurrency;
840
+ private resourceSemaphore;
841
+ constructor(config?: ParallelSchedulerConfig);
842
+ /**
843
+ * Groups nodes into execution levels where nodes in the same level can run in parallel
844
+ * @param nodes Array of flow nodes
845
+ * @param edges Array of flow edges
846
+ * @returns Array of execution levels
847
+ */
848
+ groupNodesByExecutionLevel(nodes: FlowNode<unknown, unknown>[], edges: Array<{
849
+ source: string;
850
+ target: string;
851
+ }>): ExecutionLevel[];
852
+ /**
853
+ * Executes a batch of nodes in parallel with resource management
854
+ * @param nodeExecutors Array of async functions that execute individual nodes
855
+ * @returns Promise that resolves when all nodes complete
856
+ */
857
+ executeNodesInParallel<T>(nodeExecutors: Array<() => Promise<T>>): Promise<T[]>;
858
+ /**
859
+ * Determines if nodes can be safely executed in parallel
860
+ * @param nodes Nodes to check
861
+ * @param nodeResults Current execution results
862
+ * @returns true if all nodes have their dependencies satisfied
863
+ */
864
+ canExecuteInParallel(nodeIds: string[], nodeResults: Map<string, unknown>, reverseGraph: Record<string, string[]>): boolean;
865
+ /**
866
+ * Gets execution statistics for monitoring
867
+ */
868
+ getStats(): {
869
+ maxConcurrency: number;
870
+ };
871
+ }
872
+ //#endregion
873
+ //#region src/flow/plugins/types/optimize-node.d.ts
874
+ declare const optimizeParamsSchema: z.ZodObject<{
875
+ quality: z.ZodNumber;
876
+ format: z.ZodEnum<{
877
+ jpeg: "jpeg";
878
+ }>;
879
+ }, z.core.$strip>;
880
+ type OptimizeParams = z.infer<typeof optimizeParamsSchema>;
881
+ //#endregion
882
+ //#region src/flow/plugins/types/resize-node.d.ts
883
+ declare const resizeParamsSchema: z.ZodObject<{
884
+ width: z.ZodOptional<z.ZodNumber>;
885
+ height: z.ZodOptional<z.ZodNumber>;
886
+ fit: z.ZodEnum<{
887
+ fill: "fill";
888
+ contain: "contain";
889
+ cover: "cover";
890
+ }>;
891
+ }, z.core.$strip>;
892
+ type ResizeParams = z.infer<typeof resizeParamsSchema>;
893
+ //#endregion
894
+ //#region src/flow/plugins/image-plugin.d.ts
895
+ type ImagePluginShape = {
896
+ optimize: (input: Uint8Array, options: OptimizeParams) => Effect.Effect<Uint8Array, UploadistaError>;
897
+ resize: (input: Uint8Array, options: ResizeParams) => Effect.Effect<Uint8Array, UploadistaError>;
898
+ };
899
+ declare const ImagePlugin_base: Context.TagClass<ImagePlugin, "ImagePlugin", ImagePluginShape>;
900
+ declare class ImagePlugin extends ImagePlugin_base {}
901
+ //#endregion
902
+ //#region src/flow/types/flow-file.d.ts
903
+ type FlowFile = {
904
+ path: string;
905
+ inputBytes: Uint8Array<ArrayBufferLike>;
906
+ metadata: {
907
+ size: number;
908
+ mimeType: string;
909
+ width?: number;
910
+ height?: number;
911
+ format?: string;
912
+ originalName?: string;
913
+ extension?: string;
914
+ };
915
+ };
916
+ declare const flowFileSchema: z.ZodObject<{
917
+ path: z.ZodString;
918
+ inputBytes: z.ZodCustom<Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>>;
919
+ metadata: z.ZodObject<{
920
+ mimeType: z.ZodString;
921
+ size: z.ZodNumber;
922
+ width: z.ZodOptional<z.ZodNumber>;
923
+ height: z.ZodOptional<z.ZodNumber>;
924
+ format: z.ZodOptional<z.ZodString>;
925
+ originalName: z.ZodOptional<z.ZodString>;
926
+ extension: z.ZodOptional<z.ZodString>;
927
+ }, z.core.$strip>;
928
+ }, z.core.$strip>;
929
+ type FlowFileBatch = {
930
+ files: FlowFile[];
931
+ metadata?: {
932
+ batchId: string;
933
+ totalSize: number;
934
+ fileCount: number;
935
+ };
936
+ };
937
+ declare const flowFileBatchSchema: z.ZodObject<{
938
+ files: z.ZodArray<z.ZodObject<{
939
+ path: z.ZodString;
940
+ inputBytes: z.ZodCustom<Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>>;
941
+ metadata: z.ZodObject<{
942
+ mimeType: z.ZodString;
943
+ size: z.ZodNumber;
944
+ width: z.ZodOptional<z.ZodNumber>;
945
+ height: z.ZodOptional<z.ZodNumber>;
946
+ format: z.ZodOptional<z.ZodString>;
947
+ originalName: z.ZodOptional<z.ZodString>;
948
+ extension: z.ZodOptional<z.ZodString>;
949
+ }, z.core.$strip>;
950
+ }, z.core.$strip>>;
951
+ metadata: z.ZodOptional<z.ZodObject<{
952
+ batchId: z.ZodString;
953
+ totalSize: z.ZodNumber;
954
+ fileCount: z.ZodNumber;
955
+ }, z.core.$strip>>;
956
+ }, z.core.$strip>;
957
+ type FlowFileData = FlowFile | FlowFileBatch;
958
+ declare function isFlowFile(data: FlowFileData): data is FlowFile;
959
+ declare const flowDataSchema: z.ZodUnion<readonly [z.ZodObject<{
960
+ path: z.ZodString;
961
+ inputBytes: z.ZodCustom<Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>>;
962
+ metadata: z.ZodObject<{
963
+ mimeType: z.ZodString;
964
+ size: z.ZodNumber;
965
+ width: z.ZodOptional<z.ZodNumber>;
966
+ height: z.ZodOptional<z.ZodNumber>;
967
+ format: z.ZodOptional<z.ZodString>;
968
+ originalName: z.ZodOptional<z.ZodString>;
969
+ extension: z.ZodOptional<z.ZodString>;
970
+ }, z.core.$strip>;
971
+ }, z.core.$strip>, z.ZodObject<{
972
+ files: z.ZodArray<z.ZodObject<{
973
+ path: z.ZodString;
974
+ inputBytes: z.ZodCustom<Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>>;
975
+ metadata: z.ZodObject<{
976
+ mimeType: z.ZodString;
977
+ size: z.ZodNumber;
978
+ width: z.ZodOptional<z.ZodNumber>;
979
+ height: z.ZodOptional<z.ZodNumber>;
980
+ format: z.ZodOptional<z.ZodString>;
981
+ originalName: z.ZodOptional<z.ZodString>;
982
+ extension: z.ZodOptional<z.ZodString>;
983
+ }, z.core.$strip>;
984
+ }, z.core.$strip>>;
985
+ metadata: z.ZodOptional<z.ZodObject<{
986
+ batchId: z.ZodString;
987
+ totalSize: z.ZodNumber;
988
+ fileCount: z.ZodNumber;
989
+ }, z.core.$strip>>;
990
+ }, z.core.$strip>]>;
991
+ type FlowCondition = {
992
+ field: "mimeType" | "size" | "width" | "height" | "extension";
993
+ operator: "equals" | "notEquals" | "greaterThan" | "lessThan" | "contains" | "startsWith";
994
+ value: string | number;
995
+ };
996
+ //#endregion
997
+ //#region src/flow/types/run-args.d.ts
998
+ declare const runArgsSchema: z.ZodObject<{
999
+ inputs: z.ZodRecord<z.ZodString, z.ZodAny>;
1000
+ }, z.core.$strip>;
1001
+ type RunArgs = z.infer<typeof runArgsSchema>;
1002
+ //#endregion
1003
+ export { BaseEventEmitter, BaseEventEmitterService, BaseKvStore, BaseKvStoreService, BufferedUploadFileDataStore, ConditionField, ConditionOperator, ConditionValue, DataStore, DataStoreCapabilities, DataStoreRegistry, DataStoreWriteOptions, EventEmitter, EventType, ExecutionLevel, type Flow, FlowCondition, FlowConfig, type FlowData, type FlowEdge, type FlowEvent, FlowEventEmitter, type FlowEventFlowEnd, type FlowEventFlowStart, FlowEventJobEnd, FlowEventJobStart, FlowEventNodeEnd, FlowEventNodeError, FlowEventNodeResponse, FlowEventNodeStart, FlowExecutionContext, FlowExecutionResult, FlowFile, FlowFileBatch, FlowFileData, FlowJob, FlowJobKVStore, FlowJobStatus, FlowJobTask, FlowJobTaskStatus, FlowNode, FlowNodeData, FlowProvider, FlowProviderShape, FlowServer, FlowServerLayer, FlowServerOptions, FlowServerShape, ImagePlugin, ImagePluginShape, InputFile, KvStore, Middleware, MiddlewareContext, MiddlewareNext, MiddlewareService, MiddlewareServiceLive, NegotiatedStrategy, NodeConnectionValidator, NodeExecutionResult, NodeType, NodeTypeMap, OptimizeParams, ParallelScheduler, ParallelSchedulerConfig, ResizeParams, RunArgs, StorageParams, TypeCompatibilityChecker, TypedEventEmitter, TypedKvStore, UploadEvent, UploadEventEmitter, UploadEventType, UploadFile, UploadFileDataStore, UploadFileDataStores, UploadFileDataStoresShape, UploadFileKVStore, UploadServer, UploadServerOptions, UploadServerShape, UploadStrategy, UploadStrategyNegotiator, UploadStrategyOptions, WebSocketConnection, WebSocketMessage, completeNodeExecution, createFlow, createFlowEdge, createFlowNode, createFlowServer, createInputNode, createStorageNode, createStreamingInputNode, createUploadServer, detectMimeType, eventToMessageSerializer, flowDataSchema, flowEventEmitter, flowFileBatchSchema, flowFileSchema, flowJobKvStore, flowServer, getFlowData, getNodeData, inputFileSchema, isFlowFile, jsonSerializer, optimizeParamsSchema, resizeParamsSchema, runArgsSchema, storageParamsSchema, uploadEventEmitter, uploadEventSchema, uploadFileKvStore, uploadFileSchema, uploadServer, waitingNodeExecution, webSocketMessageSchema };
1004
+ //# sourceMappingURL=index-D-CoVpkZ.d.ts.map