#!/usr/bin/env python3
import os
import logging
from logging.handlers import RotatingFileHandler
from pathlib import Path
import datetime

# Get project root directory
PROJECT_ROOT = Path(__file__).resolve().parents[1]
LOG_DIR = os.path.join(PROJECT_ROOT, "logs")
# Create log directory if it doesn't exist
os.makedirs(LOG_DIR, exist_ok=True)

# Log file naming convention
def get_log_filename():
    """Generate log filename with current date"""
    today = datetime.datetime.now().strftime("%Y-%m-%d")
    return f"agent_{today}.log"

# Log formatter
LOG_FORMAT = logging.Formatter(
    '%(asctime)s [%(levelname)s] %(name)s - %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S'
)

def setup_logger(name, level=logging.INFO, log_subdir=None, log_filename=None):
    """
    Setup and return a logger with the given name and level.

    Args:
        name (str): The name for the logger (typically __name__ from the calling module)
        level (int or str): The logging level (default: logging.INFO)
        log_subdir (str): Optional subdirectory under LOG_DIR, e.g., model name like 'Qwen2.5'
        log_filename (str): Optional log file name, e.g., 'run_1.log'
        
    Returns:
        logging.Logger: Configured logger instance
    """
    if isinstance(level, str):
        level = getattr(logging, level.upper())

    logger = logging.getLogger(name)

    if logger.handlers:
        return logger

    logger.setLevel(level)

    log_path = os.path.join(LOG_DIR, log_subdir) if log_subdir else LOG_DIR
    os.makedirs(log_path, exist_ok=True)

    log_file = log_filename if log_filename else get_log_filename()
    log_file_path = os.path.join(log_path, log_file)

    file_handler = RotatingFileHandler(
        log_file_path,
        maxBytes=10485760,
        backupCount=10
    )
    file_handler.setFormatter(LOG_FORMAT)

    console_handler = logging.StreamHandler()
    console_handler.setFormatter(LOG_FORMAT)

    logger.addHandler(file_handler)
    logger.addHandler(console_handler)

    return logger

# Example usage:
# from src.logger import setup_logger
# logger = setup_logger(__name__)
# logger.info("Application starting")