mirror of
https://github.com/lidarr/Lidarr
synced 2025-02-27 00:02:25 +00:00
Fixed: qBittorrent Fixes for Seed Limits and Magnet links (#702)
* Fixed: Qbittorrent Fixes for Seed Limits and Magnet links * Fixed: We do Music, not TV
This commit is contained in:
parent
d5c69d0375
commit
6b40a8d87f
6 changed files with 179 additions and 94 deletions
|
@ -9,6 +9,7 @@
|
||||||
using NzbDrone.Core.Download.Clients.QBittorrent;
|
using NzbDrone.Core.Download.Clients.QBittorrent;
|
||||||
using NzbDrone.Core.MediaFiles.TorrentInfo;
|
using NzbDrone.Core.MediaFiles.TorrentInfo;
|
||||||
using NzbDrone.Test.Common;
|
using NzbDrone.Test.Common;
|
||||||
|
using NzbDrone.Core.Exceptions;
|
||||||
|
|
||||||
namespace NzbDrone.Core.Test.Download.DownloadClientTests.QBittorrentTests
|
namespace NzbDrone.Core.Test.Download.DownloadClientTests.QBittorrentTests
|
||||||
{
|
{
|
||||||
|
@ -99,14 +100,17 @@ protected void GivenHighPriority()
|
||||||
Subject.Definition.Settings.As<QBittorrentSettings>().RecentTvPriority = (int)QBittorrentPriority.First;
|
Subject.Definition.Settings.As<QBittorrentSettings>().RecentTvPriority = (int)QBittorrentPriority.First;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void GivenMaxRatio(float maxRatio, bool removeOnMaxRatio = true)
|
protected void GivenGlobalSeedLimits(float maxRatio, int maxSeedingTime = -1, bool removeOnMaxRatio = false)
|
||||||
{
|
{
|
||||||
Mocker.GetMock<IQBittorrentProxy>()
|
Mocker.GetMock<IQBittorrentProxy>()
|
||||||
.Setup(s => s.GetConfig(It.IsAny<QBittorrentSettings>()))
|
.Setup(s => s.GetConfig(It.IsAny<QBittorrentSettings>()))
|
||||||
.Returns(new QBittorrentPreferences
|
.Returns(new QBittorrentPreferences
|
||||||
{
|
{
|
||||||
RemoveOnMaxRatio = removeOnMaxRatio,
|
RemoveOnMaxRatio = removeOnMaxRatio,
|
||||||
MaxRatio = maxRatio
|
MaxRatio = maxRatio,
|
||||||
|
MaxRatioEnabled = maxRatio >= 0,
|
||||||
|
MaxSeedingTime = maxSeedingTime,
|
||||||
|
MaxSeedingTimeEnabled = maxSeedingTime >= 0
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -279,7 +283,21 @@ public void Download_should_get_hash_from_magnet_url(string magnetUrl, string ex
|
||||||
id.Should().Be(expectedHash);
|
id.Should().Be(expectedHash);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Download_should_refuse_magnet_if_dht_is_disabled()
|
[Test]
|
||||||
|
public void Download_should_refuse_magnet_if_no_trackers_provided_and_dht_is_disabled()
|
||||||
|
{
|
||||||
|
Mocker.GetMock<IQBittorrentProxy>()
|
||||||
|
.Setup(s => s.GetConfig(It.IsAny<QBittorrentSettings>()))
|
||||||
|
.Returns(new QBittorrentPreferences() { DhtEnabled = false });
|
||||||
|
|
||||||
|
var remoteAlbum = CreateRemoteAlbum();
|
||||||
|
remoteAlbum.Release.DownloadUrl = "magnet:?xt=urn:btih:ZPBPA2P6ROZPKRHK44D5OW6NHXU5Z6KR";
|
||||||
|
|
||||||
|
Assert.Throws<ReleaseDownloadException>(() => Subject.Download(remoteAlbum));
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void Download_should_accept_magnet_if_trackers_provided_and_dht_is_disabled()
|
||||||
{
|
{
|
||||||
|
|
||||||
Mocker.GetMock<IQBittorrentProxy>()
|
Mocker.GetMock<IQBittorrentProxy>()
|
||||||
|
@ -287,9 +305,12 @@ public void Download_should_refuse_magnet_if_dht_is_disabled()
|
||||||
.Returns(new QBittorrentPreferences { DhtEnabled = false });
|
.Returns(new QBittorrentPreferences { DhtEnabled = false });
|
||||||
|
|
||||||
var remoteAlbum = CreateRemoteAlbum();
|
var remoteAlbum = CreateRemoteAlbum();
|
||||||
remoteAlbum.Release.DownloadUrl = "magnet:?xt=urn:btih:ZPBPA2P6ROZPKRHK44D5OW6NHXU5Z6KR&tr=udp";
|
remoteAlbum.Release.DownloadUrl = "magnet:?xt=urn:btih:ZPBPA2P6ROZPKRHK44D5OW6NHXU5Z6KR&tr=udp://abc";
|
||||||
|
|
||||||
Assert.Throws<NotSupportedException>(() => Subject.Download(remoteAlbum));
|
Assert.DoesNotThrow(() => Subject.Download(remoteAlbum));
|
||||||
|
|
||||||
|
Mocker.GetMock<IQBittorrentProxy>()
|
||||||
|
.Verify(s => s.AddTorrentFromUrl(It.IsAny<string>(), It.IsAny<QBittorrentSettings>()), Times.Once());
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
|
@ -373,7 +394,7 @@ public void Download_should_handle_http_redirect_to_torrent()
|
||||||
[Test]
|
[Test]
|
||||||
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_not_reached()
|
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_not_reached()
|
||||||
{
|
{
|
||||||
GivenMaxRatio(1.0f);
|
GivenGlobalSeedLimits(1.0f);
|
||||||
|
|
||||||
var torrent = new QBittorrentTorrent
|
var torrent = new QBittorrentTorrent
|
||||||
{
|
{
|
||||||
|
@ -394,11 +415,11 @@ public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio
|
||||||
item.CanMoveFiles.Should().BeFalse();
|
item.CanMoveFiles.Should().BeFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
protected virtual QBittorrentTorrent GivenCompletedTorrent(
|
||||||
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_reached_and_not_paused()
|
string state = "pausedUP",
|
||||||
|
float ratio = 0.1f, float ratioLimit = -2,
|
||||||
|
int seedingTime = 1, int seedingTimeLimit = -2)
|
||||||
{
|
{
|
||||||
GivenMaxRatio(1.0f);
|
|
||||||
|
|
||||||
var torrent = new QBittorrentTorrent
|
var torrent = new QBittorrentTorrent
|
||||||
{
|
{
|
||||||
Hash = "HASH",
|
Hash = "HASH",
|
||||||
|
@ -406,13 +427,32 @@ public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio
|
||||||
Size = 1000,
|
Size = 1000,
|
||||||
Progress = 1.0,
|
Progress = 1.0,
|
||||||
Eta = 8640000,
|
Eta = 8640000,
|
||||||
State = "uploading",
|
State = state,
|
||||||
Label = "",
|
Label = "",
|
||||||
SavePath = "",
|
SavePath = "",
|
||||||
Ratio = 1.0f
|
Ratio = ratio,
|
||||||
|
RatioLimit = ratioLimit,
|
||||||
|
SeedingTimeLimit = seedingTimeLimit
|
||||||
};
|
};
|
||||||
GivenTorrents(new List<QBittorrentTorrent> { torrent });
|
|
||||||
|
|
||||||
|
GivenTorrents(new List<QBittorrentTorrent>() { torrent });
|
||||||
|
|
||||||
|
Mocker.GetMock<IQBittorrentProxy>()
|
||||||
|
.Setup(s => s.GetTorrentProperties("HASH", It.IsAny<QBittorrentSettings>()))
|
||||||
|
.Returns(new QBittorrentTorrentProperties
|
||||||
|
{
|
||||||
|
Hash = "HASH",
|
||||||
|
SeedingTime = seedingTime
|
||||||
|
});
|
||||||
|
|
||||||
|
return torrent;
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_reached_and_not_paused()
|
||||||
|
{
|
||||||
|
GivenGlobalSeedLimits(1.0f);
|
||||||
|
GivenCompletedTorrent("uploading", ratio: 1.0f);
|
||||||
var item = Subject.GetItems().Single();
|
var item = Subject.GetItems().Single();
|
||||||
item.CanBeRemoved.Should().BeFalse();
|
item.CanBeRemoved.Should().BeFalse();
|
||||||
item.CanMoveFiles.Should().BeFalse();
|
item.CanMoveFiles.Should().BeFalse();
|
||||||
|
@ -421,21 +461,8 @@ public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio
|
||||||
[Test]
|
[Test]
|
||||||
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_is_not_set()
|
public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio_is_not_set()
|
||||||
{
|
{
|
||||||
GivenMaxRatio(1.0f, false);
|
GivenGlobalSeedLimits(-1);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 1.0f);
|
||||||
var torrent = new QBittorrentTorrent
|
|
||||||
{
|
|
||||||
Hash = "HASH",
|
|
||||||
Name = _title,
|
|
||||||
Size = 1000,
|
|
||||||
Progress = 1.0,
|
|
||||||
Eta = 8640000,
|
|
||||||
State = "uploading",
|
|
||||||
Label = "",
|
|
||||||
SavePath = "",
|
|
||||||
Ratio = 1.0f
|
|
||||||
};
|
|
||||||
GivenTorrents(new List<QBittorrentTorrent> { torrent });
|
|
||||||
|
|
||||||
var item = Subject.GetItems().Single();
|
var item = Subject.GetItems().Single();
|
||||||
item.CanBeRemoved.Should().BeFalse();
|
item.CanBeRemoved.Should().BeFalse();
|
||||||
|
@ -445,21 +472,8 @@ public void should_not_be_removable_and_should_not_allow_move_files_if_max_ratio
|
||||||
[Test]
|
[Test]
|
||||||
public void should_be_removable_and_should_allow_move_files_if_max_ratio_reached_and_paused()
|
public void should_be_removable_and_should_allow_move_files_if_max_ratio_reached_and_paused()
|
||||||
{
|
{
|
||||||
GivenMaxRatio(1.0f);
|
GivenGlobalSeedLimits(1.0f);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 1.0f);
|
||||||
var torrent = new QBittorrentTorrent
|
|
||||||
{
|
|
||||||
Hash = "HASH",
|
|
||||||
Name = _title,
|
|
||||||
Size = 1000,
|
|
||||||
Progress = 1.0,
|
|
||||||
Eta = 8640000,
|
|
||||||
State = "pausedUP",
|
|
||||||
Label = "",
|
|
||||||
SavePath = "",
|
|
||||||
Ratio = 1.0f
|
|
||||||
};
|
|
||||||
GivenTorrents(new List<QBittorrentTorrent> { torrent });
|
|
||||||
|
|
||||||
var item = Subject.GetItems().Single();
|
var item = Subject.GetItems().Single();
|
||||||
item.CanBeRemoved.Should().BeTrue();
|
item.CanBeRemoved.Should().BeTrue();
|
||||||
|
@ -469,22 +483,8 @@ public void should_be_removable_and_should_allow_move_files_if_max_ratio_reached
|
||||||
[Test]
|
[Test]
|
||||||
public void should_be_removable_and_should_allow_move_files_if_overridden_max_ratio_reached_and_paused()
|
public void should_be_removable_and_should_allow_move_files_if_overridden_max_ratio_reached_and_paused()
|
||||||
{
|
{
|
||||||
GivenMaxRatio(2.0f);
|
GivenGlobalSeedLimits(2.0f);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 1.0f, ratioLimit: 0.8f);
|
||||||
var torrent = new QBittorrentTorrent
|
|
||||||
{
|
|
||||||
Hash = "HASH",
|
|
||||||
Name = _title,
|
|
||||||
Size = 1000,
|
|
||||||
Progress = 1.0,
|
|
||||||
Eta = 8640000,
|
|
||||||
State = "pausedUP",
|
|
||||||
Label = "",
|
|
||||||
SavePath = "",
|
|
||||||
Ratio = 1.0f,
|
|
||||||
RatioLimit = 0.8f
|
|
||||||
};
|
|
||||||
GivenTorrents(new List<QBittorrentTorrent> { torrent });
|
|
||||||
|
|
||||||
var item = Subject.GetItems().Single();
|
var item = Subject.GetItems().Single();
|
||||||
item.CanBeRemoved.Should().BeTrue();
|
item.CanBeRemoved.Should().BeTrue();
|
||||||
|
@ -494,33 +494,75 @@ public void should_be_removable_and_should_allow_move_files_if_overridden_max_ra
|
||||||
[Test]
|
[Test]
|
||||||
public void should_not_be_removable_if_overridden_max_ratio_not_reached_and_paused()
|
public void should_not_be_removable_if_overridden_max_ratio_not_reached_and_paused()
|
||||||
{
|
{
|
||||||
GivenMaxRatio(0.2f);
|
GivenGlobalSeedLimits(0.2f);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 0.5f, ratioLimit: 0.8f);
|
||||||
|
|
||||||
var torrent = new QBittorrentTorrent
|
var item = Subject.GetItems().Single();
|
||||||
|
item.CanBeRemoved.Should().BeFalse();
|
||||||
|
item.CanMoveFiles.Should().BeFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_not_be_removable_and_should_not_allow_move_files_if_max_seedingtime_reached_and_not_paused()
|
||||||
{
|
{
|
||||||
Hash = "HASH",
|
GivenGlobalSeedLimits(-1, 20);
|
||||||
Name = _title,
|
GivenCompletedTorrent("uploading", ratio: 2.0f, seedingTime: 30);
|
||||||
Size = 1000,
|
|
||||||
Progress = 1.0,
|
|
||||||
Eta = 8640000,
|
|
||||||
State = "pausedUP",
|
|
||||||
Label = "",
|
|
||||||
SavePath = "",
|
|
||||||
Ratio = 0.5f,
|
|
||||||
RatioLimit = 0.8f
|
|
||||||
};
|
|
||||||
GivenTorrents(new List<QBittorrentTorrent> { torrent });
|
|
||||||
|
|
||||||
var item = Subject.GetItems().Single();
|
var item = Subject.GetItems().Single();
|
||||||
item.CanBeRemoved.Should().BeFalse();
|
item.CanBeRemoved.Should().BeFalse();
|
||||||
item.CanMoveFiles.Should().BeFalse();
|
item.CanMoveFiles.Should().BeFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_removable_and_should_allow_move_files_if_max_seedingtime_reached_and_paused()
|
||||||
|
{
|
||||||
|
GivenGlobalSeedLimits(-1, 20);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 2.0f, seedingTime: 20);
|
||||||
|
|
||||||
|
var item = Subject.GetItems().Single();
|
||||||
|
item.CanBeRemoved.Should().BeTrue();
|
||||||
|
item.CanMoveFiles.Should().BeTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_removable_and_should_allow_move_files_if_overridden_max_seedingtime_reached_and_paused()
|
||||||
|
{
|
||||||
|
GivenGlobalSeedLimits(-1, 40);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 2.0f, seedingTime: 20, seedingTimeLimit: 10);
|
||||||
|
|
||||||
|
var item = Subject.GetItems().Single();
|
||||||
|
item.CanBeRemoved.Should().BeTrue();
|
||||||
|
item.CanMoveFiles.Should().BeTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_not_be_removable_if_overridden_max_seedingtime_not_reached_and_paused()
|
||||||
|
{
|
||||||
|
GivenGlobalSeedLimits(-1, 20);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 2.0f, seedingTime: 30, seedingTimeLimit: 40);
|
||||||
|
|
||||||
|
var item = Subject.GetItems().Single();
|
||||||
|
item.CanBeRemoved.Should().BeFalse();
|
||||||
|
item.CanMoveFiles.Should().BeFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void should_be_removable_and_should_allow_move_files_if_max_seedingtime_reached_but_ratio_not_and_paused()
|
||||||
|
{
|
||||||
|
GivenGlobalSeedLimits(2.0f, 20);
|
||||||
|
GivenCompletedTorrent("pausedUP", ratio: 1.0f, seedingTime: 30);
|
||||||
|
|
||||||
|
var item = Subject.GetItems().Single();
|
||||||
|
item.CanBeRemoved.Should().BeTrue();
|
||||||
|
item.CanMoveFiles.Should().BeTrue();
|
||||||
|
}
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void should_get_category_from_the_category_if_set()
|
public void should_get_category_from_the_category_if_set()
|
||||||
{
|
{
|
||||||
const string category = "music-lidarr";
|
const string category = "music-lidarr";
|
||||||
GivenMaxRatio(1.0f);
|
GivenGlobalSeedLimits(1.0f);
|
||||||
|
|
||||||
var torrent = new QBittorrentTorrent
|
var torrent = new QBittorrentTorrent
|
||||||
{
|
{
|
||||||
|
@ -545,7 +587,7 @@ public void should_get_category_from_the_category_if_set()
|
||||||
public void should_get_category_from_the_label_if_the_category_is_not_available()
|
public void should_get_category_from_the_label_if_the_category_is_not_available()
|
||||||
{
|
{
|
||||||
const string category = "music-lidarr";
|
const string category = "music-lidarr";
|
||||||
GivenMaxRatio(1.0f);
|
GivenGlobalSeedLimits(1.0f);
|
||||||
|
|
||||||
var torrent = new QBittorrentTorrent
|
var torrent = new QBittorrentTorrent
|
||||||
{
|
{
|
||||||
|
|
|
@ -35,9 +35,9 @@ public QBittorrent(IQBittorrentProxySelector proxySelector,
|
||||||
|
|
||||||
protected override string AddFromMagnetLink(RemoteAlbum remoteAlbum, string hash, string magnetLink)
|
protected override string AddFromMagnetLink(RemoteAlbum remoteAlbum, string hash, string magnetLink)
|
||||||
{
|
{
|
||||||
if (!Proxy.GetConfig(Settings).DhtEnabled)
|
if (!Proxy.GetConfig(Settings).DhtEnabled && !magnetLink.Contains("&tr="))
|
||||||
{
|
{
|
||||||
throw new NotSupportedException("Magnet Links not supported if DHT is disabled");
|
throw new NotSupportedException("Magnet Links without trackers not supported if DHT is disabled");
|
||||||
}
|
}
|
||||||
|
|
||||||
Proxy.AddTorrentFromUrl(magnetLink, Settings);
|
Proxy.AddTorrentFromUrl(magnetLink, Settings);
|
||||||
|
@ -389,35 +389,52 @@ protected bool HasReachedSeedLimit(QBittorrentTorrent torrent, QBittorrentPrefer
|
||||||
{
|
{
|
||||||
if (torrent.RatioLimit >= 0)
|
if (torrent.RatioLimit >= 0)
|
||||||
{
|
{
|
||||||
if (torrent.Ratio < torrent.RatioLimit)
|
if (torrent.Ratio >= torrent.RatioLimit)
|
||||||
{
|
{
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (torrent.RatioLimit == -2 && config.MaxRatioEnabled)
|
else if (torrent.RatioLimit == -2 && config.MaxRatioEnabled)
|
||||||
{
|
{
|
||||||
if (torrent.Ratio < config.MaxRatio)
|
if (torrent.Ratio >= config.MaxRatio)
|
||||||
{
|
{
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (torrent.SeedingTimeLimit >= 0)
|
if (torrent.SeedingTimeLimit >= 0)
|
||||||
{
|
{
|
||||||
if (torrent.SeedingTime < torrent.SeedingTimeLimit)
|
if (!torrent.SeedingTime.HasValue)
|
||||||
{
|
{
|
||||||
return false;
|
FetchTorrentDetails(torrent);
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (torrent.RatioLimit == -2 && config.MaxSeedingTimeEnabled)
|
|
||||||
{
|
|
||||||
if (torrent.SeedingTime < config.MaxSeedingTime)
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (torrent.SeedingTime >= torrent.SeedingTimeLimit)
|
||||||
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (torrent.SeedingTimeLimit == -2 && config.MaxSeedingTimeEnabled)
|
||||||
|
{
|
||||||
|
if (!torrent.SeedingTime.HasValue)
|
||||||
|
{
|
||||||
|
FetchTorrentDetails(torrent);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (torrent.SeedingTime >= config.MaxSeedingTime)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void FetchTorrentDetails(QBittorrentTorrent torrent)
|
||||||
|
{
|
||||||
|
var torrentProperties = Proxy.GetTorrentProperties(torrent.Hash, Settings);
|
||||||
|
|
||||||
|
torrent.SeedingTime = torrentProperties.SeedingTime;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,7 @@ public interface IQBittorrentProxy
|
||||||
string GetVersion(QBittorrentSettings settings);
|
string GetVersion(QBittorrentSettings settings);
|
||||||
QBittorrentPreferences GetConfig(QBittorrentSettings settings);
|
QBittorrentPreferences GetConfig(QBittorrentSettings settings);
|
||||||
List<QBittorrentTorrent> GetTorrents(QBittorrentSettings settings);
|
List<QBittorrentTorrent> GetTorrents(QBittorrentSettings settings);
|
||||||
|
QBittorrentTorrentProperties GetTorrentProperties(string hash, QBittorrentSettings settings);
|
||||||
|
|
||||||
void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings);
|
void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings);
|
||||||
void AddTorrentFromFile(string fileName, byte[] fileContent, QBittorrentSettings settings);
|
void AddTorrentFromFile(string fileName, byte[] fileContent, QBittorrentSettings settings);
|
||||||
|
|
|
@ -95,6 +95,14 @@ public List<QBittorrentTorrent> GetTorrents(QBittorrentSettings settings)
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public QBittorrentTorrentProperties GetTorrentProperties(string hash, QBittorrentSettings settings)
|
||||||
|
{
|
||||||
|
var request = BuildRequest(settings).Resource($"/query/propertiesGeneral/{hash}");
|
||||||
|
var response = ProcessRequest<QBittorrentTorrentProperties>(request, settings);
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
public void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings)
|
public void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings)
|
||||||
{
|
{
|
||||||
var request = BuildRequest(settings).Resource("/command/download")
|
var request = BuildRequest(settings).Resource("/command/download")
|
||||||
|
|
|
@ -93,6 +93,15 @@ public List<QBittorrentTorrent> GetTorrents(QBittorrentSettings settings)
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public QBittorrentTorrentProperties GetTorrentProperties(string hash, QBittorrentSettings settings)
|
||||||
|
{
|
||||||
|
var request = BuildRequest(settings).Resource("/api/v2/torrents/properties")
|
||||||
|
.AddQueryParam("hash", hash);
|
||||||
|
var response = ProcessRequest<QBittorrentTorrentProperties>(request, settings);
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
public void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings)
|
public void AddTorrentFromUrl(string torrentUrl, QBittorrentSettings settings)
|
||||||
{
|
{
|
||||||
var request = BuildRequest(settings).Resource("/api/v2/torrents/add")
|
var request = BuildRequest(settings).Resource("/api/v2/torrents/add")
|
||||||
|
|
|
@ -30,10 +30,18 @@ public class QBittorrentTorrent
|
||||||
public float RatioLimit { get; set; } = -2;
|
public float RatioLimit { get; set; } = -2;
|
||||||
|
|
||||||
[JsonProperty(PropertyName = "seeding_time")]
|
[JsonProperty(PropertyName = "seeding_time")]
|
||||||
public long SeedingTime { get; set; } // Torrent seeding time
|
public long? SeedingTime { get; set; } // Torrent seeding time (not provided by the list api)
|
||||||
|
|
||||||
[JsonProperty(PropertyName = "seeding_time_limit")] // Per torrent seeding time limit (-2 = use global, -1 = unlimited)
|
[JsonProperty(PropertyName = "seeding_time_limit")] // Per torrent seeding time limit (-2 = use global, -1 = unlimited)
|
||||||
public long SeedingTimeLimit { get; set; } = -2;
|
public long SeedingTimeLimit { get; set; } = -2;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class QBittorrentTorrentProperties
|
||||||
|
{
|
||||||
|
public string Hash { get; set; } // Torrent hash
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "seeding_time")]
|
||||||
|
public long SeedingTime { get; set; } // Torrent seeding time
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue