queue_entities.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508
  1. from datetime import datetime
  2. from enum import Enum, StrEnum
  3. from typing import Any, Optional
  4. from pydantic import BaseModel
  5. from core.model_runtime.entities.llm_entities import LLMResult, LLMResultChunk
  6. from core.workflow.entities.node_entities import NodeRunMetadataKey
  7. from core.workflow.graph_engine.entities.graph_runtime_state import GraphRuntimeState
  8. from core.workflow.nodes import NodeType
  9. from core.workflow.nodes.base import BaseNodeData
  10. class QueueEvent(StrEnum):
  11. """
  12. QueueEvent enum
  13. """
  14. LLM_CHUNK = "llm_chunk"
  15. TEXT_CHUNK = "text_chunk"
  16. AGENT_MESSAGE = "agent_message"
  17. MESSAGE_REPLACE = "message_replace"
  18. MESSAGE_END = "message_end"
  19. ADVANCED_CHAT_MESSAGE_END = "advanced_chat_message_end"
  20. WORKFLOW_STARTED = "workflow_started"
  21. WORKFLOW_SUCCEEDED = "workflow_succeeded"
  22. WORKFLOW_FAILED = "workflow_failed"
  23. ITERATION_START = "iteration_start"
  24. ITERATION_NEXT = "iteration_next"
  25. ITERATION_COMPLETED = "iteration_completed"
  26. NODE_STARTED = "node_started"
  27. NODE_SUCCEEDED = "node_succeeded"
  28. NODE_FAILED = "node_failed"
  29. RETRIEVER_RESOURCES = "retriever_resources"
  30. ANNOTATION_REPLY = "annotation_reply"
  31. AGENT_THOUGHT = "agent_thought"
  32. MESSAGE_FILE = "message_file"
  33. PARALLEL_BRANCH_RUN_STARTED = "parallel_branch_run_started"
  34. PARALLEL_BRANCH_RUN_SUCCEEDED = "parallel_branch_run_succeeded"
  35. PARALLEL_BRANCH_RUN_FAILED = "parallel_branch_run_failed"
  36. ERROR = "error"
  37. PING = "ping"
  38. STOP = "stop"
  39. class AppQueueEvent(BaseModel):
  40. """
  41. QueueEvent abstract entity
  42. """
  43. event: QueueEvent
  44. class QueueLLMChunkEvent(AppQueueEvent):
  45. """
  46. QueueLLMChunkEvent entity
  47. Only for basic mode apps
  48. """
  49. event: QueueEvent = QueueEvent.LLM_CHUNK
  50. chunk: LLMResultChunk
  51. class QueueIterationStartEvent(AppQueueEvent):
  52. """
  53. QueueIterationStartEvent entity
  54. """
  55. event: QueueEvent = QueueEvent.ITERATION_START
  56. node_execution_id: str
  57. node_id: str
  58. node_type: NodeType
  59. node_data: BaseNodeData
  60. parallel_id: Optional[str] = None
  61. """parallel id if node is in parallel"""
  62. parallel_start_node_id: Optional[str] = None
  63. """parallel start node id if node is in parallel"""
  64. parent_parallel_id: Optional[str] = None
  65. """parent parallel id if node is in parallel"""
  66. parent_parallel_start_node_id: Optional[str] = None
  67. """parent parallel start node id if node is in parallel"""
  68. start_at: datetime
  69. node_run_index: int
  70. inputs: Optional[dict[str, Any]] = None
  71. predecessor_node_id: Optional[str] = None
  72. metadata: Optional[dict[str, Any]] = None
  73. class QueueIterationNextEvent(AppQueueEvent):
  74. """
  75. QueueIterationNextEvent entity
  76. """
  77. event: QueueEvent = QueueEvent.ITERATION_NEXT
  78. index: int
  79. node_execution_id: str
  80. node_id: str
  81. node_type: NodeType
  82. node_data: BaseNodeData
  83. parallel_id: Optional[str] = None
  84. """parallel id if node is in parallel"""
  85. parallel_start_node_id: Optional[str] = None
  86. """parallel start node id if node is in parallel"""
  87. parent_parallel_id: Optional[str] = None
  88. """parent parallel id if node is in parallel"""
  89. parent_parallel_start_node_id: Optional[str] = None
  90. """parent parallel start node id if node is in parallel"""
  91. parallel_mode_run_id: Optional[str] = None
  92. """iteratoin run in parallel mode run id"""
  93. node_run_index: int
  94. output: Optional[Any] = None # output for the current iteration
  95. duration: Optional[float] = None
  96. class QueueIterationCompletedEvent(AppQueueEvent):
  97. """
  98. QueueIterationCompletedEvent entity
  99. """
  100. event: QueueEvent = QueueEvent.ITERATION_COMPLETED
  101. node_execution_id: str
  102. node_id: str
  103. node_type: NodeType
  104. node_data: BaseNodeData
  105. parallel_id: Optional[str] = None
  106. """parallel id if node is in parallel"""
  107. parallel_start_node_id: Optional[str] = None
  108. """parallel start node id if node is in parallel"""
  109. parent_parallel_id: Optional[str] = None
  110. """parent parallel id if node is in parallel"""
  111. parent_parallel_start_node_id: Optional[str] = None
  112. """parent parallel start node id if node is in parallel"""
  113. start_at: datetime
  114. node_run_index: int
  115. inputs: Optional[dict[str, Any]] = None
  116. outputs: Optional[dict[str, Any]] = None
  117. metadata: Optional[dict[str, Any]] = None
  118. steps: int = 0
  119. error: Optional[str] = None
  120. class QueueTextChunkEvent(AppQueueEvent):
  121. """
  122. QueueTextChunkEvent entity
  123. """
  124. event: QueueEvent = QueueEvent.TEXT_CHUNK
  125. text: str
  126. from_variable_selector: Optional[list[str]] = None
  127. """from variable selector"""
  128. in_iteration_id: Optional[str] = None
  129. """iteration id if node is in iteration"""
  130. class QueueAgentMessageEvent(AppQueueEvent):
  131. """
  132. QueueMessageEvent entity
  133. """
  134. event: QueueEvent = QueueEvent.AGENT_MESSAGE
  135. chunk: LLMResultChunk
  136. class QueueMessageReplaceEvent(AppQueueEvent):
  137. """
  138. QueueMessageReplaceEvent entity
  139. """
  140. event: QueueEvent = QueueEvent.MESSAGE_REPLACE
  141. text: str
  142. class QueueRetrieverResourcesEvent(AppQueueEvent):
  143. """
  144. QueueRetrieverResourcesEvent entity
  145. """
  146. event: QueueEvent = QueueEvent.RETRIEVER_RESOURCES
  147. retriever_resources: list[dict]
  148. in_iteration_id: Optional[str] = None
  149. """iteration id if node is in iteration"""
  150. class QueueAnnotationReplyEvent(AppQueueEvent):
  151. """
  152. QueueAnnotationReplyEvent entity
  153. """
  154. event: QueueEvent = QueueEvent.ANNOTATION_REPLY
  155. message_annotation_id: str
  156. class QueueMessageEndEvent(AppQueueEvent):
  157. """
  158. QueueMessageEndEvent entity
  159. """
  160. event: QueueEvent = QueueEvent.MESSAGE_END
  161. llm_result: Optional[LLMResult] = None
  162. class QueueAdvancedChatMessageEndEvent(AppQueueEvent):
  163. """
  164. QueueAdvancedChatMessageEndEvent entity
  165. """
  166. event: QueueEvent = QueueEvent.ADVANCED_CHAT_MESSAGE_END
  167. class QueueWorkflowStartedEvent(AppQueueEvent):
  168. """
  169. QueueWorkflowStartedEvent entity
  170. """
  171. event: QueueEvent = QueueEvent.WORKFLOW_STARTED
  172. graph_runtime_state: GraphRuntimeState
  173. class QueueWorkflowSucceededEvent(AppQueueEvent):
  174. """
  175. QueueWorkflowSucceededEvent entity
  176. """
  177. event: QueueEvent = QueueEvent.WORKFLOW_SUCCEEDED
  178. outputs: Optional[dict[str, Any]] = None
  179. class QueueWorkflowFailedEvent(AppQueueEvent):
  180. """
  181. QueueWorkflowFailedEvent entity
  182. """
  183. event: QueueEvent = QueueEvent.WORKFLOW_FAILED
  184. error: str
  185. class QueueNodeStartedEvent(AppQueueEvent):
  186. """
  187. QueueNodeStartedEvent entity
  188. """
  189. event: QueueEvent = QueueEvent.NODE_STARTED
  190. node_execution_id: str
  191. node_id: str
  192. node_type: NodeType
  193. node_data: BaseNodeData
  194. node_run_index: int = 1
  195. predecessor_node_id: Optional[str] = None
  196. parallel_id: Optional[str] = None
  197. """parallel id if node is in parallel"""
  198. parallel_start_node_id: Optional[str] = None
  199. """parallel start node id if node is in parallel"""
  200. parent_parallel_id: Optional[str] = None
  201. """parent parallel id if node is in parallel"""
  202. parent_parallel_start_node_id: Optional[str] = None
  203. """parent parallel start node id if node is in parallel"""
  204. in_iteration_id: Optional[str] = None
  205. """iteration id if node is in iteration"""
  206. start_at: datetime
  207. parallel_mode_run_id: Optional[str] = None
  208. """iteratoin run in parallel mode run id"""
  209. class QueueNodeSucceededEvent(AppQueueEvent):
  210. """
  211. QueueNodeSucceededEvent entity
  212. """
  213. event: QueueEvent = QueueEvent.NODE_SUCCEEDED
  214. node_execution_id: str
  215. node_id: str
  216. node_type: NodeType
  217. node_data: BaseNodeData
  218. parallel_id: Optional[str] = None
  219. """parallel id if node is in parallel"""
  220. parallel_start_node_id: Optional[str] = None
  221. """parallel start node id if node is in parallel"""
  222. parent_parallel_id: Optional[str] = None
  223. """parent parallel id if node is in parallel"""
  224. parent_parallel_start_node_id: Optional[str] = None
  225. """parent parallel start node id if node is in parallel"""
  226. in_iteration_id: Optional[str] = None
  227. """iteration id if node is in iteration"""
  228. start_at: datetime
  229. inputs: Optional[dict[str, Any]] = None
  230. process_data: Optional[dict[str, Any]] = None
  231. outputs: Optional[dict[str, Any]] = None
  232. execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
  233. error: Optional[str] = None
  234. """single iteration duration map"""
  235. iteration_duration_map: Optional[dict[str, float]] = None
  236. class QueueNodeInIterationFailedEvent(AppQueueEvent):
  237. """
  238. QueueNodeInIterationFailedEvent entity
  239. """
  240. event: QueueEvent = QueueEvent.NODE_FAILED
  241. node_execution_id: str
  242. node_id: str
  243. node_type: NodeType
  244. node_data: BaseNodeData
  245. parallel_id: Optional[str] = None
  246. """parallel id if node is in parallel"""
  247. parallel_start_node_id: Optional[str] = None
  248. """parallel start node id if node is in parallel"""
  249. parent_parallel_id: Optional[str] = None
  250. """parent parallel id if node is in parallel"""
  251. parent_parallel_start_node_id: Optional[str] = None
  252. """parent parallel start node id if node is in parallel"""
  253. in_iteration_id: Optional[str] = None
  254. """iteration id if node is in iteration"""
  255. start_at: datetime
  256. inputs: Optional[dict[str, Any]] = None
  257. process_data: Optional[dict[str, Any]] = None
  258. outputs: Optional[dict[str, Any]] = None
  259. execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
  260. error: str
  261. class QueueNodeFailedEvent(AppQueueEvent):
  262. """
  263. QueueNodeFailedEvent entity
  264. """
  265. event: QueueEvent = QueueEvent.NODE_FAILED
  266. node_execution_id: str
  267. node_id: str
  268. node_type: NodeType
  269. node_data: BaseNodeData
  270. parallel_id: Optional[str] = None
  271. """parallel id if node is in parallel"""
  272. parallel_start_node_id: Optional[str] = None
  273. """parallel start node id if node is in parallel"""
  274. parent_parallel_id: Optional[str] = None
  275. """parent parallel id if node is in parallel"""
  276. parent_parallel_start_node_id: Optional[str] = None
  277. """parent parallel start node id if node is in parallel"""
  278. in_iteration_id: Optional[str] = None
  279. """iteration id if node is in iteration"""
  280. start_at: datetime
  281. inputs: Optional[dict[str, Any]] = None
  282. process_data: Optional[dict[str, Any]] = None
  283. outputs: Optional[dict[str, Any]] = None
  284. execution_metadata: Optional[dict[NodeRunMetadataKey, Any]] = None
  285. error: str
  286. class QueueAgentThoughtEvent(AppQueueEvent):
  287. """
  288. QueueAgentThoughtEvent entity
  289. """
  290. event: QueueEvent = QueueEvent.AGENT_THOUGHT
  291. agent_thought_id: str
  292. class QueueMessageFileEvent(AppQueueEvent):
  293. """
  294. QueueAgentThoughtEvent entity
  295. """
  296. event: QueueEvent = QueueEvent.MESSAGE_FILE
  297. message_file_id: str
  298. class QueueErrorEvent(AppQueueEvent):
  299. """
  300. QueueErrorEvent entity
  301. """
  302. event: QueueEvent = QueueEvent.ERROR
  303. error: Any = None
  304. class QueuePingEvent(AppQueueEvent):
  305. """
  306. QueuePingEvent entity
  307. """
  308. event: QueueEvent = QueueEvent.PING
  309. class QueueStopEvent(AppQueueEvent):
  310. """
  311. QueueStopEvent entity
  312. """
  313. class StopBy(Enum):
  314. """
  315. Stop by enum
  316. """
  317. USER_MANUAL = "user-manual"
  318. ANNOTATION_REPLY = "annotation-reply"
  319. OUTPUT_MODERATION = "output-moderation"
  320. INPUT_MODERATION = "input-moderation"
  321. event: QueueEvent = QueueEvent.STOP
  322. stopped_by: StopBy
  323. def get_stop_reason(self) -> str:
  324. """
  325. To stop reason
  326. """
  327. reason_mapping = {
  328. QueueStopEvent.StopBy.USER_MANUAL: "Stopped by user.",
  329. QueueStopEvent.StopBy.ANNOTATION_REPLY: "Stopped by annotation reply.",
  330. QueueStopEvent.StopBy.OUTPUT_MODERATION: "Stopped by output moderation.",
  331. QueueStopEvent.StopBy.INPUT_MODERATION: "Stopped by input moderation.",
  332. }
  333. return reason_mapping.get(self.stopped_by, "Stopped by unknown reason.")
  334. class QueueMessage(BaseModel):
  335. """
  336. QueueMessage abstract entity
  337. """
  338. task_id: str
  339. app_mode: str
  340. event: AppQueueEvent
  341. class MessageQueueMessage(QueueMessage):
  342. """
  343. MessageQueueMessage entity
  344. """
  345. message_id: str
  346. conversation_id: str
  347. class WorkflowQueueMessage(QueueMessage):
  348. """
  349. WorkflowQueueMessage entity
  350. """
  351. pass
  352. class QueueParallelBranchRunStartedEvent(AppQueueEvent):
  353. """
  354. QueueParallelBranchRunStartedEvent entity
  355. """
  356. event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_STARTED
  357. parallel_id: str
  358. parallel_start_node_id: str
  359. parent_parallel_id: Optional[str] = None
  360. """parent parallel id if node is in parallel"""
  361. parent_parallel_start_node_id: Optional[str] = None
  362. """parent parallel start node id if node is in parallel"""
  363. in_iteration_id: Optional[str] = None
  364. """iteration id if node is in iteration"""
  365. class QueueParallelBranchRunSucceededEvent(AppQueueEvent):
  366. """
  367. QueueParallelBranchRunSucceededEvent entity
  368. """
  369. event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_SUCCEEDED
  370. parallel_id: str
  371. parallel_start_node_id: str
  372. parent_parallel_id: Optional[str] = None
  373. """parent parallel id if node is in parallel"""
  374. parent_parallel_start_node_id: Optional[str] = None
  375. """parent parallel start node id if node is in parallel"""
  376. in_iteration_id: Optional[str] = None
  377. """iteration id if node is in iteration"""
  378. class QueueParallelBranchRunFailedEvent(AppQueueEvent):
  379. """
  380. QueueParallelBranchRunFailedEvent entity
  381. """
  382. event: QueueEvent = QueueEvent.PARALLEL_BRANCH_RUN_FAILED
  383. parallel_id: str
  384. parallel_start_node_id: str
  385. parent_parallel_id: Optional[str] = None
  386. """parent parallel id if node is in parallel"""
  387. parent_parallel_start_node_id: Optional[str] = None
  388. """parent parallel start node id if node is in parallel"""
  389. in_iteration_id: Optional[str] = None
  390. """iteration id if node is in iteration"""
  391. error: str