mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 13:04:23 +00:00
Merge pull request #12176 from NotTsunami/ssl
Add HTTPS tracker certificate validation option
This commit is contained in:
commit
7061242681
@ -486,6 +486,7 @@ Session::Session(QObject *parent)
|
|||||||
, m_utpMixedMode(BITTORRENT_SESSION_KEY("uTPMixedMode"), MixedModeAlgorithm::TCP
|
, m_utpMixedMode(BITTORRENT_SESSION_KEY("uTPMixedMode"), MixedModeAlgorithm::TCP
|
||||||
, clampValue(MixedModeAlgorithm::TCP, MixedModeAlgorithm::Proportional))
|
, clampValue(MixedModeAlgorithm::TCP, MixedModeAlgorithm::Proportional))
|
||||||
, m_multiConnectionsPerIpEnabled(BITTORRENT_SESSION_KEY("MultiConnectionsPerIp"), false)
|
, m_multiConnectionsPerIpEnabled(BITTORRENT_SESSION_KEY("MultiConnectionsPerIp"), false)
|
||||||
|
, m_validateHTTPSTrackerCertificate(BITTORRENT_SESSION_KEY("ValidateHTTPSTrackerCertificate"), false)
|
||||||
, m_isAddTrackersEnabled(BITTORRENT_SESSION_KEY("AddTrackersEnabled"), false)
|
, m_isAddTrackersEnabled(BITTORRENT_SESSION_KEY("AddTrackersEnabled"), false)
|
||||||
, m_additionalTrackers(BITTORRENT_SESSION_KEY("AdditionalTrackers"))
|
, m_additionalTrackers(BITTORRENT_SESSION_KEY("AdditionalTrackers"))
|
||||||
, m_globalMaxRatio(BITTORRENT_SESSION_KEY("GlobalMaxRatio"), -1, [](qreal r) { return r < 0 ? -1. : r;})
|
, m_globalMaxRatio(BITTORRENT_SESSION_KEY("GlobalMaxRatio"), -1, [](qreal r) { return r < 0 ? -1. : r;})
|
||||||
@ -1487,6 +1488,10 @@ void Session::loadLTSettings(lt::settings_pack &settingsPack)
|
|||||||
|
|
||||||
settingsPack.set_bool(lt::settings_pack::allow_multiple_connections_per_ip, multiConnectionsPerIpEnabled());
|
settingsPack.set_bool(lt::settings_pack::allow_multiple_connections_per_ip, multiConnectionsPerIpEnabled());
|
||||||
|
|
||||||
|
#ifdef HAS_HTTPS_TRACKER_VALIDATION
|
||||||
|
settingsPack.set_bool(lt::settings_pack::validate_https_trackers, validateHTTPSTrackerCertificate());
|
||||||
|
#endif
|
||||||
|
|
||||||
settingsPack.set_bool(lt::settings_pack::apply_ip_filter_to_trackers, isTrackerFilteringEnabled());
|
settingsPack.set_bool(lt::settings_pack::apply_ip_filter_to_trackers, isTrackerFilteringEnabled());
|
||||||
|
|
||||||
settingsPack.set_bool(lt::settings_pack::enable_dht, isDHTEnabled());
|
settingsPack.set_bool(lt::settings_pack::enable_dht, isDHTEnabled());
|
||||||
@ -3771,6 +3776,19 @@ void Session::setMultiConnectionsPerIpEnabled(const bool enabled)
|
|||||||
configureDeferred();
|
configureDeferred();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Session::validateHTTPSTrackerCertificate() const
|
||||||
|
{
|
||||||
|
return m_validateHTTPSTrackerCertificate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Session::setValidateHTTPSTrackerCertificate(const bool enabled)
|
||||||
|
{
|
||||||
|
if (enabled == m_validateHTTPSTrackerCertificate) return;
|
||||||
|
|
||||||
|
m_validateHTTPSTrackerCertificate = enabled;
|
||||||
|
configureDeferred();
|
||||||
|
}
|
||||||
|
|
||||||
bool Session::isTrackerFilteringEnabled() const
|
bool Session::isTrackerFilteringEnabled() const
|
||||||
{
|
{
|
||||||
return m_isTrackerFilteringEnabled;
|
return m_isTrackerFilteringEnabled;
|
||||||
|
@ -47,6 +47,10 @@
|
|||||||
#include "sessionstatus.h"
|
#include "sessionstatus.h"
|
||||||
#include "torrentinfo.h"
|
#include "torrentinfo.h"
|
||||||
|
|
||||||
|
#if ((LIBTORRENT_VERSION_NUM >= 10206) && !defined(Q_OS_WIN))
|
||||||
|
#define HAS_HTTPS_TRACKER_VALIDATION
|
||||||
|
#endif
|
||||||
|
|
||||||
class QFile;
|
class QFile;
|
||||||
class QNetworkConfiguration;
|
class QNetworkConfiguration;
|
||||||
class QNetworkConfigurationManager;
|
class QNetworkConfigurationManager;
|
||||||
@ -401,6 +405,8 @@ namespace BitTorrent
|
|||||||
void setUtpMixedMode(MixedModeAlgorithm mode);
|
void setUtpMixedMode(MixedModeAlgorithm mode);
|
||||||
bool multiConnectionsPerIpEnabled() const;
|
bool multiConnectionsPerIpEnabled() const;
|
||||||
void setMultiConnectionsPerIpEnabled(bool enabled);
|
void setMultiConnectionsPerIpEnabled(bool enabled);
|
||||||
|
bool validateHTTPSTrackerCertificate() const;
|
||||||
|
void setValidateHTTPSTrackerCertificate(bool enabled);
|
||||||
bool isTrackerFilteringEnabled() const;
|
bool isTrackerFilteringEnabled() const;
|
||||||
void setTrackerFilteringEnabled(bool enabled);
|
void setTrackerFilteringEnabled(bool enabled);
|
||||||
QStringList bannedIPs() const;
|
QStringList bannedIPs() const;
|
||||||
@ -665,6 +671,7 @@ namespace BitTorrent
|
|||||||
CachedSettingValue<bool> m_isUTPRateLimited;
|
CachedSettingValue<bool> m_isUTPRateLimited;
|
||||||
CachedSettingValue<MixedModeAlgorithm> m_utpMixedMode;
|
CachedSettingValue<MixedModeAlgorithm> m_utpMixedMode;
|
||||||
CachedSettingValue<bool> m_multiConnectionsPerIpEnabled;
|
CachedSettingValue<bool> m_multiConnectionsPerIpEnabled;
|
||||||
|
CachedSettingValue<bool> m_validateHTTPSTrackerCertificate;
|
||||||
CachedSettingValue<bool> m_isAddTrackersEnabled;
|
CachedSettingValue<bool> m_isAddTrackersEnabled;
|
||||||
CachedSettingValue<QString> m_additionalTrackers;
|
CachedSettingValue<QString> m_additionalTrackers;
|
||||||
CachedSettingValue<qreal> m_globalMaxRatio;
|
CachedSettingValue<qreal> m_globalMaxRatio;
|
||||||
|
@ -108,6 +108,9 @@ enum AdvSettingsRows
|
|||||||
#endif
|
#endif
|
||||||
UTP_MIX_MODE,
|
UTP_MIX_MODE,
|
||||||
MULTI_CONNECTIONS_PER_IP,
|
MULTI_CONNECTIONS_PER_IP,
|
||||||
|
#ifdef HAS_HTTPS_TRACKER_VALIDATION
|
||||||
|
VALIDATE_HTTPS_TRACKER_CERTIFICATE,
|
||||||
|
#endif
|
||||||
// embedded tracker
|
// embedded tracker
|
||||||
TRACKER_STATUS,
|
TRACKER_STATUS,
|
||||||
TRACKER_PORT,
|
TRACKER_PORT,
|
||||||
@ -215,6 +218,10 @@ void AdvancedSettings::saveAdvancedSettings()
|
|||||||
session->setUtpMixedMode(static_cast<BitTorrent::MixedModeAlgorithm>(m_comboBoxUtpMixedMode.currentIndex()));
|
session->setUtpMixedMode(static_cast<BitTorrent::MixedModeAlgorithm>(m_comboBoxUtpMixedMode.currentIndex()));
|
||||||
// multiple connections per IP
|
// multiple connections per IP
|
||||||
session->setMultiConnectionsPerIpEnabled(m_checkBoxMultiConnectionsPerIp.isChecked());
|
session->setMultiConnectionsPerIpEnabled(m_checkBoxMultiConnectionsPerIp.isChecked());
|
||||||
|
#ifdef HAS_HTTPS_TRACKER_VALIDATION
|
||||||
|
// Validate HTTPS tracker certificate
|
||||||
|
session->setValidateHTTPSTrackerCertificate(m_checkBoxValidateHTTPSTrackerCertificate.isChecked());
|
||||||
|
#endif
|
||||||
// Recheck torrents on completion
|
// Recheck torrents on completion
|
||||||
pref->recheckTorrentsOnCompletion(m_checkBoxRecheckCompleted.isChecked());
|
pref->recheckTorrentsOnCompletion(m_checkBoxRecheckCompleted.isChecked());
|
||||||
// Transfer list refresh interval
|
// Transfer list refresh interval
|
||||||
@ -498,6 +505,13 @@ void AdvancedSettings::loadAdvancedSettings()
|
|||||||
// multiple connections per IP
|
// multiple connections per IP
|
||||||
m_checkBoxMultiConnectionsPerIp.setChecked(session->multiConnectionsPerIpEnabled());
|
m_checkBoxMultiConnectionsPerIp.setChecked(session->multiConnectionsPerIpEnabled());
|
||||||
addRow(MULTI_CONNECTIONS_PER_IP, tr("Allow multiple connections from the same IP address"), &m_checkBoxMultiConnectionsPerIp);
|
addRow(MULTI_CONNECTIONS_PER_IP, tr("Allow multiple connections from the same IP address"), &m_checkBoxMultiConnectionsPerIp);
|
||||||
|
#ifdef HAS_HTTPS_TRACKER_VALIDATION
|
||||||
|
// Validate HTTPS tracker certificate
|
||||||
|
m_checkBoxValidateHTTPSTrackerCertificate.setChecked(session->validateHTTPSTrackerCertificate());
|
||||||
|
addRow(VALIDATE_HTTPS_TRACKER_CERTIFICATE, (tr("Validate HTTPS tracker certificates")
|
||||||
|
+ ' ' + makeLink("https://www.libtorrent.org/reference-Settings.html#validate_https_trackers", "(?)"))
|
||||||
|
, &m_checkBoxValidateHTTPSTrackerCertificate);
|
||||||
|
#endif
|
||||||
// Recheck completed torrents
|
// Recheck completed torrents
|
||||||
m_checkBoxRecheckCompleted.setChecked(pref->recheckTorrentsOnCompletion());
|
m_checkBoxRecheckCompleted.setChecked(pref->recheckTorrentsOnCompletion());
|
||||||
addRow(RECHECK_COMPLETED, tr("Recheck torrents on completion"), &m_checkBoxRecheckCompleted);
|
addRow(RECHECK_COMPLETED, tr("Recheck torrents on completion"), &m_checkBoxRecheckCompleted);
|
||||||
|
@ -64,7 +64,7 @@ private:
|
|||||||
QCheckBox m_checkBoxOsCache, m_checkBoxRecheckCompleted, m_checkBoxResolveCountries, m_checkBoxResolveHosts,
|
QCheckBox m_checkBoxOsCache, m_checkBoxRecheckCompleted, m_checkBoxResolveCountries, m_checkBoxResolveHosts,
|
||||||
m_checkBoxProgramNotifications, m_checkBoxTorrentAddedNotifications, m_checkBoxTrackerFavicon, m_checkBoxTrackerStatus,
|
m_checkBoxProgramNotifications, m_checkBoxTorrentAddedNotifications, m_checkBoxTrackerFavicon, m_checkBoxTrackerStatus,
|
||||||
m_checkBoxConfirmTorrentRecheck, m_checkBoxConfirmRemoveAllTags, m_checkBoxAnnounceAllTrackers, m_checkBoxAnnounceAllTiers,
|
m_checkBoxConfirmTorrentRecheck, m_checkBoxConfirmRemoveAllTags, m_checkBoxAnnounceAllTrackers, m_checkBoxAnnounceAllTiers,
|
||||||
m_checkBoxMultiConnectionsPerIp, m_checkBoxPieceExtentAffinity, m_checkBoxSuggestMode, m_checkBoxCoalesceRW, m_checkBoxSpeedWidgetEnabled;
|
m_checkBoxMultiConnectionsPerIp, m_checkBoxValidateHTTPSTrackerCertificate, m_checkBoxPieceExtentAffinity, m_checkBoxSuggestMode, m_checkBoxCoalesceRW, m_checkBoxSpeedWidgetEnabled;
|
||||||
QComboBox m_comboBoxInterface, m_comboBoxInterfaceAddress, m_comboBoxUtpMixedMode, m_comboBoxChokingAlgorithm, m_comboBoxSeedChokingAlgorithm;
|
QComboBox m_comboBoxInterface, m_comboBoxInterfaceAddress, m_comboBoxUtpMixedMode, m_comboBoxChokingAlgorithm, m_comboBoxSeedChokingAlgorithm;
|
||||||
QLineEdit m_lineEditAnnounceIP;
|
QLineEdit m_lineEditAnnounceIP;
|
||||||
|
|
||||||
|
@ -307,6 +307,8 @@ void AppController::preferencesAction()
|
|||||||
data["utp_tcp_mixed_mode"] = static_cast<int>(session->utpMixedMode());
|
data["utp_tcp_mixed_mode"] = static_cast<int>(session->utpMixedMode());
|
||||||
// Multiple connections per IP
|
// Multiple connections per IP
|
||||||
data["enable_multi_connections_from_same_ip"] = session->multiConnectionsPerIpEnabled();
|
data["enable_multi_connections_from_same_ip"] = session->multiConnectionsPerIpEnabled();
|
||||||
|
// Validate HTTPS tracker certificate
|
||||||
|
data["validate_https_tracker_certificate"] = session->validateHTTPSTrackerCertificate();
|
||||||
// Embedded tracker
|
// Embedded tracker
|
||||||
data["enable_embedded_tracker"] = session->isTrackerEnabled();
|
data["enable_embedded_tracker"] = session->isTrackerEnabled();
|
||||||
data["embedded_tracker_port"] = pref->getTrackerPort();
|
data["embedded_tracker_port"] = pref->getTrackerPort();
|
||||||
@ -740,6 +742,9 @@ void AppController::setPreferencesAction()
|
|||||||
// Multiple connections per IP
|
// Multiple connections per IP
|
||||||
if (hasKey("enable_multi_connections_from_same_ip"))
|
if (hasKey("enable_multi_connections_from_same_ip"))
|
||||||
session->setMultiConnectionsPerIpEnabled(it.value().toBool());
|
session->setMultiConnectionsPerIpEnabled(it.value().toBool());
|
||||||
|
// Validate HTTPS tracker certificate
|
||||||
|
if (hasKey("validate_https_tracker_certificate"))
|
||||||
|
session->setValidateHTTPSTrackerCertificate(it.value().toBool());
|
||||||
// Embedded tracker
|
// Embedded tracker
|
||||||
if (hasKey("embedded_tracker_port"))
|
if (hasKey("embedded_tracker_port"))
|
||||||
pref->setTrackerPort(it.value().toInt());
|
pref->setTrackerPort(it.value().toInt());
|
||||||
|
@ -1034,6 +1034,14 @@
|
|||||||
<input type="checkbox" id="allowMultipleConnectionsFromTheSameIPAddress" />
|
<input type="checkbox" id="allowMultipleConnectionsFromTheSameIPAddress" />
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
<label for="validateHTTPSTrackerCertificate">QBT_TR(Validate HTTPS tracker certificate:)QBT_TR[CONTEXT=OptionsDialog] <a href="https://www.libtorrent.org/reference-Settings.html#validate_https_trackers" target="_blank">(?)</a></label>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<input type="checkbox" id="validateHTTPSTrackerCertificate" />
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
<label for="enableEmbeddedTracker">QBT_TR(Enable embedded tracker:)QBT_TR[CONTEXT=OptionsDialog]</label>
|
<label for="enableEmbeddedTracker">QBT_TR(Enable embedded tracker:)QBT_TR[CONTEXT=OptionsDialog]</label>
|
||||||
@ -1790,6 +1798,7 @@
|
|||||||
$('UPnPLeaseDuration').setProperty('value', pref.upnp_lease_duration);
|
$('UPnPLeaseDuration').setProperty('value', pref.upnp_lease_duration);
|
||||||
$('utpTCPMixedModeAlgorithm').setProperty('value', pref.utp_tcp_mixed_mode);
|
$('utpTCPMixedModeAlgorithm').setProperty('value', pref.utp_tcp_mixed_mode);
|
||||||
$('allowMultipleConnectionsFromTheSameIPAddress').setProperty('checked', pref.enable_multi_connections_from_same_ip);
|
$('allowMultipleConnectionsFromTheSameIPAddress').setProperty('checked', pref.enable_multi_connections_from_same_ip);
|
||||||
|
$('validateHTTPSTrackerCertificate').setProperty('checked', pref.validate_https_tracker_certificate);
|
||||||
$('enableEmbeddedTracker').setProperty('checked', pref.enable_embedded_tracker);
|
$('enableEmbeddedTracker').setProperty('checked', pref.enable_embedded_tracker);
|
||||||
$('embeddedTrackerPort').setProperty('value', pref.embedded_tracker_port);
|
$('embeddedTrackerPort').setProperty('value', pref.embedded_tracker_port);
|
||||||
$('uploadSlotsBehavior').setProperty('value', pref.upload_slots_behavior);
|
$('uploadSlotsBehavior').setProperty('value', pref.upload_slots_behavior);
|
||||||
@ -2163,6 +2172,7 @@
|
|||||||
settings.set('upnp_lease_duration', $('UPnPLeaseDuration').getProperty('value'));
|
settings.set('upnp_lease_duration', $('UPnPLeaseDuration').getProperty('value'));
|
||||||
settings.set('utp_tcp_mixed_mode', $('utpTCPMixedModeAlgorithm').getProperty('value'));
|
settings.set('utp_tcp_mixed_mode', $('utpTCPMixedModeAlgorithm').getProperty('value'));
|
||||||
settings.set('enable_multi_connections_from_same_ip', $('allowMultipleConnectionsFromTheSameIPAddress').getProperty('checked'));
|
settings.set('enable_multi_connections_from_same_ip', $('allowMultipleConnectionsFromTheSameIPAddress').getProperty('checked'));
|
||||||
|
settings.set('validate_https_tracker_certificate', $('validateHTTPSTrackerCertificate').getProperty('checked'));
|
||||||
settings.set('enable_embedded_tracker', $('enableEmbeddedTracker').getProperty('checked'));
|
settings.set('enable_embedded_tracker', $('enableEmbeddedTracker').getProperty('checked'));
|
||||||
settings.set('embedded_tracker_port', $('embeddedTrackerPort').getProperty('value'));
|
settings.set('embedded_tracker_port', $('embeddedTrackerPort').getProperty('value'));
|
||||||
settings.set('upload_slots_behavior', $('uploadSlotsBehavior').getProperty('value'));
|
settings.set('upload_slots_behavior', $('uploadSlotsBehavior').getProperty('value'));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user