|
import requests |
|
import logging |
|
from app.utils.logging import log |
|
import app.config.settings as settings |
|
async def check_version(): |
|
""" |
|
检查应用程序版本更新 |
|
|
|
从本地和远程获取版本信息,并比较版本号以确定是否有更新 |
|
""" |
|
|
|
try: |
|
|
|
with open("./version.txt", "r") as f: |
|
version_line = f.read().strip() |
|
settings.version['local_version'] = version_line.split("=")[1] if "=" in version_line else "0.0.0" |
|
|
|
|
|
github_url = "https://raw.githubusercontent.com/wyeeeee/hajimi/refs/heads/main/version.txt" |
|
response = requests.get(github_url, timeout=5) |
|
if response.status_code == 200: |
|
version_line = response.text.strip() |
|
settings.version['remote_version']= version_line.split("=")[1] if "=" in version_line else "0.0.0" |
|
|
|
local_parts = [int(x) for x in settings.version['local_version'].split(".")] |
|
remote_parts = [int(x) for x in settings.version['remote_version'].split(".")] |
|
|
|
|
|
while len(local_parts) < len(remote_parts): |
|
local_parts.append(0) |
|
while len(remote_parts) < len(local_parts): |
|
remote_parts.append(0) |
|
|
|
|
|
settings.version['has_update'] = False |
|
for i in range(len(local_parts)): |
|
if remote_parts[i] > local_parts[i]: |
|
settings.version['has_update'] = True |
|
break |
|
elif remote_parts[i] < local_parts[i]: |
|
break |
|
|
|
log('info', f"版本检查: 本地版本 {settings.version['local_version']}, 远程版本 {settings.version['remote_version']}, 有更新: {settings.version['has_update']}") |
|
else: |
|
log('warning', f"无法获取远程版本信息,HTTP状态码: {response.status_code}") |
|
except Exception as e: |
|
log('error', f"版本检查失败: {str(e)}") |
|
|
|
return settings.version['has_update'] |