footprintjs 0.2.2 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +137 -41
- package/dist/esm/index.js +7 -1
- package/dist/esm/lib/builder/FlowChartBuilder.js +72 -91
- package/dist/esm/lib/builder/types.js +1 -1
- package/dist/esm/lib/contract/defineContract.js +32 -0
- package/dist/esm/lib/contract/index.js +18 -0
- package/dist/esm/lib/contract/openapi.js +120 -0
- package/dist/esm/lib/contract/schema.js +199 -0
- package/dist/esm/lib/contract/types.js +9 -0
- package/dist/esm/lib/engine/graph/StageNode.js +1 -1
- package/dist/esm/lib/engine/handlers/ChildrenExecutor.js +5 -5
- package/dist/esm/lib/engine/handlers/ContinuationResolver.js +6 -6
- package/dist/esm/lib/engine/handlers/DeciderHandler.js +4 -4
- package/dist/esm/lib/engine/handlers/NodeResolver.js +1 -2
- package/dist/esm/lib/engine/handlers/RuntimeStructureManager.js +1 -2
- package/dist/esm/lib/engine/handlers/SelectorHandler.js +6 -6
- package/dist/esm/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
- package/dist/esm/lib/engine/narrative/types.js +1 -1
- package/dist/esm/lib/engine/traversal/FlowchartTraverser.js +10 -11
- package/dist/esm/lib/engine/types.js +1 -1
- package/dist/esm/lib/runner/ExecutionRuntime.js +1 -1
- package/dist/esm/types/index.d.ts +4 -0
- package/dist/esm/types/lib/builder/FlowChartBuilder.d.ts +17 -10
- package/dist/esm/types/lib/builder/types.d.ts +6 -6
- package/dist/esm/types/lib/contract/defineContract.d.ts +18 -0
- package/dist/esm/types/lib/contract/index.d.ts +14 -0
- package/dist/esm/types/lib/contract/openapi.d.ts +12 -0
- package/dist/esm/types/lib/contract/schema.d.ts +14 -0
- package/dist/esm/types/lib/contract/types.d.ts +94 -0
- package/dist/esm/types/lib/engine/graph/StageNode.d.ts +0 -2
- package/dist/esm/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
- package/dist/esm/types/lib/engine/narrative/types.d.ts +6 -6
- package/dist/esm/types/lib/engine/types.d.ts +0 -1
- package/dist/esm/types/lib/runner/ExecutionRuntime.d.ts +0 -1
- package/dist/index.js +12 -2
- package/dist/lib/builder/FlowChartBuilder.js +72 -91
- package/dist/lib/builder/types.js +1 -1
- package/dist/lib/contract/defineContract.js +36 -0
- package/dist/lib/contract/index.js +26 -0
- package/dist/lib/contract/openapi.js +124 -0
- package/dist/lib/contract/schema.js +205 -0
- package/dist/lib/contract/types.js +10 -0
- package/dist/lib/engine/graph/StageNode.js +1 -1
- package/dist/lib/engine/handlers/ChildrenExecutor.js +5 -5
- package/dist/lib/engine/handlers/ContinuationResolver.js +6 -6
- package/dist/lib/engine/handlers/DeciderHandler.js +4 -4
- package/dist/lib/engine/handlers/NodeResolver.js +1 -2
- package/dist/lib/engine/handlers/RuntimeStructureManager.js +1 -2
- package/dist/lib/engine/handlers/SelectorHandler.js +6 -6
- package/dist/lib/engine/narrative/ControlFlowNarrativeGenerator.js +13 -18
- package/dist/lib/engine/narrative/types.js +1 -1
- package/dist/lib/engine/traversal/FlowchartTraverser.js +10 -11
- package/dist/lib/engine/types.js +1 -1
- package/dist/lib/runner/ExecutionRuntime.js +1 -1
- package/dist/types/index.d.ts +4 -0
- package/dist/types/lib/builder/FlowChartBuilder.d.ts +17 -10
- package/dist/types/lib/builder/types.d.ts +6 -6
- package/dist/types/lib/contract/defineContract.d.ts +18 -0
- package/dist/types/lib/contract/index.d.ts +14 -0
- package/dist/types/lib/contract/openapi.d.ts +12 -0
- package/dist/types/lib/contract/schema.d.ts +14 -0
- package/dist/types/lib/contract/types.d.ts +94 -0
- package/dist/types/lib/engine/graph/StageNode.d.ts +0 -2
- package/dist/types/lib/engine/narrative/ControlFlowNarrativeGenerator.d.ts +6 -6
- package/dist/types/lib/engine/narrative/types.d.ts +6 -6
- package/dist/types/lib/engine/types.d.ts +0 -1
- package/dist/types/lib/runner/ExecutionRuntime.d.ts +0 -1
- package/package.json +1 -1
|
@@ -6,4 +6,4 @@
|
|
|
6
6
|
* are defined locally here for the new library.
|
|
7
7
|
*/
|
|
8
8
|
export {};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/builder/types.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Zero deps on old code. Only imports from lib/memory (Phase 1).\n * Types that originated in executor/Pipeline.ts and executor/types.ts\n * are defined locally here for the new library.\n */\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Logger (copied from utils/logger.ts to avoid old-code dep)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection (copied from scope/protection/types.ts)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Stage Function\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Callback for streaming stages to emit tokens incrementally. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n *\n * TOut   – return type produced by the stage\n * TScope – the scope object passed to the stage\n */\nexport type PipelineStageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = PipelineStageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Streaming\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Subflow Mount Options\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// StageNode — the runtime graph node\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type StageNode<TOut = any, TScope = any> = {\n  /** Human-readable stage name; also used as the stageMap key. */\n  name: string;\n  /** Optional stable id (required by decider/fork aggregation). */\n  id?: string;\n  /** Human-readable display name for UI. */\n  displayName?: string;\n  /** Human-readable description of what this stage does. */\n  description?: string;\n\n  // ── Continuations ──\n  /** Linear continuation. */\n  next?: StageNode<TOut, TScope>;\n  /** Parallel children (fork). */\n  children?: StageNode<TOut, TScope>[];\n\n  // ── Deciders & Selectors ──\n  /** When true, fn IS the decider — returns a branch ID string. */\n  deciderFn?: boolean;\n  /** When true, fn IS the selector — returns branch ID(s). */\n  selectorFn?: boolean;\n\n  // ── Stage function ──\n  fn?: PipelineStageFunction<TOut, TScope>;\n\n  // ── Streaming ──\n  isStreaming?: boolean;\n  streamId?: string;\n\n  // ── Subflow ──\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  $ref?: string;\n  mountId?: string;\n  subflowMountOptions?: SubflowMountOptions;\n\n  /** When true, parallel children use fail-fast semantics (reject on first error). */\n  failFast?: boolean;\n\n  /** Inline subflow definition for dynamic subflow attachment. */\n  subflowDef?: {\n    root: StageNode;\n    stageMap?: Map<string, PipelineStageFunction<TOut, TScope>>;\n    buildTimeStructure?: unknown;\n    subflows?: Record<string, { root: StageNode }>;\n  };\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  displayName?: string;\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  displayName?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, PipelineStageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  displayName?: string;\n  fn?: PipelineStageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n  displayName?: string;\n}\n"]}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/builder/types.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG","sourcesContent":["/**\n * builder/types.ts — All types used by the builder library.\n *\n * Zero deps on old code. Only imports from lib/memory (Phase 1).\n * Types that originated in executor/Pipeline.ts and executor/types.ts\n * are defined locally here for the new library.\n */\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Logger (copied from utils/logger.ts to avoid old-code dep)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface ILogger {\n  info(message?: any, ...optionalParams: any[]): void;\n  log(message?: any, ...optionalParams: any[]): void;\n  debug(message?: any, ...optionalParams: any[]): void;\n  error(message?: any, ...optionalParams: any[]): void;\n  warn(message?: any, ...optionalParams: any[]): void;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Scope Protection (copied from scope/protection/types.ts)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ScopeProtectionMode = 'error' | 'warn' | 'off';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Stage Function\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Callback for streaming stages to emit tokens incrementally. */\nexport type StreamCallback = (token: string) => void;\n\n/**\n * The function signature for stage handlers.\n *\n * TOut   – return type produced by the stage\n * TScope – the scope object passed to the stage\n */\nexport type PipelineStageFunction<TOut = any, TScope = any> = (\n  scope: TScope,\n  breakPipeline: () => void,\n  streamCallback?: StreamCallback,\n) => Promise<TOut> | TOut;\n\n/** Relaxed-generic alias for builder ergonomics. */\nexport type StageFn = PipelineStageFunction<any, any>;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Streaming\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type StreamTokenHandler = (streamId: string, token: string) => void;\nexport type StreamLifecycleHandler = (streamId: string, fullText?: string) => void;\n\nexport interface StreamHandlers {\n  onToken?: StreamTokenHandler;\n  onStart?: StreamLifecycleHandler;\n  onEnd?: StreamLifecycleHandler;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Subflow Mount Options\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowMountOptions<TParentScope = any, TSubflowInput = any, TSubflowOutput = any> {\n  inputMapper?: (parentScope: TParentScope) => TSubflowInput;\n  outputMapper?: (subflowOutput: TSubflowOutput, parentScope: TParentScope) => Record<string, unknown>;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// StageNode — the runtime graph node\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type StageNode<TOut = any, TScope = any> = {\n  /** Human-readable stage name; also used as the stageMap key. */\n  name: string;\n  /** Optional stable id (required by decider/fork aggregation). */\n  id?: string;\n  /** Human-readable description of what this stage does. */\n  description?: string;\n\n  // ── Continuations ──\n  /** Linear continuation. */\n  next?: StageNode<TOut, TScope>;\n  /** Parallel children (fork). */\n  children?: StageNode<TOut, TScope>[];\n\n  // ── Deciders & Selectors ──\n  /** When true, fn IS the decider — returns a branch ID string. */\n  deciderFn?: boolean;\n  /** When true, fn IS the selector — returns branch ID(s). */\n  selectorFn?: boolean;\n\n  // ── Stage function ──\n  fn?: PipelineStageFunction<TOut, TScope>;\n\n  // ── Streaming ──\n  isStreaming?: boolean;\n  streamId?: string;\n\n  // ── Subflow ──\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  $ref?: string;\n  mountId?: string;\n  subflowMountOptions?: SubflowMountOptions;\n\n  /** When true, parallel children use fail-fast semantics (reject on first error). */\n  failFast?: boolean;\n\n  /** Inline subflow definition for dynamic subflow attachment. */\n  subflowDef?: {\n    root: StageNode;\n    stageMap?: Map<string, PipelineStageFunction<TOut, TScope>>;\n    buildTimeStructure?: unknown;\n    subflows?: Record<string, { root: StageNode }>;\n  };\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Serialized Pipeline Structure (JSON-safe, for visualization)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SerializedPipelineStructure {\n  name: string;\n  id?: string;\n  type: 'stage' | 'decider' | 'fork' | 'streaming';\n  description?: string;\n  children?: SerializedPipelineStructure[];\n  next?: SerializedPipelineStructure;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n  subflowStructure?: SerializedPipelineStructure;\n  iterationCount?: number;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChartSpec (pure JSON, no functions — for FE→BE transport)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface FlowChartSpec {\n  name: string;\n  id?: string;\n  description?: string;\n  children?: FlowChartSpec[];\n  next?: FlowChartSpec;\n  hasDecider?: boolean;\n  hasSelector?: boolean;\n  branchIds?: string[];\n  loopTarget?: string;\n  isStreaming?: boolean;\n  streamId?: string;\n  isParallelChild?: boolean;\n  parallelGroupId?: string;\n  isSubflowRoot?: boolean;\n  subflowId?: string;\n  subflowName?: string;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Build-Time Extractor\n// ─────────────────────────────────────────────────────────────────────────────\n\n/** Metadata provided to the build-time extractor for each node. */\nexport type BuildTimeNodeMetadata = FlowChartSpec;\n\nexport type BuildTimeExtractor<TResult = FlowChartSpec> = (metadata: BuildTimeNodeMetadata) => TResult;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Traversal Extractor (runtime)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type TraversalExtractor<TResult = unknown> = (snapshot: unknown) => TResult | undefined | null;\n\n// ─────────────────────────────────────────────────────────────────────────────\n// FlowChart — compiled output of build()\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type FlowChart<TOut = any, TScope = any> = {\n  root: StageNode<TOut, TScope>;\n  stageMap: Map<string, PipelineStageFunction<TOut, TScope>>;\n  extractor?: TraversalExtractor;\n  subflows?: Record<string, { root: StageNode<TOut, TScope> }>;\n  buildTimeStructure: SerializedPipelineStructure;\n  enableNarrative?: boolean;\n  logger?: ILogger;\n  description: string;\n  stageDescriptions: Map<string, string>;\n  /** Input schema (Zod or JSON Schema) — declared via setInputSchema(). */\n  inputSchema?: unknown;\n  /** Output schema (Zod or JSON Schema) — declared via setOutputSchema(). */\n  outputSchema?: unknown;\n  /** Output mapper — extracts response from final scope. */\n  outputMapper?: (finalScope: Record<string, unknown>) => unknown;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Simplified Parallel Spec (for addListOfFunction)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type SimplifiedParallelSpec<TOut = any, TScope = any> = {\n  id: string;\n  name: string;\n  fn?: PipelineStageFunction<TOut, TScope>;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// ExecOptions (for execute() convenience — used by runner layer)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport type ExecOptions = {\n  defaults?: unknown;\n  initial?: unknown;\n  readOnly?: unknown;\n  throttlingErrorChecker?: (e: unknown) => boolean;\n  scopeProtectionMode?: ScopeProtectionMode;\n  enableNarrative?: boolean;\n};\n\n// ─────────────────────────────────────────────────────────────────────────────\n// SubflowRef\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport interface SubflowRef {\n  $ref: string;\n  mountId: string;\n}\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* contract/defineContract.ts — Factory for creating a FlowChartContract.
|
|
3
|
+
*
|
|
4
|
+
* Wraps a compiled FlowChart with I/O schemas and an output mapper,
|
|
5
|
+
* using the same pattern as SubflowMountOptions (inputMapper/outputMapper).
|
|
6
|
+
*
|
|
7
|
+
* Usage:
|
|
8
|
+
* const contract = defineContract(chart, {
|
|
9
|
+
* inputSchema: z.object({ name: z.string() }),
|
|
10
|
+
* outputSchema: z.object({ greeting: z.string() }),
|
|
11
|
+
* outputMapper: (scope) => ({ greeting: scope.message as string }),
|
|
12
|
+
* });
|
|
13
|
+
*
|
|
14
|
+
* const openapi = contract.toOpenAPI();
|
|
15
|
+
*/
|
|
16
|
+
import { generateOpenAPI } from './openapi';
|
|
17
|
+
import { normalizeSchema } from './schema';
|
|
18
|
+
export function defineContract(chart, options) {
|
|
19
|
+
const inputSchema = options.inputSchema ? normalizeSchema(options.inputSchema) : undefined;
|
|
20
|
+
const outputSchema = options.outputSchema ? normalizeSchema(options.outputSchema) : undefined;
|
|
21
|
+
const contract = {
|
|
22
|
+
chart,
|
|
23
|
+
inputSchema,
|
|
24
|
+
outputSchema,
|
|
25
|
+
outputMapper: options.outputMapper,
|
|
26
|
+
toOpenAPI(apiOptions) {
|
|
27
|
+
return generateOpenAPI(contract, apiOptions);
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
return contract;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmaW5lQ29udHJhY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvbnRyYWN0L2RlZmluZUNvbnRyYWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBR0gsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM1QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRzNDLE1BQU0sVUFBVSxjQUFjLENBQzVCLEtBQWdCLEVBQ2hCLE9BQWtEO0lBRWxELE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUMzRixNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFFOUYsTUFBTSxRQUFRLEdBQXVDO1FBQ25ELEtBQUs7UUFDTCxXQUFXO1FBQ1gsWUFBWTtRQUNaLFlBQVksRUFBRSxPQUFPLENBQUMsWUFBWTtRQUNsQyxTQUFTLENBQUMsVUFBMkI7WUFDbkMsT0FBTyxlQUFlLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQy9DLENBQUM7S0FDRixDQUFDO0lBRUYsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogY29udHJhY3QvZGVmaW5lQ29udHJhY3QudHMg4oCUIEZhY3RvcnkgZm9yIGNyZWF0aW5nIGEgRmxvd0NoYXJ0Q29udHJhY3QuXG4gKlxuICogV3JhcHMgYSBjb21waWxlZCBGbG93Q2hhcnQgd2l0aCBJL08gc2NoZW1hcyBhbmQgYW4gb3V0cHV0IG1hcHBlcixcbiAqIHVzaW5nIHRoZSBzYW1lIHBhdHRlcm4gYXMgU3ViZmxvd01vdW50T3B0aW9ucyAoaW5wdXRNYXBwZXIvb3V0cHV0TWFwcGVyKS5cbiAqXG4gKiBVc2FnZTpcbiAqICAgY29uc3QgY29udHJhY3QgPSBkZWZpbmVDb250cmFjdChjaGFydCwge1xuICogICAgIGlucHV0U2NoZW1hOiB6Lm9iamVjdCh7IG5hbWU6IHouc3RyaW5nKCkgfSksXG4gKiAgICAgb3V0cHV0U2NoZW1hOiB6Lm9iamVjdCh7IGdyZWV0aW5nOiB6LnN0cmluZygpIH0pLFxuICogICAgIG91dHB1dE1hcHBlcjogKHNjb3BlKSA9PiAoeyBncmVldGluZzogc2NvcGUubWVzc2FnZSBhcyBzdHJpbmcgfSksXG4gKiAgIH0pO1xuICpcbiAqICAgY29uc3Qgb3BlbmFwaSA9IGNvbnRyYWN0LnRvT3BlbkFQSSgpO1xuICovXG5cbmltcG9ydCB0eXBlIHsgRmxvd0NoYXJ0IH0gZnJvbSAnLi4vYnVpbGRlci90eXBlcyc7XG5pbXBvcnQgeyBnZW5lcmF0ZU9wZW5BUEkgfSBmcm9tICcuL29wZW5hcGknO1xuaW1wb3J0IHsgbm9ybWFsaXplU2NoZW1hIH0gZnJvbSAnLi9zY2hlbWEnO1xuaW1wb3J0IHR5cGUgeyBGbG93Q2hhcnRDb250cmFjdCwgRmxvd0NoYXJ0Q29udHJhY3RPcHRpb25zLCBPcGVuQVBJT3B0aW9ucywgT3BlbkFQSVNwZWMgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZUNvbnRyYWN0PFRJbnB1dCA9IHVua25vd24sIFRPdXRwdXQgPSB1bmtub3duPihcbiAgY2hhcnQ6IEZsb3dDaGFydCxcbiAgb3B0aW9uczogRmxvd0NoYXJ0Q29udHJhY3RPcHRpb25zPFRJbnB1dCwgVE91dHB1dD4sXG4pOiBGbG93Q2hhcnRDb250cmFjdDxUSW5wdXQsIFRPdXRwdXQ+IHtcbiAgY29uc3QgaW5wdXRTY2hlbWEgPSBvcHRpb25zLmlucHV0U2NoZW1hID8gbm9ybWFsaXplU2NoZW1hKG9wdGlvbnMuaW5wdXRTY2hlbWEpIDogdW5kZWZpbmVkO1xuICBjb25zdCBvdXRwdXRTY2hlbWEgPSBvcHRpb25zLm91dHB1dFNjaGVtYSA/IG5vcm1hbGl6ZVNjaGVtYShvcHRpb25zLm91dHB1dFNjaGVtYSkgOiB1bmRlZmluZWQ7XG5cbiAgY29uc3QgY29udHJhY3Q6IEZsb3dDaGFydENvbnRyYWN0PFRJbnB1dCwgVE91dHB1dD4gPSB7XG4gICAgY2hhcnQsXG4gICAgaW5wdXRTY2hlbWEsXG4gICAgb3V0cHV0U2NoZW1hLFxuICAgIG91dHB1dE1hcHBlcjogb3B0aW9ucy5vdXRwdXRNYXBwZXIsXG4gICAgdG9PcGVuQVBJKGFwaU9wdGlvbnM/OiBPcGVuQVBJT3B0aW9ucyk6IE9wZW5BUElTcGVjIHtcbiAgICAgIHJldHVybiBnZW5lcmF0ZU9wZW5BUEkoY29udHJhY3QsIGFwaU9wdGlvbnMpO1xuICAgIH0sXG4gIH07XG5cbiAgcmV0dXJuIGNvbnRyYWN0O1xufVxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/* istanbul ignore file */
|
|
2
|
+
/**
|
|
3
|
+
* contract/ — FlowChart I/O contract and OpenAPI generation layer.
|
|
4
|
+
*
|
|
5
|
+
* Standalone library: wraps a compiled FlowChart with input/output schemas
|
|
6
|
+
* and generates OpenAPI 3.1 specs. Uses the same inputMapper/outputMapper
|
|
7
|
+
* pattern as subflow mounting.
|
|
8
|
+
*
|
|
9
|
+
* Zero runtime deps on Zod — Zod schemas detected via duck-typing and
|
|
10
|
+
* converted to JSON Schema at contract creation time.
|
|
11
|
+
*/
|
|
12
|
+
// Factory
|
|
13
|
+
export { defineContract } from './defineContract';
|
|
14
|
+
// Schema utilities
|
|
15
|
+
export { isZodSchema, normalizeSchema, zodToJsonSchema } from './schema';
|
|
16
|
+
// OpenAPI generator
|
|
17
|
+
export { generateOpenAPI } from './openapi';
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvbnRyYWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBCQUEwQjtBQUMxQjs7Ozs7Ozs7O0dBU0c7QUFFSCxVQUFVO0FBQ1YsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWxELG1CQUFtQjtBQUNuQixPQUFPLEVBQUUsV0FBVyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFekUsb0JBQW9CO0FBQ3BCLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuLyoqXG4gKiBjb250cmFjdC8g4oCUIEZsb3dDaGFydCBJL08gY29udHJhY3QgYW5kIE9wZW5BUEkgZ2VuZXJhdGlvbiBsYXllci5cbiAqXG4gKiBTdGFuZGFsb25lIGxpYnJhcnk6IHdyYXBzIGEgY29tcGlsZWQgRmxvd0NoYXJ0IHdpdGggaW5wdXQvb3V0cHV0IHNjaGVtYXNcbiAqIGFuZCBnZW5lcmF0ZXMgT3BlbkFQSSAzLjEgc3BlY3MuIFVzZXMgdGhlIHNhbWUgaW5wdXRNYXBwZXIvb3V0cHV0TWFwcGVyXG4gKiBwYXR0ZXJuIGFzIHN1YmZsb3cgbW91bnRpbmcuXG4gKlxuICogWmVybyBydW50aW1lIGRlcHMgb24gWm9kIOKAlCBab2Qgc2NoZW1hcyBkZXRlY3RlZCB2aWEgZHVjay10eXBpbmcgYW5kXG4gKiBjb252ZXJ0ZWQgdG8gSlNPTiBTY2hlbWEgYXQgY29udHJhY3QgY3JlYXRpb24gdGltZS5cbiAqL1xuXG4vLyBGYWN0b3J5XG5leHBvcnQgeyBkZWZpbmVDb250cmFjdCB9IGZyb20gJy4vZGVmaW5lQ29udHJhY3QnO1xuXG4vLyBTY2hlbWEgdXRpbGl0aWVzXG5leHBvcnQgeyBpc1pvZFNjaGVtYSwgbm9ybWFsaXplU2NoZW1hLCB6b2RUb0pzb25TY2hlbWEgfSBmcm9tICcuL3NjaGVtYSc7XG5cbi8vIE9wZW5BUEkgZ2VuZXJhdG9yXG5leHBvcnQgeyBnZW5lcmF0ZU9wZW5BUEkgfSBmcm9tICcuL29wZW5hcGknO1xuXG4vLyBUeXBlc1xuZXhwb3J0IHR5cGUge1xuICBGbG93Q2hhcnRDb250cmFjdCxcbiAgRmxvd0NoYXJ0Q29udHJhY3RPcHRpb25zLFxuICBKc29uU2NoZW1hLFxuICBPcGVuQVBJT3B0aW9ucyxcbiAgT3BlbkFQSVNwZWMsXG4gIFNjaGVtYUlucHV0LFxufSBmcm9tICcuL3R5cGVzJztcbiJdfQ==
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* contract/openapi.ts — OpenAPI 3.1 spec generator.
|
|
3
|
+
*
|
|
4
|
+
* Generates an OpenAPI spec from a FlowChartContract by combining:
|
|
5
|
+
* - chart.description → operation description
|
|
6
|
+
* - chart.stageDescriptions → step-by-step detail
|
|
7
|
+
* - inputSchema → requestBody
|
|
8
|
+
* - outputSchema → response
|
|
9
|
+
* - chart.buildTimeStructure → operation metadata (branches, forks, etc.)
|
|
10
|
+
*/
|
|
11
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
12
|
+
// Internal helpers
|
|
13
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
14
|
+
function slugify(name) {
|
|
15
|
+
return name
|
|
16
|
+
.toLowerCase()
|
|
17
|
+
.replace(/[^a-z0-9]+/g, '-')
|
|
18
|
+
.replace(/^-|-$/g, '');
|
|
19
|
+
}
|
|
20
|
+
function buildStepsDescription(chart) {
|
|
21
|
+
// Walk buildTimeStructure to produce a step-by-step description
|
|
22
|
+
const lines = [];
|
|
23
|
+
let step = 0;
|
|
24
|
+
const walk = (node) => {
|
|
25
|
+
step++;
|
|
26
|
+
const desc = node.description ? ` — ${node.description}` : '';
|
|
27
|
+
if (node.hasDecider && node.branchIds) {
|
|
28
|
+
lines.push(`${step}. ${node.name}${desc} — Decides between: ${node.branchIds.join(', ')}`);
|
|
29
|
+
}
|
|
30
|
+
else if (node.children && node.children.length > 0 && !node.hasDecider) {
|
|
31
|
+
const childNames = node.children.map((c) => c.name).join(', ');
|
|
32
|
+
lines.push(`${step}. ${node.name}${desc} (parallel: ${childNames})`);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
lines.push(`${step}. ${node.name}${desc}`);
|
|
36
|
+
}
|
|
37
|
+
if (node.children) {
|
|
38
|
+
for (const child of node.children)
|
|
39
|
+
walk(child);
|
|
40
|
+
}
|
|
41
|
+
if (node.next)
|
|
42
|
+
walk(node.next);
|
|
43
|
+
};
|
|
44
|
+
walk(chart.buildTimeStructure);
|
|
45
|
+
const header = chart.description ? `${chart.description}\n\n` : '';
|
|
46
|
+
return `${header}FlowChart: ${chart.root.name}\nSteps:\n${lines.join('\n')}`;
|
|
47
|
+
}
|
|
48
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
49
|
+
// Public API
|
|
50
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
51
|
+
export function generateOpenAPI(contract, options) {
|
|
52
|
+
var _a, _b, _c;
|
|
53
|
+
const { chart, inputSchema, outputSchema } = contract;
|
|
54
|
+
const version = (_a = options === null || options === void 0 ? void 0 : options.version) !== null && _a !== void 0 ? _a : '1.0.0';
|
|
55
|
+
const basePath = (_b = options === null || options === void 0 ? void 0 : options.basePath) !== null && _b !== void 0 ? _b : '/';
|
|
56
|
+
const method = (_c = options === null || options === void 0 ? void 0 : options.method) !== null && _c !== void 0 ? _c : 'post';
|
|
57
|
+
const rootName = chart.root.name;
|
|
58
|
+
const operationId = slugify(rootName);
|
|
59
|
+
const path = `${basePath === '/' ? '' : basePath}/${operationId}`;
|
|
60
|
+
const fullDescription = buildStepsDescription(chart);
|
|
61
|
+
// Build schemas for components
|
|
62
|
+
const schemas = {};
|
|
63
|
+
const inputRef = `${rootName}Input`;
|
|
64
|
+
const outputRef = `${rootName}Output`;
|
|
65
|
+
if (inputSchema)
|
|
66
|
+
schemas[inputRef] = inputSchema;
|
|
67
|
+
if (outputSchema)
|
|
68
|
+
schemas[outputRef] = outputSchema;
|
|
69
|
+
// Build operation
|
|
70
|
+
const operation = {
|
|
71
|
+
operationId,
|
|
72
|
+
summary: rootName,
|
|
73
|
+
description: fullDescription,
|
|
74
|
+
...(inputSchema
|
|
75
|
+
? {
|
|
76
|
+
requestBody: {
|
|
77
|
+
required: true,
|
|
78
|
+
content: {
|
|
79
|
+
'application/json': {
|
|
80
|
+
schema: { $ref: `#/components/schemas/${inputRef}` },
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
}
|
|
85
|
+
: {}),
|
|
86
|
+
responses: {
|
|
87
|
+
'200': {
|
|
88
|
+
description: 'Successful execution',
|
|
89
|
+
...(outputSchema
|
|
90
|
+
? {
|
|
91
|
+
content: {
|
|
92
|
+
'application/json': {
|
|
93
|
+
schema: { $ref: `#/components/schemas/${outputRef}` },
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
}
|
|
97
|
+
: {}),
|
|
98
|
+
},
|
|
99
|
+
'500': {
|
|
100
|
+
description: 'Pipeline execution error',
|
|
101
|
+
},
|
|
102
|
+
},
|
|
103
|
+
};
|
|
104
|
+
const spec = {
|
|
105
|
+
openapi: '3.1.0',
|
|
106
|
+
info: {
|
|
107
|
+
title: rootName,
|
|
108
|
+
description: fullDescription,
|
|
109
|
+
version,
|
|
110
|
+
},
|
|
111
|
+
paths: {
|
|
112
|
+
[path]: {
|
|
113
|
+
[method]: operation,
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
...(Object.keys(schemas).length > 0 ? { components: { schemas } } : {}),
|
|
117
|
+
};
|
|
118
|
+
return spec;
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"openapi.js","sourceRoot":"","sources":["../../../../src/lib/contract/openapi.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * contract/openapi.ts — OpenAPI 3.1 spec generator.\n *\n * Generates an OpenAPI spec from a FlowChartContract by combining:\n * - chart.description → operation description\n * - chart.stageDescriptions → step-by-step detail\n * - inputSchema → requestBody\n * - outputSchema → response\n * - chart.buildTimeStructure → operation metadata (branches, forks, etc.)\n */\n\nimport type { FlowChart, SerializedPipelineStructure } from '../builder/types';\nimport type { FlowChartContract, JsonSchema, OpenAPIOperation, OpenAPIOptions, OpenAPISpec } from './types';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Internal helpers\n// ─────────────────────────────────────────────────────────────────────────────\n\nfunction slugify(name: string): string {\n  return name\n    .toLowerCase()\n    .replace(/[^a-z0-9]+/g, '-')\n    .replace(/^-|-$/g, '');\n}\n\nfunction buildStepsDescription(chart: FlowChart): string {\n  // Walk buildTimeStructure to produce a step-by-step description\n  const lines: string[] = [];\n  let step = 0;\n\n  const walk = (node: SerializedPipelineStructure) => {\n    step++;\n    const desc = node.description ? ` — ${node.description}` : '';\n\n    if (node.hasDecider && node.branchIds) {\n      lines.push(`${step}. ${node.name}${desc} — Decides between: ${node.branchIds.join(', ')}`);\n    } else if (node.children && node.children.length > 0 && !node.hasDecider) {\n      const childNames = node.children.map((c) => c.name).join(', ');\n      lines.push(`${step}. ${node.name}${desc} (parallel: ${childNames})`);\n    } else {\n      lines.push(`${step}. ${node.name}${desc}`);\n    }\n\n    if (node.children) {\n      for (const child of node.children) walk(child);\n    }\n    if (node.next) walk(node.next);\n  };\n\n  walk(chart.buildTimeStructure);\n\n  const header = chart.description ? `${chart.description}\\n\\n` : '';\n  return `${header}FlowChart: ${chart.root.name}\\nSteps:\\n${lines.join('\\n')}`;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Public API\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport function generateOpenAPI(contract: FlowChartContract, options?: OpenAPIOptions): OpenAPISpec {\n  const { chart, inputSchema, outputSchema } = contract;\n  const version = options?.version ?? '1.0.0';\n  const basePath = options?.basePath ?? '/';\n  const method = options?.method ?? 'post';\n\n  const rootName = chart.root.name;\n  const operationId = slugify(rootName);\n  const path = `${basePath === '/' ? '' : basePath}/${operationId}`;\n\n  const fullDescription = buildStepsDescription(chart);\n\n  // Build schemas for components\n  const schemas: Record<string, JsonSchema> = {};\n  const inputRef = `${rootName}Input`;\n  const outputRef = `${rootName}Output`;\n\n  if (inputSchema) schemas[inputRef] = inputSchema;\n  if (outputSchema) schemas[outputRef] = outputSchema;\n\n  // Build operation\n  const operation: OpenAPIOperation = {\n    operationId,\n    summary: rootName,\n    description: fullDescription,\n    ...(inputSchema\n      ? {\n          requestBody: {\n            required: true,\n            content: {\n              'application/json': {\n                schema: { $ref: `#/components/schemas/${inputRef}` },\n              },\n            },\n          },\n        }\n      : {}),\n    responses: {\n      '200': {\n        description: 'Successful execution',\n        ...(outputSchema\n          ? {\n              content: {\n                'application/json': {\n                  schema: { $ref: `#/components/schemas/${outputRef}` },\n                },\n              },\n            }\n          : {}),\n      },\n      '500': {\n        description: 'Pipeline execution error',\n      },\n    },\n  };\n\n  const spec: OpenAPISpec = {\n    openapi: '3.1.0',\n    info: {\n      title: rootName,\n      description: fullDescription,\n      version,\n    },\n    paths: {\n      [path]: {\n        [method]: operation,\n      },\n    },\n    ...(Object.keys(schemas).length > 0 ? { components: { schemas } } : {}),\n  };\n\n  return spec;\n}\n"]}
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* contract/schema.ts — Schema normalization utilities.
|
|
3
|
+
*
|
|
4
|
+
* Converts Zod schemas or raw JSON Schema objects into a normalized
|
|
5
|
+
* JsonSchema format. Zod detection uses duck-typing (checks for `_def`).
|
|
6
|
+
*
|
|
7
|
+
* Standalone: no dependency on Zod at import time.
|
|
8
|
+
* Compatible with Zod v4 internals.
|
|
9
|
+
*/
|
|
10
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
11
|
+
// Zod Detection (duck-typing)
|
|
12
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
13
|
+
export function isZodSchema(input) {
|
|
14
|
+
if (!input || typeof input !== 'object')
|
|
15
|
+
return false;
|
|
16
|
+
const obj = input;
|
|
17
|
+
// Zod v4: top-level schema has `def` with a `type` string
|
|
18
|
+
if ('def' in obj && typeof obj.def === 'object' && obj.def !== null) {
|
|
19
|
+
return typeof obj.def.type === 'string';
|
|
20
|
+
}
|
|
21
|
+
// Zod v3 fallback: `_def` with `typeName`
|
|
22
|
+
if ('_def' in obj && typeof obj._def === 'object' && obj._def !== null) {
|
|
23
|
+
return typeof obj._def.type === 'string';
|
|
24
|
+
}
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
28
|
+
// Zod v4 → JSON Schema (minimal converter for common types)
|
|
29
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
30
|
+
/**
|
|
31
|
+
* Get the def object from a Zod schema.
|
|
32
|
+
* In Zod v4, top-level schemas have `.def`, inner types accessed via
|
|
33
|
+
* `_def` or `.def` depending on context.
|
|
34
|
+
*/
|
|
35
|
+
function getDef(zodSchema) {
|
|
36
|
+
// Top-level Zod v4 schema: `.def` property
|
|
37
|
+
if (zodSchema.def && typeof zodSchema.def === 'object') {
|
|
38
|
+
return zodSchema.def;
|
|
39
|
+
}
|
|
40
|
+
// Nested via _def (e.g., when accessing directly)
|
|
41
|
+
if (zodSchema._def && typeof zodSchema._def === 'object') {
|
|
42
|
+
return zodSchema._def;
|
|
43
|
+
}
|
|
44
|
+
return undefined;
|
|
45
|
+
}
|
|
46
|
+
/** Get description from a Zod v4 schema (stored via .description or .meta()) */
|
|
47
|
+
function getDescription(zodSchema) {
|
|
48
|
+
if (typeof zodSchema.description === 'string')
|
|
49
|
+
return zodSchema.description;
|
|
50
|
+
return undefined;
|
|
51
|
+
}
|
|
52
|
+
function zodDefToJsonSchema(def, zodSchema) {
|
|
53
|
+
const typeName = def.type;
|
|
54
|
+
const description = zodSchema ? getDescription(zodSchema) : undefined;
|
|
55
|
+
const base = {};
|
|
56
|
+
if (description)
|
|
57
|
+
base.description = description;
|
|
58
|
+
switch (typeName) {
|
|
59
|
+
case 'string':
|
|
60
|
+
return { ...base, type: 'string' };
|
|
61
|
+
case 'number':
|
|
62
|
+
return { ...base, type: 'number' };
|
|
63
|
+
case 'boolean':
|
|
64
|
+
return { ...base, type: 'boolean' };
|
|
65
|
+
case 'literal': {
|
|
66
|
+
// Zod v4: _def.values is an array of literal values
|
|
67
|
+
const values = def.values;
|
|
68
|
+
if (values && values.length === 1) {
|
|
69
|
+
return { ...base, type: typeof values[0], enum: values };
|
|
70
|
+
}
|
|
71
|
+
return { ...base, enum: values !== null && values !== void 0 ? values : [] };
|
|
72
|
+
}
|
|
73
|
+
case 'enum': {
|
|
74
|
+
// Zod v4: _def.entries is { key: value } object
|
|
75
|
+
const entries = def.entries;
|
|
76
|
+
const values = entries ? Object.values(entries) : [];
|
|
77
|
+
return { ...base, type: 'string', enum: values };
|
|
78
|
+
}
|
|
79
|
+
case 'array': {
|
|
80
|
+
// Zod v4: _def.element is the inner schema object
|
|
81
|
+
const element = def.element;
|
|
82
|
+
const elementDef = element ? getDef(element) : undefined;
|
|
83
|
+
const items = elementDef ? zodDefToJsonSchema(elementDef, element) : {};
|
|
84
|
+
return { ...base, type: 'array', items };
|
|
85
|
+
}
|
|
86
|
+
case 'object': {
|
|
87
|
+
// Zod v4: _def.shape is a direct object (not a function)
|
|
88
|
+
const shape = def.shape;
|
|
89
|
+
if (!shape)
|
|
90
|
+
return { ...base, type: 'object' };
|
|
91
|
+
const properties = {};
|
|
92
|
+
const required = [];
|
|
93
|
+
for (const [key, value] of Object.entries(shape)) {
|
|
94
|
+
const fieldSchema = value;
|
|
95
|
+
const fieldDef = getDef(fieldSchema);
|
|
96
|
+
if (fieldDef) {
|
|
97
|
+
// Check if field is optional or has default
|
|
98
|
+
if (fieldDef.type === 'optional' || fieldDef.type === 'default') {
|
|
99
|
+
const inner = fieldDef.innerType;
|
|
100
|
+
const innerDef = inner ? getDef(inner) : undefined;
|
|
101
|
+
if (innerDef) {
|
|
102
|
+
const schema = zodDefToJsonSchema(innerDef, inner);
|
|
103
|
+
if (fieldDef.type === 'default' && fieldDef.defaultValue !== undefined) {
|
|
104
|
+
schema.default = fieldDef.defaultValue;
|
|
105
|
+
}
|
|
106
|
+
properties[key] = schema;
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
properties[key] = {};
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
properties[key] = zodDefToJsonSchema(fieldDef, fieldSchema);
|
|
114
|
+
required.push(key);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return {
|
|
119
|
+
...base,
|
|
120
|
+
type: 'object',
|
|
121
|
+
properties,
|
|
122
|
+
...(required.length > 0 ? { required } : {}),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
case 'optional': {
|
|
126
|
+
const inner = def.innerType;
|
|
127
|
+
const innerDef = inner ? getDef(inner) : undefined;
|
|
128
|
+
return innerDef ? zodDefToJsonSchema(innerDef, inner) : base;
|
|
129
|
+
}
|
|
130
|
+
case 'default': {
|
|
131
|
+
const inner = def.innerType;
|
|
132
|
+
const innerDef = inner ? getDef(inner) : undefined;
|
|
133
|
+
const schema = innerDef ? zodDefToJsonSchema(innerDef, inner) : base;
|
|
134
|
+
if (def.defaultValue !== undefined) {
|
|
135
|
+
schema.default = def.defaultValue;
|
|
136
|
+
}
|
|
137
|
+
return schema;
|
|
138
|
+
}
|
|
139
|
+
case 'nullable': {
|
|
140
|
+
const inner = def.innerType;
|
|
141
|
+
const innerDef = inner ? getDef(inner) : undefined;
|
|
142
|
+
const schema = innerDef ? zodDefToJsonSchema(innerDef, inner) : {};
|
|
143
|
+
return { ...base, oneOf: [schema, { type: 'null' }] };
|
|
144
|
+
}
|
|
145
|
+
case 'union': {
|
|
146
|
+
const options = def.options;
|
|
147
|
+
if (!options)
|
|
148
|
+
return base;
|
|
149
|
+
return {
|
|
150
|
+
...base,
|
|
151
|
+
oneOf: options
|
|
152
|
+
.map((o) => {
|
|
153
|
+
const oDef = getDef(o);
|
|
154
|
+
return oDef ? zodDefToJsonSchema(oDef, o) : null;
|
|
155
|
+
})
|
|
156
|
+
.filter((s) => s !== null),
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
case 'record': {
|
|
160
|
+
// Zod v4: _def.valueType is the value schema
|
|
161
|
+
const valueType = def.valueType;
|
|
162
|
+
const valueDef = valueType ? getDef(valueType) : undefined;
|
|
163
|
+
return {
|
|
164
|
+
...base,
|
|
165
|
+
type: 'object',
|
|
166
|
+
additionalProperties: valueDef ? zodDefToJsonSchema(valueDef, valueType) : true,
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
case 'any':
|
|
170
|
+
return base;
|
|
171
|
+
case 'pipe': {
|
|
172
|
+
// Zod v4: .transform() / .refine() — unwrap to input schema
|
|
173
|
+
const inner = def.in;
|
|
174
|
+
const innerDef = inner ? getDef(inner) : undefined;
|
|
175
|
+
return innerDef ? zodDefToJsonSchema(innerDef, inner) : base;
|
|
176
|
+
}
|
|
177
|
+
default:
|
|
178
|
+
// Unknown Zod type — return empty schema
|
|
179
|
+
return base;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
/** Convert a Zod schema object to JSON Schema. */
|
|
183
|
+
export function zodToJsonSchema(zodSchema) {
|
|
184
|
+
const def = getDef(zodSchema);
|
|
185
|
+
if (!def)
|
|
186
|
+
return {};
|
|
187
|
+
return zodDefToJsonSchema(def, zodSchema);
|
|
188
|
+
}
|
|
189
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
190
|
+
// Normalize — accepts either Zod or JSON Schema, returns JSON Schema
|
|
191
|
+
// ─────────────────────────────────────────────────────────────────────────────
|
|
192
|
+
export function normalizeSchema(input) {
|
|
193
|
+
if (isZodSchema(input)) {
|
|
194
|
+
return zodToJsonSchema(input);
|
|
195
|
+
}
|
|
196
|
+
// Already a JSON Schema
|
|
197
|
+
return input;
|
|
198
|
+
}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["../../../../src/lib/contract/schema.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * contract/schema.ts — Schema normalization utilities.\n *\n * Converts Zod schemas or raw JSON Schema objects into a normalized\n * JsonSchema format. Zod detection uses duck-typing (checks for `_def`).\n *\n * Standalone: no dependency on Zod at import time.\n * Compatible with Zod v4 internals.\n */\n\nimport type { JsonSchema, SchemaInput } from './types';\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Zod Detection (duck-typing)\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport function isZodSchema(input: unknown): boolean {\n  if (!input || typeof input !== 'object') return false;\n  const obj = input as Record<string, unknown>;\n  // Zod v4: top-level schema has `def` with a `type` string\n  if ('def' in obj && typeof obj.def === 'object' && obj.def !== null) {\n    return typeof (obj.def as Record<string, unknown>).type === 'string';\n  }\n  // Zod v3 fallback: `_def` with `typeName`\n  if ('_def' in obj && typeof obj._def === 'object' && obj._def !== null) {\n    return typeof (obj._def as Record<string, unknown>).type === 'string';\n  }\n  return false;\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Zod v4 → JSON Schema (minimal converter for common types)\n// ─────────────────────────────────────────────────────────────────────────────\n\n/**\n * Get the def object from a Zod schema.\n * In Zod v4, top-level schemas have `.def`, inner types accessed via\n * `_def` or `.def` depending on context.\n */\nfunction getDef(zodSchema: Record<string, unknown>): Record<string, unknown> | undefined {\n  // Top-level Zod v4 schema: `.def` property\n  if (zodSchema.def && typeof zodSchema.def === 'object') {\n    return zodSchema.def as Record<string, unknown>;\n  }\n  // Nested via _def (e.g., when accessing directly)\n  if (zodSchema._def && typeof zodSchema._def === 'object') {\n    return zodSchema._def as Record<string, unknown>;\n  }\n  return undefined;\n}\n\n/** Get description from a Zod v4 schema (stored via .description or .meta()) */\nfunction getDescription(zodSchema: Record<string, unknown>): string | undefined {\n  if (typeof zodSchema.description === 'string') return zodSchema.description;\n  return undefined;\n}\n\nfunction zodDefToJsonSchema(def: Record<string, unknown>, zodSchema?: Record<string, unknown>): JsonSchema {\n  const typeName = def.type as string | undefined;\n  const description = zodSchema ? getDescription(zodSchema) : undefined;\n  const base: JsonSchema = {};\n  if (description) base.description = description;\n\n  switch (typeName) {\n    case 'string':\n      return { ...base, type: 'string' };\n\n    case 'number':\n      return { ...base, type: 'number' };\n\n    case 'boolean':\n      return { ...base, type: 'boolean' };\n\n    case 'literal': {\n      // Zod v4: _def.values is an array of literal values\n      const values = def.values as unknown[] | undefined;\n      if (values && values.length === 1) {\n        return { ...base, type: typeof values[0], enum: values };\n      }\n      return { ...base, enum: values ?? [] };\n    }\n\n    case 'enum': {\n      // Zod v4: _def.entries is { key: value } object\n      const entries = def.entries as Record<string, unknown> | undefined;\n      const values = entries ? Object.values(entries) : [];\n      return { ...base, type: 'string', enum: values };\n    }\n\n    case 'array': {\n      // Zod v4: _def.element is the inner schema object\n      const element = def.element as Record<string, unknown> | undefined;\n      const elementDef = element ? getDef(element) : undefined;\n      const items = elementDef ? zodDefToJsonSchema(elementDef, element) : {};\n      return { ...base, type: 'array', items };\n    }\n\n    case 'object': {\n      // Zod v4: _def.shape is a direct object (not a function)\n      const shape = def.shape as Record<string, unknown> | undefined;\n      if (!shape) return { ...base, type: 'object' };\n\n      const properties: Record<string, JsonSchema> = {};\n      const required: string[] = [];\n\n      for (const [key, value] of Object.entries(shape)) {\n        const fieldSchema = value as Record<string, unknown>;\n        const fieldDef = getDef(fieldSchema);\n        if (fieldDef) {\n          // Check if field is optional or has default\n          if (fieldDef.type === 'optional' || fieldDef.type === 'default') {\n            const inner = fieldDef.innerType as Record<string, unknown> | undefined;\n            const innerDef = inner ? getDef(inner) : undefined;\n            if (innerDef) {\n              const schema = zodDefToJsonSchema(innerDef, inner);\n              if (fieldDef.type === 'default' && fieldDef.defaultValue !== undefined) {\n                schema.default = fieldDef.defaultValue;\n              }\n              properties[key] = schema;\n            } else {\n              properties[key] = {};\n            }\n          } else {\n            properties[key] = zodDefToJsonSchema(fieldDef, fieldSchema);\n            required.push(key);\n          }\n        }\n      }\n\n      return {\n        ...base,\n        type: 'object',\n        properties,\n        ...(required.length > 0 ? { required } : {}),\n      };\n    }\n\n    case 'optional': {\n      const inner = def.innerType as Record<string, unknown> | undefined;\n      const innerDef = inner ? getDef(inner) : undefined;\n      return innerDef ? zodDefToJsonSchema(innerDef, inner) : base;\n    }\n\n    case 'default': {\n      const inner = def.innerType as Record<string, unknown> | undefined;\n      const innerDef = inner ? getDef(inner) : undefined;\n      const schema = innerDef ? zodDefToJsonSchema(innerDef, inner) : base;\n      if (def.defaultValue !== undefined) {\n        schema.default = def.defaultValue;\n      }\n      return schema;\n    }\n\n    case 'nullable': {\n      const inner = def.innerType as Record<string, unknown> | undefined;\n      const innerDef = inner ? getDef(inner) : undefined;\n      const schema = innerDef ? zodDefToJsonSchema(innerDef, inner) : {};\n      return { ...base, oneOf: [schema, { type: 'null' }] };\n    }\n\n    case 'union': {\n      const options = def.options as Array<Record<string, unknown>> | undefined;\n      if (!options) return base;\n      return {\n        ...base,\n        oneOf: options\n          .map((o) => {\n            const oDef = getDef(o);\n            return oDef ? zodDefToJsonSchema(oDef, o) : null;\n          })\n          .filter((s): s is JsonSchema => s !== null),\n      };\n    }\n\n    case 'record': {\n      // Zod v4: _def.valueType is the value schema\n      const valueType = def.valueType as Record<string, unknown> | undefined;\n      const valueDef = valueType ? getDef(valueType) : undefined;\n      return {\n        ...base,\n        type: 'object',\n        additionalProperties: valueDef ? zodDefToJsonSchema(valueDef, valueType) : true,\n      };\n    }\n\n    case 'any':\n      return base;\n\n    case 'pipe': {\n      // Zod v4: .transform() / .refine() — unwrap to input schema\n      const inner = def.in as Record<string, unknown> | undefined;\n      const innerDef = inner ? getDef(inner) : undefined;\n      return innerDef ? zodDefToJsonSchema(innerDef, inner) : base;\n    }\n\n    default:\n      // Unknown Zod type — return empty schema\n      return base;\n  }\n}\n\n/** Convert a Zod schema object to JSON Schema. */\nexport function zodToJsonSchema(zodSchema: Record<string, unknown>): JsonSchema {\n  const def = getDef(zodSchema);\n  if (!def) return {};\n  return zodDefToJsonSchema(def, zodSchema);\n}\n\n// ─────────────────────────────────────────────────────────────────────────────\n// Normalize — accepts either Zod or JSON Schema, returns JSON Schema\n// ─────────────────────────────────────────────────────────────────────────────\n\nexport function normalizeSchema(input: SchemaInput): JsonSchema {\n  if (isZodSchema(input)) {\n    return zodToJsonSchema(input as Record<string, unknown>);\n  }\n  // Already a JSON Schema\n  return input as JsonSchema;\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* contract/types.ts — Types for the FlowChart contract layer.
|
|
3
|
+
*
|
|
4
|
+
* Defines the I/O boundary for a flowchart: input schema, output schema,
|
|
5
|
+
* and output mapper. Uses the same pattern as SubflowMountOptions
|
|
6
|
+
* (inputMapper/outputMapper) but at the top-level flowchart boundary.
|
|
7
|
+
*/
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvbnRyYWN0L3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogY29udHJhY3QvdHlwZXMudHMg4oCUIFR5cGVzIGZvciB0aGUgRmxvd0NoYXJ0IGNvbnRyYWN0IGxheWVyLlxuICpcbiAqIERlZmluZXMgdGhlIEkvTyBib3VuZGFyeSBmb3IgYSBmbG93Y2hhcnQ6IGlucHV0IHNjaGVtYSwgb3V0cHV0IHNjaGVtYSxcbiAqIGFuZCBvdXRwdXQgbWFwcGVyLiBVc2VzIHRoZSBzYW1lIHBhdHRlcm4gYXMgU3ViZmxvd01vdW50T3B0aW9uc1xuICogKGlucHV0TWFwcGVyL291dHB1dE1hcHBlcikgYnV0IGF0IHRoZSB0b3AtbGV2ZWwgZmxvd2NoYXJ0IGJvdW5kYXJ5LlxuICovXG5cbmltcG9ydCB0eXBlIHsgRmxvd0NoYXJ0IH0gZnJvbSAnLi4vYnVpbGRlci90eXBlcyc7XG5cbi8vIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgFxuLy8gSlNPTiBTY2hlbWEgKHN1YnNldCBvZiBKU09OIFNjaGVtYSBEcmFmdCAyMDIwLTEyIC8gT3BlbkFQSSAzLjEpXG4vLyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIBcblxuZXhwb3J0IHR5cGUgSnNvblNjaGVtYSA9IHtcbiAgdHlwZT86IHN0cmluZyB8IHN0cmluZ1tdO1xuICBwcm9wZXJ0aWVzPzogUmVjb3JkPHN0cmluZywgSnNvblNjaGVtYT47XG4gIHJlcXVpcmVkPzogc3RyaW5nW107XG4gIGl0ZW1zPzogSnNvblNjaGVtYTtcbiAgZW51bT86IHVua25vd25bXTtcbiAgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gIGRlZmF1bHQ/OiB1bmtub3duO1xuICBmb3JtYXQ/OiBzdHJpbmc7XG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzPzogYm9vbGVhbiB8IEpzb25TY2hlbWE7XG4gIG9uZU9mPzogSnNvblNjaGVtYVtdO1xuICBhbnlPZj86IEpzb25TY2hlbWFbXTtcbiAgYWxsT2Y/OiBKc29uU2NoZW1hW107XG4gICRyZWY/OiBzdHJpbmc7XG4gIFtrZXk6IHN0cmluZ106IHVua25vd247XG59O1xuXG4vLyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIBcbi8vIFNjaGVtYSBJbnB1dCDigJQgYWNjZXB0cyBlaXRoZXIgWm9kIHNjaGVtYSBvciByYXcgSlNPTiBTY2hlbWFcbi8vIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgFxuXG4vKiogQW55dGhpbmcgd2l0aCBhIGBkZWZgIChab2QgdjQpIG9yIGBfZGVmYCAoWm9kIHYzKSBwcm9wZXJ0eSBpcyB0cmVhdGVkIGFzIGEgWm9kIHNjaGVtYS4gKi9cbmV4cG9ydCB0eXBlIFNjaGVtYUlucHV0ID0gSnNvblNjaGVtYSB8IHsgZGVmOiB1bmtub3duOyBba2V5OiBzdHJpbmddOiB1bmtub3duIH07XG5cbi8vIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgFxuLy8gRmxvd0NoYXJ0IENvbnRyYWN0IOKAlCBJL08gYm91bmRhcnkgZGVmaW5pdGlvblxuLy8g4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSAXG5cbmV4cG9ydCBpbnRlcmZhY2UgRmxvd0NoYXJ0Q29udHJhY3RPcHRpb25zPFRJbnB1dCA9IHVua25vd24sIFRPdXRwdXQgPSB1bmtub3duPiB7XG4gIC8qKiBTY2hlbWEgZGVzY3JpYmluZyB0aGUgaW5wdXQgKHJlYWRPbmx5Q29udGV4dCkgc2hhcGUuIFpvZCBvciBKU09OIFNjaGVtYS4gKi9cbiAgaW5wdXRTY2hlbWE/OiBTY2hlbWFJbnB1dDtcbiAgLyoqIFNjaGVtYSBkZXNjcmliaW5nIHRoZSBvdXRwdXQgc2hhcGUuIFpvZCBvciBKU09OIFNjaGVtYS4gKi9cbiAgb3V0cHV0U2NoZW1hPzogU2NoZW1hSW5wdXQ7XG4gIC8qKiBNYXBzIHRoZSBmaW5hbCBzY29wZSBzdGF0ZSBpbnRvIHRoZSByZXNwb25zZSBzaGFwZS4gKi9cbiAgb3V0cHV0TWFwcGVyPzogKGZpbmFsU2NvcGU6IFJlY29yZDxzdHJpbmcsIHVua25vd24+KSA9PiBUT3V0cHV0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZsb3dDaGFydENvbnRyYWN0PFRJbnB1dCA9IHVua25vd24sIFRPdXRwdXQgPSB1bmtub3duPiB7XG4gIC8qKiBUaGUgY29tcGlsZWQgZmxvd2NoYXJ0LiAqL1xuICBjaGFydDogRmxvd0NoYXJ0O1xuICAvKiogSlNPTiBTY2hlbWEgZm9yIHRoZSBpbnB1dCAobm9ybWFsaXplZCBmcm9tIFpvZCBvciByYXcpLiAqL1xuICBpbnB1dFNjaGVtYT86IEpzb25TY2hlbWE7XG4gIC8qKiBKU09OIFNjaGVtYSBmb3IgdGhlIG91dHB1dCAobm9ybWFsaXplZCBmcm9tIFpvZCBvciByYXcpLiAqL1xuICBvdXRwdXRTY2hlbWE/OiBKc29uU2NoZW1hO1xuICAvKiogTWFwcyB0aGUgZmluYWwgc2NvcGUgc3RhdGUgaW50byB0aGUgcmVzcG9uc2Ugc2hhcGUuICovXG4gIG91dHB1dE1hcHBlcj86IChmaW5hbFNjb3BlOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikgPT4gVE91dHB1dDtcbiAgLyoqIEF1dG8tZ2VuZXJhdGVkIE9wZW5BUEkgc3BlYy4gKi9cbiAgdG9PcGVuQVBJKG9wdGlvbnM/OiBPcGVuQVBJT3B0aW9ucyk6IE9wZW5BUElTcGVjO1xufVxuXG4vLyDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIDilIBcbi8vIE9wZW5BUEkgVHlwZXMgKG1pbmltYWwgc3Vic2V0IG9mIE9wZW5BUEkgMy4xKVxuLy8g4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSAXG5cbmV4cG9ydCBpbnRlcmZhY2UgT3BlbkFQSU9wdGlvbnMge1xuICAvKiogQVBJIHZlcnNpb24gc3RyaW5nIChkZWZhdWx0OiBcIjEuMC4wXCIpLiAqL1xuICB2ZXJzaW9uPzogc3RyaW5nO1xuICAvKiogQmFzZSBwYXRoIHByZWZpeCAoZGVmYXVsdDogXCIvXCIpLiAqL1xuICBiYXNlUGF0aD86IHN0cmluZztcbiAgLyoqIEhUVFAgbWV0aG9kIGZvciB0aGUgZXhlY3V0ZSBlbmRwb2ludCAoZGVmYXVsdDogXCJwb3N0XCIpLiAqL1xuICBtZXRob2Q/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3BlbkFQSVNwZWMge1xuICBvcGVuYXBpOiAnMy4xLjAnO1xuICBpbmZvOiB7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgIHZlcnNpb246IHN0cmluZztcbiAgfTtcbiAgcGF0aHM6IFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIE9wZW5BUElPcGVyYXRpb24+PjtcbiAgY29tcG9uZW50cz86IHtcbiAgICBzY2hlbWFzPzogUmVjb3JkPHN0cmluZywgSnNvblNjaGVtYT47XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3BlbkFQSU9wZXJhdGlvbiB7XG4gIG9wZXJhdGlvbklkOiBzdHJpbmc7XG4gIHN1bW1hcnk6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgcmVxdWVzdEJvZHk/OiB7XG4gICAgcmVxdWlyZWQ6IGJvb2xlYW47XG4gICAgY29udGVudDoge1xuICAgICAgJ2FwcGxpY2F0aW9uL2pzb24nOiB7XG4gICAgICAgIHNjaGVtYTogSnNvblNjaGVtYSB8IHsgJHJlZjogc3RyaW5nIH07XG4gICAgICB9O1xuICAgIH07XG4gIH07XG4gIHJlc3BvbnNlczogUmVjb3JkPFxuICAgIHN0cmluZyxcbiAgICB7XG4gICAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICAgICAgY29udGVudD86IHtcbiAgICAgICAgJ2FwcGxpY2F0aW9uL2pzb24nOiB7XG4gICAgICAgICAgc2NoZW1hOiBKc29uU2NoZW1hIHwgeyAkcmVmOiBzdHJpbmcgfTtcbiAgICAgICAgfTtcbiAgICAgIH07XG4gICAgfVxuICA+O1xufVxuIl19
|
|
@@ -35,4 +35,4 @@ export function isStageNodeReturn(output) {
|
|
|
35
35
|
return false;
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3RhZ2VOb2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9lbmdpbmUvZ3JhcGgvU3RhZ2VOb2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7R0FTRztBQXFGSCw4RUFBOEU7QUFDOUUscUVBQXFFO0FBQ3JFLDhFQUE4RTtBQUU5RTs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxVQUFVLGlCQUFpQixDQUFDLE1BQWU7SUFDL0MsSUFBSSxDQUFDLE1BQU0sSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRO1FBQUUsT0FBTyxLQUFLLENBQUM7SUFFeEQsSUFBSSxDQUFDO1FBQ0gsTUFBTSxHQUFHLEdBQUcsTUFBaUMsQ0FBQztRQUM5QyxJQUFJLE9BQU8sR0FBRyxDQUFDLElBQUksS0FBSyxRQUFRO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFFL0MsTUFBTSxlQUFlLEdBQ25CLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1lBQ3hELEdBQUcsQ0FBQyxJQUFJLEtBQUssU0FBUztZQUN0QixPQUFPLEdBQUcsQ0FBQyxnQkFBZ0IsS0FBSyxVQUFVLENBQUM7UUFFN0MsT0FBTyxlQUFlLENBQUM7SUFDekIsQ0FBQztJQUFDLFdBQU0sQ0FBQztRQUNQLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFN0YWdlTm9kZSDigJQgVGhlIGdyYXBoIG5vZGUgdHlwZSBmb3IgZmxvd2NoYXJ0IHRyYXZlcnNhbC5cbiAqXG4gKiBEZWZpbmVzIHRoZSBzaGFwZSBvZiBlYWNoIG5vZGUgaW4gdGhlIGZsb3djaGFydCBEQUc6XG4gKiAtIExpbmVhciBjb250aW51YXRpb24gdmlhIGBuZXh0YCAobGlua2VkIGxpc3QgdHJhdmVyc2FsKVxuICogLSBQYXJhbGxlbCBmYW4tb3V0IHZpYSBgY2hpbGRyZW5gIChmb3JrKVxuICogLSBDb25kaXRpb25hbCBicmFuY2hpbmcgdmlhIGBkZWNpZGVyRm5gIChzaW5nbGUtY2hvaWNlKSBvciBgc2VsZWN0b3JGbmAgKG11bHRpLWNob2ljZSlcbiAqIC0gQmFjay1lZGdlcyB2aWEgZHluYW1pYyBuZXh0IChsb29wKVxuICogLSBJc29sYXRlZCBzdWItdHJhdmVyc2FscyB2aWEgYGlzU3ViZmxvd1Jvb3RgIChzdWJmbG93KVxuICovXG5cbmltcG9ydCB0eXBlIHsgU3RhZ2VGdW5jdGlvbiwgU3ViZmxvd01vdW50T3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJztcblxuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBEZWNpZGVyICsgU2VsZWN0b3Jcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuXG4vKiogUGlja3MgZXhhY3RseSBPTkUgY2hpbGQgYnkgSUQuIENvbmRpdGlvbmFsIGJyYW5jaCAoaWYvc3dpdGNoKS4gKi9cbmV4cG9ydCB0eXBlIERlY2lkZXIgPSAobm9kZUFyZ3M6IGFueSkgPT4gc3RyaW5nIHwgUHJvbWlzZTxzdHJpbmc+O1xuXG4vKipcbiAqIFBpY2tzIE9ORSBPUiBNT1JFIGNoaWxkcmVuIGJ5IElELiBGaWx0ZXJlZCBmYW4tb3V0LlxuICogLSBTaW5nbGUgc3RyaW5nOiBiZWhhdmVzIGxpa2UgRGVjaWRlclxuICogLSBBcnJheTogc2VsZWN0ZWQgY2hpbGRyZW4gZXhlY3V0ZSBpbiBwYXJhbGxlbFxuICogLSBFbXB0eSBhcnJheTogc2tpcCBhbGwgY2hpbGRyZW5cbiAqL1xuZXhwb3J0IHR5cGUgU2VsZWN0b3IgPSAobm9kZUFyZ3M6IGFueSkgPT4gc3RyaW5nIHwgc3RyaW5nW10gfCBQcm9taXNlPHN0cmluZyB8IHN0cmluZ1tdPjtcblxuLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4vLyBTdGFnZU5vZGVcbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuXG5leHBvcnQgdHlwZSBTdGFnZU5vZGU8VE91dCA9IGFueSwgVFNjb3BlID0gYW55PiA9IHtcbiAgLyoqIEh1bWFuLXJlYWRhYmxlIHN0YWdlIG5hbWU7IGFsc28gdXNlZCBhcyB0aGUgc3RhZ2VNYXAga2V5ICovXG4gIG5hbWU6IHN0cmluZztcbiAgLyoqIE9wdGlvbmFsIHN0YWJsZSBpZCAocmVxdWlyZWQgYnkgZGVjaWRlci9mb3JrIGFnZ3JlZ2F0aW9uKSAqL1xuICBpZD86IHN0cmluZztcbiAgLyoqIERlc2NyaXB0aW9uIG9mIHdoYXQgdGhpcyBzdGFnZSBkb2VzLiBVc2VkIGZvciBuYXJyYXRpdmUgYW5kIHRvb2wgZGVzY3JpcHRpb25zLiAqL1xuICBkZXNjcmlwdGlvbj86IHN0cmluZztcblxuICAvLyDilIDilIAgQ29udGludWF0aW9uIHBvaW50ZXJzIOKUgOKUgFxuXG4gIC8qKiBMaW5lYXIgY29udGludWF0aW9uIChsaW5rZWQgbGlzdCBuZXh0IHBvaW50ZXIpICovXG4gIG5leHQ/OiBTdGFnZU5vZGU8VE91dCwgVFNjb3BlPjtcbiAgLyoqIFBhcmFsbGVsIGNoaWxkcmVuIChmb3JrIGZhbi1vdXQpICovXG4gIGNoaWxkcmVuPzogU3RhZ2VOb2RlPFRPdXQsIFRTY29wZT5bXTtcblxuICAvLyDilIDilIAgQnJhbmNoaW5nIOKUgOKUgFxuXG4gIC8qKiBPdXRwdXQtYmFzZWQgc2VsZWN0b3I6IHBpY2tzIHN1YnNldCBvZiBjaGlsZHJlbiAqL1xuICBuZXh0Tm9kZVNlbGVjdG9yPzogU2VsZWN0b3I7XG4gIC8qKiBXaGVuIHRydWUsIGZuIElTIGEgc2NvcGUtYmFzZWQgZGVjaWRlciB0aGF0IHJldHVybnMgYSBicmFuY2ggSUQgc3RyaW5nICovXG4gIGRlY2lkZXJGbj86IGJvb2xlYW47XG4gIC8qKiBXaGVuIHRydWUsIGZuIElTIGEgc2NvcGUtYmFzZWQgc2VsZWN0b3IgdGhhdCByZXR1cm5zIGJyYW5jaCBJRChzKSAqL1xuICBzZWxlY3RvckZuPzogYm9vbGVhbjtcblxuICAvLyDilIDilIAgU3RhZ2UgZnVuY3Rpb24g4pSA4pSAXG5cbiAgLyoqIEVtYmVkZGVkIGZ1bmN0aW9uOyBvdGhlcndpc2UgcmVzb2x2ZWQgZnJvbSBzdGFnZU1hcCBieSBgbmFtZWAgKi9cbiAgZm4/OiBTdGFnZUZ1bmN0aW9uPFRPdXQsIFRTY29wZT47XG5cbiAgLy8g4pSA4pSAIFN0cmVhbWluZyDilIDilIBcblxuICAvKiogV2hlbiB0cnVlLCBQaXBlbGluZSBpbmplY3RzIGEgc3RyZWFtQ2FsbGJhY2sgYXMgM3JkIHBhcmFtZXRlciAqL1xuICBpc1N0cmVhbWluZz86IGJvb2xlYW47XG4gIC8qKiBVbmlxdWUgc3RyZWFtIGlkZW50aWZpZXIgZm9yIHJvdXRpbmcgdG9rZW5zICovXG4gIHN0cmVhbUlkPzogc3RyaW5nO1xuXG4gIC8vIOKUgOKUgCBTdWJmbG93IOKUgOKUgFxuXG4gIC8qKiBUcnVlIGlmIHRoaXMgaXMgdGhlIHJvb3Qgbm9kZSBvZiBhIG1vdW50ZWQgc3ViZmxvdyAqL1xuICBpc1N1YmZsb3dSb290PzogYm9vbGVhbjtcbiAgLyoqIE1vdW50IGlkIG9mIHRoZSBzdWJmbG93IChlLmcuLCBcImxsbS1jb3JlXCIpICovXG4gIHN1YmZsb3dJZD86IHN0cmluZztcbiAgLyoqIERpc3BsYXkgbmFtZSBvZiB0aGUgc3ViZmxvdyAqL1xuICBzdWJmbG93TmFtZT86IHN0cmluZztcbiAgLyoqIFJlZmVyZW5jZSBrZXkgaW50byB0aGUgc3ViZmxvd3MgZGljdGlvbmFyeSAqL1xuICAkcmVmPzogc3RyaW5nO1xuICAvKiogVW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoaXMgbW91bnQgaW5zdGFuY2UgKi9cbiAgbW91bnRJZD86IHN0cmluZztcbiAgLyoqIElucHV0L291dHB1dCBtYXBwaW5nIG9wdGlvbnMgZm9yIHN1YmZsb3dzICovXG4gIHN1YmZsb3dNb3VudE9wdGlvbnM/OiBTdWJmbG93TW91bnRPcHRpb25zO1xuICAvKiogV2hlbiB0cnVlLCBwYXJhbGxlbCBjaGlsZHJlbiB1c2UgZmFpbC1mYXN0IHNlbWFudGljcyAocmVqZWN0IG9uIGZpcnN0IGVycm9yKSAqL1xuICBmYWlsRmFzdD86IGJvb2xlYW47XG5cbiAgLyoqIElubGluZSBzdWJmbG93IGRlZmluaXRpb24gZm9yIGR5bmFtaWMgc3ViZmxvdyBhdHRhY2htZW50ICovXG4gIHN1YmZsb3dEZWY/OiB7XG4gICAgcm9vdDogU3RhZ2VOb2RlO1xuICAgIHN0YWdlTWFwPzogTWFwPHN0cmluZywgU3RhZ2VGdW5jdGlvbjxUT3V0LCBUU2NvcGU+PjtcbiAgICBidWlsZFRpbWVTdHJ1Y3R1cmU/OiB1bmtub3duO1xuICAgIHN1YmZsb3dzPzogUmVjb3JkPHN0cmluZywgeyByb290OiBTdGFnZU5vZGUgfT47XG4gIH07XG59O1xuXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbi8vIGlzU3RhZ2VOb2RlUmV0dXJuIOKAlCBkdWNrLXR5cGluZyBkZXRlY3Rpb24gZm9yIGR5bmFtaWMgY29udGludWF0aW9uXG4vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cblxuLyoqXG4gKiBEZXRlY3RzIGlmIGEgc3RhZ2Ugb3V0cHV0IGlzIGEgU3RhZ2VOb2RlIGZvciBkeW5hbWljIGNvbnRpbnVhdGlvbi5cbiAqXG4gKiBVc2VzIGR1Y2stdHlwaW5nOiBtdXN0IGhhdmUgYG5hbWVgIChzdHJpbmcpIEFORCBhdCBsZWFzdCBvbmUgY29udGludWF0aW9uXG4gKiBwcm9wZXJ0eSAobm9uLWVtcHR5IGNoaWxkcmVuLCBuZXh0LCBvciBuZXh0Tm9kZVNlbGVjdG9yKS5cbiAqXG4gKiBTYWZlbHkgaGFuZGxlcyBwcm94eSBvYmplY3RzIChlLmcuLCBab2Qgc2NvcGUpIHRoYXQgbWF5IHRocm93IG9uIHByb3BlcnR5IGFjY2Vzcy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzU3RhZ2VOb2RlUmV0dXJuKG91dHB1dDogdW5rbm93bik6IG91dHB1dCBpcyBTdGFnZU5vZGUge1xuICBpZiAoIW91dHB1dCB8fCB0eXBlb2Ygb3V0cHV0ICE9PSAnb2JqZWN0JykgcmV0dXJuIGZhbHNlO1xuXG4gIHRyeSB7XG4gICAgY29uc3Qgb2JqID0gb3V0cHV0IGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICAgIGlmICh0eXBlb2Ygb2JqLm5hbWUgIT09ICdzdHJpbmcnKSByZXR1cm4gZmFsc2U7XG5cbiAgICBjb25zdCBoYXNDb250aW51YXRpb24gPVxuICAgICAgKEFycmF5LmlzQXJyYXkob2JqLmNoaWxkcmVuKSAmJiBvYmouY2hpbGRyZW4ubGVuZ3RoID4gMCkgfHxcbiAgICAgIG9iai5uZXh0ICE9PSB1bmRlZmluZWQgfHxcbiAgICAgIHR5cGVvZiBvYmoubmV4dE5vZGVTZWxlY3RvciA9PT0gJ2Z1bmN0aW9uJztcblxuICAgIHJldHVybiBoYXNDb250aW51YXRpb247XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuIl19
|