1
0
forked from bot/app

新增启动时对本地仓库的检测

This commit is contained in:
远野千束 2024-06-01 15:26:13 +08:00
parent 62928e47eb
commit 4cdf29557c
3 changed files with 13 additions and 4 deletions

View File

@ -29,7 +29,7 @@ if get_config("debug", False):
Handler for code file changes Handler for code file changes
""" """
def on_modified(self, event): def on_modified(self, event):
if event.src_path.endswith(src_excludes_extensions) or event.is_directory: if event.src_path.endswith(src_excludes_extensions) or event.is_directory or "__pycache__" in event.src_path:
return return
nonebot.logger.debug(f"{event.src_path} modified, reloading bot...") nonebot.logger.debug(f"{event.src_path} modified, reloading bot...")
Reloader.reload() Reloader.reload()

View File

@ -15,11 +15,11 @@ from liteyuki.utils.base.resource import get_loaded_resource_packs, get_path
from liteyuki.utils.message.html_tool import template2image from liteyuki.utils.message.html_tool import template2image
from liteyuki.utils import satori_utils from liteyuki.utils import satori_utils
from .counter_for_satori import satori_counter from .counter_for_satori import satori_counter
from git import Repo
require("nonebot_plugin_apscheduler") require("nonebot_plugin_apscheduler")
from nonebot_plugin_apscheduler import scheduler from nonebot_plugin_apscheduler import scheduler
commit_hash = None commit_hash = Repo(".").head.commit.hexsha
protocol_names = { protocol_names = {
0: "iPad", 0: "iPad",
@ -265,7 +265,7 @@ async def get_liteyuki_data() -> dict:
temp_data: TempConfig = common_db.where_one(TempConfig(), default=TempConfig()) temp_data: TempConfig = common_db.where_one(TempConfig(), default=TempConfig())
result = { result = {
"name": list(get_config("nickname", [__NAME__]))[0], "name": list(get_config("nickname", [__NAME__]))[0],
"version": f"{__VERSION__}({commit_hash})", "version": f"{__VERSION__}({commit_hash[:7] if (commit_hash and len(commit_hash) > 8) else ''})",
"plugins": len(nonebot.get_loaded_plugins()), "plugins": len(nonebot.get_loaded_plugins()),
"resources": len(get_loaded_resource_packs()), "resources": len(get_loaded_resource_packs()),
"nonebot": f"{nonebot.__version__}", "nonebot": f"{nonebot.__version__}",

View File

@ -14,6 +14,8 @@ import requests
from liteyuki.utils.base.config import load_from_yaml, config from liteyuki.utils.base.config import load_from_yaml, config
from liteyuki.utils.base.log import init_log from liteyuki.utils.base.log import init_log
from liteyuki.utils.base.data_manager import TempConfig, auto_migrate, common_db from liteyuki.utils.base.data_manager import TempConfig, auto_migrate, common_db
from git import Repo
major, minor, patch = map(int, __VERSION__.split(".")) major, minor, patch = map(int, __VERSION__.split("."))
__VERSION_I__ = major * 10000 + minor * 100 + patch __VERSION_I__ = major * 10000 + minor * 100 + patch
@ -56,6 +58,13 @@ def init():
if sys.version_info < (3, 10): if sys.version_info < (3, 10):
nonebot.logger.error("Requires Python3.10+ to run, please upgrade your Python Environment.") nonebot.logger.error("Requires Python3.10+ to run, please upgrade your Python Environment.")
exit(1) exit(1)
try:
# 检测git仓库
repo = Repo(".")
except Exception as e:
nonebot.logger.error(f"Failed to load git repository: {e}, please clone this project from GitHub instead of downloading the zip file.")
temp_data: TempConfig = common_db.where_one(TempConfig(), default=TempConfig()) temp_data: TempConfig = common_db.where_one(TempConfig(), default=TempConfig())
temp_data.data["start_time"] = time.time() temp_data.data["start_time"] = time.time()
common_db.save(temp_data) common_db.save(temp_data)