mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-25 22:14:32 +00:00
Merge pull request #3371 from ngosang/webuialterdl
[Web UI] Fix alternative global rate limits. Closes #3359
This commit is contained in:
commit
647140c7c7
@ -42,8 +42,13 @@ static const char *__TRANSLATIONS__[] = {
|
|||||||
QT_TRANSLATE_NOOP("HttpServer", "Download local torrent"),
|
QT_TRANSLATE_NOOP("HttpServer", "Download local torrent"),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Download"),
|
QT_TRANSLATE_NOOP("HttpServer", "Download"),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Are you sure you want to delete the selected torrents from the transfer list?"),
|
QT_TRANSLATE_NOOP("HttpServer", "Are you sure you want to delete the selected torrents from the transfer list?"),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Download rate limit must be greater than 0 or disabled."),
|
QT_TRANSLATE_NOOP("HttpServer", "Global upload rate limit must be greater than 0 or disabled."),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Upload rate limit must be greater than 0 or disabled."),
|
QT_TRANSLATE_NOOP("HttpServer", "Global download rate limit must be greater than 0 or disabled."),
|
||||||
|
QT_TRANSLATE_NOOP("HttpServer", "Alternative upload rate limit must be greater than 0 or disabled."),
|
||||||
|
QT_TRANSLATE_NOOP("HttpServer", "Alternative download rate limit must be greater than 0 or disabled."),
|
||||||
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum active downloads must be greater than -1."),
|
||||||
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum active uploads must be greater than -1."),
|
||||||
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum active torrents must be greater than -1."),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of connections limit must be greater than 0 or disabled."),
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of connections limit must be greater than 0 or disabled."),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of connections per torrent limit must be greater than 0 or disabled."),
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of connections per torrent limit must be greater than 0 or disabled."),
|
||||||
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of upload slots per torrent limit must be greater than 0 or disabled."),
|
QT_TRANSLATE_NOOP("HttpServer", "Maximum number of upload slots per torrent limit must be greater than 0 or disabled."),
|
||||||
|
@ -50,12 +50,14 @@ QByteArray prefjson::getPreferences()
|
|||||||
{
|
{
|
||||||
const Preferences* const pref = Preferences::instance();
|
const Preferences* const pref = Preferences::instance();
|
||||||
QVariantMap data;
|
QVariantMap data;
|
||||||
// UI
|
|
||||||
data["locale"] = pref->getLocale();
|
|
||||||
// Downloads
|
// Downloads
|
||||||
|
// Hard Disk
|
||||||
data["save_path"] = Utils::Fs::toNativePath(pref->getSavePath());
|
data["save_path"] = Utils::Fs::toNativePath(pref->getSavePath());
|
||||||
data["temp_path_enabled"] = pref->isTempPathEnabled();
|
data["temp_path_enabled"] = pref->isTempPathEnabled();
|
||||||
data["temp_path"] = Utils::Fs::toNativePath(pref->getTempPath());
|
data["temp_path"] = Utils::Fs::toNativePath(pref->getTempPath());
|
||||||
|
data["preallocate_all"] = pref->preAllocateAllFiles();
|
||||||
|
data["incomplete_files_ext"] = pref->useIncompleteFilesExtension();
|
||||||
QVariantList l;
|
QVariantList l;
|
||||||
foreach (const QString& s, pref->getScanDirs()) {
|
foreach (const QString& s, pref->getScanDirs()) {
|
||||||
l << Utils::Fs::toNativePath(s);
|
l << Utils::Fs::toNativePath(s);
|
||||||
@ -66,10 +68,9 @@ QByteArray prefjson::getPreferences()
|
|||||||
var_list << b;
|
var_list << b;
|
||||||
}
|
}
|
||||||
data["download_in_scan_dirs"] = var_list;
|
data["download_in_scan_dirs"] = var_list;
|
||||||
data["export_dir_enabled"] = pref->isTorrentExportEnabled();
|
|
||||||
data["export_dir"] = Utils::Fs::toNativePath(pref->getTorrentExportDir());
|
data["export_dir"] = Utils::Fs::toNativePath(pref->getTorrentExportDir());
|
||||||
data["export_dir_fin_enabled"] = pref->isFinishedTorrentExportEnabled();
|
|
||||||
data["export_dir_fin"] = Utils::Fs::toNativePath(pref->getFinishedTorrentExportDir());
|
data["export_dir_fin"] = Utils::Fs::toNativePath(pref->getFinishedTorrentExportDir());
|
||||||
|
// Email notification upon download completion
|
||||||
data["mail_notification_enabled"] = pref->isMailNotificationEnabled();
|
data["mail_notification_enabled"] = pref->isMailNotificationEnabled();
|
||||||
data["mail_notification_email"] = pref->getMailNotificationEmail();
|
data["mail_notification_email"] = pref->getMailNotificationEmail();
|
||||||
data["mail_notification_smtp"] = pref->getMailNotificationSMTP();
|
data["mail_notification_smtp"] = pref->getMailNotificationSMTP();
|
||||||
@ -77,48 +78,21 @@ QByteArray prefjson::getPreferences()
|
|||||||
data["mail_notification_auth_enabled"] = pref->getMailNotificationSMTPAuth();
|
data["mail_notification_auth_enabled"] = pref->getMailNotificationSMTPAuth();
|
||||||
data["mail_notification_username"] = pref->getMailNotificationSMTPUsername();
|
data["mail_notification_username"] = pref->getMailNotificationSMTPUsername();
|
||||||
data["mail_notification_password"] = pref->getMailNotificationSMTPPassword();
|
data["mail_notification_password"] = pref->getMailNotificationSMTPPassword();
|
||||||
|
// Run an external program on torrent completion
|
||||||
data["autorun_enabled"] = pref->isAutoRunEnabled();
|
data["autorun_enabled"] = pref->isAutoRunEnabled();
|
||||||
data["autorun_program"] = Utils::Fs::toNativePath(pref->getAutoRunProgram());
|
data["autorun_program"] = Utils::Fs::toNativePath(pref->getAutoRunProgram());
|
||||||
data["preallocate_all"] = pref->preAllocateAllFiles();
|
|
||||||
data["queueing_enabled"] = pref->isQueueingSystemEnabled();
|
|
||||||
data["max_active_downloads"] = pref->getMaxActiveDownloads();
|
|
||||||
data["max_active_torrents"] = pref->getMaxActiveTorrents();
|
|
||||||
data["max_active_uploads"] = pref->getMaxActiveUploads();
|
|
||||||
data["max_ratio_enabled"] = (pref->getGlobalMaxRatio() >= 0.);
|
|
||||||
data["max_ratio"] = pref->getGlobalMaxRatio();
|
|
||||||
data["max_ratio_act"] = pref->getMaxRatioAction();
|
|
||||||
data["dont_count_slow_torrents"] = pref->ignoreSlowTorrentsForQueueing();
|
|
||||||
data["incomplete_files_ext"] = pref->useIncompleteFilesExtension();
|
|
||||||
// Connection
|
// Connection
|
||||||
|
// Listening Port
|
||||||
data["listen_port"] = pref->getSessionPort();
|
data["listen_port"] = pref->getSessionPort();
|
||||||
data["upnp"] = pref->isUPnPEnabled();
|
data["upnp"] = pref->isUPnPEnabled();
|
||||||
data["random_port"] = pref->useRandomPort();
|
data["random_port"] = pref->useRandomPort();
|
||||||
data["dl_limit"] = pref->getGlobalDownloadLimit();
|
// Connections Limits
|
||||||
data["up_limit"] = pref->getGlobalUploadLimit();
|
|
||||||
data["max_connec"] = pref->getMaxConnecs();
|
data["max_connec"] = pref->getMaxConnecs();
|
||||||
data["max_connec_per_torrent"] = pref->getMaxConnecsPerTorrent();
|
data["max_connec_per_torrent"] = pref->getMaxConnecsPerTorrent();
|
||||||
data["max_uploads"] = pref->getMaxUploads();
|
data["max_uploads"] = pref->getMaxUploads();
|
||||||
data["max_uploads_per_torrent"] = pref->getMaxUploadsPerTorrent();
|
data["max_uploads_per_torrent"] = pref->getMaxUploadsPerTorrent();
|
||||||
data["enable_utp"] = pref->isuTPEnabled();
|
// Proxy Server
|
||||||
data["limit_utp_rate"] = pref->isuTPRateLimited();
|
|
||||||
data["limit_tcp_overhead"] = pref->includeOverheadInLimits();
|
|
||||||
data["alt_dl_limit"] = pref->getAltGlobalDownloadLimit();
|
|
||||||
data["alt_up_limit"] = pref->getAltGlobalUploadLimit();
|
|
||||||
data["scheduler_enabled"] = pref->isSchedulerEnabled();
|
|
||||||
const QTime start_time = pref->getSchedulerStartTime();
|
|
||||||
data["schedule_from_hour"] = start_time.hour();
|
|
||||||
data["schedule_from_min"] = start_time.minute();
|
|
||||||
const QTime end_time = pref->getSchedulerEndTime();
|
|
||||||
data["schedule_to_hour"] = end_time.hour();
|
|
||||||
data["schedule_to_min"] = end_time.minute();
|
|
||||||
data["scheduler_days"] = pref->getSchedulerDays();
|
|
||||||
// Bittorrent
|
|
||||||
data["dht"] = pref->isDHTEnabled();
|
|
||||||
data["pex"] = pref->isPeXEnabled();
|
|
||||||
data["lsd"] = pref->isLSDEnabled();
|
|
||||||
data["encryption"] = pref->getEncryptionSetting();
|
|
||||||
data["anonymous_mode"] = pref->isAnonymousModeEnabled();
|
|
||||||
// Proxy
|
|
||||||
data["proxy_type"] = pref->getProxyType();
|
data["proxy_type"] = pref->getProxyType();
|
||||||
data["proxy_ip"] = pref->getProxyIp();
|
data["proxy_ip"] = pref->getProxyIp();
|
||||||
data["proxy_port"] = pref->getProxyPort();
|
data["proxy_port"] = pref->getProxyPort();
|
||||||
@ -129,19 +103,61 @@ QByteArray prefjson::getPreferences()
|
|||||||
data["proxy_auth_enabled"] = pref->isProxyAuthEnabled();
|
data["proxy_auth_enabled"] = pref->isProxyAuthEnabled();
|
||||||
data["proxy_username"] = pref->getProxyUsername();
|
data["proxy_username"] = pref->getProxyUsername();
|
||||||
data["proxy_password"] = pref->getProxyPassword();
|
data["proxy_password"] = pref->getProxyPassword();
|
||||||
// IP Filter
|
// IP Filtering
|
||||||
data["ip_filter_enabled"] = pref->isFilteringEnabled();
|
data["ip_filter_enabled"] = pref->isFilteringEnabled();
|
||||||
data["ip_filter_path"] = Utils::Fs::toNativePath(pref->getFilter());
|
data["ip_filter_path"] = Utils::Fs::toNativePath(pref->getFilter());
|
||||||
data["ip_filter_trackers"] = pref->isFilteringTrackerEnabled();
|
data["ip_filter_trackers"] = pref->isFilteringTrackerEnabled();
|
||||||
|
|
||||||
|
// Speed
|
||||||
|
// Global Rate Limits
|
||||||
|
data["dl_limit"] = pref->getGlobalDownloadLimit();
|
||||||
|
data["up_limit"] = pref->getGlobalUploadLimit();
|
||||||
|
data["enable_utp"] = pref->isuTPEnabled();
|
||||||
|
data["limit_utp_rate"] = pref->isuTPRateLimited();
|
||||||
|
data["limit_tcp_overhead"] = pref->includeOverheadInLimits();
|
||||||
|
data["alt_dl_limit"] = pref->getAltGlobalDownloadLimit();
|
||||||
|
data["alt_up_limit"] = pref->getAltGlobalUploadLimit();
|
||||||
|
// Scheduling
|
||||||
|
data["scheduler_enabled"] = pref->isSchedulerEnabled();
|
||||||
|
const QTime start_time = pref->getSchedulerStartTime();
|
||||||
|
data["schedule_from_hour"] = start_time.hour();
|
||||||
|
data["schedule_from_min"] = start_time.minute();
|
||||||
|
const QTime end_time = pref->getSchedulerEndTime();
|
||||||
|
data["schedule_to_hour"] = end_time.hour();
|
||||||
|
data["schedule_to_min"] = end_time.minute();
|
||||||
|
data["scheduler_days"] = pref->getSchedulerDays();
|
||||||
|
|
||||||
|
// Bittorrent
|
||||||
|
// Privacy
|
||||||
|
data["dht"] = pref->isDHTEnabled();
|
||||||
|
data["pex"] = pref->isPeXEnabled();
|
||||||
|
data["lsd"] = pref->isLSDEnabled();
|
||||||
|
data["encryption"] = pref->getEncryptionSetting();
|
||||||
|
data["anonymous_mode"] = pref->isAnonymousModeEnabled();
|
||||||
|
// Torrent Queueing
|
||||||
|
data["queueing_enabled"] = pref->isQueueingSystemEnabled();
|
||||||
|
data["max_active_downloads"] = pref->getMaxActiveDownloads();
|
||||||
|
data["max_active_torrents"] = pref->getMaxActiveTorrents();
|
||||||
|
data["max_active_uploads"] = pref->getMaxActiveUploads();
|
||||||
|
data["dont_count_slow_torrents"] = pref->ignoreSlowTorrentsForQueueing();
|
||||||
|
// Share Ratio Limiting
|
||||||
|
data["max_ratio_enabled"] = (pref->getGlobalMaxRatio() >= 0.);
|
||||||
|
data["max_ratio"] = pref->getGlobalMaxRatio();
|
||||||
|
data["max_ratio_act"] = pref->getMaxRatioAction();
|
||||||
|
|
||||||
// Web UI
|
// Web UI
|
||||||
|
// Language
|
||||||
|
data["locale"] = pref->getLocale();
|
||||||
|
// HTTP Server
|
||||||
data["web_ui_port"] = pref->getWebUiPort();
|
data["web_ui_port"] = pref->getWebUiPort();
|
||||||
data["web_ui_username"] = pref->getWebUiUsername();
|
|
||||||
data["web_ui_password"] = pref->getWebUiPassword();
|
|
||||||
data["bypass_local_auth"] = !pref->isWebUiLocalAuthEnabled();
|
|
||||||
data["use_https"] = pref->isWebUiHttpsEnabled();
|
data["use_https"] = pref->isWebUiHttpsEnabled();
|
||||||
data["ssl_key"] = QString::fromLatin1(pref->getWebUiHttpsKey());
|
data["ssl_key"] = QString::fromLatin1(pref->getWebUiHttpsKey());
|
||||||
data["ssl_cert"] = QString::fromLatin1(pref->getWebUiHttpsCertificate());
|
data["ssl_cert"] = QString::fromLatin1(pref->getWebUiHttpsCertificate());
|
||||||
// DynDns
|
// Authentication
|
||||||
|
data["web_ui_username"] = pref->getWebUiUsername();
|
||||||
|
data["web_ui_password"] = pref->getWebUiPassword();
|
||||||
|
data["bypass_local_auth"] = !pref->isWebUiLocalAuthEnabled();
|
||||||
|
// Update my dynamic domain name
|
||||||
data["dyndns_enabled"] = pref->isDynDNSEnabled();
|
data["dyndns_enabled"] = pref->isDynDNSEnabled();
|
||||||
data["dyndns_service"] = pref->getDynDNSService();
|
data["dyndns_service"] = pref->getDynDNSService();
|
||||||
data["dyndns_username"] = pref->getDynDNSUsername();
|
data["dyndns_username"] = pref->getDynDNSUsername();
|
||||||
@ -153,31 +169,21 @@ QByteArray prefjson::getPreferences()
|
|||||||
|
|
||||||
void prefjson::setPreferences(const QString& json)
|
void prefjson::setPreferences(const QString& json)
|
||||||
{
|
{
|
||||||
|
Preferences* const pref = Preferences::instance();
|
||||||
const QVariantMap m = json::fromJson(json).toMap();
|
const QVariantMap m = json::fromJson(json).toMap();
|
||||||
|
|
||||||
// UI
|
|
||||||
Preferences* const pref = Preferences::instance();
|
|
||||||
if (m.contains("locale")) {
|
|
||||||
QString locale = m["locale"].toString();
|
|
||||||
if (pref->getLocale() != locale) {
|
|
||||||
QTranslator *translator = new QTranslator;
|
|
||||||
if (translator->load(QString::fromUtf8(":/lang/qbittorrent_") + locale)) {
|
|
||||||
qDebug("%s locale recognized, using translation.", qPrintable(locale));
|
|
||||||
}else{
|
|
||||||
qDebug("%s locale unrecognized, using default (en).", qPrintable(locale));
|
|
||||||
}
|
|
||||||
qApp->installTranslator(translator);
|
|
||||||
|
|
||||||
pref->setLocale(locale);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Downloads
|
// Downloads
|
||||||
|
// Hard Disk
|
||||||
if (m.contains("save_path"))
|
if (m.contains("save_path"))
|
||||||
pref->setSavePath(m["save_path"].toString());
|
pref->setSavePath(m["save_path"].toString());
|
||||||
if (m.contains("temp_path_enabled"))
|
if (m.contains("temp_path_enabled"))
|
||||||
pref->setTempPathEnabled(m["temp_path_enabled"].toBool());
|
pref->setTempPathEnabled(m["temp_path_enabled"].toBool());
|
||||||
if (m.contains("temp_path"))
|
if (m.contains("temp_path"))
|
||||||
pref->setTempPath(m["temp_path"].toString());
|
pref->setTempPath(m["temp_path"].toString());
|
||||||
|
if (m.contains("preallocate_all"))
|
||||||
|
pref->preAllocateAllFiles(m["preallocate_all"].toBool());
|
||||||
|
if (m.contains("incomplete_files_ext"))
|
||||||
|
pref->useIncompleteFilesExtension(m["incomplete_files_ext"].toBool());
|
||||||
if (m.contains("scan_dirs") && m.contains("download_in_scan_dirs")) {
|
if (m.contains("scan_dirs") && m.contains("download_in_scan_dirs")) {
|
||||||
QVariantList download_at_path_tmp = m["download_in_scan_dirs"].toList();
|
QVariantList download_at_path_tmp = m["download_in_scan_dirs"].toList();
|
||||||
QList<bool> download_at_path;
|
QList<bool> download_at_path;
|
||||||
@ -210,6 +216,7 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setTorrentExportDir(m["export_dir"].toString());
|
pref->setTorrentExportDir(m["export_dir"].toString());
|
||||||
if (m.contains("export_dir_fin"))
|
if (m.contains("export_dir_fin"))
|
||||||
pref->setFinishedTorrentExportDir(m["export_dir_fin"].toString());
|
pref->setFinishedTorrentExportDir(m["export_dir_fin"].toString());
|
||||||
|
// Email notification upon download completion
|
||||||
if (m.contains("mail_notification_enabled"))
|
if (m.contains("mail_notification_enabled"))
|
||||||
pref->setMailNotificationEnabled(m["mail_notification_enabled"].toBool());
|
pref->setMailNotificationEnabled(m["mail_notification_enabled"].toBool());
|
||||||
if (m.contains("mail_notification_email"))
|
if (m.contains("mail_notification_email"))
|
||||||
@ -224,41 +231,21 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setMailNotificationSMTPUsername(m["mail_notification_username"].toString());
|
pref->setMailNotificationSMTPUsername(m["mail_notification_username"].toString());
|
||||||
if (m.contains("mail_notification_password"))
|
if (m.contains("mail_notification_password"))
|
||||||
pref->setMailNotificationSMTPPassword(m["mail_notification_password"].toString());
|
pref->setMailNotificationSMTPPassword(m["mail_notification_password"].toString());
|
||||||
|
// Run an external program on torrent completion
|
||||||
if (m.contains("autorun_enabled"))
|
if (m.contains("autorun_enabled"))
|
||||||
pref->setAutoRunEnabled(m["autorun_enabled"].toBool());
|
pref->setAutoRunEnabled(m["autorun_enabled"].toBool());
|
||||||
if (m.contains("autorun_program"))
|
if (m.contains("autorun_program"))
|
||||||
pref->setAutoRunProgram(m["autorun_program"].toString());
|
pref->setAutoRunProgram(m["autorun_program"].toString());
|
||||||
if (m.contains("preallocate_all"))
|
|
||||||
pref->preAllocateAllFiles(m["preallocate_all"].toBool());
|
|
||||||
if (m.contains("queueing_enabled"))
|
|
||||||
pref->setQueueingSystemEnabled(m["queueing_enabled"].toBool());
|
|
||||||
if (m.contains("max_active_downloads"))
|
|
||||||
pref->setMaxActiveDownloads(m["max_active_downloads"].toInt());
|
|
||||||
if (m.contains("max_active_torrents"))
|
|
||||||
pref->setMaxActiveTorrents(m["max_active_torrents"].toInt());
|
|
||||||
if (m.contains("max_active_uploads"))
|
|
||||||
pref->setMaxActiveUploads(m["max_active_uploads"].toInt());
|
|
||||||
if (m.contains("max_ratio_enabled"))
|
|
||||||
pref->setGlobalMaxRatio(m["max_ratio"].toInt());
|
|
||||||
else
|
|
||||||
pref->setGlobalMaxRatio(-1);
|
|
||||||
if (m.contains("max_ratio_act"))
|
|
||||||
pref->setMaxRatioAction(m["max_ratio_act"].toInt());
|
|
||||||
if (m.contains("dont_count_slow_torrents"))
|
|
||||||
pref->setIgnoreSlowTorrentsForQueueing(m["dont_count_slow_torrents"].toBool());
|
|
||||||
if (m.contains("incomplete_files_ext"))
|
|
||||||
pref->useIncompleteFilesExtension(m["incomplete_files_ext"].toBool());
|
|
||||||
// Connection
|
// Connection
|
||||||
|
// Listening Port
|
||||||
if (m.contains("listen_port"))
|
if (m.contains("listen_port"))
|
||||||
pref->setSessionPort(m["listen_port"].toInt());
|
pref->setSessionPort(m["listen_port"].toInt());
|
||||||
if (m.contains("upnp"))
|
if (m.contains("upnp"))
|
||||||
pref->setUPnPEnabled(m["upnp"].toBool());
|
pref->setUPnPEnabled(m["upnp"].toBool());
|
||||||
if (m.contains("random_port"))
|
if (m.contains("random_port"))
|
||||||
pref->setRandomPort(m["random_port"].toBool());
|
pref->setRandomPort(m["random_port"].toBool());
|
||||||
if (m.contains("dl_limit"))
|
// Connections Limits
|
||||||
pref->setGlobalDownloadLimit(m["dl_limit"].toInt());
|
|
||||||
if (m.contains("up_limit"))
|
|
||||||
pref->setGlobalUploadLimit(m["up_limit"].toInt());
|
|
||||||
if (m.contains("max_connec"))
|
if (m.contains("max_connec"))
|
||||||
pref->setMaxConnecs(m["max_connec"].toInt());
|
pref->setMaxConnecs(m["max_connec"].toInt());
|
||||||
if (m.contains("max_connec_per_torrent"))
|
if (m.contains("max_connec_per_torrent"))
|
||||||
@ -267,41 +254,7 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setMaxUploads(m["max_uploads"].toInt());
|
pref->setMaxUploads(m["max_uploads"].toInt());
|
||||||
if (m.contains("max_uploads_per_torrent"))
|
if (m.contains("max_uploads_per_torrent"))
|
||||||
pref->setMaxUploadsPerTorrent(m["max_uploads_per_torrent"].toInt());
|
pref->setMaxUploadsPerTorrent(m["max_uploads_per_torrent"].toInt());
|
||||||
if (m.contains("enable_utp"))
|
// Proxy Server
|
||||||
pref->setuTPEnabled(m["enable_utp"].toBool());
|
|
||||||
if (m.contains("limit_utp_rate"))
|
|
||||||
pref->setuTPRateLimited(m["limit_utp_rate"].toBool());
|
|
||||||
if (m.contains("limit_tcp_overhead"))
|
|
||||||
pref->includeOverheadInLimits(m["limit_tcp_overhead"].toBool());
|
|
||||||
if (m.contains("alt_dl_limit"))
|
|
||||||
pref->setAltGlobalDownloadLimit(m["alt_dl_limit"].toInt());
|
|
||||||
if (m.contains("alt_up_limit"))
|
|
||||||
pref->setAltGlobalUploadLimit(m["alt_up_limit"].toInt());
|
|
||||||
if (m.contains("scheduler_enabled"))
|
|
||||||
pref->setSchedulerEnabled(m["scheduler_enabled"].toBool());
|
|
||||||
if (m.contains("schedule_from_hour") && m.contains("schedule_from_min")) {
|
|
||||||
pref->setSchedulerStartTime(QTime(m["schedule_from_hour"].toInt(),
|
|
||||||
m["schedule_from_min"].toInt()));
|
|
||||||
}
|
|
||||||
if (m.contains("schedule_to_hour") && m.contains("schedule_to_min")) {
|
|
||||||
pref->setSchedulerEndTime(QTime(m["schedule_to_hour"].toInt(),
|
|
||||||
m["schedule_to_min"].toInt()));
|
|
||||||
}
|
|
||||||
if (m.contains("scheduler_days"))
|
|
||||||
pref->setSchedulerDays(scheduler_days(m["scheduler_days"].toInt()));
|
|
||||||
// Bittorrent
|
|
||||||
if (m.contains("dht"))
|
|
||||||
pref->setDHTEnabled(m["dht"].toBool());
|
|
||||||
if (m.contains("pex"))
|
|
||||||
pref->setPeXEnabled(m["pex"].toBool());
|
|
||||||
qDebug("Pex support: %d", (int)m["pex"].toBool());
|
|
||||||
if (m.contains("lsd"))
|
|
||||||
pref->setLSDEnabled(m["lsd"].toBool());
|
|
||||||
if (m.contains("encryption"))
|
|
||||||
pref->setEncryptionSetting(m["encryption"].toInt());
|
|
||||||
if (m.contains("anonymous_mode"))
|
|
||||||
pref->enableAnonymousMode(m["anonymous_mode"].toBool());
|
|
||||||
// Proxy
|
|
||||||
if (m.contains("proxy_type"))
|
if (m.contains("proxy_type"))
|
||||||
pref->setProxyType(m["proxy_type"].toInt());
|
pref->setProxyType(m["proxy_type"].toInt());
|
||||||
if (m.contains("proxy_ip"))
|
if (m.contains("proxy_ip"))
|
||||||
@ -320,22 +273,94 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setProxyUsername(m["proxy_username"].toString());
|
pref->setProxyUsername(m["proxy_username"].toString());
|
||||||
if (m.contains("proxy_password"))
|
if (m.contains("proxy_password"))
|
||||||
pref->setProxyPassword(m["proxy_password"].toString());
|
pref->setProxyPassword(m["proxy_password"].toString());
|
||||||
// IP Filter
|
// IP Filtering
|
||||||
if (m.contains("ip_filter_enabled"))
|
if (m.contains("ip_filter_enabled"))
|
||||||
pref->setFilteringEnabled(m["ip_filter_enabled"].toBool());
|
pref->setFilteringEnabled(m["ip_filter_enabled"].toBool());
|
||||||
if (m.contains("ip_filter_path"))
|
if (m.contains("ip_filter_path"))
|
||||||
pref->setFilter(m["ip_filter_path"].toString());
|
pref->setFilter(m["ip_filter_path"].toString());
|
||||||
if (m.contains("ip_filter_trackers"))
|
if (m.contains("ip_filter_trackers"))
|
||||||
pref->setFilteringTrackerEnabled(m["ip_filter_trackers"].toBool());
|
pref->setFilteringTrackerEnabled(m["ip_filter_trackers"].toBool());
|
||||||
|
|
||||||
|
// Speed
|
||||||
|
// Global Rate Limits
|
||||||
|
if (m.contains("dl_limit"))
|
||||||
|
pref->setGlobalDownloadLimit(m["dl_limit"].toInt());
|
||||||
|
if (m.contains("up_limit"))
|
||||||
|
pref->setGlobalUploadLimit(m["up_limit"].toInt());
|
||||||
|
if (m.contains("enable_utp"))
|
||||||
|
pref->setuTPEnabled(m["enable_utp"].toBool());
|
||||||
|
if (m.contains("limit_utp_rate"))
|
||||||
|
pref->setuTPRateLimited(m["limit_utp_rate"].toBool());
|
||||||
|
if (m.contains("limit_tcp_overhead"))
|
||||||
|
pref->includeOverheadInLimits(m["limit_tcp_overhead"].toBool());
|
||||||
|
if (m.contains("alt_dl_limit"))
|
||||||
|
pref->setAltGlobalDownloadLimit(m["alt_dl_limit"].toInt());
|
||||||
|
if (m.contains("alt_up_limit"))
|
||||||
|
pref->setAltGlobalUploadLimit(m["alt_up_limit"].toInt());
|
||||||
|
// Scheduling
|
||||||
|
if (m.contains("scheduler_enabled"))
|
||||||
|
pref->setSchedulerEnabled(m["scheduler_enabled"].toBool());
|
||||||
|
if (m.contains("schedule_from_hour") && m.contains("schedule_from_min")) {
|
||||||
|
pref->setSchedulerStartTime(QTime(m["schedule_from_hour"].toInt(),
|
||||||
|
m["schedule_from_min"].toInt()));
|
||||||
|
}
|
||||||
|
if (m.contains("schedule_to_hour") && m.contains("schedule_to_min")) {
|
||||||
|
pref->setSchedulerEndTime(QTime(m["schedule_to_hour"].toInt(),
|
||||||
|
m["schedule_to_min"].toInt()));
|
||||||
|
}
|
||||||
|
if (m.contains("scheduler_days"))
|
||||||
|
pref->setSchedulerDays(scheduler_days(m["scheduler_days"].toInt()));
|
||||||
|
|
||||||
|
// Bittorrent
|
||||||
|
// Privacy
|
||||||
|
if (m.contains("dht"))
|
||||||
|
pref->setDHTEnabled(m["dht"].toBool());
|
||||||
|
if (m.contains("pex"))
|
||||||
|
pref->setPeXEnabled(m["pex"].toBool());
|
||||||
|
if (m.contains("lsd"))
|
||||||
|
pref->setLSDEnabled(m["lsd"].toBool());
|
||||||
|
if (m.contains("encryption"))
|
||||||
|
pref->setEncryptionSetting(m["encryption"].toInt());
|
||||||
|
if (m.contains("anonymous_mode"))
|
||||||
|
pref->enableAnonymousMode(m["anonymous_mode"].toBool());
|
||||||
|
// Torrent Queueing
|
||||||
|
if (m.contains("queueing_enabled"))
|
||||||
|
pref->setQueueingSystemEnabled(m["queueing_enabled"].toBool());
|
||||||
|
if (m.contains("max_active_downloads"))
|
||||||
|
pref->setMaxActiveDownloads(m["max_active_downloads"].toInt());
|
||||||
|
if (m.contains("max_active_torrents"))
|
||||||
|
pref->setMaxActiveTorrents(m["max_active_torrents"].toInt());
|
||||||
|
if (m.contains("max_active_uploads"))
|
||||||
|
pref->setMaxActiveUploads(m["max_active_uploads"].toInt());
|
||||||
|
if (m.contains("dont_count_slow_torrents"))
|
||||||
|
pref->setIgnoreSlowTorrentsForQueueing(m["dont_count_slow_torrents"].toBool());
|
||||||
|
// Share Ratio Limiting
|
||||||
|
if (m.contains("max_ratio_enabled"))
|
||||||
|
pref->setGlobalMaxRatio(m["max_ratio"].toInt());
|
||||||
|
else
|
||||||
|
pref->setGlobalMaxRatio(-1);
|
||||||
|
if (m.contains("max_ratio_act"))
|
||||||
|
pref->setMaxRatioAction(m["max_ratio_act"].toInt());
|
||||||
|
|
||||||
// Web UI
|
// Web UI
|
||||||
|
// Language
|
||||||
|
if (m.contains("locale")) {
|
||||||
|
QString locale = m["locale"].toString();
|
||||||
|
if (pref->getLocale() != locale) {
|
||||||
|
QTranslator *translator = new QTranslator;
|
||||||
|
if (translator->load(QString::fromUtf8(":/lang/qbittorrent_") + locale)) {
|
||||||
|
qDebug("%s locale recognized, using translation.", qPrintable(locale));
|
||||||
|
}else{
|
||||||
|
qDebug("%s locale unrecognized, using default (en).", qPrintable(locale));
|
||||||
|
}
|
||||||
|
qApp->installTranslator(translator);
|
||||||
|
|
||||||
|
pref->setLocale(locale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// HTTP Server
|
||||||
if (m.contains("web_ui_port"))
|
if (m.contains("web_ui_port"))
|
||||||
pref->setWebUiPort(m["web_ui_port"].toUInt());
|
pref->setWebUiPort(m["web_ui_port"].toUInt());
|
||||||
if (m.contains("web_ui_username"))
|
|
||||||
pref->setWebUiUsername(m["web_ui_username"].toString());
|
|
||||||
if (m.contains("web_ui_password"))
|
|
||||||
pref->setWebUiPassword(m["web_ui_password"].toString());
|
|
||||||
if (m.contains("bypass_local_auth"))
|
|
||||||
pref->setWebUiLocalAuthEnabled(!m["bypass_local_auth"].toBool());
|
|
||||||
if (m.contains("use_https"))
|
if (m.contains("use_https"))
|
||||||
pref->setWebUiHttpsEnabled(m["use_https"].toBool());
|
pref->setWebUiHttpsEnabled(m["use_https"].toBool());
|
||||||
#ifndef QT_NO_OPENSSL
|
#ifndef QT_NO_OPENSSL
|
||||||
@ -350,7 +375,14 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setWebUiHttpsCertificate(raw_cert);
|
pref->setWebUiHttpsCertificate(raw_cert);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
// Dyndns
|
// Authentication
|
||||||
|
if (m.contains("web_ui_username"))
|
||||||
|
pref->setWebUiUsername(m["web_ui_username"].toString());
|
||||||
|
if (m.contains("web_ui_password"))
|
||||||
|
pref->setWebUiPassword(m["web_ui_password"].toString());
|
||||||
|
if (m.contains("bypass_local_auth"))
|
||||||
|
pref->setWebUiLocalAuthEnabled(!m["bypass_local_auth"].toBool());
|
||||||
|
// Update my dynamic domain name
|
||||||
if (m.contains("dyndns_enabled"))
|
if (m.contains("dyndns_enabled"))
|
||||||
pref->setDynDNSEnabled(m["dyndns_enabled"].toBool());
|
pref->setDynDNSEnabled(m["dyndns_enabled"].toBool());
|
||||||
if (m.contains("dyndns_service"))
|
if (m.contains("dyndns_service"))
|
||||||
@ -361,6 +393,7 @@ void prefjson::setPreferences(const QString& json)
|
|||||||
pref->setDynDNSPassword(m["dyndns_password"].toString());
|
pref->setDynDNSPassword(m["dyndns_password"].toString());
|
||||||
if (m.contains("dyndns_domain"))
|
if (m.contains("dyndns_domain"))
|
||||||
pref->setDynDomainName(m["dyndns_domain"].toString());
|
pref->setDynDomainName(m["dyndns_domain"].toString());
|
||||||
|
|
||||||
// Save preferences
|
// Save preferences
|
||||||
pref->apply();
|
pref->apply();
|
||||||
}
|
}
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user