| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584 | 
							- from datetime import datetime
 - from enum import Enum, StrEnum
 - from typing import Any, Optional
 - 
 - from pydantic import BaseModel
 - 
 - from core.model_runtime.entities.llm_entities import LLMResult, LLMResultChunk
 - from core.workflow.entities.node_entities import NodeRunMetadataKey
 - from core.workflow.graph_engine.entities.graph_runtime_state import GraphRuntimeState
 - from core.workflow.nodes import NodeType
 - from core.workflow.nodes.base import BaseNodeData
 - 
 - 
 - class QueueEvent(StrEnum):
 -     """
 -     QueueEvent enum
 -     """
 - 
 -     LLM_CHUNK = "llm_chunk"
 -     TEXT_CHUNK = "text_chunk"
 -     AGENT_MESSAGE = "agent_message"
 -     MESSAGE_REPLACE = "message_replace"
 -     MESSAGE_END = "message_end"
 -     ADVANCED_CHAT_MESSAGE_END = "advanced_chat_message_end"
 -     WORKFLOW_STARTED = "workflow_started"
 -     WORKFLOW_SUCCEEDED = "workflow_succeeded"
 -     WORKFLOW_FAILED = "workflow_failed"
 -     WORKFLOW_PARTIAL_SUCCEEDED = "workflow_partial_succeeded"
 -     ITERATION_START = "iteration_start"
 -     ITERATION_NEXT = "iteration_next"
 -     ITERATION_COMPLETED = "iteration_completed"
 -     NODE_STARTED = "node_started"
 -     NODE_SUCCEEDED = "node_succeeded"
 -     NODE_FAILED = "node_failed"
 -     NODE_EXCEPTION = "node_exception"
 -     RETRIEVER_RESOURCES = "retriever_resources"
 -     ANNOTATION_REPLY = "annotation_reply"
 -     AGENT_THOUGHT = "agent_thought"
 -     MESSAGE_FILE = "message_file"
 -     PARALLEL_BRANCH_RUN_STARTED = "parallel_branch_run_started"
 -     PARALLEL_BRANCH_RUN_SUCCEEDED = "parallel_branch_run_succeeded"
 -     PARALLEL_BRANCH_RUN_FAILED = "parallel_branch_run_failed"
 -     ERROR = "error"
 -     PING = "ping"
 -     STOP = "stop"
 -     RETRY = "retry"
 - 
 - 
 - class AppQueueEvent(BaseModel):
 -     """
 -     QueueEvent abstract entity
 -     """
 - 
 -     event: QueueEvent
 - 
 - 
 - class QueueLLMChunkEvent(AppQueueEvent):
 -     """
 -     QueueLLMChunkEvent entity
 -     Only for basic mode apps
 -     """
 - 
 -     event: QueueEvent = QueueEvent.LLM_CHUNK
 -     chunk: LLMResultChunk
 - 
 - 
 - class QueueIterationStartEvent(AppQueueEvent):
 -     """
 -     QueueIterationStartEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ITERATION_START
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     start_at: datetime
 - 
 -     node_run_index: int
 -     inputs: Optional[dict[str, Any]] = None
 -     predecessor_node_id: Optional[str] = None
 -     metadata: Optional[dict[str, Any]] = None
 - 
 - 
 - class QueueIterationNextEvent(AppQueueEvent):
 -     """
 -     QueueIterationNextEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ITERATION_NEXT
 - 
 -     index: int
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     parallel_mode_run_id: Optional[str] = None
 -     """iteratoin run in parallel mode run id"""
 -     node_run_index: int
 -     output: Optional[Any] = None  # output for the current iteration
 -     duration: Optional[float] = None
 - 
 - 
 - class QueueIterationCompletedEvent(AppQueueEvent):
 -     """
 -     QueueIterationCompletedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ITERATION_COMPLETED
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     start_at: datetime
 - 
 -     node_run_index: int
 -     inputs: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     metadata: Optional[dict[str, Any]] = None
 -     steps: int = 0
 - 
 -     error: Optional[str] = None
 - 
 - 
 - class QueueTextChunkEvent(AppQueueEvent):
 -     """
 -     QueueTextChunkEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.TEXT_CHUNK
 -     text: str
 -     from_variable_selector: Optional[list[str]] = None
 -     """from variable selector"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 - 
 - 
 - class QueueAgentMessageEvent(AppQueueEvent):
 -     """
 -     QueueMessageEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.AGENT_MESSAGE
 -     chunk: LLMResultChunk
 - 
 - 
 - class QueueMessageReplaceEvent(AppQueueEvent):
 -     """
 -     QueueMessageReplaceEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.MESSAGE_REPLACE
 -     text: str
 - 
 - 
 - class QueueRetrieverResourcesEvent(AppQueueEvent):
 -     """
 -     QueueRetrieverResourcesEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.RETRIEVER_RESOURCES
 -     retriever_resources: list[dict]
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 - 
 - 
 - class QueueAnnotationReplyEvent(AppQueueEvent):
 -     """
 -     QueueAnnotationReplyEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ANNOTATION_REPLY
 -     message_annotation_id: str
 - 
 - 
 - class QueueMessageEndEvent(AppQueueEvent):
 -     """
 -     QueueMessageEndEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.MESSAGE_END
 -     llm_result: Optional[LLMResult] = None
 - 
 - 
 - class QueueAdvancedChatMessageEndEvent(AppQueueEvent):
 -     """
 -     QueueAdvancedChatMessageEndEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ADVANCED_CHAT_MESSAGE_END
 - 
 - 
 - class QueueWorkflowStartedEvent(AppQueueEvent):
 -     """
 -     QueueWorkflowStartedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.WORKFLOW_STARTED
 -     graph_runtime_state: GraphRuntimeState
 - 
 - 
 - class QueueWorkflowSucceededEvent(AppQueueEvent):
 -     """
 -     QueueWorkflowSucceededEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.WORKFLOW_SUCCEEDED
 -     outputs: Optional[dict[str, Any]] = None
 - 
 - 
 - class QueueWorkflowFailedEvent(AppQueueEvent):
 -     """
 -     QueueWorkflowFailedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.WORKFLOW_FAILED
 -     error: str
 -     exceptions_count: int
 - 
 - 
 - class QueueWorkflowPartialSuccessEvent(AppQueueEvent):
 -     """
 -     QueueWorkflowFailedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.WORKFLOW_PARTIAL_SUCCEEDED
 -     exceptions_count: int
 -     outputs: Optional[dict[str, Any]] = None
 - 
 - 
 - class QueueNodeStartedEvent(AppQueueEvent):
 -     """
 -     QueueNodeStartedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.NODE_STARTED
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     node_run_index: int = 1
 -     predecessor_node_id: Optional[str] = None
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 -     parallel_mode_run_id: Optional[str] = None
 -     """iteratoin run in parallel mode run id"""
 - 
 - 
 - class QueueNodeSucceededEvent(AppQueueEvent):
 -     """
 -     QueueNodeSucceededEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.NODE_SUCCEEDED
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 - 
 -     inputs: Optional[dict[str, Any]] = None
 -     process_data: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
 - 
 -     error: Optional[str] = None
 -     """single iteration duration map"""
 -     iteration_duration_map: Optional[dict[str, float]] = None
 - 
 - 
 - class QueueNodeRetryEvent(AppQueueEvent):
 -     """QueueNodeRetryEvent entity"""
 - 
 -     event: QueueEvent = QueueEvent.RETRY
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 - 
 -     inputs: Optional[dict[str, Any]] = None
 -     process_data: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
 - 
 -     error: str
 -     retry_index: int  # retry index
 -     start_index: int  # start index
 - 
 - 
 - class QueueNodeInIterationFailedEvent(AppQueueEvent):
 -     """
 -     QueueNodeInIterationFailedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.NODE_FAILED
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 - 
 -     inputs: Optional[dict[str, Any]] = None
 -     process_data: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
 - 
 -     error: str
 - 
 - 
 - class QueueNodeExceptionEvent(AppQueueEvent):
 -     """
 -     QueueNodeExceptionEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.NODE_EXCEPTION
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 - 
 -     inputs: Optional[dict[str, Any]] = None
 -     process_data: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
 - 
 -     error: str
 - 
 - 
 - class QueueNodeFailedEvent(AppQueueEvent):
 -     """
 -     QueueNodeFailedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.NODE_FAILED
 - 
 -     node_execution_id: str
 -     node_id: str
 -     node_type: NodeType
 -     node_data: BaseNodeData
 -     parallel_id: Optional[str] = None
 -     """parallel id if node is in parallel"""
 -     parallel_start_node_id: Optional[str] = None
 -     """parallel start node id if node is in parallel"""
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     start_at: datetime
 - 
 -     inputs: Optional[dict[str, Any]] = None
 -     process_data: Optional[dict[str, Any]] = None
 -     outputs: Optional[dict[str, Any]] = None
 -     execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
 - 
 -     error: str
 - 
 - 
 - class QueueAgentThoughtEvent(AppQueueEvent):
 -     """
 -     QueueAgentThoughtEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.AGENT_THOUGHT
 -     agent_thought_id: str
 - 
 - 
 - class QueueMessageFileEvent(AppQueueEvent):
 -     """
 -     QueueAgentThoughtEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.MESSAGE_FILE
 -     message_file_id: str
 - 
 - 
 - class QueueErrorEvent(AppQueueEvent):
 -     """
 -     QueueErrorEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.ERROR
 -     error: Any = None
 - 
 - 
 - class QueuePingEvent(AppQueueEvent):
 -     """
 -     QueuePingEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.PING
 - 
 - 
 - class QueueStopEvent(AppQueueEvent):
 -     """
 -     QueueStopEvent entity
 -     """
 - 
 -     class StopBy(Enum):
 -         """
 -         Stop by enum
 -         """
 - 
 -         USER_MANUAL = "user-manual"
 -         ANNOTATION_REPLY = "annotation-reply"
 -         OUTPUT_MODERATION = "output-moderation"
 -         INPUT_MODERATION = "input-moderation"
 - 
 -     event: QueueEvent = QueueEvent.STOP
 -     stopped_by: StopBy
 - 
 -     def get_stop_reason(self) -> str:
 -         """
 -         To stop reason
 -         """
 -         reason_mapping = {
 -             QueueStopEvent.StopBy.USER_MANUAL: "Stopped by user.",
 -             QueueStopEvent.StopBy.ANNOTATION_REPLY: "Stopped by annotation reply.",
 -             QueueStopEvent.StopBy.OUTPUT_MODERATION: "Stopped by output moderation.",
 -             QueueStopEvent.StopBy.INPUT_MODERATION: "Stopped by input moderation.",
 -         }
 - 
 -         return reason_mapping.get(self.stopped_by, "Stopped by unknown reason.")
 - 
 - 
 - class QueueMessage(BaseModel):
 -     """
 -     QueueMessage abstract entity
 -     """
 - 
 -     task_id: str
 -     app_mode: str
 -     event: AppQueueEvent
 - 
 - 
 - class MessageQueueMessage(QueueMessage):
 -     """
 -     MessageQueueMessage entity
 -     """
 - 
 -     message_id: str
 -     conversation_id: str
 - 
 - 
 - class WorkflowQueueMessage(QueueMessage):
 -     """
 -     WorkflowQueueMessage entity
 -     """
 - 
 -     pass
 - 
 - 
 - class QueueParallelBranchRunStartedEvent(AppQueueEvent):
 -     """
 -     QueueParallelBranchRunStartedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_STARTED
 - 
 -     parallel_id: str
 -     parallel_start_node_id: str
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 - 
 - 
 - class QueueParallelBranchRunSucceededEvent(AppQueueEvent):
 -     """
 -     QueueParallelBranchRunSucceededEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_SUCCEEDED
 - 
 -     parallel_id: str
 -     parallel_start_node_id: str
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 - 
 - 
 - class QueueParallelBranchRunFailedEvent(AppQueueEvent):
 -     """
 -     QueueParallelBranchRunFailedEvent entity
 -     """
 - 
 -     event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_FAILED
 - 
 -     parallel_id: str
 -     parallel_start_node_id: str
 -     parent_parallel_id: Optional[str] = None
 -     """parent parallel id if node is in parallel"""
 -     parent_parallel_start_node_id: Optional[str] = None
 -     """parent parallel start node id if node is in parallel"""
 -     in_iteration_id: Optional[str] = None
 -     """iteration id if node is in iteration"""
 -     error: str
 
 
  |