Merge pull request #41 from SaigyoujiYusora/debug

初次启动检测
This commit is contained in:
SengokuCola
2025-03-04 10:04:02 +08:00
committed by GitHub
5 changed files with 37 additions and 13 deletions

2
.env
View File

@@ -1,2 +0,0 @@
# 您不应该修改默认值,这个文件被仓库索引,请修改.env.prod
ENVIRONMENT=.dev

3
.gitignore vendored
View File

@@ -9,9 +9,10 @@ message_queue_window.bat
message_queue_window.txt
queue_update.txt
memory_graph.gml
.env
.env.*
config/bot_config_dev.toml
config/bot_config.toml
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]

45
bot.py
View File

@@ -6,6 +6,7 @@ from loguru import logger
'''彩蛋'''
from colorama import init, Fore
init()
text = "多年以后面对行刑队张三将会回想起他2023年在会议上讨论人工智能的那个下午"
rainbow_colors = [Fore.RED, Fore.YELLOW, Fore.GREEN, Fore.CYAN, Fore.BLUE, Fore.MAGENTA]
@@ -15,22 +16,47 @@ for i, char in enumerate(text):
print(rainbow_text)
'''彩蛋'''
# 初次启动检测
if not os.path.exists("config/bot_config.toml") or not os.path.exists(".env"):
logger.info("检测到bot_config.toml不存在正在从模板复制")
import shutil
shutil.copy("config/bot_config_template.toml", "config/bot_config.toml")
logger.info("复制完成请修改config/bot_config.toml和.env.prod中的配置后重新启动")
# 初始化.env 默认ENVIRONMENT=prod
if not os.path.exists(".env"):
with open(".env", "w") as f:
f.write("ENVIRONMENT=prod")
# 检测.env.prod文件是否存在
if not os.path.exists(".env.prod"):
logger.error("检测到.env.prod文件不存在")
shutil.copy("template.env", "./.env.prod")
# 首先加载基础环境变量.env
if os.path.exists(".env"):
load_dotenv(".env")
logger.success("成功加载基础环境变量配置")
else:
logger.error("基础环境变量配置文件 .env 不存在")
exit(1)
if os.path.exists(".env.dev"):
# 根据 ENVIRONMENT 加载对应的环境配置
if os.getenv("ENVIRONMENT") == "prod":
logger.success("加载生产环境变量配置")
load_dotenv(".env.prod", override=True) # override=True 允许覆盖已存在的环境变量
elif os.getenv("ENVIRONMENT") == "dev":
logger.success("加载开发环境变量配置")
load_dotenv(".env.dev", override=True) # override=True 允许覆盖已存在的环境变量
elif os.path.exists(".env.prod"):
logger.success("加载环境变量配置")
load_dotenv(".env.prod", override=True) # override=True 允许覆盖已存在的环境变量
elif os.path.exists(f".env.{os.getenv('ENVIRONMENT')}"):
logger.success(f"加载{os.getenv('ENVIRONMENT')}环境变量配置")
load_dotenv(f".env.{os.getenv('ENVIRONMENT')}", override=True) # override=True 允许覆盖已存在的环境变量
else:
logger.error(f".env对应的环境配置文件不存在,请修改.env文件中的ENVIRONMENT变量为 prod.")
logger.error(f"ENVIRONMENT配置错误请检查.env文件中的ENVIRONMENT变量对应的.env.{os.getenv('ENVIRONMENT')}是否存在")
exit(1)
# 检测Key是否存在
if not os.getenv("DEEP_SEEK_KEY") and not os.getenv("SILICONFLOW_KEY") and not os.getenv("CHAT_ANY_WHERE_KEY"):
logger.error("缺失必要的API KEY")
logger.info(f"请至少在.env.{os.getenv('ENVIRONMENT')}文件中填写SILICONFLOW_KEY后重新启动")
exit(1)
# 获取所有环境变量
@@ -54,5 +80,4 @@ driver.register_adapter(Adapter)
nonebot.load_plugins("src/plugins")
if __name__ == "__main__":
nonebot.run()
nonebot.run()