mirror of
https://github.com/hyb-oyqq/FRAISEMOE-Addons-Installer-NEXT.git
synced 2025-12-17 04:20:28 +00:00
- 在主窗口中添加离线模式管理器,支持自动切换到离线模式。 - 更新下载管理器以处理离线模式下的下载逻辑,确保用户体验流畅。 - 添加版本警告机制,提示用户在版本过低时的操作选项。 - 优化配置管理器,确保在离线模式下仍可使用相关功能。 - 更新UI管理器以反映当前工作模式,提升用户界面友好性。
101 lines
4.2 KiB
Python
101 lines
4.2 KiB
Python
import json
|
||
import requests
|
||
import webbrowser
|
||
from PySide6.QtCore import QThread, Signal
|
||
from PySide6.QtWidgets import QMessageBox
|
||
import sys
|
||
|
||
class ConfigFetchThread(QThread):
|
||
finished = Signal(object, str) # data, error_message
|
||
|
||
def __init__(self, url, headers, debug_mode=False, parent=None):
|
||
super().__init__(parent)
|
||
self.url = url
|
||
self.headers = headers
|
||
self.debug_mode = debug_mode
|
||
|
||
def run(self):
|
||
try:
|
||
if self.debug_mode:
|
||
print("--- Starting to fetch cloud config ---")
|
||
# 完全隐藏URL
|
||
print(f"DEBUG: Requesting URL: ***URL protection***")
|
||
print(f"DEBUG: Using Headers: {self.headers}")
|
||
|
||
response = requests.get(self.url, headers=self.headers, timeout=10)
|
||
|
||
if self.debug_mode:
|
||
print(f"DEBUG: Response Status Code: {response.status_code}")
|
||
print(f"DEBUG: Response Headers: {response.headers}")
|
||
|
||
# 解析并隐藏响应中的敏感URL
|
||
try:
|
||
response_data = response.json()
|
||
# 创建安全版本用于日志输出
|
||
safe_response = self._create_safe_config_for_logging(response_data)
|
||
print(f"DEBUG: Response Text: {json.dumps(safe_response, indent=2)}")
|
||
except:
|
||
# 如果不是JSON,直接打印文本
|
||
from utils.helpers import censor_url
|
||
censored_text = censor_url(response.text)
|
||
print(f"DEBUG: Response Text: {censored_text}")
|
||
|
||
response.raise_for_status()
|
||
|
||
# 首先,总是尝试解析JSON
|
||
config_data = response.json()
|
||
|
||
# 检查是否是要求更新的错误信息 - 使用Unicode编码的更新提示文本
|
||
update_required_msg = "\u8bf7\u4f7f\u7528\u6700\u65b0\u7248\u672c\u7684FraiseMoe2-Next\u8fdb\u884c\u4e0b\u8f7d"
|
||
if isinstance(config_data, str) and config_data == update_required_msg:
|
||
self.finished.emit(None, "update_required")
|
||
return
|
||
elif isinstance(config_data, dict) and config_data.get("message") == update_required_msg:
|
||
self.finished.emit(None, "update_required")
|
||
return
|
||
|
||
# 检查是否是有效的配置文件
|
||
required_keys = [f"vol.{i+1}.data" for i in range(4)] + ["after.data"]
|
||
missing_keys = [key for key in required_keys if key not in config_data]
|
||
if missing_keys:
|
||
self.finished.emit(None, f"missing_keys:{','.join(missing_keys)}")
|
||
return
|
||
|
||
self.finished.emit(config_data, "")
|
||
except requests.exceptions.RequestException as e:
|
||
error_msg = "访问云端配置失败,请检查网络状况或稍后再试。"
|
||
if self.debug_mode:
|
||
error_msg += f"\n详细错误: {e}"
|
||
self.finished.emit(None, error_msg)
|
||
except (ValueError, json.JSONDecodeError) as e:
|
||
error_msg = "访问云端配置失败,请检查网络状况或稍后再试。"
|
||
if self.debug_mode:
|
||
error_msg += f"\nJSON解析失败: {e}"
|
||
self.finished.emit(None, error_msg)
|
||
finally:
|
||
if self.debug_mode:
|
||
print("--- Finished fetching cloud config ---")
|
||
|
||
def _create_safe_config_for_logging(self, config_data):
|
||
"""创建用于日志记录的安全配置副本,隐藏敏感URL
|
||
|
||
Args:
|
||
config_data: 原始配置数据
|
||
|
||
Returns:
|
||
dict: 安全的配置数据副本
|
||
"""
|
||
if not config_data or not isinstance(config_data, dict):
|
||
return config_data
|
||
|
||
# 创建深拷贝,避免修改原始数据
|
||
import copy
|
||
safe_config = copy.deepcopy(config_data)
|
||
|
||
# 隐藏敏感URL
|
||
for key in safe_config:
|
||
if isinstance(safe_config[key], dict) and "url" in safe_config[key]:
|
||
# 完全隐藏URL
|
||
safe_config[key]["url"] = "***URL protection***"
|
||
|
||
return safe_config |