mirror of
https://github.com/hyb-oyqq/FRAISEMOE-Addons-Installer-NEXT.git
synced 2025-12-16 20:10:28 +00:00
- 更新日志记录机制,将日志文件存储在程序根目录下的log文件夹中,并使用日期+时间戳格式命名。 - 在多个模块中添加详细的错误处理逻辑,确保在发生异常时能够记录相关信息,便于后续排查。 - 优化UI管理器中的日志文件打开功能,增加对日志文件存在性和大小的检查,提升用户体验。 - 在下载管理器和补丁管理器中增强调试信息的记录,确保在关键操作中提供更清晰的反馈。
91 lines
3.4 KiB
Python
91 lines
3.4 KiB
Python
import os
|
||
import base64
|
||
import datetime
|
||
|
||
# 配置信息
|
||
app_data = {
|
||
"APP_VERSION": "1.3.2",
|
||
"APP_NAME": "FRAISEMOE Addons Installer NEXT",
|
||
"TEMP": "TEMP",
|
||
"CACHE": "FRAISEMOE",
|
||
"PLUGIN": "PLUGIN",
|
||
"CONFIG_URL": "aHR0cHM6Ly9hcGkuMncyLnRvcC9hcGkvb3V5YW5ncWlxaS9uZWtvcGFyYS9kb3dubG9hZF91cmwuanNvbg==",
|
||
"UA_TEMPLATE": "Mozilla/5.0 (Linux debian12 FraiseMoe2-Accept-Next) Gecko/20100101 Firefox/114.0 FraiseMoe2/{}",
|
||
"game_info": {
|
||
"NEKOPARA Vol.1": {
|
||
"exe": "nekopara_vol1.exe",
|
||
"hash": "04b48b231a7f34431431e5027fcc7b27affaa951b8169c541709156acf754f3e",
|
||
"install_path": "NEKOPARA Vol. 1/adultsonly.xp3",
|
||
"plugin_path": "vol.1/adultsonly.xp3",
|
||
},
|
||
"NEKOPARA Vol.2": {
|
||
"exe": "nekopara_vol2.exe",
|
||
"hash": "b9c00a2b113a1e768bf78400e4f9075ceb7b35349cdeca09be62eb014f0d4b42",
|
||
"install_path": "NEKOPARA Vol. 2/adultsonly.xp3",
|
||
"plugin_path": "vol.2/adultsonly.xp3",
|
||
},
|
||
"NEKOPARA Vol.3": {
|
||
"exe": "NEKOPARAvol3.exe",
|
||
"hash": "2ce7b223c84592e1ebc3b72079dee1e5e8d064ade15723328a64dee58833b9d5",
|
||
"install_path": "NEKOPARA Vol. 3/update00.int",
|
||
"plugin_path": "vol.3/update00.int",
|
||
},
|
||
"NEKOPARA Vol.4": {
|
||
"exe": "nekopara_vol4.exe",
|
||
"hash": "4a4a9ae5a75a18aacbe3ab0774d7f93f99c046afe3a777ee0363e8932b90f36a",
|
||
"install_path": "NEKOPARA Vol. 4/vol4adult.xp3",
|
||
"plugin_path": "vol.4/vol4adult.xp3",
|
||
},
|
||
"NEKOPARA After": {
|
||
"exe": "nekopara_after.exe",
|
||
"hash": "eb26ff6850096a240af8340ba21c5c3232e90f29fb8191e24b6ce701acae0aa9",
|
||
"install_path": "NEKOPARA After/afteradult.xp3",
|
||
"plugin_path": "after/afteradult.xp3",
|
||
"sig_path": "after/afteradult.xp3.sig"
|
||
},
|
||
},
|
||
}
|
||
|
||
# Base64解码
|
||
def decode_base64(encoded_str):
|
||
return base64.b64decode(encoded_str).decode("utf-8")
|
||
|
||
# 全局变量
|
||
APP_VERSION = app_data["APP_VERSION"]
|
||
APP_NAME = app_data["APP_NAME"]
|
||
TEMP = os.getenv(app_data["TEMP"]) or app_data["TEMP"]
|
||
CACHE = os.path.join(TEMP, app_data["CACHE"])
|
||
CONFIG_FILE = os.path.join(CACHE, "config.json")
|
||
|
||
# 将log文件放在程序根目录下的log文件夹中,使用日期+时间戳格式命名
|
||
root_dir = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))
|
||
log_dir = os.path.join(root_dir, "log")
|
||
current_datetime = datetime.datetime.now().strftime("%Y%m%d-%H%M%S")
|
||
LOG_FILE = os.path.join(log_dir, f"log-{current_datetime}.txt")
|
||
|
||
PLUGIN = os.path.join(CACHE, app_data["PLUGIN"])
|
||
CONFIG_URL = decode_base64(app_data["CONFIG_URL"])
|
||
UA = app_data["UA_TEMPLATE"].format(APP_VERSION)
|
||
GAME_INFO = app_data["game_info"]
|
||
BLOCK_SIZE = 67108864
|
||
HASH_SIZE = 134217728
|
||
PLUGIN_HASH = {
|
||
"NEKOPARA Vol.1": GAME_INFO["NEKOPARA Vol.1"]["hash"],
|
||
"NEKOPARA Vol.2": GAME_INFO["NEKOPARA Vol.2"]["hash"],
|
||
"NEKOPARA Vol.3": GAME_INFO["NEKOPARA Vol.3"]["hash"],
|
||
"NEKOPARA Vol.4": GAME_INFO["NEKOPARA Vol.4"]["hash"],
|
||
"NEKOPARA After": GAME_INFO["NEKOPARA After"]["hash"]
|
||
}
|
||
PROCESS_INFO = {info["exe"]: game for game, info in GAME_INFO.items()}
|
||
|
||
# 下载线程档位设置
|
||
DOWNLOAD_THREADS = {
|
||
"low": 1, # 低速
|
||
"medium": 8, # 中速(默认)
|
||
"high": 16, # 高速
|
||
"extreme": 32, # 极速
|
||
"insane": 64 # 狂暴
|
||
}
|
||
|
||
# 默认下载线程档位
|
||
DEFAULT_DOWNLOAD_THREAD_LEVEL = "high" |