# -*-coding:utf-8-*-

import logging.config


def singleton(cls):
    instances = {}

    def get_instance():
        if cls not in instances:
            instances[cls] = cls()
        return instances[cls]

    return get_instance()

import time
@singleton
class Logger():
    def __init__(self):
        logging.basicConfig(format='%(asctime)s %(levelname)s %(process)d [%(filename)s:%(lineno)d] %(message)s',
                            level=logging.INFO)
        self.logger = logging.getLogger('root')

    def set_logger(self, env='terminal'):
        '''
        default evn is terminal
        when we connect our agent with web service, we need to automatic output all logger into one file, pls set evn='web'
        :param env:
        :return:
        '''
        if env == 'terminal':
            logging.basicConfig(format='%(asctime)s %(levelname)s %(process)d [%(filename)s:%(lineno)d] %(message)s',
                                level=logging.INFO)
            self.logger = logging.getLogger('root')
        else:
            self.logger = logging.getLogger('root')
            self.logger.setLevel(logging.INFO)
            
            # os.makedirs("train_logs", exist_ok=True)

            # # 使用 datetime 生成格式化时间戳作为文件名
            # timestamp = datetime.now().strftime("%Y-%m-%d_%H-%M-%S")
            # file_name = os.path.join("logs", f"log_{timestamp}.log")

            BASIC_FORMAT = '%(asctime)s %(levelname)s %(process)d [%(filename)s:%(lineno)d] %(message)s'
            formatter = logging.Formatter(BASIC_FORMAT)

            # stdout
            chlr = logging.StreamHandler()
            chlr.setLevel(logging.INFO)
            chlr.setFormatter(formatter)
            # log file
            file_name = time.strftime("%Y-%m-%d-%H:%M:%S", time.localtime()) + ".log"
            fhlr = logging.FileHandler(file_name)
            fhlr.setLevel(logging.INFO)
            fhlr.setFormatter(formatter)

            self.logger.addHandler(chlr)
            self.logger.addHandler(fhlr)