diff --git a/src/NzbDrone.Core/Download/Clients/Flood/Flood.cs b/src/NzbDrone.Core/Download/Clients/Flood/Flood.cs index f7bb77dcf..d0642a943 100644 --- a/src/NzbDrone.Core/Download/Clients/Flood/Flood.cs +++ b/src/NzbDrone.Core/Download/Clients/Flood/Flood.cs @@ -4,6 +4,7 @@ using System.Linq; using FluentValidation.Results; using NLog; using NzbDrone.Common.Disk; +using NzbDrone.Common.Extensions; using NzbDrone.Common.Http; using NzbDrone.Core.Configuration; using NzbDrone.Core.Download.Clients.Flood.Models; @@ -233,10 +234,17 @@ namespace NzbDrone.Core.Download.Clients.Flood public override DownloadClientInfo GetStatus() { + var destDir = _proxy.GetClientSettings(Settings).DirectoryDefault; + + if (Settings.Destination.IsNotNullOrWhiteSpace()) + { + destDir = Settings.Destination; + } + return new DownloadClientInfo { IsLocalhost = Settings.Host == "127.0.0.1" || Settings.Host == "::1" || Settings.Host == "localhost", - OutputRootFolders = new List { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, new OsPath(Settings.Destination)) } + OutputRootFolders = new List { _remotePathMappingService.RemapRemoteToLocal(Settings.Host, new OsPath(destDir)) } }; } diff --git a/src/NzbDrone.Core/Download/Clients/Flood/FloodProxy.cs b/src/NzbDrone.Core/Download/Clients/Flood/FloodProxy.cs index 06bca878f..20a53da78 100644 --- a/src/NzbDrone.Core/Download/Clients/Flood/FloodProxy.cs +++ b/src/NzbDrone.Core/Download/Clients/Flood/FloodProxy.cs @@ -19,6 +19,7 @@ namespace NzbDrone.Core.Download.Clients.Flood Dictionary GetTorrents(FloodSettings settings); List GetTorrentContentPaths(string hash, FloodSettings settings); void SetTorrentsTags(string hash, IEnumerable tags, FloodSettings settings); + FloodClientSettings GetClientSettings(FloodSettings settings); } public class FloodProxy : IFloodProxy @@ -210,5 +211,14 @@ namespace NzbDrone.Core.Download.Clients.Flood HandleRequest(tagsRequest, settings); } + + public FloodClientSettings GetClientSettings(FloodSettings settings) + { + var contentsRequest = BuildRequest(settings).Resource($"/client/settings").Build(); + + contentsRequest.Method = HttpMethod.Get; + + return Json.Deserialize(HandleRequest(contentsRequest, settings).Content); + } } } diff --git a/src/NzbDrone.Core/Download/Clients/Flood/Types/FloodClientSettings.cs b/src/NzbDrone.Core/Download/Clients/Flood/Types/FloodClientSettings.cs new file mode 100644 index 000000000..49eb36b7b --- /dev/null +++ b/src/NzbDrone.Core/Download/Clients/Flood/Types/FloodClientSettings.cs @@ -0,0 +1,7 @@ +namespace NzbDrone.Core.Download.Clients.Flood.Types +{ + public class FloodClientSettings + { + public string DirectoryDefault { get; set; } + } +}