123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- from enum import Enum
- from typing import Any, Optional
- from pydantic import Field
- from core.workflow.nodes.base import BaseIterationNodeData, BaseIterationState, BaseNodeData
- class ErrorHandleMode(str, Enum):
- TERMINATED = "terminated"
- CONTINUE_ON_ERROR = "continue-on-error"
- REMOVE_ABNORMAL_OUTPUT = "remove-abnormal-output"
- class IterationNodeData(BaseIterationNodeData):
- """
- Iteration Node Data.
- """
- parent_loop_id: Optional[str] = None # redundant field, not used currently
- iterator_selector: list[str] # variable selector
- output_selector: list[str] # output selector
- is_parallel: bool = False # open the parallel mode or not
- parallel_nums: int = 10 # the numbers of parallel
- error_handle_mode: ErrorHandleMode = ErrorHandleMode.TERMINATED # how to handle the error
- class IterationStartNodeData(BaseNodeData):
- """
- Iteration Start Node Data.
- """
- pass
- class IterationState(BaseIterationState):
- """
- Iteration State.
- """
- outputs: list[Any] = Field(default_factory=list)
- current_output: Optional[Any] = None
- class MetaData(BaseIterationState.MetaData):
- """
- Data.
- """
- iterator_length: int
- def get_last_output(self) -> Optional[Any]:
- """
- Get last output.
- """
- if self.outputs:
- return self.outputs[-1]
- return None
- def get_current_output(self) -> Optional[Any]:
- """
- Get current output.
- """
- return self.current_output
|