"""Logging utilities for CIRBench.

Provides standardized logging configuration including Rich console output,
JSONL structured logs, and file logging. Includes helpers for redacting
sensitive text and compacting log messages to a single line.
"""
from __future__ import annotations
import logging, json, re, os
from pathlib import Path

try:
    from rich.logging import RichHandler
except Exception:
    RichHandler = None

def get_logger(name: str = "cirbench") -> logging.Logger:
    """Return a logger instance with the given name."""
    return logging.getLogger(name)

def _collapse_ws(s: str) -> str:
    """Collapse whitespace into single spaces."""
    return re.sub(r"\s+", " ", s).strip()

def _redact(s: str) -> str:
    """Redact common secret patterns such as API keys and Bearer tokens."""
    s = re.sub(r"(api[_-]?key\s*[:=]\s*)([A-Za-z0-9_\-]{12,})", r"\1***", s, flags=re.I)
    s = re.sub(r"(Bearer\s+)[A-Za-z0-9_\-]{12,}", r"\1***", s)
    return s

def one_line(s: str, maxlen: int = 160) -> str:
    """Compact a string into a single sanitized line up to maxlen."""
    s = _collapse_ws(_redact(s))
    return (s[: maxlen - 3] + "...") if len(s) > maxlen else s

def debug_on() -> bool:
    """Return True if CIRBENCH_DEBUG=1."""
    return os.getenv("CIRBENCH_DEBUG", "0") == "1"

def debug_full_on() -> bool:
    """Return True if CIRBENCH_DEBUG_FULL=1."""
    return os.getenv("CIRBENCH_DEBUG_FULL", "0") == "1"

def setup_logging(
    log_dir: Path,
    level: int = logging.INFO,
    log_json: bool = True,
    console_rich: bool = True,
    log_name: str = "cirbench",
) -> logging.Logger:
    """Configure console, file, and JSONL logging for CIRBench.

    Args:
        log_dir: Directory where logs will be stored.
        level: Logging level (default: INFO).
        log_json: Whether to also write JSONL logs.
        console_rich: Whether to use RichHandler for console output.
        log_name: Logger name (default: 'cirbench').

    Returns:
        The configured logger instance.
    """
    log_dir = Path(log_dir)
    log_dir.mkdir(parents=True, exist_ok=True)
    os.environ["CIRBENCH_LOG_DIR"] = str(log_dir) 

    logger = logging.getLogger(log_name)
    logger.setLevel(level)
    logger.propagate = False

    # Remove old handlers to prevent duplicate logs
    for h in list(logger.handlers):
        logger.removeHandler(h)

    # Console
    if console_rich and RichHandler is not None:
        ch = RichHandler(rich_tracebacks=False, show_time=True, show_path=False, markup=False)
        ch.setFormatter(logging.Formatter("%(message)s"))
    else:
        ch = logging.StreamHandler()
        ch.setFormatter(logging.Formatter(
            fmt="%(asctime)s | %(levelname)s | %(message)s",
            datefmt="%Y-%m-%d %H:%M:%S",
        ))
    ch.setLevel(level)
    logger.addHandler(ch)

    # Text file
    fh = logging.FileHandler(log_dir / "cirbench.log", encoding="utf-8")
    fh.setLevel(level)
    fh.setFormatter(logging.Formatter(
        fmt="%(asctime)s | %(levelname)s | %(name)s | %(message)s",
        datefmt="%Y-%m-%d %H:%M:%S",
    ))
    logger.addHandler(fh)

    # JSONL
    if log_json:
        class JsonlFormatter(logging.Formatter):
            def format(self, record: logging.LogRecord) -> str:
                obj = {
                    "ts": self.formatTime(record, "%Y-%m-%d %H:%M:%S"),
                    "level": record.levelname,
                    "logger": record.name,
                    "msg": record.getMessage(),
                }
                return json.dumps(obj, ensure_ascii=False)
        jh = logging.FileHandler(log_dir / "cirbench.jsonl", encoding="utf-8")
        jh.setLevel(level)
        jh.setFormatter(JsonlFormatter())
        logger.addHandler(jh)

    return logger