from loguru import logger
import os
import sys

distflow_LOG_DIRCTORY = os.getenv("distflow_LOG_DIRECTORY", "distflow_logs")

distflow_LOGGING_FILENAME = os.getenv("distflow_LOGGING_FILENAME", "distflow")
if distflow_LOGGING_FILENAME != "":
    distflow_LOGGING_FILENAME += "_"


def set_basic_config():
    """
    This function sets the global logging format and level. It will be called when import distflow
    """

    log_level = os.environ.get("LOGURU_LEVEL", "INFO")

    logger.remove()
    logger.level("CRITICAL", color="<bold white on red>")
    # logger.level("ERROR", color="<red><bold>")
    # logger.level("WARNING", color="<yellow>")
    logger.add(
        sys.stderr,
        level=log_level,
        format=(
            "<green>{time:YYYY-MM-DD HH:mm:ss.SSS}</green> | "
            "<level>{level.icon}</level> "
            "<level>{level: <8}</level> | "
            # Added :<magenta>{line}</magenta> to include the line number
            "<blue>{file}</blue>:<magenta>{line}</magenta>:<cyan>{function}</cyan> >> "
            "<level>{message}</level>"
        ),
        enqueue=True,
        colorize=True,
    )
    os.makedirs(distflow_LOG_DIRCTORY, exist_ok=True)

    logger.add(
        sink=os.path.join(distflow_LOG_DIRCTORY, distflow_LOGGING_FILENAME + "{time:YYYY-MM-DD-HH}.log"),
        level=log_level,
        rotation="500 MB",
        retention="30 days",
        format="{time:YYYY-MM-DD HH:mm:ss.SSS} | {level} | {module}:{function}:{line} >> {message}",
        compression="zip",
        encoding="utf-8",
        enqueue=True,
    )
