from loguru import logger
import sys
import os

# Flag to track if already configured
_configured = False

def configure_logger():
    """
    Configure loguru logger, ensuring it's only configured once
    """
    global _configured
    if _configured:
        return
    

    os.makedirs('logs', exist_ok=True)
    

    logger.remove()
    

    logger.add(
        sys.stdout,
        format="<green>{time:HH:mm:ss}</green> | <level>{level: <8}</level> | <cyan>{name}</cyan>:<cyan>{function}</cyan>:<cyan>{line}</cyan> - <level>{message}</level>",
        level="INFO"
    )
    

    logger.add(
        "logs/infer_{time:YYYY-MM-DD-HH-mm}.log",
        format="{time:YYYY-MM-DD HH:mm:ss} | {level: <8} | {name}:{function}:{line} - {message}",
        level="DEBUG",
        rotation="10 GB",  # 10GB rotation
        retention="30 days",
        compression="zip",
        encoding="utf-8"
    )
    
    #
    logger.add(
        "logs/error_{time:YYYY-MM-DD-HH-mm}.log",
        format="{time:YYYY-MM-DD HH:mm:ss} | {level: <8} | {name}:{function}:{line} - {message}",
        level="ERROR",
        rotation="5 GB", 
        retention="30 days",
        compression="zip",
        encoding="utf-8"
    )
    
    _configured = True


configure_logger()