From 9b247b67f64af903fd610481e74dbe7175580b84 Mon Sep 17 00:00:00 2001 From: Jesse Plamondon-Willard Date: Sun, 24 Sep 2017 13:19:02 -0400 Subject: improve version normalising (#336, #361) --- .../ModRepositories/ChucklefishRepository.cs | 27 ++++++++-------------- 1 file changed, 10 insertions(+), 17 deletions(-) (limited to 'src/StardewModdingAPI.Web/Framework/ModRepositories/ChucklefishRepository.cs') diff --git a/src/StardewModdingAPI.Web/Framework/ModRepositories/ChucklefishRepository.cs b/src/StardewModdingAPI.Web/Framework/ModRepositories/ChucklefishRepository.cs index 59d7f3ba..4822c414 100644 --- a/src/StardewModdingAPI.Web/Framework/ModRepositories/ChucklefishRepository.cs +++ b/src/StardewModdingAPI.Web/Framework/ModRepositories/ChucklefishRepository.cs @@ -8,26 +8,19 @@ using StardewModdingAPI.Models; namespace StardewModdingAPI.Web.Framework.ModRepositories { /// An HTTP client for fetching mod metadata from the Chucklefish mod site. - internal class ChucklefishRepository : IModRepository + internal class ChucklefishRepository : RepositoryBase { /********* ** Properties *********/ - /// The underlying HTTP client. - private readonly IClient Client; - - - /********* - ** Accessors - *********/ - /// The unique key for this vendor. - public string VendorKey { get; } - /// The base URL for the Chucklefish mod site. - public string BaseUrl { get; } + private readonly string BaseUrl; /// The URL for a mod page excluding the base URL, where {0} is the mod ID. - public string ModPageUrlFormat { get; } + private readonly string ModPageUrlFormat; + + /// The underlying HTTP client. + private readonly IClient Client; /********* @@ -39,8 +32,8 @@ namespace StardewModdingAPI.Web.Framework.ModRepositories /// The base URL for the Chucklefish mod site. /// The URL for a mod page excluding the , where {0} is the mod ID. public ChucklefishRepository(string vendorKey, string userAgent, string baseUrl, string modPageUrlFormat) + : base(vendorKey) { - this.VendorKey = vendorKey; this.BaseUrl = baseUrl; this.ModPageUrlFormat = modPageUrlFormat; this.Client = new FluentClient(baseUrl).SetUserAgent(userAgent); @@ -48,7 +41,7 @@ namespace StardewModdingAPI.Web.Framework.ModRepositories /// Get metadata about a mod in the repository. /// The mod ID in this repository. - public async Task GetModInfoAsync(string id) + public override async Task GetModInfoAsync(string id) { try { @@ -77,7 +70,7 @@ namespace StardewModdingAPI.Web.Framework.ModRepositories string version = doc.DocumentNode.SelectSingleNode("//h1/span").InnerText; // create model - return new ModInfoModel(name, version, url); + return new ModInfoModel(name, this.NormaliseVersion(version), url); } catch (Exception ex) { @@ -86,7 +79,7 @@ namespace StardewModdingAPI.Web.Framework.ModRepositories } /// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources. - public void Dispose() + public override void Dispose() { this.Client.Dispose(); } -- cgit