123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517 |
- from datetime import datetime
- from enum import Enum
- from typing import Any, Optional
- from pydantic import BaseModel, field_validator
- 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(str, Enum):
- """
- 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"
- ITERATION_START = "iteration_start"
- ITERATION_NEXT = "iteration_next"
- ITERATION_COMPLETED = "iteration_completed"
- NODE_STARTED = "node_started"
- NODE_SUCCEEDED = "node_succeeded"
- NODE_FAILED = "node_failed"
- 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"
- 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
- @field_validator("output", mode="before")
- @classmethod
- def set_output(cls, v):
- """
- Set output
- """
- if v is None:
- return None
- if isinstance(v, int | float | str | bool | dict | list):
- return v
- raise ValueError("output must be a valid type")
- 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
- 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
- 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 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
|