ytsm/app/YtManagerApp/appmain.py

48 lines
1.4 KiB
Python
Raw Normal View History

2018-10-11 01:43:50 +03:00
import logging
import logging.handlers
import os
2018-12-21 12:28:06 +02:00
import sys
from django.conf import settings as dj_settings
from .management.appconfig import appconfig
2019-08-14 17:14:16 +03:00
from .management.jobs.synchronize import SynchronizeJob
from .scheduler import scheduler
from django.db.utils import OperationalError
2018-12-21 12:28:06 +02:00
def __initialize_logger():
log_dir = os.path.join(dj_settings.DATA_DIR, 'logs')
os.makedirs(log_dir, exist_ok=True)
file_handler = logging.handlers.RotatingFileHandler(
os.path.join(log_dir, "log.log"),
maxBytes=1024 * 1024,
backupCount=5
)
2018-12-30 00:10:30 +02:00
file_handler.setLevel(dj_settings.LOG_LEVEL)
file_handler.setFormatter(logging.Formatter(dj_settings.LOG_FORMAT))
logging.root.addHandler(file_handler)
logging.root.setLevel(dj_settings.LOG_LEVEL)
2018-12-21 12:28:06 +02:00
if dj_settings.DEBUG:
console_handler = logging.StreamHandler(stream=sys.stdout)
console_handler.setLevel(logging.DEBUG)
2018-12-30 00:10:30 +02:00
console_handler.setFormatter(logging.Formatter(dj_settings.CONSOLE_LOG_FORMAT))
logging.root.addHandler(console_handler)
2018-10-11 01:43:50 +03:00
def main():
__initialize_logger()
try:
if appconfig.initialized:
2019-08-14 17:14:16 +03:00
scheduler.initialize()
SynchronizeJob.schedule_global_job()
except OperationalError:
2019-08-14 17:14:16 +03:00
# Settings table is not created when running migrate or makemigrations;
# Just don't do anything in this case.
pass
2018-10-11 01:43:50 +03:00
logging.info('Initialization complete.')