import wandb

from omegaconf import DictConfig, OmegaConf


def retrieve_tags(config: DictConfig) -> str:
    """Retrieve tags from config."""
    
    tags = []
    for key in config:
        if isinstance(config[key], DictConfig):
            tags.extend(retrieve_tags(config[key]))
        elif key == 'tags':
            tags.extend(config[key])
        else:
            pass
    
    return tags

def init_logger(config: DictConfig) -> None:
    """
    Initialize the logger for the experiment.
    
    Args:
        config (DictConfig): Configuration for the experiment.
    """

    if config.logger.name not in ["wandb", "none"]:
        raise ValueError(f"Unsupported logger: {config.logger.name}. Supported loggers: ['wandb', 'none']")

    if config.logger.name == "none":
        print("No logger initialized. Skipping logging.")
        return
    
    # Initialize Weights & Biases
    wandb.init(
        project=config.logger.project,
        tags=retrieve_tags(config),
    )
    
    # Log the configuration
    wandb.config.update(OmegaConf.to_container(config, resolve=True))
    
    print("Wandb logger initialized with configuration:")
    print(OmegaConf.to_yaml(config))