From ec6ad41ec35427b8a8560c855e64ef3f6eb9db3b Mon Sep 17 00:00:00 2001 From: Mikal Stordal Date: Mon, 30 Oct 2023 15:43:00 +0100 Subject: [PATCH] misc: hopefully fix the return body when an update to the web UI fails because it somehow failed to use the github api. --- .../API/v3/Controllers/WebUIController.cs | 21 ++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/Shoko.Server/API/v3/Controllers/WebUIController.cs b/Shoko.Server/API/v3/Controllers/WebUIController.cs index 0e1dfcfc7..53239ab9e 100644 --- a/Shoko.Server/API/v3/Controllers/WebUIController.cs +++ b/Shoko.Server/API/v3/Controllers/WebUIController.cs @@ -9,6 +9,7 @@ using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Caching.Memory; +using Microsoft.Extensions.Logging; using Shoko.Server.API.Annotations; using Shoko.Server.API.ModelBinders; using Shoko.Server.API.v3.Helpers; @@ -43,6 +44,9 @@ public class WebUIController : BaseController }); private static readonly TimeSpan CacheTTL = TimeSpan.FromHours(1); + + private readonly ILogger _logger; + private readonly WebUIFactory _webUIFactory; /// @@ -306,7 +310,10 @@ public ActionResult InstallWebUI([FromQuery] ReleaseChannel channel = ReleaseCha catch (WebException ex) { if (ex.Status != WebExceptionStatus.Success) - return StatusCode((int)HttpStatusCode.BadGateway, "Unable to use the GitHub API to check for an update. Check your connection."); + { + _logger.LogError(ex, "An error occured while trying to install the Web UI."); + return Problem("Unable to use the GitHub API to check for an update. Check your connection and try again.", null, (int)HttpStatusCode.BadGateway, "Unable to connect to GitHub."); + } throw; } @@ -335,18 +342,21 @@ public ActionResult UpdateWebUI([FromQuery] ReleaseChannel channel = ReleaseChan catch (WebException ex) { if (ex.Status != WebExceptionStatus.Success) - return StatusCode((int)HttpStatusCode.BadGateway, "Unable to use the GitHub API to check for an update. Check your connection."); + { + _logger.LogError(ex, "An error occured while trying to update the Web UI."); + return Problem("Unable to use the GitHub API to check for an update. Check your connection and try again.", null, (int)HttpStatusCode.BadGateway, "Unable to connect to GitHub."); + } throw; } return NoContent(); } - + /// [DatabaseBlockedExempt] [InitFriendly] [HttpGet("Update")] - [Obsolete("Post is correct, but we want old versions of the webui to be able to update. We can remove this later")] + [Obsolete("Post is correct, but we want old versions of the webui to be able to update. We can remove this laterâ„¢.")] public ActionResult UpdateWebUIOld([FromQuery] ReleaseChannel channel = ReleaseChannel.Stable) { return UpdateWebUI(channel); @@ -564,8 +574,9 @@ public ActionResult LatestServerWebUIVersion([FromQuery] Relea } - public WebUIController(ISettingsProvider settingsProvider, WebUIFactory webUIFactory) : base(settingsProvider) + public WebUIController(ISettingsProvider settingsProvider, WebUIFactory webUIFactory, ILogger logger) : base(settingsProvider) { + _logger = logger; _webUIFactory = webUIFactory; } }