From a58a2a418e7e07fbebfe7b1a4a83804ce9067315 Mon Sep 17 00:00:00 2001 From: Jack Steel Date: Wed, 3 Feb 2021 02:07:19 +1300 Subject: [PATCH] Provide the base URL if possible for Sonarr/Radarr. If the API returns a base URL that differs from the one currently set, output that in the error message. Even though Sonarr/Radarr return a result here, they will fail for POST requests, so this does need to be set correctly. --- src/Ombi.Api.Radarr/Models/V2/SystemStatus.cs | 1 + src/Ombi.Core/Models/TesterResultModel.cs | 8 ++++ .../ClientApp/src/app/interfaces/ITester.ts | 4 ++ .../ClientApp/src/app/interfaces/index.ts | 3 +- .../services/applications/tester.service.ts | 13 ++++--- .../app/settings/lidarr/lidarr.component.ts | 12 +++--- .../app/settings/radarr/radarr.component.ts | 12 +++--- .../app/settings/sonarr/sonarr.component.ts | 8 ++-- .../V1/External/TesterController.cs | 38 +++++++++++-------- 9 files changed, 63 insertions(+), 36 deletions(-) create mode 100644 src/Ombi.Core/Models/TesterResultModel.cs create mode 100644 src/Ombi/ClientApp/src/app/interfaces/ITester.ts diff --git a/src/Ombi.Api.Radarr/Models/V2/SystemStatus.cs b/src/Ombi.Api.Radarr/Models/V2/SystemStatus.cs index 6877708c5..699b37b3c 100644 --- a/src/Ombi.Api.Radarr/Models/V2/SystemStatus.cs +++ b/src/Ombi.Api.Radarr/Models/V2/SystemStatus.cs @@ -3,5 +3,6 @@ public class SystemStatus { public string version { get; set; } + public string urlBase { get; set; } } } \ No newline at end of file diff --git a/src/Ombi.Core/Models/TesterResultModel.cs b/src/Ombi.Core/Models/TesterResultModel.cs new file mode 100644 index 000000000..f23e14d43 --- /dev/null +++ b/src/Ombi.Core/Models/TesterResultModel.cs @@ -0,0 +1,8 @@ +namespace Ombi.Core.Models +{ + public class TesterResultModel + { + public bool IsValid { get; set; } + public string ExpectedSubDir { get; set; } + } +} diff --git a/src/Ombi/ClientApp/src/app/interfaces/ITester.ts b/src/Ombi/ClientApp/src/app/interfaces/ITester.ts new file mode 100644 index 000000000..c61292be4 --- /dev/null +++ b/src/Ombi/ClientApp/src/app/interfaces/ITester.ts @@ -0,0 +1,4 @@ +export interface ITesterResult { + isValid: boolean; + expectedSubDir?: string; +} diff --git a/src/Ombi/ClientApp/src/app/interfaces/index.ts b/src/Ombi/ClientApp/src/app/interfaces/index.ts index 8c0bf9cad..40916cd00 100644 --- a/src/Ombi/ClientApp/src/app/interfaces/index.ts +++ b/src/Ombi/ClientApp/src/app/interfaces/index.ts @@ -1,4 +1,4 @@ -export * from "./ICommon"; +export * from "./ICommon"; export * from "./ICouchPotato"; export * from "./IImages"; export * from "./IMediaServerStatus"; @@ -20,3 +20,4 @@ export * from "./ISearchMusicResult"; export * from "./IVote"; export * from "./IFailedRequests"; export * from "./IHub"; +export * from "./ITester"; diff --git a/src/Ombi/ClientApp/src/app/services/applications/tester.service.ts b/src/Ombi/ClientApp/src/app/services/applications/tester.service.ts index 0d68d695f..9209cf84f 100644 --- a/src/Ombi/ClientApp/src/app/services/applications/tester.service.ts +++ b/src/Ombi/ClientApp/src/app/services/applications/tester.service.ts @@ -25,6 +25,7 @@ import { ISlackNotificationSettings, ISonarrSettings, ITelegramNotifcationSettings, + ITesterResult, IWebhookNotificationSettings, IWhatsAppSettings, } from "../../interfaces"; @@ -83,16 +84,16 @@ export class TesterService extends ServiceHelpers { return this.http.post(`${this.url}jellyfin`, JSON.stringify(settings), {headers: this.headers}); } - public radarrTest(settings: IRadarrSettings): Observable { - return this.http.post(`${this.url}radarr`, JSON.stringify(settings), {headers: this.headers}); + public radarrTest(settings: IRadarrSettings): Observable { + return this.http.post(`${this.url}radarr`, JSON.stringify(settings), {headers: this.headers}); } - public lidarrTest(settings: ILidarrSettings): Observable { - return this.http.post(`${this.url}lidarr`, JSON.stringify(settings), {headers: this.headers}); + public lidarrTest(settings: ILidarrSettings): Observable { + return this.http.post(`${this.url}lidarr`, JSON.stringify(settings), {headers: this.headers}); } - public sonarrTest(settings: ISonarrSettings): Observable { - return this.http.post(`${this.url}sonarr`, JSON.stringify(settings), {headers: this.headers}); + public sonarrTest(settings: ISonarrSettings): Observable { + return this.http.post(`${this.url}sonarr`, JSON.stringify(settings), {headers: this.headers}); } public couchPotatoTest(settings: ICouchPotatoSettings): Observable { diff --git a/src/Ombi/ClientApp/src/app/settings/lidarr/lidarr.component.ts b/src/Ombi/ClientApp/src/app/settings/lidarr/lidarr.component.ts index 7ff770c4c..ddb58b970 100644 --- a/src/Ombi/ClientApp/src/app/settings/lidarr/lidarr.component.ts +++ b/src/Ombi/ClientApp/src/app/settings/lidarr/lidarr.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit } from "@angular/core"; +import { Component, OnInit } from "@angular/core"; import { FormBuilder, FormGroup, Validators } from "@angular/forms"; import { ILidarrSettings, IMinimumAvailability, IProfiles, IRadarrProfile, IRadarrRootFolder } from "../../interfaces"; @@ -106,11 +106,13 @@ export class LidarrComponent implements OnInit { return; } const settings = form.value; - this.testerService.lidarrTest(settings).subscribe(x => { - if (x === true) { - this.notificationService.success("Successfully connected to Lidarr!"); + this.testerService.lidarrTest(settings).subscribe(result => { + if (result.isValid) { + this.notificationService.success("Successfully connected to Sonarr!"); + } else if (result.expectedSubDir !== null) { + this.notificationService.error("Your Sonarr Base URL must be set to " + result.expectedSubDir); } else { - this.notificationService.error("We could not connect to Lidarr!"); + this.notificationService.error("We could not connect to Sonarr!"); } }); } diff --git a/src/Ombi/ClientApp/src/app/settings/radarr/radarr.component.ts b/src/Ombi/ClientApp/src/app/settings/radarr/radarr.component.ts index 905a72f36..dc7ae8f3d 100644 --- a/src/Ombi/ClientApp/src/app/settings/radarr/radarr.component.ts +++ b/src/Ombi/ClientApp/src/app/settings/radarr/radarr.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit } from "@angular/core"; +import { Component, OnInit } from "@angular/core"; import { FormBuilder, FormGroup, Validators } from "@angular/forms"; import { IMinimumAvailability, IRadarrProfile, IRadarrRootFolder } from "../../interfaces"; @@ -96,11 +96,13 @@ export class RadarrComponent implements OnInit { return; } const settings = form.value; - this.testerService.radarrTest(settings).subscribe(x => { - if (x === true) { - this.notificationService.success("Successfully connected to Radarr!"); + this.testerService.radarrTest(settings).subscribe(result => { + if (result.isValid) { + this.notificationService.success("Successfully connected to Sonarr!"); + } else if (result.expectedSubDir !== null) { + this.notificationService.error("Your Sonarr Base URL must be set to " + result.expectedSubDir); } else { - this.notificationService.error("We could not connect to Radarr!"); + this.notificationService.error("We could not connect to Sonarr!"); } }); } diff --git a/src/Ombi/ClientApp/src/app/settings/sonarr/sonarr.component.ts b/src/Ombi/ClientApp/src/app/settings/sonarr/sonarr.component.ts index f3cc71018..edd22bbdd 100644 --- a/src/Ombi/ClientApp/src/app/settings/sonarr/sonarr.component.ts +++ b/src/Ombi/ClientApp/src/app/settings/sonarr/sonarr.component.ts @@ -1,4 +1,4 @@ -import { Component, OnInit } from "@angular/core"; +import { Component, OnInit } from "@angular/core"; import { FormBuilder, FormControl, FormGroup, Validators } from "@angular/forms"; import { ILanguageProfiles, ISonarrProfile, ISonarrRootFolder } from "../../interfaces"; @@ -150,9 +150,11 @@ export class SonarrComponent implements OnInit { return; } const settings = form.value; - this.testerService.sonarrTest(settings).subscribe(x => { - if (x) { + this.testerService.sonarrTest(settings).subscribe(result => { + if (result.isValid) { this.notificationService.success("Successfully connected to Sonarr!"); + } else if (result.expectedSubDir !== null) { + this.notificationService.error("Your Sonarr Base URL must be set to " + result.expectedSubDir); } else { this.notificationService.error("We could not connect to Sonarr!"); } diff --git a/src/Ombi/Controllers/V1/External/TesterController.cs b/src/Ombi/Controllers/V1/External/TesterController.cs index 0c80b051c..82182c012 100644 --- a/src/Ombi/Controllers/V1/External/TesterController.cs +++ b/src/Ombi/Controllers/V1/External/TesterController.cs @@ -15,6 +15,7 @@ using Ombi.Api.Sonarr; using Ombi.Api.Twilio; using Ombi.Attributes; using Ombi.Core.Authentication; +using Ombi.Core.Models; using Ombi.Core.Models.UI; using Ombi.Core.Notifications; using Ombi.Core.Settings.Models.External; @@ -364,19 +365,23 @@ namespace Ombi.Controllers.V1.External /// /// [HttpPost("radarr")] - public async Task Radarr([FromBody] RadarrSettings settings) + public async Task Radarr([FromBody] RadarrSettings settings) { try { var result = await RadarrApi.SystemStatus(settings.ApiKey, settings.FullUri); - return result.version != null; + return new TesterResultModel + { + IsValid = result.urlBase == settings.SubDir, + ExpectedSubDir = result.urlBase + }; } catch (Exception e) { Log.LogError(LoggingEvents.Api, e, "Could not test Radarr"); - return false; + return new TesterResultModel { IsValid = false }; } } @@ -386,23 +391,27 @@ namespace Ombi.Controllers.V1.External /// /// [HttpPost("sonarr")] - public async Task Sonarr([FromBody] SonarrSettings settings) + public async Task Sonarr([FromBody] SonarrSettings settings) { try { var result = await SonarrApi.SystemStatus(settings.ApiKey, settings.FullUri); - return result.version != null; + return new TesterResultModel + { + IsValid = result.urlBase == settings.SubDir, + ExpectedSubDir = result.urlBase + }; } catch (Exception e) { Log.LogError(LoggingEvents.Api, e, "Could not test Sonarr"); - return false; + return new TesterResultModel { IsValid = false }; } } /// - /// Checks if we can connect to Sonarr with the provided settings + /// Checks if we can connect to CouchPotato with the provided settings /// /// /// @@ -497,24 +506,21 @@ namespace Ombi.Controllers.V1.External } [HttpPost("lidarr")] - public async Task LidarrTest([FromBody] LidarrSettings settings) + public async Task LidarrTest([FromBody] LidarrSettings settings) { try { var status = await LidarrApi.Status(settings.ApiKey, settings.FullUri); - if (status != null & status?.version.HasValue() ?? false) + return new TesterResultModel { - return true; - } - else - { - return false; - } + IsValid = status?.urlBase == settings.SubDir, + ExpectedSubDir = status?.urlBase + }; } catch (Exception e) { Log.LogError(LoggingEvents.Api, e, "Could not test Lidarr"); - return false; + return new TesterResultModel { IsValid = false }; } }