queue_entities.py 14 KB

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