mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-09 22:37:59 +00:00
parent
b0cfe53329
commit
f99a98306d
@ -2680,22 +2680,26 @@ bool SessionImpl::addTorrent_impl(const std::variant<MagnetUri, TorrentInfo> &so
|
|||||||
if (m_loadingTorrents.contains(id) || (infoHash.isHybrid() && m_loadingTorrents.contains(altID)))
|
if (m_loadingTorrents.contains(id) || (infoHash.isHybrid() && m_loadingTorrents.contains(altID)))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (Torrent *torrent = findTorrent(infoHash); torrent)
|
if (Torrent *torrent = findTorrent(infoHash))
|
||||||
{
|
{
|
||||||
// a duplicate torrent is being added
|
// a duplicate torrent is being added
|
||||||
if (torrent->isPrivate())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (hasMetadata)
|
if (hasMetadata)
|
||||||
{
|
{
|
||||||
// Trying to set metadata to existing torrent in case if it has none
|
// Trying to set metadata to existing torrent in case if it has none
|
||||||
torrent->setMetadata(std::get<TorrentInfo>(source));
|
torrent->setMetadata(std::get<TorrentInfo>(source));
|
||||||
|
}
|
||||||
|
|
||||||
|
const bool isPrivate = torrent->isPrivate() || (hasMetadata && std::get<TorrentInfo>(source).isPrivate());
|
||||||
|
if (isPrivate)
|
||||||
|
{
|
||||||
|
LogMsg(tr("Found existing torrent. Trackers cannot be merged because it is a private torrent. Torrent: %1").arg(torrent->name()));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (hasMetadata)
|
||||||
|
{
|
||||||
const TorrentInfo &torrentInfo = std::get<TorrentInfo>(source);
|
const TorrentInfo &torrentInfo = std::get<TorrentInfo>(source);
|
||||||
|
|
||||||
if (torrentInfo.isPrivate())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// merge trackers and web seeds
|
// merge trackers and web seeds
|
||||||
torrent->addTrackers(torrentInfo.trackers());
|
torrent->addTrackers(torrentInfo.trackers());
|
||||||
torrent->addUrlSeeds(torrentInfo.urlSeeds());
|
torrent->addUrlSeeds(torrentInfo.urlSeeds());
|
||||||
@ -2709,6 +2713,7 @@ bool SessionImpl::addTorrent_impl(const std::variant<MagnetUri, TorrentInfo> &so
|
|||||||
torrent->addUrlSeeds(magnetUri.urlSeeds());
|
torrent->addUrlSeeds(magnetUri.urlSeeds());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LogMsg(tr("Found existing torrent. Trackers are merged from new source. Torrent: %1").arg(torrent->name()));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user