"""
Attack Logger Wrapper
========================
"""


import os
import logging


class Logger:
    """An abstract class for different methods of logging attack results."""

    def __init__(self, save_path = r'logger.log'):
        """
        NOTE:
        - This class is kept for backward compatibility, but it should NOT reconfigure
          global logging or add duplicate handlers (especially under multi-threading),
          otherwise each log line will be printed N times.
        - We default to being a no-op. If you want a per-run file log, set
          EASYJAILBREAK_ENABLE_FILE_LOG=true.
        """
        self.logger = logging.getLogger()

        enable_file_log = os.environ.get("EASYJAILBREAK_ENABLE_FILE_LOG", "false").lower() == "true"
        if enable_file_log and save_path:
            # Add a single file handler (idempotent) with a stable name.
            handler_name = "easyjailbreak_file_handler"
            if not any(getattr(h, "name", None) == handler_name for h in self.logger.handlers):
                file_handler = logging.FileHandler(save_path)
                file_handler.setFormatter(
                    logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")
                )
                try:
                    file_handler.set_name(handler_name)
                except Exception:
                    # Older Python/logging may not support naming; still safe due to handler check above.
                    pass
                self.logger.addHandler(file_handler)

    def log_attack_result(self, result, examples_completed=None):
        pass

    def log_summary_rows(self, rows, title, window_id):
        pass

    def log_hist(self, arr, numbins, title, window_id):
        pass

    def log_sep(self):
        pass

    def flush(self):
        pass

    def close(self):
        pass



class KeywordFilter(logging.Filter):
    def __init__(self, keyword):
        self.keyword = keyword

    def filter(self, record):
        # Drop log records whose message contains the keyword.
        return self.keyword not in record.getMessage()

# Create a logger.

# Create and attach filters.
