debug_mixin.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. from typing import Any
  2. from openhands.core.logger import llm_prompt_logger, llm_response_logger
  3. from openhands.core.logger import openhands_logger as logger
  4. MESSAGE_SEPARATOR = '\n\n----------\n\n'
  5. class DebugMixin:
  6. def log_prompt(self, messages: list[dict[str, Any]] | dict[str, Any]):
  7. if not messages:
  8. logger.debug('No completion messages!')
  9. return
  10. messages = messages if isinstance(messages, list) else [messages]
  11. debug_message = MESSAGE_SEPARATOR.join(
  12. self._format_message_content(msg) for msg in messages if msg['content']
  13. )
  14. if debug_message:
  15. llm_prompt_logger.debug(debug_message)
  16. else:
  17. logger.debug('No completion messages!')
  18. def log_response(self, message_back: str):
  19. if message_back:
  20. llm_response_logger.debug(message_back)
  21. def _format_message_content(self, message: dict[str, Any]):
  22. content = message['content']
  23. if isinstance(content, list):
  24. return '\n'.join(
  25. self._format_content_element(element) for element in content
  26. )
  27. return str(content)
  28. def _format_content_element(self, element: dict[str, Any]):
  29. if isinstance(element, dict):
  30. if 'text' in element:
  31. return element['text']
  32. if (
  33. self.vision_is_active()
  34. and 'image_url' in element
  35. and 'url' in element['image_url']
  36. ):
  37. return element['image_url']['url']
  38. return str(element)
  39. # This method should be implemented in the class that uses DebugMixin
  40. def vision_is_active(self):
  41. raise NotImplementedError