mirror of
https://github.com/d47081/qBittorrent.git
synced 2025-01-23 13:04:23 +00:00
commit
4adcd03ec7
@ -3,7 +3,7 @@ language: cpp
|
|||||||
os:
|
os:
|
||||||
- linux
|
- linux
|
||||||
- osx
|
- osx
|
||||||
osx_image: xcode7.3
|
osx_image: xcode8
|
||||||
|
|
||||||
env:
|
env:
|
||||||
matrix:
|
matrix:
|
||||||
|
@ -259,7 +259,6 @@ int main(int argc, char *argv[])
|
|||||||
&& isatty(fileno(stdout)))) return EXIT_FAILURE;
|
&& isatty(fileno(stdout)))) return EXIT_FAILURE;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
srand(time(0));
|
|
||||||
#ifdef DISABLE_GUI
|
#ifdef DISABLE_GUI
|
||||||
if (params.shouldDaemonize) {
|
if (params.shouldDaemonize) {
|
||||||
app.reset(); // Destroy current application
|
app.reset(); // Destroy current application
|
||||||
|
@ -44,6 +44,7 @@ rss/rssmanager.h
|
|||||||
utils/fs.h
|
utils/fs.h
|
||||||
utils/gzip.h
|
utils/gzip.h
|
||||||
utils/misc.h
|
utils/misc.h
|
||||||
|
utils/random.h
|
||||||
utils/string.h
|
utils/string.h
|
||||||
filesystemwatcher.h
|
filesystemwatcher.h
|
||||||
iconprovider.h
|
iconprovider.h
|
||||||
@ -103,6 +104,7 @@ rss/rssmanager.cpp
|
|||||||
utils/fs.cpp
|
utils/fs.cpp
|
||||||
utils/gzip.cpp
|
utils/gzip.cpp
|
||||||
utils/misc.cpp
|
utils/misc.cpp
|
||||||
|
utils/random.cpp
|
||||||
utils/string.cpp
|
utils/string.cpp
|
||||||
filesystemwatcher.cpp
|
filesystemwatcher.cpp
|
||||||
iconprovider.cpp
|
iconprovider.cpp
|
||||||
|
@ -52,6 +52,7 @@ HEADERS += \
|
|||||||
$$PWD/utils/fs.h \
|
$$PWD/utils/fs.h \
|
||||||
$$PWD/utils/gzip.h \
|
$$PWD/utils/gzip.h \
|
||||||
$$PWD/utils/misc.h \
|
$$PWD/utils/misc.h \
|
||||||
|
$$PWD/utils/random.h \
|
||||||
$$PWD/utils/string.h \
|
$$PWD/utils/string.h \
|
||||||
$$PWD/unicodestrings.h \
|
$$PWD/unicodestrings.h \
|
||||||
$$PWD/torrentfileguard.h \
|
$$PWD/torrentfileguard.h \
|
||||||
@ -107,6 +108,7 @@ SOURCES += \
|
|||||||
$$PWD/utils/fs.cpp \
|
$$PWD/utils/fs.cpp \
|
||||||
$$PWD/utils/gzip.cpp \
|
$$PWD/utils/gzip.cpp \
|
||||||
$$PWD/utils/misc.cpp \
|
$$PWD/utils/misc.cpp \
|
||||||
|
$$PWD/utils/random.cpp \
|
||||||
$$PWD/utils/string.cpp \
|
$$PWD/utils/string.cpp \
|
||||||
$$PWD/torrentfileguard.cpp \
|
$$PWD/torrentfileguard.cpp \
|
||||||
$$PWD/torrentfilter.cpp \
|
$$PWD/torrentfilter.cpp \
|
||||||
|
@ -76,6 +76,7 @@
|
|||||||
#include "base/unicodestrings.h"
|
#include "base/unicodestrings.h"
|
||||||
#include "base/utils/misc.h"
|
#include "base/utils/misc.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
|
#include "base/utils/random.h"
|
||||||
#include "base/utils/string.h"
|
#include "base/utils/string.h"
|
||||||
#include "cachestatus.h"
|
#include "cachestatus.h"
|
||||||
#include "magneturi.h"
|
#include "magneturi.h"
|
||||||
@ -2210,7 +2211,7 @@ void Session::setSaveResumeDataInterval(uint value)
|
|||||||
|
|
||||||
int Session::port() const
|
int Session::port() const
|
||||||
{
|
{
|
||||||
static int randomPort = rand() % 64512 + 1024;
|
static int randomPort = Utils::Random::rand(1024, 65535);
|
||||||
if (useRandomPort())
|
if (useRandomPort())
|
||||||
return randomPort;
|
return randomPort;
|
||||||
return m_port;
|
return m_port;
|
||||||
|
@ -451,7 +451,11 @@ void Preferences::setWebUiPort(quint16 port)
|
|||||||
|
|
||||||
bool Preferences::useUPnPForWebUIPort() const
|
bool Preferences::useUPnPForWebUIPort() const
|
||||||
{
|
{
|
||||||
|
#ifdef DISABLE_GUI
|
||||||
return value("Preferences/WebUI/UseUPnP", true).toBool();
|
return value("Preferences/WebUI/UseUPnP", true).toBool();
|
||||||
|
#else
|
||||||
|
return value("Preferences/WebUI/UseUPnP", false).toBool();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preferences::setUPnPForWebUIPort(bool enabled)
|
void Preferences::setUPnPForWebUIPort(bool enabled)
|
||||||
|
53
src/base/utils/random.cpp
Normal file
53
src/base/utils/random.cpp
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Bittorrent Client using Qt and libtorrent.
|
||||||
|
* Copyright (C) 2017 Mike Tzou
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* In addition, as a special exception, the copyright holders give permission to
|
||||||
|
* link this program with the OpenSSL project's "OpenSSL" library (or with
|
||||||
|
* modified versions of it that use the same license as the "OpenSSL" library),
|
||||||
|
* and distribute the linked executables. You must obey the GNU General Public
|
||||||
|
* License in all respects for all of the code used other than "OpenSSL". If you
|
||||||
|
* modify file(s), you may extend this exception to your version of the file(s),
|
||||||
|
* but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
* exception statement from your version.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "random.h"
|
||||||
|
|
||||||
|
#include <cassert>
|
||||||
|
#include <chrono>
|
||||||
|
#include <random>
|
||||||
|
|
||||||
|
// on some platform `std::random_device` may generate the same number sequence
|
||||||
|
static bool hasTrueRandomDevice{ std::random_device{}() != std::random_device{}() };
|
||||||
|
static thread_local std::mt19937 generator{
|
||||||
|
hasTrueRandomDevice
|
||||||
|
? std::random_device{}()
|
||||||
|
: (std::random_device::result_type) std::chrono::system_clock::now().time_since_epoch().count()
|
||||||
|
};
|
||||||
|
|
||||||
|
uint32_t Utils::Random::rand(const uint32_t min, const uint32_t max)
|
||||||
|
{
|
||||||
|
// better replacement for `std::rand`, don't use this for real cryptography application
|
||||||
|
// min <= returned_value <= max
|
||||||
|
assert(min <= max);
|
||||||
|
|
||||||
|
// new distribution is cheap: http://stackoverflow.com/a/19036349
|
||||||
|
std::uniform_int_distribution<uint32_t> uniform(min, max);
|
||||||
|
return uniform(generator);
|
||||||
|
}
|
44
src/base/utils/random.h
Normal file
44
src/base/utils/random.h
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/*
|
||||||
|
* Bittorrent Client using Qt and libtorrent.
|
||||||
|
* Copyright (C) 2017 Mike Tzou
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* In addition, as a special exception, the copyright holders give permission to
|
||||||
|
* link this program with the OpenSSL project's "OpenSSL" library (or with
|
||||||
|
* modified versions of it that use the same license as the "OpenSSL" library),
|
||||||
|
* and distribute the linked executables. You must obey the GNU General Public
|
||||||
|
* License in all respects for all of the code used other than "OpenSSL". If you
|
||||||
|
* modify file(s), you may extend this exception to your version of the file(s),
|
||||||
|
* but you are not obligated to do so. If you do not wish to do so, delete this
|
||||||
|
* exception statement from your version.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef UTILS_RANDOM_H
|
||||||
|
#define UTILS_RANDOM_H
|
||||||
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <cstdlib>
|
||||||
|
|
||||||
|
namespace Utils
|
||||||
|
{
|
||||||
|
namespace Random
|
||||||
|
{
|
||||||
|
uint32_t rand(uint32_t min = 0, uint32_t max = UINT32_MAX);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // UTILS_FS_H
|
@ -58,6 +58,7 @@
|
|||||||
#include "base/torrentfileguard.h"
|
#include "base/torrentfileguard.h"
|
||||||
#include "base/unicodestrings.h"
|
#include "base/unicodestrings.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
|
#include "base/utils/random.h"
|
||||||
#include "addnewtorrentdialog.h"
|
#include "addnewtorrentdialog.h"
|
||||||
#include "advancedsettings.h"
|
#include "advancedsettings.h"
|
||||||
#include "guiiconprovider.h"
|
#include "guiiconprovider.h"
|
||||||
@ -1002,7 +1003,7 @@ int OptionsDialog::getPort() const
|
|||||||
void OptionsDialog::on_randomButton_clicked()
|
void OptionsDialog::on_randomButton_clicked()
|
||||||
{
|
{
|
||||||
// Range [1024: 65535]
|
// Range [1024: 65535]
|
||||||
m_ui->spinPort->setValue(rand() % 64512 + 1024);
|
m_ui->spinPort->setValue(Utils::Random::rand(1024, 65535));
|
||||||
}
|
}
|
||||||
|
|
||||||
int OptionsDialog::getEncryptionSetting() const
|
int OptionsDialog::getEncryptionSetting() const
|
||||||
|
@ -26,6 +26,8 @@
|
|||||||
* exception statement from your version.
|
* exception statement from your version.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "abstractwebapplication.h"
|
||||||
|
|
||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#include <QDateTime>
|
#include <QDateTime>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
@ -37,8 +39,8 @@
|
|||||||
|
|
||||||
#include "base/preferences.h"
|
#include "base/preferences.h"
|
||||||
#include "base/utils/fs.h"
|
#include "base/utils/fs.h"
|
||||||
|
#include "base/utils/random.h"
|
||||||
#include "websessiondata.h"
|
#include "websessiondata.h"
|
||||||
#include "abstractwebapplication.h"
|
|
||||||
|
|
||||||
// UnbanTimer
|
// UnbanTimer
|
||||||
|
|
||||||
@ -219,13 +221,12 @@ QString AbstractWebApplication::generateSid()
|
|||||||
{
|
{
|
||||||
QString sid;
|
QString sid;
|
||||||
|
|
||||||
qsrand(QDateTime::currentDateTime().toTime_t());
|
|
||||||
do {
|
do {
|
||||||
const size_t size = 6;
|
const size_t size = 6;
|
||||||
quint32 tmp[size];
|
quint32 tmp[size];
|
||||||
|
|
||||||
for (size_t i = 0; i < size; ++i)
|
for (size_t i = 0; i < size; ++i)
|
||||||
tmp[i] = qrand();
|
tmp[i] = Utils::Random::rand();
|
||||||
|
|
||||||
sid = QByteArray::fromRawData(reinterpret_cast<const char *>(tmp), sizeof(quint32) * size).toBase64();
|
sid = QByteArray::fromRawData(reinterpret_cast<const char *>(tmp), sizeof(quint32) * size).toBase64();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user