# Default logging configuration
default_level: INFO # Default level for modules not explicitly configured

# Per-module logging configuration
modules:
  haipr:  # Root module
    level: DEBUG
  haipr.train:
    level: DEBUG
  # haipr.data:
  #   level: INFO
#   haipr.models:
#     level: DEBUG

version: 1
disable_existing_loggers: false

filters:
  job_context:
    (): haipr.utils.logger.JobContextFilter

formatters:
  simple:
    format: '%(levelname)s [%(name)s] %(message)s'
  detailed:
    format: '%(asctime)s %(levelname)s [%(name)s]  %(filename)s:%(lineno)d - %(message)s'
    datefmt: '%Y-%m-%d %H:%M:%S'

handlers:
  console:
    class: logging.StreamHandler
    formatter: detailed
    filters: [job_context]
    stream: ext://sys.stdout
  mlflow:
    class: haipr.utils.logger.MLflowHandler
    formatter: detailed
    filters: [job_context]
    level: DEBUG
    formatter_config:
      log_base_dir: ${oc.env:HAIPR_LOG_DIR/, logs/}/${oc.select:mlflow.experiment_name, TEST}/${oc.select:mlflow.parent_run_name, run}/${now:%Y%m%d_%H%M%S}/logs
      buffer_size: 10
      loggers: haipr
  error:
    class: logging.StreamHandler
    formatter: detailed
    stream: ext://sys.stderr
    level: ERROR

loggers:
  haipr:
    handlers: [console, mlflow]
    propagate: false
root:
  handlers: [console]

