@uploadista/core 0.0.18-beta.2 → 0.0.18-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/flow/index.cjs +1 -1
- package/dist/flow/index.d.cts +2 -2
- package/dist/flow/index.d.mts +2 -2
- package/dist/flow/index.mjs +1 -1
- package/dist/flow-NBmCjMqI.mjs +2 -0
- package/dist/flow-NBmCjMqI.mjs.map +1 -0
- package/dist/flow-yTdzjQ0k.cjs +1 -0
- package/dist/{index-DiHUjE9t.d.mts → index-BJxZyw0A.d.mts} +550 -195
- package/dist/index-BJxZyw0A.d.mts.map +1 -0
- package/dist/index-CoAMCnm6.d.cts.map +1 -1
- package/dist/{index-D5ALjvAb.d.cts → index-uOAh_6qk.d.cts} +550 -195
- package/dist/index-uOAh_6qk.d.cts.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.mts +2 -2
- package/dist/index.mjs +1 -1
- package/dist/testing/index.cjs +1 -1
- package/dist/testing/index.d.cts +1 -1
- package/dist/testing/index.d.mts +1 -1
- package/dist/testing/index.mjs +1 -1
- package/dist/types/index.d.cts +1 -1
- package/dist/types/index.d.mts +1 -1
- package/dist/upload/index.d.cts +1 -1
- package/dist/upload/index.d.mts +1 -1
- package/package.json +5 -2
- package/src/flow/index.ts +2 -0
- package/src/flow/nodes/transform-node.ts +43 -2
- package/src/flow/types/flow-types.ts +148 -0
- package/src/flow/utils/file-naming.ts +308 -0
- package/dist/flow-CAywogte.mjs +0 -2
- package/dist/flow-CAywogte.mjs.map +0 -1
- package/dist/flow-D7QeEZVs.cjs +0 -1
- package/dist/index-D5ALjvAb.d.cts.map +0 -1
- package/dist/index-DiHUjE9t.d.mts.map +0 -1
package/dist/flow/index.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
require(`../types-Ce7ILjFt.cjs`),require(`../uploadista-error-Di9fniB1.cjs`),require(`../errors-CRm1FHHT.cjs`);const e=require(`../flow-
|
|
1
|
+
require(`../types-Ce7ILjFt.cjs`),require(`../uploadista-error-Di9fniB1.cjs`),require(`../errors-CRm1FHHT.cjs`);const e=require(`../flow-yTdzjQ0k.cjs`);require(`../upload-uQfkhcMj.cjs`),require(`../checksum-B1XGxTsI.cjs`),require(`../stream-limiter-B6CRA3Zd.cjs`),exports.AVAILABLE_TEMPLATE_VARIABLES=e.F,exports.CredentialProvider=e.N,exports.DocumentAiPlugin=e.M,exports.DocumentPlugin=e.j,exports.EventType=e.jt,exports.FlowProvider=e.H,exports.FlowServer=e.U,exports.FlowWaitUntil=e.W,exports.IMAGE_DESCRIPTION_OUTPUT_TYPE_ID=e.ut,exports.ImageAiPlugin=e.A,exports.ImagePlugin=e.k,exports.InputTypeRegistry=e.Ot,exports.NodeType=e.St,exports.OCR_OUTPUT_TYPE_ID=e.dt,exports.OutputTypeRegistry=e.Tt,exports.ParallelScheduler=e.lt,exports.STORAGE_OUTPUT_TYPE_ID=e.ft,exports.STREAMING_INPUT_TYPE_ID=e.pt,exports.VideoPlugin=e.a,exports.VirusScanPlugin=e.i,exports.ZipPlugin=e.r,exports.applyFileNaming=e.I,exports.blurTransformSchema=e.s,exports.brightnessTransformSchema=e.c,exports.buildNamingContext=e.L,exports.completeNodeExecution=e.bt,exports.contrastTransformSchema=e.l,exports.createFlow=e.n,exports.createFlowEdge=e.Mt,exports.createFlowNode=e.Ct,exports.createFlowServer=e.G,exports.createFlowWithSchema=e.q,exports.createInputNode=e.gt,exports.createTransformNode=e.P,exports.createTypeGuard=e.Y,exports.describeImageParamsSchema=e.O,exports.describeVideoMetadataSchema=e.D,exports.extractFrameVideoParamsSchema=e.E,exports.filterOutputsByType=e.X,exports.flipTransformSchema=e.u,exports.flowServer=e.K,exports.getBaseName=e.R,exports.getExtension=e.z,exports.getFirstOutputByType=e.Z,exports.getFlowData=e.J,exports.getNodeData=e.wt,exports.getOutputByNodeId=e.Q,exports.getSingleOutputByType=e.$,exports.grayscaleTransformSchema=e.d,exports.hasOutputOfType=e.et,exports.imageDescriptionOutputSchema=e.mt,exports.inputDataSchema=e._t,exports.inputNodeParamsSchema=e.vt,exports.inputTypeRegistry=e.kt,exports.interpolateFileName=e.B,exports.isFinalizeOperation=e.tt,exports.isImageDescriptionOutput=e.nt,exports.isInitOperation=e.rt,exports.isOcrOutput=e.it,exports.isStorageOutput=e.at,exports.isUploadFile=e.ot,exports.isUploadOperation=e.st,exports.isUrlOperation=e.ct,exports.logoTransformSchema=e.f,exports.ocrOutputSchema=e.ht,exports.optimizeParamsSchema=e.T,exports.outputTypeRegistry=e.Et,exports.removeBackgroundParamsSchema=e.w,exports.resizeParamsSchema=e.C,exports.resizeTransformSchema=e.p,exports.resizeVideoParamsSchema=e.S,exports.resolveUploadMetadata=e.yt,exports.rotateTransformSchema=e.m,exports.runArgsSchema=e.t,exports.sepiaTransformSchema=e.h,exports.sharpenTransformSchema=e.g,exports.textTransformSchema=e._,exports.transcodeVideoParamsSchema=e.x,exports.transformImageParamsSchema=e.v,exports.transformationSchema=e.y,exports.trimVideoParamsSchema=e.o,exports.validateFlowInput=e.At,exports.validateFlowOutput=e.Dt,exports.validatePattern=e.V,exports.waitingNodeExecution=e.xt,exports.watermarkTransformSchema=e.b;
|
package/dist/flow/index.d.cts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "../uploadista-error-DigegPz2.cjs";
|
|
2
2
|
import "../index-_wQ5ClJU.cjs";
|
|
3
|
-
import { $ as
|
|
3
|
+
import { $ as VideoPlugin, $i as createFlowNode, $t as DocumentMetadata, A as isImageDescriptionOutput, Ai as TypeCompatibilityChecker, An as createInputNode, Ar as OcrOutput, At as WatermarkTransform, B as describeImageParamsSchema, Bi as FlowEventFlowStart, Bn as WaitUntilCallback, Br as InputTypeDefinition, Bt as sharpenTransformSchema, C as createTypeGuard, Ci as FlowConfig, Cn as ExtractEffectRequirements, Ct as RotateTransform, D as getSingleOutputByType, Di as NodeConnectionValidator, Dn as FlowCondition, Dr as IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, Dt as TransformImageParams, E as getOutputByNodeId, Ei as NamingContext, En as ResolveEffect, Et as TextTransform, F as isUploadOperation, Fi as FlowEvent, Fn as FlowServer, Fr as OutputTypeDefinition, Ft as grayscaleTransformSchema, G as ZipPlugin, Gi as FlowEventNodePause, Gn as FlowJobTask, Gr as Flow, Gt as ResizeParams, H as PluginLayer, Hi as FlowEventJobStart, Hn as flowServer, Hr as InputValidationResult, Ht as transformImageParamsSchema, I as isUrlOperation, Ii as FlowEventFlowCancel, In as FlowServerLayer, Ir as OutputTypeRegistry, It as logoTransformSchema, J as ScanMetadata, Ji as FlowEventNodeStart, Jr as createFlowWithSchema, Jt as optimizeParamsSchema, K as ZipPluginLayer, Ki as FlowEventNodeResponse, Kn as FlowJobTaskStatus, Kr as FlowData, Kt as resizeParamsSchema, L as RemoveBackgroundParams, Li as FlowEventFlowEnd, Ln as FlowServerOptions, Lr as OutputValidationResult, Lt as resizeTransformSchema, M as isOcrOutput, Mi as completeNodeExecution, Mn as inputNodeParamsSchema, Mr as STREAMING_INPUT_TYPE_ID, Mt as brightnessTransformSchema, N as isStorageOutput, Ni as waitingNodeExecution, Nn as FlowProvider, Nr as imageDescriptionOutputSchema, Nt as contrastTransformSchema, O as hasOutputOfType, Oi as NodeExecutionResult, On as InputData, Or as ImageDescriptionOutput, Ot as Transformation, P as isUploadFile, Pi as EventType, Pn as FlowProviderShape, Pr as ocrOutputSchema, Pt as flipTransformSchema, Q as VirusScanPluginShape, Qi as NodeType, Qt as ImageAiPluginShape, R as removeBackgroundParamsSchema, Ri as FlowEventFlowError, Rn as FlowServerShape, Rr as outputTypeRegistry, Rt as rotateTransformSchema, S as NarrowedTypedOutput, Si as FileNamingFunction, Sn as ExtractEffectError, St as ResizeTransform, T as getFirstOutputByType, Ti as FlowNodeData, Tn as ExtractLayerServices, Tt as SharpenTransform, U as ZipInput, Ui as FlowEventNodeEnd, Un as FlowJob, Ur as inputTypeRegistry, Ut as transformationSchema, V as Plugin, Vi as FlowEventJobEnd, Vn as createFlowServer, Vr as InputTypeRegistry, Vt as textTransformSchema, W as ZipParams, Wi as FlowEventNodeError, Wn as FlowJobStatus, Wr as validateFlowInput, Wt as watermarkTransformSchema, X as VirusScanPlugin, Xi as ConditionOperator, Xt as ImageAiPlugin, Y as ScanResult, Yi as ConditionField, Yr as getFlowData, Yt as ImageAiContext, Z as VirusScanPluginLayer, Zi as ConditionValue, Zt as ImageAiPluginLayer, _ as NodeDefinitionsRecord, _i as createFlowEdge, _n as ExecutionLevel, _t as ContrastTransform, a as getExtension, an as SplitPdfResult, at as transcodeVideoParamsSchema, b as TypedFlowEdge, bi as CustomTypedOutput, bn as TransformNodeConfig, bt as LogoTransform, c as ResolvedUploadMetadata, cn as DocumentAiPluginLayer, ct as ExtractFrameVideoParams, d as runArgsSchema, dn as OcrResolution, dt as describeVideoMetadataSchema, ea as getNodeData, en as DocumentPlugin, et as VideoPluginLayer, f as FlowInputMap, fn as OcrResult, ft as ImagePlugin, g as NodeDefinition, gi as FlowEdge, gn as CredentialProviderShape, gt as BrightnessTransform, h as FlowRequirements, hn as CredentialProviderLayer, ht as BlurTransform, i as getBaseName, in as SplitPdfParams, it as TranscodeVideoParams, j as isInitOperation, ji as TypedOutput, jn as inputDataSchema, jr as STORAGE_OUTPUT_TYPE_ID, jt as blurTransformSchema, k as isFinalizeOperation, ki as NodeTypeMap, kn as InputNodeParams, kr as OCR_OUTPUT_TYPE_ID, kt as TransformationType, l as resolveUploadMetadata, ln as DocumentAiPluginShape, lt as extractFrameVideoParamsSchema, m as FlowPluginRequirements, mn as CredentialProvider, mt as ImagePluginShape, n as applyFileNaming, nn as DocumentPluginShape, nt as TrimVideoParams, o as interpolateFileName, on as DocumentAiContext, ot as ResizeVideoParams, p as FlowOutputMap, pn as OcrTaskType, pt as ImagePluginLayer, q as ZipPluginShape, qi as FlowEventNodeResume, qr as FlowExecutionResult, qt as OptimizeParams, r as buildNamingContext, rn as MergePdfParams, rt as trimVideoParamsSchema, s as validatePattern, sn as DocumentAiPlugin, st as resizeVideoParamsSchema, t as AVAILABLE_TEMPLATE_VARIABLES, tn as DocumentPluginLayer, tt as VideoPluginShape, u as RunArgs, un as OcrParams, ut as DescribeVideoMetadata, v as TypedFlow, vi as AutoNamingSuffixGenerator, vn as ParallelScheduler, vt as FlipTransform, w as filterOutputsByType, wi as FlowNode, wn as ExtractLayerService, wt as SepiaTransform, x as createFlow, xi as FileNamingConfig, xn as createTransformNode, xt as OverlayPosition, y as TypedFlowConfig, yi as BuiltInTypedOutput, yn as ParallelSchedulerConfig, yt as GrayscaleTransform, z as DescribeImageParams, zi as FlowEventFlowPause, zn as FlowWaitUntil, zr as validateFlowOutput, zt as sepiaTransformSchema } from "../index-uOAh_6qk.cjs";
|
|
4
4
|
import "../index-CoAMCnm6.cjs";
|
|
5
5
|
import "../index-C4zZWqtz.cjs";
|
|
6
|
-
export { BlurTransform, BrightnessTransform, BuiltInTypedOutput, ConditionField, ConditionOperator, ConditionValue, ContrastTransform, CredentialProvider, CredentialProviderLayer, CredentialProviderShape, CustomTypedOutput, DescribeImageParams, DescribeVideoMetadata, DocumentAiContext, DocumentAiPlugin, DocumentAiPluginLayer, DocumentAiPluginShape, DocumentMetadata, DocumentPlugin, DocumentPluginLayer, DocumentPluginShape, EventType, ExecutionLevel, ExtractEffectError, ExtractEffectRequirements, ExtractFrameVideoParams, ExtractLayerService, ExtractLayerServices, FlipTransform, Flow, FlowCondition, FlowConfig, FlowData, FlowEdge, FlowEvent, FlowEventFlowCancel, FlowEventFlowEnd, FlowEventFlowError, FlowEventFlowPause, FlowEventFlowStart, FlowEventJobEnd, FlowEventJobStart, FlowEventNodeEnd, FlowEventNodeError, FlowEventNodePause, FlowEventNodeResponse, FlowEventNodeResume, FlowEventNodeStart, FlowExecutionResult, FlowInputMap, FlowJob, FlowJobStatus, FlowJobTask, FlowJobTaskStatus, FlowNode, FlowNodeData, FlowOutputMap, FlowPluginRequirements, FlowProvider, FlowProviderShape, FlowRequirements, FlowServer, FlowServerLayer, FlowServerOptions, FlowServerShape, FlowWaitUntil, GrayscaleTransform, IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, ImageAiContext, ImageAiPlugin, ImageAiPluginLayer, ImageAiPluginShape, ImageDescriptionOutput, ImagePlugin, ImagePluginLayer, ImagePluginShape, InputData, InputNodeParams, InputTypeDefinition, InputTypeRegistry, InputValidationResult, LogoTransform, MergePdfParams, NarrowedTypedOutput, NodeConnectionValidator, NodeDefinition, NodeDefinitionsRecord, NodeExecutionResult, NodeType, NodeTypeMap, OCR_OUTPUT_TYPE_ID, OcrOutput, OcrParams, OcrResolution, OcrResult, OcrTaskType, OptimizeParams, OutputTypeDefinition, OutputTypeRegistry, OutputValidationResult, OverlayPosition, ParallelScheduler, ParallelSchedulerConfig, Plugin, PluginLayer, RemoveBackgroundParams, ResizeParams, ResizeTransform, ResizeVideoParams, ResolveEffect, ResolvedUploadMetadata, RotateTransform, RunArgs, STORAGE_OUTPUT_TYPE_ID, STREAMING_INPUT_TYPE_ID, ScanMetadata, ScanResult, SepiaTransform, SharpenTransform, SplitPdfParams, SplitPdfResult, TextTransform, TranscodeVideoParams, TransformImageParams, TransformNodeConfig, Transformation, TransformationType, TrimVideoParams, TypeCompatibilityChecker, TypedFlow, TypedFlowConfig, TypedFlowEdge, TypedOutput, VideoPlugin, VideoPluginLayer, VideoPluginShape, VirusScanPlugin, VirusScanPluginLayer, VirusScanPluginShape, WaitUntilCallback, WatermarkTransform, ZipInput, ZipParams, ZipPlugin, ZipPluginLayer, ZipPluginShape, blurTransformSchema, brightnessTransformSchema, completeNodeExecution, contrastTransformSchema, createFlow, createFlowEdge, createFlowNode, createFlowServer, createFlowWithSchema, createInputNode, createTransformNode, createTypeGuard, describeImageParamsSchema, describeVideoMetadataSchema, extractFrameVideoParamsSchema, filterOutputsByType, flipTransformSchema, flowServer, getFirstOutputByType, getFlowData, getNodeData, getOutputByNodeId, getSingleOutputByType, grayscaleTransformSchema, hasOutputOfType, imageDescriptionOutputSchema, inputDataSchema, inputNodeParamsSchema, inputTypeRegistry, isFinalizeOperation, isImageDescriptionOutput, isInitOperation, isOcrOutput, isStorageOutput, isUploadFile, isUploadOperation, isUrlOperation, logoTransformSchema, ocrOutputSchema, optimizeParamsSchema, outputTypeRegistry, removeBackgroundParamsSchema, resizeParamsSchema, resizeTransformSchema, resizeVideoParamsSchema, resolveUploadMetadata, rotateTransformSchema, runArgsSchema, sepiaTransformSchema, sharpenTransformSchema, textTransformSchema, transcodeVideoParamsSchema, transformImageParamsSchema, transformationSchema, trimVideoParamsSchema, validateFlowInput, validateFlowOutput, waitingNodeExecution, watermarkTransformSchema };
|
|
6
|
+
export { AVAILABLE_TEMPLATE_VARIABLES, AutoNamingSuffixGenerator, BlurTransform, BrightnessTransform, BuiltInTypedOutput, ConditionField, ConditionOperator, ConditionValue, ContrastTransform, CredentialProvider, CredentialProviderLayer, CredentialProviderShape, CustomTypedOutput, DescribeImageParams, DescribeVideoMetadata, DocumentAiContext, DocumentAiPlugin, DocumentAiPluginLayer, DocumentAiPluginShape, DocumentMetadata, DocumentPlugin, DocumentPluginLayer, DocumentPluginShape, EventType, ExecutionLevel, ExtractEffectError, ExtractEffectRequirements, ExtractFrameVideoParams, ExtractLayerService, ExtractLayerServices, FileNamingConfig, FileNamingFunction, FlipTransform, Flow, FlowCondition, FlowConfig, FlowData, FlowEdge, FlowEvent, FlowEventFlowCancel, FlowEventFlowEnd, FlowEventFlowError, FlowEventFlowPause, FlowEventFlowStart, FlowEventJobEnd, FlowEventJobStart, FlowEventNodeEnd, FlowEventNodeError, FlowEventNodePause, FlowEventNodeResponse, FlowEventNodeResume, FlowEventNodeStart, FlowExecutionResult, FlowInputMap, FlowJob, FlowJobStatus, FlowJobTask, FlowJobTaskStatus, FlowNode, FlowNodeData, FlowOutputMap, FlowPluginRequirements, FlowProvider, FlowProviderShape, FlowRequirements, FlowServer, FlowServerLayer, FlowServerOptions, FlowServerShape, FlowWaitUntil, GrayscaleTransform, IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, ImageAiContext, ImageAiPlugin, ImageAiPluginLayer, ImageAiPluginShape, ImageDescriptionOutput, ImagePlugin, ImagePluginLayer, ImagePluginShape, InputData, InputNodeParams, InputTypeDefinition, InputTypeRegistry, InputValidationResult, LogoTransform, MergePdfParams, NamingContext, NarrowedTypedOutput, NodeConnectionValidator, NodeDefinition, NodeDefinitionsRecord, NodeExecutionResult, NodeType, NodeTypeMap, OCR_OUTPUT_TYPE_ID, OcrOutput, OcrParams, OcrResolution, OcrResult, OcrTaskType, OptimizeParams, OutputTypeDefinition, OutputTypeRegistry, OutputValidationResult, OverlayPosition, ParallelScheduler, ParallelSchedulerConfig, Plugin, PluginLayer, RemoveBackgroundParams, ResizeParams, ResizeTransform, ResizeVideoParams, ResolveEffect, ResolvedUploadMetadata, RotateTransform, RunArgs, STORAGE_OUTPUT_TYPE_ID, STREAMING_INPUT_TYPE_ID, ScanMetadata, ScanResult, SepiaTransform, SharpenTransform, SplitPdfParams, SplitPdfResult, TextTransform, TranscodeVideoParams, TransformImageParams, TransformNodeConfig, Transformation, TransformationType, TrimVideoParams, TypeCompatibilityChecker, TypedFlow, TypedFlowConfig, TypedFlowEdge, TypedOutput, VideoPlugin, VideoPluginLayer, VideoPluginShape, VirusScanPlugin, VirusScanPluginLayer, VirusScanPluginShape, WaitUntilCallback, WatermarkTransform, ZipInput, ZipParams, ZipPlugin, ZipPluginLayer, ZipPluginShape, applyFileNaming, blurTransformSchema, brightnessTransformSchema, buildNamingContext, completeNodeExecution, contrastTransformSchema, createFlow, createFlowEdge, createFlowNode, createFlowServer, createFlowWithSchema, createInputNode, createTransformNode, createTypeGuard, describeImageParamsSchema, describeVideoMetadataSchema, extractFrameVideoParamsSchema, filterOutputsByType, flipTransformSchema, flowServer, getBaseName, getExtension, getFirstOutputByType, getFlowData, getNodeData, getOutputByNodeId, getSingleOutputByType, grayscaleTransformSchema, hasOutputOfType, imageDescriptionOutputSchema, inputDataSchema, inputNodeParamsSchema, inputTypeRegistry, interpolateFileName, isFinalizeOperation, isImageDescriptionOutput, isInitOperation, isOcrOutput, isStorageOutput, isUploadFile, isUploadOperation, isUrlOperation, logoTransformSchema, ocrOutputSchema, optimizeParamsSchema, outputTypeRegistry, removeBackgroundParamsSchema, resizeParamsSchema, resizeTransformSchema, resizeVideoParamsSchema, resolveUploadMetadata, rotateTransformSchema, runArgsSchema, sepiaTransformSchema, sharpenTransformSchema, textTransformSchema, transcodeVideoParamsSchema, transformImageParamsSchema, transformationSchema, trimVideoParamsSchema, validateFlowInput, validateFlowOutput, validatePattern, waitingNodeExecution, watermarkTransformSchema };
|
package/dist/flow/index.d.mts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "../uploadista-error-DMMrZF03.mjs";
|
|
2
2
|
import "../index-C-svZlpj.mjs";
|
|
3
|
-
import { $ as
|
|
3
|
+
import { $ as VideoPlugin, $i as createFlowNode, $t as DocumentMetadata, A as isImageDescriptionOutput, Ai as TypeCompatibilityChecker, An as createInputNode, Ar as OcrOutput, At as WatermarkTransform, B as describeImageParamsSchema, Bi as FlowEventFlowStart, Bn as WaitUntilCallback, Br as InputTypeDefinition, Bt as sharpenTransformSchema, C as createTypeGuard, Ci as FlowConfig, Cn as ExtractEffectRequirements, Ct as RotateTransform, D as getSingleOutputByType, Di as NodeConnectionValidator, Dn as FlowCondition, Dr as IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, Dt as TransformImageParams, E as getOutputByNodeId, Ei as NamingContext, En as ResolveEffect, Et as TextTransform, F as isUploadOperation, Fi as FlowEvent, Fn as FlowServer, Fr as OutputTypeDefinition, Ft as grayscaleTransformSchema, G as ZipPlugin, Gi as FlowEventNodePause, Gn as FlowJobTask, Gr as Flow, Gt as ResizeParams, H as PluginLayer, Hi as FlowEventJobStart, Hn as flowServer, Hr as InputValidationResult, Ht as transformImageParamsSchema, I as isUrlOperation, Ii as FlowEventFlowCancel, In as FlowServerLayer, Ir as OutputTypeRegistry, It as logoTransformSchema, J as ScanMetadata, Ji as FlowEventNodeStart, Jr as createFlowWithSchema, Jt as optimizeParamsSchema, K as ZipPluginLayer, Ki as FlowEventNodeResponse, Kn as FlowJobTaskStatus, Kr as FlowData, Kt as resizeParamsSchema, L as RemoveBackgroundParams, Li as FlowEventFlowEnd, Ln as FlowServerOptions, Lr as OutputValidationResult, Lt as resizeTransformSchema, M as isOcrOutput, Mi as completeNodeExecution, Mn as inputNodeParamsSchema, Mr as STREAMING_INPUT_TYPE_ID, Mt as brightnessTransformSchema, N as isStorageOutput, Ni as waitingNodeExecution, Nn as FlowProvider, Nr as imageDescriptionOutputSchema, Nt as contrastTransformSchema, O as hasOutputOfType, Oi as NodeExecutionResult, On as InputData, Or as ImageDescriptionOutput, Ot as Transformation, P as isUploadFile, Pi as EventType, Pn as FlowProviderShape, Pr as ocrOutputSchema, Pt as flipTransformSchema, Q as VirusScanPluginShape, Qi as NodeType, Qt as ImageAiPluginShape, R as removeBackgroundParamsSchema, Ri as FlowEventFlowError, Rn as FlowServerShape, Rr as outputTypeRegistry, Rt as rotateTransformSchema, S as NarrowedTypedOutput, Si as FileNamingFunction, Sn as ExtractEffectError, St as ResizeTransform, T as getFirstOutputByType, Ti as FlowNodeData, Tn as ExtractLayerServices, Tt as SharpenTransform, U as ZipInput, Ui as FlowEventNodeEnd, Un as FlowJob, Ur as inputTypeRegistry, Ut as transformationSchema, V as Plugin, Vi as FlowEventJobEnd, Vn as createFlowServer, Vr as InputTypeRegistry, Vt as textTransformSchema, W as ZipParams, Wi as FlowEventNodeError, Wn as FlowJobStatus, Wr as validateFlowInput, Wt as watermarkTransformSchema, X as VirusScanPlugin, Xi as ConditionOperator, Xt as ImageAiPlugin, Y as ScanResult, Yi as ConditionField, Yr as getFlowData, Yt as ImageAiContext, Z as VirusScanPluginLayer, Zi as ConditionValue, Zt as ImageAiPluginLayer, _ as NodeDefinitionsRecord, _i as createFlowEdge, _n as ExecutionLevel, _t as ContrastTransform, a as getExtension, an as SplitPdfResult, at as transcodeVideoParamsSchema, b as TypedFlowEdge, bi as CustomTypedOutput, bn as TransformNodeConfig, bt as LogoTransform, c as ResolvedUploadMetadata, cn as DocumentAiPluginLayer, ct as ExtractFrameVideoParams, d as runArgsSchema, dn as OcrResolution, dt as describeVideoMetadataSchema, ea as getNodeData, en as DocumentPlugin, et as VideoPluginLayer, f as FlowInputMap, fn as OcrResult, ft as ImagePlugin, g as NodeDefinition, gi as FlowEdge, gn as CredentialProviderShape, gt as BrightnessTransform, h as FlowRequirements, hn as CredentialProviderLayer, ht as BlurTransform, i as getBaseName, in as SplitPdfParams, it as TranscodeVideoParams, j as isInitOperation, ji as TypedOutput, jn as inputDataSchema, jr as STORAGE_OUTPUT_TYPE_ID, jt as blurTransformSchema, k as isFinalizeOperation, ki as NodeTypeMap, kn as InputNodeParams, kr as OCR_OUTPUT_TYPE_ID, kt as TransformationType, l as resolveUploadMetadata, ln as DocumentAiPluginShape, lt as extractFrameVideoParamsSchema, m as FlowPluginRequirements, mn as CredentialProvider, mt as ImagePluginShape, n as applyFileNaming, nn as DocumentPluginShape, nt as TrimVideoParams, o as interpolateFileName, on as DocumentAiContext, ot as ResizeVideoParams, p as FlowOutputMap, pn as OcrTaskType, pt as ImagePluginLayer, q as ZipPluginShape, qi as FlowEventNodeResume, qr as FlowExecutionResult, qt as OptimizeParams, r as buildNamingContext, rn as MergePdfParams, rt as trimVideoParamsSchema, s as validatePattern, sn as DocumentAiPlugin, st as resizeVideoParamsSchema, t as AVAILABLE_TEMPLATE_VARIABLES, tn as DocumentPluginLayer, tt as VideoPluginShape, u as RunArgs, un as OcrParams, ut as DescribeVideoMetadata, v as TypedFlow, vi as AutoNamingSuffixGenerator, vn as ParallelScheduler, vt as FlipTransform, w as filterOutputsByType, wi as FlowNode, wn as ExtractLayerService, wt as SepiaTransform, x as createFlow, xi as FileNamingConfig, xn as createTransformNode, xt as OverlayPosition, y as TypedFlowConfig, yi as BuiltInTypedOutput, yn as ParallelSchedulerConfig, yt as GrayscaleTransform, z as DescribeImageParams, zi as FlowEventFlowPause, zn as FlowWaitUntil, zr as validateFlowOutput, zt as sepiaTransformSchema } from "../index-BJxZyw0A.mjs";
|
|
4
4
|
import "../index-CHQtirAp.mjs";
|
|
5
5
|
import "../index-zQ707AXp.mjs";
|
|
6
|
-
export { BlurTransform, BrightnessTransform, BuiltInTypedOutput, ConditionField, ConditionOperator, ConditionValue, ContrastTransform, CredentialProvider, CredentialProviderLayer, CredentialProviderShape, CustomTypedOutput, DescribeImageParams, DescribeVideoMetadata, DocumentAiContext, DocumentAiPlugin, DocumentAiPluginLayer, DocumentAiPluginShape, DocumentMetadata, DocumentPlugin, DocumentPluginLayer, DocumentPluginShape, EventType, ExecutionLevel, ExtractEffectError, ExtractEffectRequirements, ExtractFrameVideoParams, ExtractLayerService, ExtractLayerServices, FlipTransform, Flow, FlowCondition, FlowConfig, FlowData, FlowEdge, FlowEvent, FlowEventFlowCancel, FlowEventFlowEnd, FlowEventFlowError, FlowEventFlowPause, FlowEventFlowStart, FlowEventJobEnd, FlowEventJobStart, FlowEventNodeEnd, FlowEventNodeError, FlowEventNodePause, FlowEventNodeResponse, FlowEventNodeResume, FlowEventNodeStart, FlowExecutionResult, FlowInputMap, FlowJob, FlowJobStatus, FlowJobTask, FlowJobTaskStatus, FlowNode, FlowNodeData, FlowOutputMap, FlowPluginRequirements, FlowProvider, FlowProviderShape, FlowRequirements, FlowServer, FlowServerLayer, FlowServerOptions, FlowServerShape, FlowWaitUntil, GrayscaleTransform, IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, ImageAiContext, ImageAiPlugin, ImageAiPluginLayer, ImageAiPluginShape, ImageDescriptionOutput, ImagePlugin, ImagePluginLayer, ImagePluginShape, InputData, InputNodeParams, InputTypeDefinition, InputTypeRegistry, InputValidationResult, LogoTransform, MergePdfParams, NarrowedTypedOutput, NodeConnectionValidator, NodeDefinition, NodeDefinitionsRecord, NodeExecutionResult, NodeType, NodeTypeMap, OCR_OUTPUT_TYPE_ID, OcrOutput, OcrParams, OcrResolution, OcrResult, OcrTaskType, OptimizeParams, OutputTypeDefinition, OutputTypeRegistry, OutputValidationResult, OverlayPosition, ParallelScheduler, ParallelSchedulerConfig, Plugin, PluginLayer, RemoveBackgroundParams, ResizeParams, ResizeTransform, ResizeVideoParams, ResolveEffect, ResolvedUploadMetadata, RotateTransform, RunArgs, STORAGE_OUTPUT_TYPE_ID, STREAMING_INPUT_TYPE_ID, ScanMetadata, ScanResult, SepiaTransform, SharpenTransform, SplitPdfParams, SplitPdfResult, TextTransform, TranscodeVideoParams, TransformImageParams, TransformNodeConfig, Transformation, TransformationType, TrimVideoParams, TypeCompatibilityChecker, TypedFlow, TypedFlowConfig, TypedFlowEdge, TypedOutput, VideoPlugin, VideoPluginLayer, VideoPluginShape, VirusScanPlugin, VirusScanPluginLayer, VirusScanPluginShape, WaitUntilCallback, WatermarkTransform, ZipInput, ZipParams, ZipPlugin, ZipPluginLayer, ZipPluginShape, blurTransformSchema, brightnessTransformSchema, completeNodeExecution, contrastTransformSchema, createFlow, createFlowEdge, createFlowNode, createFlowServer, createFlowWithSchema, createInputNode, createTransformNode, createTypeGuard, describeImageParamsSchema, describeVideoMetadataSchema, extractFrameVideoParamsSchema, filterOutputsByType, flipTransformSchema, flowServer, getFirstOutputByType, getFlowData, getNodeData, getOutputByNodeId, getSingleOutputByType, grayscaleTransformSchema, hasOutputOfType, imageDescriptionOutputSchema, inputDataSchema, inputNodeParamsSchema, inputTypeRegistry, isFinalizeOperation, isImageDescriptionOutput, isInitOperation, isOcrOutput, isStorageOutput, isUploadFile, isUploadOperation, isUrlOperation, logoTransformSchema, ocrOutputSchema, optimizeParamsSchema, outputTypeRegistry, removeBackgroundParamsSchema, resizeParamsSchema, resizeTransformSchema, resizeVideoParamsSchema, resolveUploadMetadata, rotateTransformSchema, runArgsSchema, sepiaTransformSchema, sharpenTransformSchema, textTransformSchema, transcodeVideoParamsSchema, transformImageParamsSchema, transformationSchema, trimVideoParamsSchema, validateFlowInput, validateFlowOutput, waitingNodeExecution, watermarkTransformSchema };
|
|
6
|
+
export { AVAILABLE_TEMPLATE_VARIABLES, AutoNamingSuffixGenerator, BlurTransform, BrightnessTransform, BuiltInTypedOutput, ConditionField, ConditionOperator, ConditionValue, ContrastTransform, CredentialProvider, CredentialProviderLayer, CredentialProviderShape, CustomTypedOutput, DescribeImageParams, DescribeVideoMetadata, DocumentAiContext, DocumentAiPlugin, DocumentAiPluginLayer, DocumentAiPluginShape, DocumentMetadata, DocumentPlugin, DocumentPluginLayer, DocumentPluginShape, EventType, ExecutionLevel, ExtractEffectError, ExtractEffectRequirements, ExtractFrameVideoParams, ExtractLayerService, ExtractLayerServices, FileNamingConfig, FileNamingFunction, FlipTransform, Flow, FlowCondition, FlowConfig, FlowData, FlowEdge, FlowEvent, FlowEventFlowCancel, FlowEventFlowEnd, FlowEventFlowError, FlowEventFlowPause, FlowEventFlowStart, FlowEventJobEnd, FlowEventJobStart, FlowEventNodeEnd, FlowEventNodeError, FlowEventNodePause, FlowEventNodeResponse, FlowEventNodeResume, FlowEventNodeStart, FlowExecutionResult, FlowInputMap, FlowJob, FlowJobStatus, FlowJobTask, FlowJobTaskStatus, FlowNode, FlowNodeData, FlowOutputMap, FlowPluginRequirements, FlowProvider, FlowProviderShape, FlowRequirements, FlowServer, FlowServerLayer, FlowServerOptions, FlowServerShape, FlowWaitUntil, GrayscaleTransform, IMAGE_DESCRIPTION_OUTPUT_TYPE_ID, ImageAiContext, ImageAiPlugin, ImageAiPluginLayer, ImageAiPluginShape, ImageDescriptionOutput, ImagePlugin, ImagePluginLayer, ImagePluginShape, InputData, InputNodeParams, InputTypeDefinition, InputTypeRegistry, InputValidationResult, LogoTransform, MergePdfParams, NamingContext, NarrowedTypedOutput, NodeConnectionValidator, NodeDefinition, NodeDefinitionsRecord, NodeExecutionResult, NodeType, NodeTypeMap, OCR_OUTPUT_TYPE_ID, OcrOutput, OcrParams, OcrResolution, OcrResult, OcrTaskType, OptimizeParams, OutputTypeDefinition, OutputTypeRegistry, OutputValidationResult, OverlayPosition, ParallelScheduler, ParallelSchedulerConfig, Plugin, PluginLayer, RemoveBackgroundParams, ResizeParams, ResizeTransform, ResizeVideoParams, ResolveEffect, ResolvedUploadMetadata, RotateTransform, RunArgs, STORAGE_OUTPUT_TYPE_ID, STREAMING_INPUT_TYPE_ID, ScanMetadata, ScanResult, SepiaTransform, SharpenTransform, SplitPdfParams, SplitPdfResult, TextTransform, TranscodeVideoParams, TransformImageParams, TransformNodeConfig, Transformation, TransformationType, TrimVideoParams, TypeCompatibilityChecker, TypedFlow, TypedFlowConfig, TypedFlowEdge, TypedOutput, VideoPlugin, VideoPluginLayer, VideoPluginShape, VirusScanPlugin, VirusScanPluginLayer, VirusScanPluginShape, WaitUntilCallback, WatermarkTransform, ZipInput, ZipParams, ZipPlugin, ZipPluginLayer, ZipPluginShape, applyFileNaming, blurTransformSchema, brightnessTransformSchema, buildNamingContext, completeNodeExecution, contrastTransformSchema, createFlow, createFlowEdge, createFlowNode, createFlowServer, createFlowWithSchema, createInputNode, createTransformNode, createTypeGuard, describeImageParamsSchema, describeVideoMetadataSchema, extractFrameVideoParamsSchema, filterOutputsByType, flipTransformSchema, flowServer, getBaseName, getExtension, getFirstOutputByType, getFlowData, getNodeData, getOutputByNodeId, getSingleOutputByType, grayscaleTransformSchema, hasOutputOfType, imageDescriptionOutputSchema, inputDataSchema, inputNodeParamsSchema, inputTypeRegistry, interpolateFileName, isFinalizeOperation, isImageDescriptionOutput, isInitOperation, isOcrOutput, isStorageOutput, isUploadFile, isUploadOperation, isUrlOperation, logoTransformSchema, ocrOutputSchema, optimizeParamsSchema, outputTypeRegistry, removeBackgroundParamsSchema, resizeParamsSchema, resizeTransformSchema, resizeVideoParamsSchema, resolveUploadMetadata, rotateTransformSchema, runArgsSchema, sepiaTransformSchema, sharpenTransformSchema, textTransformSchema, transcodeVideoParamsSchema, transformImageParamsSchema, transformationSchema, trimVideoParamsSchema, validateFlowInput, validateFlowOutput, validatePattern, waitingNodeExecution, watermarkTransformSchema };
|
package/dist/flow/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import"../uploadista-error-B-kFH_SE.mjs";import"../errors-CtPUOWNd.mjs";import{$ as e,A as t,
|
|
1
|
+
import"../uploadista-error-B-kFH_SE.mjs";import"../errors-CtPUOWNd.mjs";import{$ as e,A as t,At as n,B as r,C as i,Ct as a,D as o,Dt as s,E as c,Et as l,F as u,G as d,H as f,I as p,J as m,K as h,L as g,M as _,Mt as v,N as y,O as b,Ot as x,P as S,Q as C,R as w,S as T,St as E,T as D,Tt as O,U as k,V as A,W as j,X as M,Y as N,Z as P,_ as F,_t as I,a as L,at as R,b as z,bt as B,c as V,ct as H,d as U,dt as W,et as G,f as K,ft as q,g as J,gt as Y,h as X,ht as Z,i as Q,it as $,j as ee,jt as te,k as ne,kt as re,l as ie,lt as ae,m as oe,mt as se,n as ce,nt as le,o as ue,ot as de,p as fe,pt as pe,q as me,r as he,rt as ge,s as _e,st as ve,t as ye,tt as be,u as xe,ut as Se,v as Ce,vt as we,w as Te,wt as Ee,x as De,xt as Oe,y as ke,yt as Ae,z as je}from"../flow-NBmCjMqI.mjs";import"../types-CnhCQFkg.mjs";import"../upload-DPX3jSQH.mjs";import"../checksum-DsSiXsPO.mjs";import"../stream-limiter-ByVdSC5T.mjs";export{u as AVAILABLE_TEMPLATE_VARIABLES,y as CredentialProvider,_ as DocumentAiPlugin,ee as DocumentPlugin,te as EventType,f as FlowProvider,k as FlowServer,j as FlowWaitUntil,Se as IMAGE_DESCRIPTION_OUTPUT_TYPE_ID,t as ImageAiPlugin,ne as ImagePlugin,x as InputTypeRegistry,E as NodeType,W as OCR_OUTPUT_TYPE_ID,O as OutputTypeRegistry,ae as ParallelScheduler,q as STORAGE_OUTPUT_TYPE_ID,pe as STREAMING_INPUT_TYPE_ID,L as VideoPlugin,Q as VirusScanPlugin,he as ZipPlugin,p as applyFileNaming,_e as blurTransformSchema,V as brightnessTransformSchema,g as buildNamingContext,B as completeNodeExecution,ie as contrastTransformSchema,ce as createFlow,v as createFlowEdge,a as createFlowNode,d as createFlowServer,me as createFlowWithSchema,Y as createInputNode,S as createTransformNode,N as createTypeGuard,b as describeImageParamsSchema,o as describeVideoMetadataSchema,c as extractFrameVideoParamsSchema,M as filterOutputsByType,xe as flipTransformSchema,h as flowServer,w as getBaseName,je as getExtension,P as getFirstOutputByType,m as getFlowData,Ee as getNodeData,C as getOutputByNodeId,e as getSingleOutputByType,U as grayscaleTransformSchema,G as hasOutputOfType,se as imageDescriptionOutputSchema,I as inputDataSchema,we as inputNodeParamsSchema,re as inputTypeRegistry,r as interpolateFileName,be as isFinalizeOperation,le as isImageDescriptionOutput,ge as isInitOperation,$ as isOcrOutput,R as isStorageOutput,de as isUploadFile,ve as isUploadOperation,H as isUrlOperation,K as logoTransformSchema,Z as ocrOutputSchema,D as optimizeParamsSchema,l as outputTypeRegistry,Te as removeBackgroundParamsSchema,i as resizeParamsSchema,fe as resizeTransformSchema,T as resizeVideoParamsSchema,Ae as resolveUploadMetadata,oe as rotateTransformSchema,ye as runArgsSchema,X as sepiaTransformSchema,J as sharpenTransformSchema,F as textTransformSchema,De as transcodeVideoParamsSchema,Ce as transformImageParamsSchema,ke as transformationSchema,ue as trimVideoParamsSchema,n as validateFlowInput,s as validateFlowOutput,A as validatePattern,Oe as waitingNodeExecution,z as watermarkTransformSchema};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{n as e}from"./uploadista-error-B-kFH_SE.mjs";import{D as t,h as n,s as r,w as i}from"./types-CnhCQFkg.mjs";import{a,n as o,o as s}from"./upload-DPX3jSQH.mjs";import{Context as c,Effect as l,Layer as u,Option as d,Runtime as f,Stream as p}from"effect";import{z as m}from"zod";import{render as h}from"micromustache";function g({source:e,target:t,sourcePort:n,targetPort:r}){return{source:e,target:t,sourcePort:n,targetPort:r}}let _=function(e){return e.JobStart=`job-start`,e.JobEnd=`job-end`,e.FlowStart=`flow-start`,e.FlowEnd=`flow-end`,e.FlowError=`flow-error`,e.FlowPause=`flow-pause`,e.FlowCancel=`flow-cancel`,e.NodeStart=`node-start`,e.NodeEnd=`node-end`,e.NodePause=`node-pause`,e.NodeResume=`node-resume`,e.NodeError=`node-error`,e.NodeStream=`node-stream`,e.NodeResponse=`node-response`,e}({});var v=class{types;constructor(){this.types=new Map}register(t){if(this.types.has(t.id))throw e.fromCode(`VALIDATION_ERROR`,{body:`Input type "${t.id}" is already registered. Types cannot be modified or re-registered.`,details:{typeId:t.id}});this.types.set(t.id,t)}get(e){return this.types.get(e)}list(){return Array.from(this.types.values())}validate(t,n){let r=this.types.get(t);if(!r)return{success:!1,error:e.fromCode(`VALIDATION_ERROR`,{body:`Input type "${t}" is not registered`,details:{typeId:t}})};try{return{success:!0,data:r.schema.parse(n)}}catch(n){return{success:!1,error:e.fromCode(`VALIDATION_ERROR`,{body:`Data validation failed for input type "${t}"`,cause:n,details:{typeId:t,validationErrors:n}})}}}has(e){return this.types.has(e)}size(){return this.types.size}};const y=new v;function b(e,t){return y.validate(e,t)}var x=class{types;constructor(){this.types=new Map}register(t){if(this.types.has(t.id))throw e.fromCode(`VALIDATION_ERROR`,{body:`Output type "${t.id}" is already registered. Types cannot be modified or re-registered.`,details:{typeId:t.id}});this.types.set(t.id,t)}get(e){return this.types.get(e)}list(){return Array.from(this.types.values())}validate(t,n){let r=this.types.get(t);if(!r)return{success:!1,error:e.fromCode(`VALIDATION_ERROR`,{body:`Output type "${t}" is not registered`,details:{typeId:t}})};try{return{success:!0,data:r.schema.parse(n)}}catch(n){return{success:!1,error:e.fromCode(`VALIDATION_ERROR`,{body:`Data validation failed for output type "${t}"`,cause:n,details:{typeId:t,validationErrors:n}})}}}has(e){return this.types.has(e)}size(){return this.types.size}};const S=new x;function C(e,t){return S.validate(e,t)}let w=function(e){return e.input=`input`,e.process=`process`,e.conditional=`conditional`,e.multiplex=`multiplex`,e.merge=`merge`,e}({});function T({id:t,name:n,description:r,type:i,inputSchema:a,outputSchema:o,run:s,condition:c,multiInput:u=!1,multiOutput:d=!1,pausable:f=!1,retry:p,inputTypeId:m,outputTypeId:h,keepOutput:g=!1}){return l.gen(function*(){return m&&!y.get(m)?yield*e.fromCode(`INVALID_INPUT_TYPE`,{body:`Input type "${m}" is not registered in inputTypeRegistry`,details:{inputTypeId:m,nodeId:t}}).toEffect():h&&!S.get(h)?yield*e.fromCode(`INVALID_OUTPUT_TYPE`,{body:`Output type "${h}" is not registered in outputTypeRegistry`,details:{outputTypeId:h,nodeId:t}}).toEffect():{id:t,name:n,description:r,type:i,inputTypeId:m,outputTypeId:h,keepOutput:g,inputSchema:a,outputSchema:o,pausable:f,run:({data:r,jobId:i,flowId:c,storageId:u,clientId:d})=>l.gen(function*(){let f=yield*s({data:yield*l.try({try:()=>a.parse(r),catch:r=>{let i=r instanceof Error?r.message:String(r);return e.fromCode(`FLOW_INPUT_VALIDATION_ERROR`,{body:`Node '${n}' (${t}) input validation failed: ${i}`,cause:r})}}),jobId:i,storageId:u,flowId:c,clientId:d});return f.type===`waiting`?{type:`waiting`,partialData:f.partialData,nodeType:h,nodeId:t}:{type:`complete`,data:yield*l.try({try:()=>o.parse(f.data),catch:r=>{let i=r instanceof Error?r.message:String(r);return e.fromCode(`FLOW_OUTPUT_VALIDATION_ERROR`,{body:`Node '${n}' (${t}) output validation failed: ${i}`,cause:r})}}),nodeType:h,nodeId:t}}),condition:c,multiInput:u,multiOutput:d,retry:p}})}const E=e=>({id:e.id,name:e.name,description:e.description,type:e.type,inputTypeId:e.inputTypeId,outputTypeId:e.outputTypeId}),D=e=>({type:`complete`,data:e}),O=e=>({type:`waiting`,partialData:e}),k=(e,t)=>{if(e===t)return!0;try{return!!(e&&t&&typeof e==`object`&&typeof t==`object`)}catch{return!0}};var A=class{typeChecker;constructor(e=k){this.typeChecker=e}validateConnection(e,t,n){return this.getCompatibleTypes(e.outputSchema,t.inputSchema)}getCompatibleTypes(e,t){return this.typeChecker(e,t)}validateFlow(e,t){let n=[],r=new Map(e.map(e=>[e.id,e]));for(let e of t){let t=r.get(e.source),i=r.get(e.target);if(!t){n.push(`Source node ${e.source} not found`);continue}if(!i){n.push(`Target node ${e.target} not found`);continue}this.validateConnection(t,i,e)||n.push(`Schema mismatch: ${t.id} output schema incompatible with ${i.id} input schema`)}return{isValid:n.length===0,errors:n}}getExpectedInputSchemas(e,t,n){let r=new Map(t.map(e=>[e.id,e])),i={};for(let t of n)if(t.target===e){let e=r.get(t.source);if(e){let n=t.sourcePort||t.source;i[n]=e.outputSchema}}return i}getActualOutputSchemas(e,t,n){let r=new Map(t.map(e=>[e.id,e])),i={};for(let t of n)if(t.source===e){let e=r.get(t.target);if(e){let n=t.targetPort||t.target;i[n]=e.inputSchema}}return i}validateData(e,t){try{return t.parse(e),{isValid:!0,errors:[]}}catch(e){return e instanceof Error&&`errors`in e?{isValid:!1,errors:e.errors.map(e=>`${e.path.join(`.`)}: ${e.message}`)}:{isValid:!1,errors:[e instanceof Error?e.message:`Validation failed`]}}}};function j(e){if(!e)return{type:``,fileName:``,metadata:void 0,metadataJson:void 0};let t={...e},n=String(t.type||t.mimeType||t[`content-type`]||``);n&&(t.type||=n,t.mimeType||=n);let r=String(t.fileName||t.originalName||t.name||``);return r&&(t.fileName||=r,t.originalName||=r,t.name||=r),{type:n,fileName:r,metadata:t,metadataJson:JSON.stringify(t)}}const ee=m.object({operation:m.literal(`init`),storageId:m.string(),metadata:m.record(m.string(),m.any()).optional()}),te=m.object({operation:m.literal(`finalize`),uploadId:m.string()}),ne=m.object({operation:m.literal(`url`),url:m.string(),storageId:m.string().optional(),metadata:m.record(m.string(),m.any()).optional()}),M=m.union([ee,te,ne]),re=m.object({allowedMimeTypes:m.array(m.string()).optional(),minSize:m.number().positive().optional(),maxSize:m.number().positive().optional()});function N(t,n){return l.gen(function*(){if(n){if(n.allowedMimeTypes&&n.allowedMimeTypes.length>0&&!n.allowedMimeTypes.some(e=>{if(e.endsWith(`/*`)){let n=e.slice(0,-2);return t.type.startsWith(n)}return t.type===e}))throw yield*e.fromCode(`VALIDATION_ERROR`,{cause:Error(`File type "${t.type}" is not allowed. Allowed types: ${n.allowedMimeTypes.join(`, `)}`)}).toEffect();if(n.minSize!==void 0&&t.size<n.minSize)throw yield*e.fromCode(`VALIDATION_ERROR`,{cause:Error(`File size (${t.size} bytes) is below minimum (${n.minSize} bytes)`)}).toEffect();if(n.maxSize!==void 0&&t.size>n.maxSize)throw yield*e.fromCode(`VALIDATION_ERROR`,{cause:Error(`File size (${t.size} bytes) exceeds maximum (${n.maxSize} bytes)`)}).toEffect()}})}function ie(n,r,i){let c=i?.keepOutput??!1;return l.gen(function*(){let i=yield*o;return yield*T({id:n,name:`Input`,description:`Handles file input through multiple methods - streaming upload (init/finalize) or direct URL fetch`,type:w.input,inputSchema:M,outputSchema:t,keepOutput:c,inputTypeId:L,outputTypeId:P,run:({data:t,flowId:o,jobId:c,clientId:u})=>l.gen(function*(){switch(t.operation){case`init`:{let e={storageId:t.storageId,size:t.metadata?.size||0,type:t.metadata?.mimeType||`application/octet-stream`,fileName:t.metadata?.originalName,lastModified:t.metadata?.size?Date.now():void 0,metadata:t.metadata?JSON.stringify(t.metadata):void 0,flow:{flowId:o,nodeId:n,jobId:c}};return O(yield*i.createUpload(e,u))}case`finalize`:{let e=yield*i.getUpload(t.uploadId),{type:n}=j(e.metadata);return yield*N({type:n,size:e.size||0},r),D(e)}case`url`:{let e=yield*s(t.url),l=yield*a(e),d=t.metadata?.mimeType||e.headers.get(`content-type`)||`application/octet-stream`,f=t.metadata?.size||Number(e.headers.get(`content-length`)||0),p=t.metadata?.originalName||t.url.split(`/`).pop()||`file`;yield*N({type:d,size:f},r);let m=new ReadableStream({start(e){e.enqueue(new Uint8Array(l)),e.close()}}),h={storageId:t.storageId||`buffer`,size:f,type:d,fileName:p,lastModified:Date.now(),metadata:t.metadata?JSON.stringify(t.metadata):void 0};return D({...yield*i.upload(h,u,m),flow:{flowId:o,nodeId:n,jobId:c}})}default:throw yield*e.fromCode(`VALIDATION_ERROR`,{cause:Error(`Invalid operation`)}).toEffect()}})})})}const P=`storage-output-v1`,F=`ocr-output-v1`,I=`image-description-output-v1`,L=`streaming-input-v1`,R=m.object({extractedText:m.string(),format:m.enum([`markdown`,`plain`,`structured`]),taskType:m.enum([`convertToMarkdown`,`freeOcr`,`parseFigure`,`locateObject`]),confidence:m.number().min(0).max(1).optional()}),z=m.object({description:m.string(),confidence:m.number().min(0).max(1).optional(),metadata:m.record(m.string(),m.unknown()).optional()});y.register({id:L,schema:M,version:`1.0.0`,description:`Streaming file input with init/finalize/url operations for flexible file ingestion`}),S.register({id:P,schema:t,version:`1.0.0`,description:`Storage output node that saves files to configured storage backend`}),S.register({id:F,schema:R,version:`1.0.0`,description:`OCR output node that extracts structured text from documents using AI`}),S.register({id:I,schema:z,version:`1.0.0`,description:`Image description output node that generates AI-powered descriptions of images`});var B=class{maxConcurrency;constructor(e={}){this.maxConcurrency=e.maxConcurrency??4}groupNodesByExecutionLevel(e,t){let n={},r={};e.forEach(e=>{n[e.id]=[],r[e.id]=0}),t.forEach(e=>{n[e.source]?.push(e.target),r[e.target]=(r[e.target]||0)+1});let i=[],a=new Set,o=0;for(;a.size<e.length;){let e=Object.keys(r).filter(e=>r[e]===0&&!a.has(e));if(e.length===0)throw Error(`Cycle detected in flow graph - cannot execute in parallel`);i.push({level:o++,nodes:e}),e.forEach(e=>{a.add(e),delete r[e],n[e]?.forEach(e=>{r[e]!==void 0&&r[e]--})})}return i}executeNodesInParallel(e){return l.all(e.map(e=>e()),{concurrency:this.maxConcurrency})}canExecuteInParallel(e,t,n){return e.every(e=>(n[e]||[]).every(e=>t.has(e)))}getStats(){return{maxConcurrency:this.maxConcurrency}}};function V(e){return t=>{if(t.nodeType!==e)return!1;let n=S.get(e);return n?n.schema.safeParse(t.data).success:!1}}function H(e){return!e||typeof e!=`object`?!1:t.safeParse(e).success}const ae=V(`storage-output-v1`),oe=V(F),se=V(I);function U(e,t){return e.filter(t)}function ce(t,n){return l.gen(function*(){let r=U(t,n);return r.length===0?yield*e.fromCode(`OUTPUT_NOT_FOUND`,{body:`No output of the specified type was found in the flow results`}).toEffect():r.length>1?yield*e.fromCode(`MULTIPLE_OUTPUTS_FOUND`,{body:`Found ${r.length} outputs of the specified type, expected exactly one`,details:{foundCount:r.length,nodeIds:r.map(e=>e.nodeId)}}).toEffect():r[0]})}function le(e,t){return U(e,t)[0]}function ue(e,t){return e.find(e=>e.nodeId===t)}function de(e,t){return e.some(t)}function fe(e){return e.operation===`init`}function pe(e){return e.operation===`finalize`}function me(e){return e.operation===`url`}function he(e){return e.operation===`init`||e.operation===`url`}const W=e=>({id:e.id,name:e.name,nodes:e.nodes.map(E),edges:e.edges});function G(t){return l.gen(function*(){let n=yield*l.all(t.nodes.map(e=>l.isEffect(e)?e:l.succeed(e))),{flowId:r,name:a,onEvent:o,checkJobStatus:s,edges:c,inputSchema:u,outputSchema:d,typeChecker:f}=t,h=n,g=new A(f),v=()=>{let e={},t={},n={};return h.forEach(r=>{e[r.id]=[],n[r.id]=[],t[r.id]=0}),c.forEach(r=>{e[r.source]?.push(r.target),n[r.target]?.push(r.source),t[r.target]=(t[r.target]||0)+1}),{graph:e,reverseGraph:n,inDegree:t}},y=()=>{let{graph:e,inDegree:t}=v(),n=[],r=[];for(Object.keys(t).forEach(e=>{t[e]===0&&n.push(e)});n.length>0;){let i=n.shift();if(!i)throw Error(`No current node found`);r.push(i),e[i]?.forEach(e=>{t[e]=(t[e]||0)-1,t[e]===0&&n.push(e)})}return r},b=(e,t)=>{if(!e.condition)return l.succeed(!0);let{field:n,operator:r,value:i}=e.condition,a=t,o=a?.metadata?.[n]||a?.[n],s=(()=>{switch(r){case`equals`:return o===i;case`notEquals`:return o!==i;case`greaterThan`:return Number(o)>Number(i);case`lessThan`:return Number(o)<Number(i);case`contains`:return String(o).includes(String(i));case`startsWith`:return String(o).startsWith(String(i));default:return!0}})();return l.succeed(s)},x=(e,t)=>{let{reverseGraph:n}=v(),r=n[e]||[],i={};return r.forEach(e=>{let n=t.get(e);n!==void 0&&(i[e]=n)}),i},S=e=>{let t=h.filter(e=>e.type===`input`),n={};return t.forEach(t=>{e&&typeof e==`object`&&t.id in e&&(n[t.id]=u.parse(e[t.id]))}),n},C=e=>!c.some(t=>t.source===e),w=e=>{let t=h.find(t=>t.id===e);return C(e)||t?.keepOutput===!0},T=e=>{let t=h.filter(e=>w(e.id)),n={};return t.forEach(t=>{let r=e.get(t.id);r!==void 0&&(n[t.id]=r)}),n},E=(e,t)=>{let n=h.filter(e=>w(e.id)),r=[];return n.forEach(n=>{let i=e.get(n.id);if(i!==void 0){let e=t.get(n.id);r.push({nodeId:n.id,nodeType:e,data:i,timestamp:new Date().toISOString()})}}),r},D=(e,t,n)=>l.gen(function*(){if(e.storage.id===t)return e;let r=yield*i,a=yield*r.getDataStore(e.storage.id,n),o=yield*r.getDataStore(t,n),s=yield*a.read(e.id),c=p.make(s),l={...e,storage:{id:t,type:e.storage.type}},u=yield*o.create(l);return yield*o.write({file_id:u.id,stream:c,offset:0},{}),u}),O=(n,i,a,c,u,d,f)=>l.gen(function*(){let p=u.get(n);if(!p)return yield*e.fromCode(`FLOW_NODE_NOT_FOUND`).toEffect();if(s){let t=yield*s(d);if(t===`paused`)return yield*e.fromCode(`FLOW_PAUSED`,{cause:`Flow ${r} was paused by user at job ${d}`}).toEffect();if(t===`cancelled`)return yield*e.fromCode(`FLOW_CANCELLED`,{cause:`Flow ${r} was cancelled by user at job ${d}`}).toEffect()}o&&(yield*o({jobId:d,flowId:r,nodeId:n,eventType:_.NodeStart,nodeName:p.name,nodeType:p.type}));let m=p.retry?.maxRetries??0,h=p.retry?.retryDelay??1e3,g=p.retry?.exponentialBackoff??!0,v=0,y=null;for(;v<=m;)try{let s,u={};if(p.type===`input`){if(s=a[n],s===void 0)return yield*l.logError(`Input node ${n} has no input data`),yield*e.fromCode(`FLOW_NODE_ERROR`,{cause:Error(`Input node ${n} has no input data`)}).toEffect()}else{if(u=x(n,c),Object.keys(u).length===0)return yield*l.logError(`Node ${n} has no input data`),yield*e.fromCode(`FLOW_NODE_ERROR`,{cause:Error(`Node ${n} has no input data`)}).toEffect();if(p.multiInput)s=u;else{let t=Object.keys(u)[0];if(!t)return yield*e.fromCode(`FLOW_NODE_ERROR`,{cause:Error(`Node ${n} has no input data`)}).toEffect();s=u[t]}}if(p.type===`conditional`&&!(yield*b(p,s)))return o&&(yield*o({jobId:d,flowId:r,nodeId:n,eventType:_.NodeEnd,nodeName:p.name})),{nodeId:n,result:s,success:!0,waiting:!1};let m=yield*p.run({data:s,inputs:u,jobId:d,flowId:r,storageId:i,clientId:f});if(m.type===`waiting`){let e=m.partialData;return o&&(yield*o({jobId:d,flowId:r,nodeId:n,eventType:_.NodePause,nodeName:p.name,partialData:e})),{nodeId:n,result:e,success:!0,waiting:!0,nodeType:m.nodeType}}let h=m.data;if(w(n)&&(H(h)&&h.storage.id!==i&&(yield*l.logDebug(`Auto-persisting output node ${n} output from ${h.storage.id} to ${i}`),h=yield*D(h,i,f)),t.hooks?.onNodeOutput)){yield*l.logDebug(`Calling onNodeOutput hook for sink node ${n}`);let e=t.hooks.onNodeOutput({output:h,nodeId:n,flowId:r,jobId:d,storageId:i,clientId:f});h=yield*l.isEffect(e)?e:l.promise(()=>e)}return o&&(yield*o({jobId:d,flowId:r,nodeId:n,eventType:_.NodeEnd,nodeName:p.name,result:h})),{nodeId:n,result:h,success:!0,waiting:!1,nodeType:m.nodeType}}catch(t){if(y=t instanceof e?t:e.fromCode(`FLOW_NODE_ERROR`,{cause:t}),v<m){v++;let e=g?h*2**(v-1):h;yield*l.logWarning(`Node ${n} (${p.name}) failed, retrying (${v}/${m}) after ${e}ms`),yield*l.sleep(e);continue}return o&&(yield*o({jobId:d,flowId:r,nodeId:n,eventType:_.NodeError,nodeName:p.name,error:y.body,retryCount:v})),yield*y.toEffect()}return y?yield*y.toEffect():yield*e.fromCode(`FLOW_NODE_ERROR`,{cause:Error(`Unexpected error in retry loop`)}).toEffect()}),k=({inputs:n,storageId:i,jobId:a,resumeFrom:s,clientId:u})=>l.gen(function*(){!s&&o&&(yield*o({jobId:a,eventType:_.FlowStart,flowId:r}));let f=S(n||{}),p,g,v;s?(p=s.executionOrder,g=s.nodeResults,v=s.currentIndex):(p=y(),g=new Map,v=0);let b=new Map;if(p.length!==h.length)return yield*e.fromCode(`FLOW_CYCLE_ERROR`).toEffect();let x=new Map(h.map(e=>[e.id,e]));if(t.parallelExecution?.enabled??!1){yield*l.logDebug(`Flow ${r}: Executing in parallel mode (maxConcurrency: ${t.parallelExecution?.maxConcurrency??4})`);let e=new B({maxConcurrency:t.parallelExecution?.maxConcurrency??4}),n=e.groupNodesByExecutionLevel(h,c);yield*l.logDebug(`Flow ${r}: Grouped nodes into ${n.length} execution levels`);let d={};h.forEach(e=>{d[e.id]=[]}),c.forEach(e=>{d[e.target]?.push(e.source)});for(let t of n){yield*l.logDebug(`Flow ${r}: Executing level ${t.level} with nodes: ${t.nodes.join(`, `)}`);let n=t.nodes.map(e=>()=>l.gen(function*(){if(s&&e===s.executionOrder[v]&&o){let t=x.get(e);t&&(yield*o({jobId:a,flowId:r,nodeId:e,eventType:_.NodeResume,nodeName:t.name,nodeType:t.type}))}return{nodeId:e,nodeResult:yield*O(e,i,f,g,x,a,u)}})),c=yield*e.executeNodesInParallel(n);for(let{nodeId:e,nodeResult:t}of c){if(t.waiting)return t.result!==void 0&&(g.set(e,t.result),t.nodeType&&b.set(e,t.nodeType)),{type:`paused`,nodeId:e,executionState:{executionOrder:p,currentIndex:p.indexOf(e),inputs:f}};t.success&&(g.set(e,t.result),t.nodeType&&b.set(e,t.nodeType))}}}else{yield*l.logDebug(`Flow ${r}: Executing in sequential mode`);for(let t=v;t<p.length;t++){let n=p[t];if(!n)return yield*e.fromCode(`FLOW_NODE_NOT_FOUND`).toEffect();if(s&&t===v&&o){let e=x.get(n);e&&(yield*o({jobId:a,flowId:r,nodeId:n,eventType:_.NodeResume,nodeName:e.name,nodeType:e.type}))}let c=yield*O(n,i,f,g,x,a,u);if(c.waiting)return c.result!==void 0&&(g.set(c.nodeId,c.result),c.nodeType&&b.set(c.nodeId,c.nodeType)),{type:`paused`,nodeId:c.nodeId,executionState:{executionOrder:p,currentIndex:t,inputs:f}};c.success&&(g.set(c.nodeId,c.result),c.nodeType&&b.set(c.nodeId,c.nodeType))}}let C=T(g),D=E(g,b),k=m.record(m.string(),d).safeParse(C);if(!k.success){let t=`Flow output validation failed: ${k.error.message}. Expected outputs: ${JSON.stringify(Object.keys(T(g)))}. Output nodes (sinks + keepOutput): ${h.filter(e=>w(e.id)).map(e=>e.id).join(`, `)}`;return o&&(yield*o({jobId:a,eventType:_.FlowError,flowId:r,error:t})),yield*e.fromCode(`FLOW_OUTPUT_VALIDATION_ERROR`,{body:t,cause:k.error}).toEffect()}let A=k.data;return o&&(yield*o({jobId:a,eventType:_.FlowEnd,flowId:r,outputs:D,result:A})),{type:`completed`,result:A,outputs:D}});return{id:r,name:a,nodes:h,edges:c,inputSchema:u,outputSchema:d,onEvent:o,checkJobStatus:s,hooks:t.hooks,run:({inputs:e,storageId:t,jobId:n,clientId:r})=>k({inputs:e,storageId:t,jobId:n,clientId:r}),resume:({jobId:e,storageId:t,nodeResults:n,executionState:r,clientId:i})=>k({inputs:r.inputs,storageId:t,jobId:e,resumeFrom:{executionOrder:r.executionOrder,nodeResults:new Map(Object.entries(n)),currentIndex:r.currentIndex},clientId:i}),validateTypes:()=>{let e=h;return g.validateFlow(e,c)},validateInputs:e=>g.validateData(e,u),validateOutputs:e=>g.validateData(e,d)}})}var K=class e extends c.Tag(`FlowWaitUntil`)(){static optional=l.serviceOption(e)},q=class extends c.Tag(`FlowProvider`)(){},J=class extends c.Tag(`FlowServer`)(){};const Y=e=>typeof e==`object`&&!!e&&`id`in e,ge=e=>typeof e==`object`&&e&&`nodeId`in e&&`data`in e&&`timestamp`in e?e.data:e;function X(t,n,r){let i=e=>{let i=t=>l.gen(function*(){let n=yield*r.get(e);n&&(yield*r.set(e,{...n,...t,updatedAt:new Date}))});return a=>l.gen(function*(){switch(t.onEvent&&(yield*l.catchAll(t.onEvent(a),e=>(l.logError(`Original onEvent failed`,e),l.succeed({eventId:null})))),yield*n.emit(e,a),l.logInfo(`Updating job ${e} with event ${a.eventType}`),a.eventType){case _.FlowStart:yield*i({status:`running`});break;case _.FlowEnd:yield*l.gen(function*(){let t=yield*r.get(e);t&&a.outputs&&(yield*r.set(e,{...t,result:a.outputs,updatedAt:new Date}))});break;case _.FlowError:yield*i({status:`failed`,error:a.error});break;case _.NodeStart:yield*l.gen(function*(){let t=yield*r.get(e);if(t){let n=t.tasks.find(e=>e.nodeId===a.nodeId)?t.tasks.map(e=>e.nodeId===a.nodeId?{...e,status:`running`,updatedAt:new Date}:e):[...t.tasks,{nodeId:a.nodeId,status:`running`,createdAt:new Date,updatedAt:new Date}];yield*r.set(e,{...t,tasks:n,updatedAt:new Date})}});break;case _.NodePause:yield*l.gen(function*(){let t=yield*r.get(e);if(t){let n=t.tasks.find(e=>e.nodeId===a.nodeId)?t.tasks.map(e=>e.nodeId===a.nodeId?{...e,status:`paused`,result:a.partialData,updatedAt:new Date}:e):[...t.tasks,{nodeId:a.nodeId,status:`paused`,result:a.partialData,createdAt:new Date,updatedAt:new Date}];yield*r.set(e,{...t,tasks:n,updatedAt:new Date})}});break;case _.NodeResume:yield*l.gen(function*(){let t=yield*r.get(e);if(t){let n=t.tasks.map(e=>e.nodeId===a.nodeId?{...e,status:`running`,updatedAt:new Date}:e);yield*r.set(e,{...t,tasks:n,updatedAt:new Date})}});break;case _.NodeEnd:yield*l.gen(function*(){let n=yield*r.get(e);if(n){let i=n.tasks.map(e=>e.nodeId===a.nodeId?{...e,status:`completed`,result:a.result,updatedAt:new Date}:e),o=!t.edges.some(e=>e.source===a.nodeId),s=t.nodes.find(e=>e.id===a.nodeId)?.keepOutput===!0,c=a.result,u=ge(c),d=n.intermediateFiles||[],f=o||s;f&&Y(u)&&u.id?(d=d.filter(e=>e!==u.id),s&&!o&&l.logInfo(`Preserving output from node ${a.nodeId} due to keepOutput flag`)):!f&&Y(u)&&u.id&&(d.includes(u.id)||d.push(u.id)),yield*r.set(e,{...n,tasks:i,intermediateFiles:d,updatedAt:new Date})}});break;case _.NodeError:yield*l.gen(function*(){let t=yield*r.get(e);if(t){let n=t.tasks.map(e=>e.nodeId===a.nodeId?{...e,status:`failed`,error:a.error,retryCount:a.retryCount,updatedAt:new Date}:e);yield*r.set(e,{...t,tasks:n,error:a.error,updatedAt:new Date})}});break}return{eventId:e}})},a=t=>t=>l.gen(function*(){let n=yield*r.get(t);return n?n.status===`paused`?`paused`:n.status===`cancelled`?`cancelled`:`running`:yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found`}))});return{...t,run:e=>l.gen(function*(){let n=e.jobId||crypto.randomUUID(),r=i(n),o=a(n);return yield*(yield*G({flowId:t.id,name:t.name,nodes:t.nodes,edges:t.edges,inputSchema:t.inputSchema,outputSchema:t.outputSchema,onEvent:r,checkJobStatus:o})).run({...e,jobId:n,clientId:e.clientId})}),resume:e=>l.gen(function*(){let n=e.jobId,r=i(n),o=a(n);return yield*(yield*G({flowId:t.id,name:t.name,nodes:t.nodes,edges:t.edges,inputSchema:t.inputSchema,outputSchema:t.outputSchema,onEvent:r,checkJobStatus:o})).resume(e)})}}function Z(){return l.gen(function*(){let t=yield*q,i=yield*n,a=yield*r,s=yield*o,c=(t,n)=>l.gen(function*(){let r=yield*a.get(t);return r?yield*a.set(t,{...r,...n}):yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found`}))}),u=(e,t)=>l.gen(function*(){let n=yield*a.get(e);!n||!n.intermediateFiles||n.intermediateFiles.length===0||(yield*l.logInfo(`Cleaning up ${n.intermediateFiles.length} intermediate files for job ${e}`),yield*l.all(n.intermediateFiles.map(e=>l.gen(function*(){yield*s.delete(e,t),yield*l.logDebug(`Deleted intermediate file ${e}`)}).pipe(l.catchAll(t=>l.gen(function*(){return yield*l.logWarning(`Failed to delete intermediate file ${e}: ${t}`),l.succeed(void 0)})))),{concurrency:5}),yield*c(e,{intermediateFiles:[]}))}),p=({jobId:t,flow:n,storageId:r,clientId:o,inputs:s})=>l.gen(function*(){console.log(`[FlowServer] executeFlowInBackground started for job: ${t}`),yield*c(t,{status:`running`}),console.log(`[FlowServer] Creating flowWithEvents for job: ${t}`);let e=X(n,i,a);console.log(`[FlowServer] Running flow for job: ${t}`);let l=yield*e.run({inputs:s,storageId:r,jobId:t,clientId:o});return console.log(`[FlowServer] Flow completed for job: ${t}, result type: ${l.type}`),l.type===`paused`?yield*c(t,{status:`paused`,pausedAt:l.nodeId,executionState:l.executionState,updatedAt:new Date}):(yield*c(t,{status:`completed`,updatedAt:new Date,endedAt:new Date}),yield*u(t,o)),l}).pipe(l.catchAll(n=>l.gen(function*(){yield*l.logError(`Flow execution failed`,n);let r=n instanceof e?n.body:String(n);yield*l.logInfo(`Updating job ${t} to failed status with error: ${r}`),yield*c(t,{status:`failed`,error:r,updatedAt:new Date}).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logError(`Failed to update job ${t}`,e),l.succeed(void 0)})));let s=yield*a.get(t);throw s&&(yield*i.emit(t,{jobId:t,eventType:_.FlowError,flowId:s.flowId,error:r}).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logError(`Failed to emit FlowError event for job ${t}`,e),l.succeed(void 0)})))),yield*u(t,o).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logWarning(`Failed to cleanup intermediate files for job ${t}`,e),l.succeed(void 0)}))),n})));return{getFlow:(e,n)=>l.gen(function*(){return yield*t.getFlow(e,n)}),getFlowData:(e,n)=>l.gen(function*(){return W(yield*t.getFlow(e,n))}),runFlow:({flowId:n,storageId:r,clientId:i,inputs:o})=>l.gen(function*(){let s=yield*K.optional,c=yield*l.try({try:()=>rt.parse({inputs:o}),catch:t=>e.fromCode(`FLOW_INPUT_VALIDATION_ERROR`,{cause:t})}),u=crypto.randomUUID(),m=new Date,h={id:u,flowId:n,storageId:r,clientId:i,status:`started`,createdAt:m,updatedAt:m,tasks:[]};yield*a.set(u,h);let g=yield*t.getFlow(n,i);console.log(`[FlowServer] About to fork flow execution for job: ${u}`);let _=p({jobId:u,flow:g,storageId:r,clientId:i,inputs:c.inputs}).pipe(l.tapErrorCause(e=>l.logError(`Flow execution failed`,e)));if(d.isSome(s)){console.log(`[FlowServer] Using waitUntil for job: ${u}`);let e=yield*l.runtime(),t=f.runPromise(e)(_);s.value(t)}else console.log(`[FlowServer] Using Effect.forkDaemon for job: ${u}`),yield*l.forkDaemon(_);return console.log(`[FlowServer] Flow execution started for job: ${u}`),h}),getJobStatus:t=>l.gen(function*(){return(yield*a.get(t))||(yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found`})))}),resumeFlow:({jobId:n,nodeId:r,newData:o,clientId:s})=>l.gen(function*(){let p=yield*K.optional,m=yield*a.get(n);if(!m)return console.error(`Job not found`),yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${n} not found`}));if(m.status!==`paused`)return console.error(`Job is not paused`),yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${n} is not paused (status: ${m.status})`}));if(m.pausedAt!==r)return console.error(`Job is not paused at the expected node`),yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${n} is paused at node ${m.pausedAt}, not ${r}`}));if(!m.executionState)return console.error(`Job has no execution state`),yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${n} has no execution state`}));let h={...m.tasks.reduce((e,t)=>(t.result!==void 0&&(e[t.nodeId]=t.result),e),{}),[r]:o},g={...m.executionState.inputs,[r]:o};yield*c(n,{status:`running`});let v=yield*t.getFlow(m.flowId,m.clientId),y=l.gen(function*(){let t=X(v,i,a);if(!m.executionState)return yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${n} has no execution state`}));let r=yield*t.resume({jobId:n,storageId:m.storageId,nodeResults:h,executionState:{...m.executionState,inputs:g},clientId:m.clientId});return r.type===`paused`?yield*c(n,{status:`paused`,pausedAt:r.nodeId,executionState:r.executionState,updatedAt:new Date}):(yield*c(n,{status:`completed`,pausedAt:void 0,executionState:void 0,updatedAt:new Date,endedAt:new Date}),yield*u(n,s)),r}).pipe(l.catchAll(t=>l.gen(function*(){yield*l.logError(`Flow resume failed`,t);let r=t instanceof e?t.body:String(t);yield*l.logInfo(`Updating job ${n} to failed status with error: ${r}`),yield*c(n,{status:`failed`,error:r,updatedAt:new Date}).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logError(`Failed to update job ${n}`,e),l.succeed(void 0)})));let o=yield*a.get(n);throw o&&(yield*i.emit(n,{jobId:n,eventType:_.FlowError,flowId:o.flowId,error:r}).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logError(`Failed to emit FlowError event for job ${n}`,e),l.succeed(void 0)})))),yield*u(n,s).pipe(l.catchAll(e=>l.gen(function*(){return yield*l.logWarning(`Failed to cleanup intermediate files for job ${n}`,e),l.succeed(void 0)}))),t}))).pipe(l.tapErrorCause(e=>l.logError(`Flow resume failed`,e)));if(d.isSome(p)){console.log(`[FlowServer] Using waitUntil for resume job: ${n}`);let e=yield*l.runtime(),t=f.runPromise(e)(y);p.value(t)}else console.log(`[FlowServer] Using Effect.forkDaemon for resume job: ${n}`),yield*l.forkDaemon(y);return(yield*a.get(n))||(yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${n} not found after update`})))}),pauseFlow:(t,n)=>l.gen(function*(){let r=yield*a.get(t);if(!r)return yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found`}));if(n!==null&&r.clientId!==n)return yield*l.fail(e.fromCode(`FLOW_NOT_AUTHORIZED`,{cause:`Client ${n} is not authorized to pause job ${t}`}));if(r.status!==`running`)return yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${t} cannot be paused (current status: ${r.status})`}));let o=r.tasks.find(e=>e.status===`running`)?.nodeId;return yield*c(t,{status:`paused`,pausedAt:o,updatedAt:new Date}),yield*i.emit(t,{jobId:t,flowId:r.flowId,eventType:_.FlowPause,pausedAt:o}),(yield*a.get(t))||(yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found after pause`})))}),cancelFlow:(t,n)=>l.gen(function*(){let r=yield*a.get(t);return r?n!==null&&r.clientId!==n?yield*l.fail(e.fromCode(`FLOW_NOT_AUTHORIZED`,{cause:`Client ${n} is not authorized to cancel job ${t}`})):r.status!==`running`&&r.status!==`paused`&&r.status!==`started`?yield*l.fail(e.fromCode(`FLOW_JOB_ERROR`,{cause:`Job ${t} cannot be cancelled (current status: ${r.status})`})):(yield*c(t,{status:`cancelled`,updatedAt:new Date,endedAt:new Date}),yield*i.emit(t,{jobId:t,flowId:r.flowId,eventType:_.FlowCancel}),yield*u(t,n),(yield*a.get(t))||(yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found after cancellation`})))):yield*l.fail(e.fromCode(`FLOW_JOB_NOT_FOUND`,{cause:`Job ${t} not found`}))}),subscribeToFlowEvents:(e,t)=>l.gen(function*(){yield*i.subscribe(e,t)}),unsubscribeFromFlowEvents:e=>l.gen(function*(){yield*i.unsubscribe(e)})}})}const _e=u.effect(J,Z());function Q(e){let t=e.lastIndexOf(`.`);return t===-1||t===0?e:e.substring(0,t)}function ve(e){let t=e.lastIndexOf(`.`);return t===-1||t===0?``:e.substring(t+1)}function ye(e,t,n){let r=e.metadata??{},i=r.fileName??r.originalName??r.name??`unnamed`;return{baseName:Q(i),extension:ve(i),fileName:i,nodeType:t.nodeType,nodeId:t.nodeId,flowId:t.flowId,jobId:t.jobId,timestamp:new Date().toISOString(),...n}}function be(e,t){try{let n={};for(let[e,r]of Object.entries(t))r!==void 0&&(n[e]=String(r));return h(e,n)}catch{return e}}function xe(e,t,n){let r=t.fileName;if(!n)return r;try{if(n.mode===`auto`){if(n.autoSuffix){let e=n.autoSuffix(t);if(e){let{baseName:n,extension:r}=t;return r?`${n}-${e}.${r}`:`${n}-${e}`}}return r}if(n.mode===`custom`){if(n.rename)return n.rename(e,t)||r;if(n.pattern)return be(n.pattern,t)||r}return r}catch{return r}}function Se(e){if(!e||e.trim()===``)return{isValid:!1,error:`Pattern cannot be empty`};let t=(e.match(/\{\{/g)||[]).length,n=(e.match(/\}\}/g)||[]).length;if(t!==n)return{isValid:!1,error:`Unbalanced braces: ${t} opening, ${n} closing`};let r=e.match(/\{\{[^}]*[^a-zA-Z0-9_}][^}]*\}\}/g);return r?{isValid:!1,error:`Invalid variable syntax: ${r[0]}`}:{isValid:!0}}const Ce=[{name:`baseName`,description:`Filename without extension`,example:`photo`},{name:`extension`,description:`File extension without dot`,example:`jpg`},{name:`fileName`,description:`Full original filename`,example:`photo.jpg`},{name:`nodeType`,description:`Type of processing node`,example:`resize`},{name:`nodeId`,description:`Specific node instance ID`,example:`resize-1`},{name:`flowId`,description:`Flow identifier`,example:`flow-abc`},{name:`jobId`,description:`Execution job ID`,example:`job-123`},{name:`timestamp`,description:`ISO 8601 processing time`,example:`2024-01-15T10:30:00Z`},{name:`width`,description:`Output width (image/video)`,example:`800`},{name:`height`,description:`Output height (image/video)`,example:`600`},{name:`format`,description:`Output format`,example:`webp`},{name:`quality`,description:`Quality setting`,example:`80`},{name:`pageNumber`,description:`Page number (documents)`,example:`1`}];function we({id:e,name:n,description:r,outputTypeId:i,keepOutput:a,naming:s,nodeType:c=`transform`,namingVars:u,transform:d}){return l.gen(function*(){let f=yield*o;return yield*T({id:e,name:n,description:r,type:w.process,outputTypeId:i,keepOutput:a,inputSchema:t,outputSchema:t,run:({data:t,storageId:n,flowId:r,jobId:i,clientId:a})=>l.gen(function*(){let o={flowId:r,nodeId:e,jobId:i},l=yield*d(yield*f.read(t.id,a),t),p=l instanceof Uint8Array?l:l.bytes,m=l instanceof Uint8Array?void 0:l.type,h=l instanceof Uint8Array?void 0:l.fileName;!h&&s&&(h=xe(t,ye(t,{flowId:r,jobId:i,nodeId:e,nodeType:c},u),s));let g=new ReadableStream({start(e){e.enqueue(p),e.close()}}),{type:_,fileName:v,metadata:y,metadataJson:b}=j(t.metadata),x=yield*f.upload({storageId:n,size:p.byteLength,type:m??_,fileName:h??v,lastModified:0,metadata:b,flow:o},a,g),S=y?{...y,...m&&{mimeType:m,type:m,"content-type":m},...h&&{fileName:h,originalName:h,name:h,extension:h.split(`.`).pop()||y.extension}}:x.metadata;return D(S?{...x,metadata:S}:x)})})})}var Te=class extends c.Tag(`CredentialProvider`)(){},Ee=class extends c.Tag(`DocumentAiPlugin`)(){},De=class extends c.Tag(`DocumentPlugin`)(){},Oe=class extends c.Tag(`ImageAiPlugin`)(){},ke=class extends c.Tag(`ImagePlugin`)(){};const Ae=m.object({serviceType:m.enum([`replicate`]).optional()}),je=m.object({duration:m.number().nonnegative(),width:m.number().positive(),height:m.number().positive(),codec:m.string(),format:m.string(),bitrate:m.number().nonnegative(),frameRate:m.number().positive(),aspectRatio:m.string(),hasAudio:m.boolean(),audioCodec:m.string().optional(),audioBitrate:m.number().nonnegative().optional(),size:m.number().nonnegative()}),Me=m.object({timestamp:m.number().nonnegative(),format:m.enum([`png`,`jpeg`]).optional(),quality:m.number().min(1).max(100).optional()}),Ne=m.object({quality:m.number().min(0).max(100),format:m.enum([`jpeg`,`webp`,`png`,`avif`])}),Pe=m.object({serviceType:m.enum([`replicate`]).optional()}),Fe=m.object({width:m.number().positive().optional(),height:m.number().positive().optional(),fit:m.enum([`contain`,`cover`,`fill`])}).refine(e=>e.width||e.height,`Either width or height must be specified for resize`),Ie=m.object({width:m.number().positive().optional(),height:m.number().positive().optional(),aspectRatio:m.enum([`keep`,`ignore`]).optional(),scaling:m.enum([`bicubic`,`bilinear`,`lanczos`]).optional()}).refine(e=>e.width||e.height,`Either width or height must be specified for video resize`),Le=m.object({format:m.enum([`mp4`,`webm`,`mov`,`avi`]),codec:m.enum([`h264`,`h265`,`vp9`,`av1`]).optional(),videoBitrate:m.string().optional(),audioBitrate:m.string().optional(),audioCodec:m.enum([`aac`,`mp3`,`opus`,`vorbis`]).optional()}),Re=m.object({type:m.literal(`resize`),width:m.number().positive().optional(),height:m.number().positive().optional(),fit:m.enum([`contain`,`cover`,`fill`])}),ze=m.object({type:m.literal(`blur`),sigma:m.number().min(.3).max(1e3)}),Be=m.object({type:m.literal(`rotate`),angle:m.number(),background:m.string().optional()}),Ve=m.object({type:m.literal(`flip`),direction:m.enum([`horizontal`,`vertical`])}),He=m.object({type:m.literal(`grayscale`)}),Ue=m.object({type:m.literal(`sepia`)}),We=m.object({type:m.literal(`brightness`),value:m.number().min(-100).max(100)}),$=m.object({type:m.literal(`contrast`),value:m.number().min(-100).max(100)}),Ge=m.object({type:m.literal(`sharpen`),sigma:m.number().positive().optional()}),Ke=m.object({type:m.literal(`watermark`),imagePath:m.string().min(1).url(),position:m.enum([`top-left`,`top-right`,`bottom-left`,`bottom-right`,`center`]),opacity:m.number().min(0).max(1),offsetX:m.number().optional(),offsetY:m.number().optional()}),qe=m.object({type:m.literal(`logo`),imagePath:m.string().min(1).url(),position:m.enum([`top-left`,`top-right`,`bottom-left`,`bottom-right`,`center`]),scale:m.number().min(.1).max(2),offsetX:m.number().optional(),offsetY:m.number().optional()}),Je=m.object({type:m.literal(`text`),text:m.string().min(1),position:m.enum([`top-left`,`top-right`,`bottom-left`,`bottom-right`,`center`]),fontSize:m.number().positive(),color:m.string().min(1),fontFamily:m.string().optional(),offsetX:m.number().optional(),offsetY:m.number().optional()}),Ye=m.discriminatedUnion(`type`,[Re,ze,Be,Ve,He,Ue,We,$,Ge,Ke,qe,Je]),Xe=m.object({transformations:m.array(Ye).min(1)}),Ze=m.object({startTime:m.number().nonnegative(),endTime:m.number().positive().optional(),duration:m.number().positive().optional()}).refine(e=>!e.endTime||!e.duration,`Cannot specify both endTime and duration`).refine(e=>!e.endTime||e.endTime>e.startTime,`endTime must be greater than startTime`);var Qe=class extends c.Tag(`VideoPlugin`)(){},$e=class extends c.Tag(`VirusScanPlugin`)(){},et=class extends c.Tag(`ZipPlugin`)(){};const tt=(e,t)=>{if(e.length===0)return t;let[n,...r]=e;return r.reduce((e,t)=>m.union([e,t]),n)};function nt(t){return l.gen(function*(){let n=Object.entries(t.nodes),r=e=>l.isEffect(e)?e:l.succeed(e),i=yield*l.forEach(n,([t,n])=>l.flatMap(r(n),n=>n.id===t?l.succeed([t,n]):l.fail(e.fromCode(`FLOW_NODE_ERROR`,{cause:Error(`Node key ${t} does not match node id ${n.id}`)})))),a=Object.fromEntries(i),o=i.map(([,e])=>e),s=i.filter(([,e])=>e.type===w.input).map(([,e])=>e.inputSchema),c=t.edges.map(e=>({source:a[e.source]?.id??e.source,target:a[e.target]?.id??e.target,sourcePort:e.sourcePort,targetPort:e.targetPort})),u=new Set(i.map(([e])=>a[e]?.id).filter(e=>e&&!c.some(t=>t.source===e))),d=i.filter(([,e])=>u.has(e.id)).map(([,e])=>e.outputSchema),f=t.inputSchema??tt(s,m.unknown()),p=t.outputSchema??tt(d,m.unknown());return yield*G({flowId:t.flowId,name:t.name,nodes:o,edges:c,inputSchema:f,outputSchema:p,typeChecker:t.typeChecker,onEvent:t.onEvent,parallelExecution:t.parallelExecution,hooks:t.hooks})})}const rt=m.object({inputs:m.record(m.string(),m.any())});export{ce as $,Oe as A,b as At,be as B,Fe as C,T as Ct,je as D,C as Dt,Me as E,S as Et,Ce as F,Z as G,q as H,xe as I,W as J,_e as K,ye as L,Ee as M,g as Mt,Te as N,Ae as O,v as Ot,we as P,ue as Q,Q as R,Ie as S,w as St,Ne as T,x as Tt,J as U,Se as V,K as W,U as X,V as Y,le as Z,Je as _,M as _t,Qe as a,ae as at,Ke as b,D as bt,We as c,me as ct,He as d,F as dt,de as et,qe as f,P as ft,Ge as g,ie as gt,Ue as h,R as ht,$e as i,oe as it,De as j,_ as jt,ke as k,y as kt,$ as l,B as lt,Be as m,z as mt,nt as n,se as nt,Ze as o,H as ot,Re as p,L as pt,G as q,et as r,fe as rt,ze as s,he as st,rt as t,pe as tt,Ve as u,I as ut,Xe as v,re as vt,Pe as w,E as wt,Le as x,O as xt,Ye as y,j as yt,ve as z};
|
|
2
|
+
//# sourceMappingURL=flow-NBmCjMqI.mjs.map
|