85 lines
3.0 KiB
Python
Raw Normal View History

2023-05-15 08:51:32 +08:00
import json
import logging
import requests
from flask_restx import Resource, fields, reqparse
from packaging import version
2023-05-15 08:51:32 +08:00
from configs import dify_config
from . import api, console_ns
2023-05-15 08:51:32 +08:00
logger = logging.getLogger(__name__)
2023-05-15 08:51:32 +08:00
@console_ns.route("/version")
2023-05-15 08:51:32 +08:00
class VersionApi(Resource):
@api.doc("check_version_update")
@api.doc(description="Check for application version updates")
@api.expect(
api.parser().add_argument(
"current_version", type=str, required=True, location="args", help="Current application version"
)
)
@api.response(
200,
"Success",
api.model(
"VersionResponse",
{
"version": fields.String(description="Latest version number"),
"release_date": fields.String(description="Release date of latest version"),
"release_notes": fields.String(description="Release notes for latest version"),
"can_auto_update": fields.Boolean(description="Whether auto-update is supported"),
"features": fields.Raw(description="Feature flags and capabilities"),
},
),
)
2023-05-15 08:51:32 +08:00
def get(self):
"""Check for application version updates"""
2023-05-15 08:51:32 +08:00
parser = reqparse.RequestParser()
parser.add_argument("current_version", type=str, required=True, location="args")
2023-05-15 08:51:32 +08:00
args = parser.parse_args()
check_update_url = dify_config.CHECK_UPDATE_URL
2023-05-15 08:51:32 +08:00
result = {
"version": dify_config.project.version,
"release_date": "",
"release_notes": "",
"can_auto_update": False,
"features": {
"can_replace_logo": dify_config.CAN_REPLACE_LOGO,
"model_load_balancing_enabled": dify_config.MODEL_LB_ENABLED,
},
}
if not check_update_url:
return result
2023-05-15 08:51:32 +08:00
try:
response = requests.get(check_update_url, {"current_version": args["current_version"]}, timeout=(3, 10))
2023-05-15 08:51:32 +08:00
except Exception as error:
logger.warning("Check update version error: %s.", str(error))
result["version"] = args["current_version"]
return result
2023-05-15 08:51:32 +08:00
content = json.loads(response.content)
if _has_new_version(latest_version=content["version"], current_version=f"{args['current_version']}"):
result["version"] = content["version"]
result["release_date"] = content["releaseDate"]
result["release_notes"] = content["releaseNotes"]
result["can_auto_update"] = content["canAutoUpdate"]
return result
2023-05-15 08:51:32 +08:00
def _has_new_version(*, latest_version: str, current_version: str) -> bool:
try:
latest = version.parse(latest_version)
current = version.parse(current_version)
# Compare versions
return latest > current
except version.InvalidVersion:
logger.warning("Invalid version format: latest=%s, current=%s", latest_version, current_version)
return False