From 6b4a58ee076b73630ab087977771c0158c263991 Mon Sep 17 00:00:00 2001 From: Rudokhvist Date: Mon, 16 Sep 2024 20:51:02 +0300 Subject: [PATCH] switch to organization --- .../ASFAchievementManager.cs | 53 ++++++++++++++++++- Directory.Build.props | 8 +-- 2 files changed, 56 insertions(+), 5 deletions(-) diff --git a/ASFAchievementManager/ASFAchievementManager.cs b/ASFAchievementManager/ASFAchievementManager.cs index 44e6a98..71c94a3 100644 --- a/ASFAchievementManager/ASFAchievementManager.cs +++ b/ASFAchievementManager/ASFAchievementManager.cs @@ -12,6 +12,8 @@ using System.Collections.Concurrent; using System.Text.Json; using System.Globalization; +using ArchiSteamFarm.Web.GitHub.Data; +using ArchiSteamFarm.Web.GitHub; namespace ASFAchievementManager; @@ -23,7 +25,56 @@ internal sealed class ASFAchievementManager : IBotSteamClient, IBotCommand2, IAS public static CultureInfo? AchievementsCulture { get; private set; } - public string RepositoryName => "Rudokhvist/ASFAchievementManager"; + public string RepositoryName => "CatPoweredPlugins/ASFAchievementManager"; + + public async Task GetTargetReleaseURL(Version asfVersion, string asfVariant, bool asfUpdate, bool stable, bool forced) { + ArgumentNullException.ThrowIfNull(asfVersion); + ArgumentException.ThrowIfNullOrEmpty(asfVariant); + + if (string.IsNullOrEmpty(RepositoryName)) { + ASF.ArchiLogger.LogGenericError(string.Format(CultureInfo.CurrentCulture, Strings.WarningFailedWithError, nameof(RepositoryName))); + + return null; + } + + ReleaseResponse? releaseResponse = await GitHubService.GetLatestRelease(RepositoryName, stable).ConfigureAwait(false); + + if (releaseResponse == null) { + return null; + } + + Version newVersion = new(releaseResponse.Tag); + + if (!(Version.Major == newVersion.Major && Version.Minor == newVersion.Minor && Version.Build == newVersion.Build) && !(asfUpdate || forced)) { + ASF.ArchiLogger.LogGenericInfo(string.Format(CultureInfo.CurrentCulture, "New {0} plugin version {1} is only compatible with latest ASF version", Name, newVersion)); + return null; + } + + + if (Version >= newVersion & !forced) { + ASF.ArchiLogger.LogGenericInfo(string.Format(CultureInfo.CurrentCulture, Strings.PluginUpdateNotFound, Name, Version, newVersion)); + + return null; + } + + if (releaseResponse.Assets.Count == 0) { + ASF.ArchiLogger.LogGenericWarning(string.Format(CultureInfo.CurrentCulture, Strings.PluginUpdateNoAssetFound, Name, Version, newVersion)); + + return null; + } + + ReleaseAsset? asset = await ((IGitHubPluginUpdates) this).GetTargetReleaseAsset(asfVersion, asfVariant, newVersion, releaseResponse.Assets).ConfigureAwait(false); + + if ((asset == null) || !releaseResponse.Assets.Contains(asset)) { + ASF.ArchiLogger.LogGenericWarning(string.Format(CultureInfo.CurrentCulture, Strings.PluginUpdateNoAssetFound, Name, Version, newVersion)); + + return null; + } + + ASF.ArchiLogger.LogGenericInfo(string.Format(CultureInfo.CurrentCulture, Strings.PluginUpdateFound, Name, Version, newVersion)); + + return asset.DownloadURL; + } private static readonly char[] Separator = [',']; diff --git a/Directory.Build.props b/Directory.Build.props index 8c203c7..9aa14a1 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -3,15 +3,15 @@ ASFAchievementManager - 1.0.0.0 + 1.0.0.1 Rudokhvist - $(Authors) - Copyright © $([System.DateTime]::UtcNow.Year) $(Company) - $(PluginName) + CatPoweredPlugins + Copyright © $([System.DateTime]::UtcNow.Year) $(Authors) + $(PluginName) by $(Authors). This plugin is cat powered! Apache-2.0 https://github.com/$(Company)/$(PluginName)