Filter torrent info endpoint by hashes

Added hashes parameter to info action.
Allows filtering seralized torrents by passing it into the TorrentFilter.
This commit is contained in:
Marcel Petersen 2018-05-02 09:14:07 +02:00 committed by sledgehammer999
parent 92fc62bb0d
commit e6f4aa6a2f
No known key found for this signature in database
GPG key ID: 6E4A2D025B7CC9A2

View file

@ -150,6 +150,7 @@ namespace
// GET params: // GET params:
// - filter (string): all, downloading, seeding, completed, paused, resumed, active, inactive // - filter (string): all, downloading, seeding, completed, paused, resumed, active, inactive
// - category (string): torrent category for filtering by it (empty string means "uncategorized"; no "category" param presented means "any category") // - category (string): torrent category for filtering by it (empty string means "uncategorized"; no "category" param presented means "any category")
// - hashes (string): filter by hashes, can contain multiple hashes separated by |
// - sort (string): name of column for sorting by its value // - sort (string): name of column for sorting by its value
// - reverse (bool): enable reverse sorting // - reverse (bool): enable reverse sorting
// - limit (int): set limit number of torrents returned (if greater than 0, otherwise - unlimited) // - limit (int): set limit number of torrents returned (if greater than 0, otherwise - unlimited)
@ -162,9 +163,10 @@ void TorrentsController::infoAction()
const bool reverse {parseBool(params()["reverse"], false)}; const bool reverse {parseBool(params()["reverse"], false)};
int limit {params()["limit"].toInt()}; int limit {params()["limit"].toInt()};
int offset {params()["offset"].toInt()}; int offset {params()["offset"].toInt()};
const QStringSet hashSet {params()["hashes"].split('|', QString::SkipEmptyParts).toSet()};
QVariantList torrentList; QVariantList torrentList;
TorrentFilter torrentFilter(filter, TorrentFilter::AnyHash, category); TorrentFilter torrentFilter(filter, (hashSet.isEmpty() ? TorrentFilter::AnyHash : hashSet), category);
foreach (BitTorrent::TorrentHandle *const torrent, BitTorrent::Session::instance()->torrents()) { foreach (BitTorrent::TorrentHandle *const torrent, BitTorrent::Session::instance()->torrents()) {
if (torrentFilter.match(torrent)) if (torrentFilter.match(torrent))
torrentList.append(serialize(*torrent)); torrentList.append(serialize(*torrent));