mirror of
https://github.com/ail-project/ail-framework.git
synced 2025-01-19 00:36:14 +00:00
53 lines
1.6 KiB
Python
Executable file
53 lines
1.6 KiB
Python
Executable file
#!/usr/bin/env python3
|
|
# -*-coding:UTF-8 -*
|
|
|
|
import os
|
|
import json
|
|
import sys
|
|
import logging
|
|
import logging.handlers
|
|
|
|
sys.path.append(os.environ['AIL_BIN'])
|
|
##################################
|
|
# Import Project packages
|
|
##################################
|
|
from lib.ConfigLoader import ConfigLoader
|
|
|
|
config_loader = ConfigLoader()
|
|
r_db = config_loader.get_db_conn("Kvrocks_DB")
|
|
config_loader = None
|
|
|
|
LOGGING_CONF_DIR = os.path.join(os.environ['AIL_HOME'], 'configs')
|
|
LOGS_DIR = os.path.join(os.environ['AIL_HOME'], 'logs')
|
|
|
|
def get_config(name=None):
|
|
if not name:
|
|
name = 'ail.log'
|
|
else:
|
|
name = f'{name}.log'
|
|
with open(os.path.join(LOGGING_CONF_DIR, f'logging.json'), 'r') as f:
|
|
config = json.load(f)
|
|
config['handlers']['file']['filename'] = os.path.join(LOGS_DIR, name)
|
|
return config
|
|
|
|
def get_access_config(create=False):
|
|
logger = logging.getLogger('access.log')
|
|
|
|
if create:
|
|
formatter = logging.Formatter('%(asctime)s - %(ip_address)s - %(user_agent)s - %(levelname)s - %(user_id)s - %(message)s')
|
|
|
|
# STDOUT
|
|
handler = logging.StreamHandler()
|
|
handler.setLevel(logging.INFO)
|
|
handler.setFormatter(formatter)
|
|
logger.addHandler(handler)
|
|
|
|
# FILE
|
|
handler = logging.handlers.RotatingFileHandler(filename=os.path.join(LOGS_DIR, f'access.log'),
|
|
maxBytes=10*1024*1024, backupCount=5)
|
|
handler.setLevel(logging.INFO)
|
|
handler.setFormatter(formatter)
|
|
logger.addHandler(handler)
|
|
|
|
logger.propagate = False
|
|
return logger
|