代码拉取完成,页面将自动刷新
同步操作将从 anydev/karaoke 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Author: leeyoshinari
import os
import shutil
import sys
import configparser
import logging.handlers
if hasattr(sys, 'frozen'):
path = os.path.dirname(sys.executable)
else:
path = os.path.dirname(os.path.abspath(__file__))
cfg = configparser.ConfigParser()
config_path = os.path.join(path, 'config.conf')
cfg.read(config_path, encoding='utf-8')
PAGE_SIZE = 20
def get_config(key):
return cfg.get('default', key, fallback=None)
TORTOISE_ORM = {
"connections": {"default": get_config("dbUrl")},
"apps": {
"models": {
"models": ["karaoke.models", "aerich.models"],
"default_connection": "default"
}
},
"timezone": "Asia/Shanghai"
}
CONTENT_TYPE = {'mp4': 'video/mp4', 'mp3': 'audio/mpeg'}
FILE_PATH = get_config("path")
if not os.path.exists(FILE_PATH):
raise FileNotFoundError(FILE_PATH)
VIDEO_PATH = os.path.join(path, 'static', 'videos')
if os.path.exists(VIDEO_PATH):
shutil.rmtree(VIDEO_PATH)
os.mkdir(VIDEO_PATH)
log_path = os.path.join(path, 'logs')
if not os.path.exists(log_path):
os.mkdir(log_path)
log_level = {
'DEBUG': logging.DEBUG,
'INFO': logging.INFO,
'WARNING': logging.WARNING,
'ERROR': logging.ERROR,
'CRITICAL': logging.CRITICAL
}
logger = logging.getLogger()
formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(threadName)s - %(filename)s[line:%(lineno)d] - %(message)s')
logger.setLevel(level=log_level.get(get_config("level")))
file_handler = logging.handlers.TimedRotatingFileHandler(os.path.join(log_path, 'access.log'), when='midnight', interval=1, backupCount=7)
file_handler.suffix = '%Y-%m-%d.log'
file_handler = logging.StreamHandler()
file_handler.setFormatter(formatter)
logger.addHandler(file_handler)
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。