|
11 | 11 | ChatMessage, |
12 | 12 | WorkflowOutputEvent, |
13 | 13 | MagenticBuilder, |
14 | | - MagenticCallbackMode, |
| 14 | + # MagenticCallbackMode, |
15 | 15 | MagenticOrchestratorMessageEvent, |
16 | 16 | MagenticAgentDeltaEvent, |
17 | 17 | MagenticAgentMessageEvent, |
@@ -166,7 +166,7 @@ async def on_event(event) -> None: |
166 | 166 | builder = ( |
167 | 167 | MagenticBuilder() |
168 | 168 | .participants(**participants) |
169 | | - .on_event(on_event, mode=MagenticCallbackMode.STREAMING) # Enable streaming events |
| 169 | + #.on_event(on_event) # Enable streaming events |
170 | 170 | .with_standard_manager(manager=manager) |
171 | 171 | ) |
172 | 172 |
|
@@ -255,15 +255,48 @@ async def run_orchestration(self, user_id: str, input_task) -> None: |
255 | 255 |
|
256 | 256 | self.logger.info("Starting workflow execution...") |
257 | 257 | async for event in workflow.run_stream(task_text): |
258 | | - # Check if this is the final output event |
259 | | - if isinstance(event, WorkflowOutputEvent): |
260 | | - # Extract text from ChatMessage object |
261 | | - output_data = event.data |
262 | | - if isinstance(output_data, ChatMessage): |
263 | | - final_output = getattr(output_data, "text", None) or str(output_data) |
264 | | - else: |
265 | | - final_output = str(output_data) |
266 | | - self.logger.debug("Received workflow output event") |
| 258 | + try: |
| 259 | + # Handle orchestrator messages (task assignments, coordination) |
| 260 | + if isinstance(event, MagenticOrchestratorMessageEvent): |
| 261 | + message_text = getattr(event.message, 'text', '') |
| 262 | + self.logger.info(f"[ORCHESTRATOR:{event.kind}] {message_text}") |
| 263 | + |
| 264 | + # Handle streaming updates from agents |
| 265 | + elif isinstance(event, MagenticAgentDeltaEvent): |
| 266 | + try: |
| 267 | + await streaming_agent_response_callback( |
| 268 | + event.agent_id, |
| 269 | + event, # Pass the event itself as the update object |
| 270 | + False, # Not final yet (streaming in progress) |
| 271 | + user_id |
| 272 | + ) |
| 273 | + except Exception as e: |
| 274 | + self.logger.error(f"Error in streaming callback for agent {event.agent_id}: {e}") |
| 275 | + |
| 276 | + # Handle final agent messages (complete response) |
| 277 | + elif isinstance(event, MagenticAgentMessageEvent): |
| 278 | + if event.message: |
| 279 | + try: |
| 280 | + agent_response_callback(event.agent_id, event.message, user_id) |
| 281 | + except Exception as e: |
| 282 | + self.logger.error(f"Error in agent callback for agent {event.agent_id}: {e}") |
| 283 | + |
| 284 | + # Handle final result from the entire workflow |
| 285 | + elif isinstance(event, MagenticFinalResultEvent): |
| 286 | + final_text = getattr(event.message, 'text', '') |
| 287 | + self.logger.info(f"[FINAL RESULT] Length: {len(final_text)} chars") |
| 288 | + |
| 289 | + # Handle workflow output event (captures final result) |
| 290 | + elif isinstance(event, WorkflowOutputEvent): |
| 291 | + output_data = event.data |
| 292 | + if isinstance(output_data, ChatMessage): |
| 293 | + final_output = getattr(output_data, "text", None) or str(output_data) |
| 294 | + else: |
| 295 | + final_output = str(output_data) |
| 296 | + self.logger.debug("Received workflow output event") |
| 297 | + |
| 298 | + except Exception as e: |
| 299 | + self.logger.error(f"Error processing event {type(event).__name__}: {e}", exc_info=True) |
267 | 300 |
|
268 | 301 | # Extract final result |
269 | 302 | final_text = final_output if final_output else "" |
|
0 commit comments