From 9458b088428b1deef31c900ace363700558ec380 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?F=C3=A9lix=20Pi=C3=A9dallu?= Date: Tue, 2 Apr 2024 13:27:24 +0200 Subject: [PATCH] Allow prereleases in autoupdater. Mainly to support Vikunja. --- schemas/manifest.v2.schema.json | 6 +++++- tools/autoupdate_app_sources/autoupdate_app_sources.py | 9 ++++++++- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/schemas/manifest.v2.schema.json b/schemas/manifest.v2.schema.json index fa8fcdb8f7..6f38292e92 100644 --- a/schemas/manifest.v2.schema.json +++ b/schemas/manifest.v2.schema.json @@ -575,6 +575,10 @@ }, "force_version": { "type": "string" + }, + "allow_prereleases": { + "type": "boolean", + "description": "Allow prereleases when using strategy = latest_X_release" } } } @@ -633,4 +637,4 @@ "resources" ], "additionalProperties": false -} \ No newline at end of file +} diff --git a/tools/autoupdate_app_sources/autoupdate_app_sources.py b/tools/autoupdate_app_sources/autoupdate_app_sources.py index ed6d944682..1960a3f788 100755 --- a/tools/autoupdate_app_sources/autoupdate_app_sources.py +++ b/tools/autoupdate_app_sources/autoupdate_app_sources.py @@ -447,6 +447,7 @@ def get_latest_version_and_asset( ) -> Optional[tuple[str, Union[str, dict[str, str]], str]]: upstream = autoupdate.get("upstream", self.main_upstream).strip("/") version_re = autoupdate.get("version_regex", None) + allow_prereleases = autoupdate.get("allow_prereleases", False) _, remote_type, revision_type = strategy.split("_") api: Union[GithubAPI, GitlabAPI, GiteaForgejoAPI] @@ -464,8 +465,14 @@ def get_latest_version_and_asset( releases: dict[str, dict[str, Any]] = { release["tag_name"]: release for release in api.releases() - if not release["draft"] and not release["prerelease"] } + + if not allow_prereleases: + releases = { + name: info for name, info in releases.items() + if not info["draft"] and not info["prerelease"] + } + latest_version_orig, latest_version = self.relevant_versions( list(releases.keys()), self.app_id, version_re )