2010-02-28 15:15:00 +00:00
|
|
|
/*
|
2015-04-16 20:08:30 +03:00
|
|
|
* Bittorrent Client using Qt and libtorrent.
|
2018-04-14 22:53:45 +03:00
|
|
|
* Copyright (C) 2010 Christian Kandeler, Christophe Dumez <chris@qbittorrent.org>
|
2010-02-28 15:15:00 +00:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2016-05-17 13:32:57 +08:00
|
|
|
#include "scanfoldersmodel.h"
|
|
|
|
|
2010-02-28 15:15:00 +00:00
|
|
|
#include <QDir>
|
|
|
|
#include <QFileInfo>
|
2015-04-16 20:08:30 +03:00
|
|
|
#include <QStringList>
|
2015-12-31 22:31:19 +02:00
|
|
|
#include <QTextStream>
|
2015-04-16 20:08:30 +03:00
|
|
|
|
2015-04-19 18:17:47 +03:00
|
|
|
#include "bittorrent/session.h"
|
2016-05-17 13:32:57 +08:00
|
|
|
#include "filesystemwatcher.h"
|
2018-11-18 20:40:37 +02:00
|
|
|
#include "global.h"
|
2016-05-17 13:32:57 +08:00
|
|
|
#include "preferences.h"
|
|
|
|
#include "utils/fs.h"
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
struct ScanFoldersModel::PathData
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2015-12-12 22:26:17 +02:00
|
|
|
PathData(const QString &watchPath, const PathType &type, const QString &downloadPath)
|
|
|
|
: watchPath(watchPath)
|
|
|
|
, downloadType(type)
|
2015-11-10 21:59:55 +02:00
|
|
|
, downloadPath(downloadPath)
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2015-12-12 22:26:17 +02:00
|
|
|
if (this->downloadPath.isEmpty() && downloadType == CUSTOM_LOCATION)
|
|
|
|
downloadType = DEFAULT_LOCATION;
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
QString watchPath;
|
|
|
|
PathType downloadType;
|
|
|
|
QString downloadPath; // valid for CUSTOM_LOCATION
|
2010-02-28 15:15:00 +00:00
|
|
|
};
|
|
|
|
|
2018-04-15 13:06:31 +03:00
|
|
|
ScanFoldersModel *ScanFoldersModel::m_instance = nullptr;
|
2015-04-16 20:08:30 +03:00
|
|
|
|
2020-02-07 15:19:23 +08:00
|
|
|
void ScanFoldersModel::initInstance()
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2020-02-07 15:19:23 +08:00
|
|
|
if (!m_instance)
|
|
|
|
m_instance = new ScanFoldersModel;
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void ScanFoldersModel::freeInstance()
|
|
|
|
{
|
2020-02-03 16:38:46 -05:00
|
|
|
delete m_instance;
|
|
|
|
m_instance = nullptr;
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
ScanFoldersModel *ScanFoldersModel::instance()
|
|
|
|
{
|
2015-04-16 20:08:30 +03:00
|
|
|
return m_instance;
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
ScanFoldersModel::ScanFoldersModel(QObject *parent)
|
2015-12-12 22:26:17 +02:00
|
|
|
: QAbstractListModel(parent)
|
2018-04-15 13:06:31 +03:00
|
|
|
, m_fsWatcher(nullptr)
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2015-04-19 18:17:47 +03:00
|
|
|
configure();
|
2018-04-18 16:59:41 +03:00
|
|
|
connect(Preferences::instance(), &Preferences::changed, this, &ScanFoldersModel::configure);
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
ScanFoldersModel::~ScanFoldersModel()
|
|
|
|
{
|
|
|
|
qDeleteAll(m_pathList);
|
2010-02-28 16:23:59 +00:00
|
|
|
}
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
int ScanFoldersModel::rowCount(const QModelIndex &parent) const
|
|
|
|
{
|
|
|
|
return parent.isValid() ? 0 : m_pathList.count();
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
int ScanFoldersModel::columnCount(const QModelIndex &parent) const
|
|
|
|
{
|
|
|
|
Q_UNUSED(parent);
|
2015-12-12 22:26:17 +02:00
|
|
|
return NB_COLUMNS;
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
QVariant ScanFoldersModel::data(const QModelIndex &index, int role) const
|
|
|
|
{
|
|
|
|
if (!index.isValid() || (index.row() >= rowCount()))
|
2019-02-14 19:16:42 +02:00
|
|
|
return {};
|
2015-04-16 20:08:30 +03:00
|
|
|
|
|
|
|
const PathData *pathData = m_pathList.at(index.row());
|
2015-11-10 21:59:55 +02:00
|
|
|
QVariant value;
|
|
|
|
|
|
|
|
switch (index.column()) {
|
2015-12-12 22:26:17 +02:00
|
|
|
case WATCH:
|
2015-11-10 21:59:55 +02:00
|
|
|
if (role == Qt::DisplayRole)
|
2015-12-12 22:26:17 +02:00
|
|
|
value = Utils::Fs::toNativePath(pathData->watchPath);
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
2015-12-12 22:26:17 +02:00
|
|
|
case DOWNLOAD:
|
2016-01-02 00:43:23 +02:00
|
|
|
if (role == Qt::UserRole) {
|
2015-12-12 22:26:17 +02:00
|
|
|
value = pathData->downloadType;
|
|
|
|
}
|
2016-01-02 00:43:23 +02:00
|
|
|
else if (role == Qt::DisplayRole) {
|
|
|
|
switch (pathData->downloadType) {
|
|
|
|
case DOWNLOAD_IN_WATCH_FOLDER:
|
|
|
|
case DEFAULT_LOCATION:
|
2016-05-17 03:02:27 +08:00
|
|
|
value = pathTypeDisplayName(pathData->downloadType);
|
2016-01-02 00:43:23 +02:00
|
|
|
break;
|
|
|
|
case CUSTOM_LOCATION:
|
|
|
|
value = pathData->downloadPath;
|
|
|
|
break;
|
|
|
|
}
|
2015-12-12 22:26:17 +02:00
|
|
|
}
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
|
|
|
}
|
2015-04-16 20:08:30 +03:00
|
|
|
|
2015-11-10 21:59:55 +02:00
|
|
|
return value;
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
QVariant ScanFoldersModel::headerData(int section, Qt::Orientation orientation, int role) const
|
|
|
|
{
|
|
|
|
if ((orientation != Qt::Horizontal) || (role != Qt::DisplayRole) || (section < 0) || (section >= columnCount()))
|
2019-02-14 19:16:42 +02:00
|
|
|
return {};
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2015-11-10 21:59:55 +02:00
|
|
|
QVariant title;
|
|
|
|
|
|
|
|
switch (section) {
|
2015-12-12 22:26:17 +02:00
|
|
|
case WATCH:
|
2016-05-14 14:41:09 +08:00
|
|
|
title = tr("Monitored Folder");
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
2015-12-12 22:26:17 +02:00
|
|
|
case DOWNLOAD:
|
2016-05-14 14:41:09 +08:00
|
|
|
title = tr("Override Save Location");
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
|
|
|
}
|
2013-11-09 19:45:01 +04:00
|
|
|
|
2015-11-10 21:59:55 +02:00
|
|
|
return title;
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
Qt::ItemFlags ScanFoldersModel::flags(const QModelIndex &index) const
|
|
|
|
{
|
2015-11-10 21:59:55 +02:00
|
|
|
if (!index.isValid() || (index.row() >= rowCount()))
|
2015-12-12 22:26:17 +02:00
|
|
|
return QAbstractListModel::flags(index);
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2015-11-10 21:59:55 +02:00
|
|
|
Qt::ItemFlags flags;
|
|
|
|
|
|
|
|
switch (index.column()) {
|
2015-12-12 22:26:17 +02:00
|
|
|
case WATCH:
|
|
|
|
flags = QAbstractListModel::flags(index);
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
2015-12-12 22:26:17 +02:00
|
|
|
case DOWNLOAD:
|
|
|
|
flags = QAbstractListModel::flags(index) | Qt::ItemIsEditable;
|
2015-11-10 21:59:55 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return flags;
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
bool ScanFoldersModel::setData(const QModelIndex &index, const QVariant &value, int role)
|
|
|
|
{
|
2015-12-12 22:26:17 +02:00
|
|
|
if (!index.isValid() || (index.row() >= rowCount()) || (index.column() >= columnCount())
|
|
|
|
|| (index.column() != DOWNLOAD))
|
2015-04-16 20:08:30 +03:00
|
|
|
return false;
|
|
|
|
|
2016-01-02 00:43:23 +02:00
|
|
|
if (role == Qt::UserRole) {
|
2019-02-21 23:31:43 +02:00
|
|
|
const auto type = static_cast<PathType>(value.toInt());
|
2015-12-12 22:26:17 +02:00
|
|
|
if (type == CUSTOM_LOCATION)
|
|
|
|
return false;
|
2015-11-10 21:59:55 +02:00
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
m_pathList[index.row()]->downloadType = type;
|
|
|
|
m_pathList[index.row()]->downloadPath.clear();
|
|
|
|
emit dataChanged(index, index);
|
|
|
|
}
|
2016-01-02 00:43:23 +02:00
|
|
|
else if (role == Qt::DisplayRole) {
|
2019-02-21 23:31:43 +02:00
|
|
|
const QString path = value.toString();
|
2015-12-12 22:26:17 +02:00
|
|
|
if (path.isEmpty()) // means we didn't pass CUSTOM_LOCATION type
|
|
|
|
return false;
|
|
|
|
|
|
|
|
m_pathList[index.row()]->downloadType = CUSTOM_LOCATION;
|
|
|
|
m_pathList[index.row()]->downloadPath = Utils::Fs::toNativePath(path);
|
2015-11-10 21:59:55 +02:00
|
|
|
emit dataChanged(index, index);
|
2015-12-12 22:26:17 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false;
|
2015-11-10 21:59:55 +02:00
|
|
|
}
|
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
return true;
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
2016-01-01 15:50:35 +02:00
|
|
|
ScanFoldersModel::PathStatus ScanFoldersModel::addPath(const QString &watchPath, const PathType &downloadType, const QString &downloadPath, bool addToFSWatcher)
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2019-02-21 23:31:43 +02:00
|
|
|
const QDir watchDir(watchPath);
|
2015-12-12 22:26:17 +02:00
|
|
|
if (!watchDir.exists()) return DoesNotExist;
|
|
|
|
if (!watchDir.isReadable()) return CannotRead;
|
2015-04-16 20:08:30 +03:00
|
|
|
|
2018-07-21 15:07:11 +08:00
|
|
|
const QString canonicalWatchPath = watchDir.canonicalPath();
|
2015-12-12 22:26:17 +02:00
|
|
|
if (findPathData(canonicalWatchPath) != -1) return AlreadyInList;
|
|
|
|
|
2019-02-21 23:31:43 +02:00
|
|
|
const QDir downloadDir(downloadPath);
|
2018-07-21 15:07:11 +08:00
|
|
|
const QString canonicalDownloadPath = downloadDir.canonicalPath();
|
2015-04-16 20:08:30 +03:00
|
|
|
|
|
|
|
if (!m_fsWatcher) {
|
|
|
|
m_fsWatcher = new FileSystemWatcher(this);
|
2018-04-18 16:59:41 +03:00
|
|
|
connect(m_fsWatcher, &FileSystemWatcher::torrentsAdded, this, &ScanFoldersModel::addTorrentsToSession);
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
2015-04-16 20:08:30 +03:00
|
|
|
|
|
|
|
beginInsertRows(QModelIndex(), rowCount(), rowCount());
|
2015-12-12 22:26:17 +02:00
|
|
|
m_pathList << new PathData(Utils::Fs::toNativePath(canonicalWatchPath), downloadType, Utils::Fs::toNativePath(canonicalDownloadPath));
|
2015-04-16 20:08:30 +03:00
|
|
|
endInsertRows();
|
|
|
|
|
|
|
|
// Start scanning
|
2016-01-01 15:50:35 +02:00
|
|
|
if (addToFSWatcher)
|
|
|
|
m_fsWatcher->addPath(canonicalWatchPath);
|
2015-04-16 20:08:30 +03:00
|
|
|
return Ok;
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2018-04-14 22:53:45 +03:00
|
|
|
ScanFoldersModel::PathStatus ScanFoldersModel::updatePath(const QString &watchPath, const PathType &downloadType, const QString &downloadPath)
|
2016-01-01 16:12:50 +02:00
|
|
|
{
|
2019-02-21 23:31:43 +02:00
|
|
|
const QDir watchDir(watchPath);
|
2018-07-21 15:07:11 +08:00
|
|
|
const QString canonicalWatchPath = watchDir.canonicalPath();
|
2019-02-21 23:31:43 +02:00
|
|
|
const int row = findPathData(canonicalWatchPath);
|
2016-01-01 16:12:50 +02:00
|
|
|
if (row == -1) return DoesNotExist;
|
|
|
|
|
2019-02-21 23:31:43 +02:00
|
|
|
const QDir downloadDir(downloadPath);
|
2018-07-21 15:07:11 +08:00
|
|
|
const QString canonicalDownloadPath = downloadDir.canonicalPath();
|
2016-01-01 16:12:50 +02:00
|
|
|
|
|
|
|
m_pathList.at(row)->downloadType = downloadType;
|
|
|
|
m_pathList.at(row)->downloadPath = Utils::Fs::toNativePath(canonicalDownloadPath);
|
|
|
|
|
|
|
|
return Ok;
|
|
|
|
}
|
|
|
|
|
2016-01-01 15:50:35 +02:00
|
|
|
void ScanFoldersModel::addToFSWatcher(const QStringList &watchPaths)
|
|
|
|
{
|
|
|
|
if (!m_fsWatcher)
|
|
|
|
return; // addPath() wasn't called before this
|
|
|
|
|
2018-11-18 20:40:37 +02:00
|
|
|
for (const QString &path : watchPaths) {
|
2019-02-21 23:31:43 +02:00
|
|
|
const QDir watchDir(path);
|
2018-07-21 15:07:11 +08:00
|
|
|
const QString canonicalWatchPath = watchDir.canonicalPath();
|
2016-01-01 15:50:35 +02:00
|
|
|
m_fsWatcher->addPath(canonicalWatchPath);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-02-21 23:31:43 +02:00
|
|
|
void ScanFoldersModel::removePath(const int row, const bool removeFromFSWatcher)
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
|
|
|
Q_ASSERT((row >= 0) && (row < rowCount()));
|
|
|
|
beginRemoveRows(QModelIndex(), row, row);
|
2016-01-02 01:23:26 +02:00
|
|
|
if (removeFromFSWatcher)
|
|
|
|
m_fsWatcher->removePath(m_pathList.at(row)->watchPath);
|
2015-12-12 22:26:17 +02:00
|
|
|
delete m_pathList.takeAt(row);
|
2015-04-16 20:08:30 +03:00
|
|
|
endRemoveRows();
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2019-02-21 23:31:43 +02:00
|
|
|
bool ScanFoldersModel::removePath(const QString &path, const bool removeFromFSWatcher)
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
|
|
|
const int row = findPathData(path);
|
|
|
|
if (row == -1) return false;
|
2010-02-28 15:15:00 +00:00
|
|
|
|
2016-01-02 01:23:26 +02:00
|
|
|
removePath(row, removeFromFSWatcher);
|
2015-04-16 20:08:30 +03:00
|
|
|
return true;
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2016-01-02 01:23:26 +02:00
|
|
|
void ScanFoldersModel::removeFromFSWatcher(const QStringList &watchPaths)
|
|
|
|
{
|
2018-11-18 20:40:37 +02:00
|
|
|
for (const QString &path : watchPaths)
|
2016-01-02 01:23:26 +02:00
|
|
|
m_fsWatcher->removePath(path);
|
|
|
|
}
|
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
bool ScanFoldersModel::downloadInWatchFolder(const QString &filePath) const
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
2015-12-12 22:26:17 +02:00
|
|
|
const int row = findPathData(QFileInfo(filePath).dir().path());
|
|
|
|
Q_ASSERT(row != -1);
|
2019-02-21 23:31:43 +02:00
|
|
|
const PathData *data = m_pathList.at(row);
|
2015-12-12 22:26:17 +02:00
|
|
|
return (data->downloadType == DOWNLOAD_IN_WATCH_FOLDER);
|
2010-02-28 15:15:00 +00:00
|
|
|
}
|
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
bool ScanFoldersModel::downloadInDefaultFolder(const QString &filePath) const
|
2015-04-16 20:08:30 +03:00
|
|
|
{
|
|
|
|
const int row = findPathData(QFileInfo(filePath).dir().path());
|
|
|
|
Q_ASSERT(row != -1);
|
2019-02-21 23:31:43 +02:00
|
|
|
const PathData *data = m_pathList.at(row);
|
2015-12-12 22:26:17 +02:00
|
|
|
return (data->downloadType == DEFAULT_LOCATION);
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
2015-11-10 21:59:55 +02:00
|
|
|
QString ScanFoldersModel::downloadPathTorrentFolder(const QString &filePath) const
|
|
|
|
{
|
|
|
|
const int row = findPathData(QFileInfo(filePath).dir().path());
|
|
|
|
Q_ASSERT(row != -1);
|
2019-02-21 23:31:43 +02:00
|
|
|
const PathData *data = m_pathList.at(row);
|
2015-12-12 22:26:17 +02:00
|
|
|
if (data->downloadType == CUSTOM_LOCATION)
|
|
|
|
return data->downloadPath;
|
|
|
|
|
2019-02-14 19:16:42 +02:00
|
|
|
return {};
|
2015-11-10 21:59:55 +02:00
|
|
|
}
|
|
|
|
|
2015-04-16 20:08:30 +03:00
|
|
|
int ScanFoldersModel::findPathData(const QString &path) const
|
|
|
|
{
|
|
|
|
for (int i = 0; i < m_pathList.count(); ++i)
|
2015-12-12 22:26:17 +02:00
|
|
|
if (m_pathList.at(i)->watchPath == Utils::Fs::toNativePath(path))
|
2015-04-16 20:08:30 +03:00
|
|
|
return i;
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void ScanFoldersModel::makePersistent()
|
|
|
|
{
|
2015-12-12 22:26:17 +02:00
|
|
|
QVariantHash dirs;
|
|
|
|
|
2018-11-27 22:15:04 +02:00
|
|
|
for (const PathData *pathData : asConst(m_pathList)) {
|
2015-12-12 22:26:17 +02:00
|
|
|
if (pathData->downloadType == CUSTOM_LOCATION)
|
2019-06-16 20:14:15 +03:00
|
|
|
dirs.insert(Utils::Fs::toUniformPath(pathData->watchPath), Utils::Fs::toUniformPath(pathData->downloadPath));
|
2015-12-12 22:26:17 +02:00
|
|
|
else
|
2019-06-16 20:14:15 +03:00
|
|
|
dirs.insert(Utils::Fs::toUniformPath(pathData->watchPath), pathData->downloadType);
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
|
|
|
|
2015-12-12 22:26:17 +02:00
|
|
|
Preferences::instance()->setScanDirs(dirs);
|
2015-04-16 20:08:30 +03:00
|
|
|
}
|
2015-04-19 18:17:47 +03:00
|
|
|
|
|
|
|
void ScanFoldersModel::configure()
|
|
|
|
{
|
2018-02-14 19:51:36 +00:00
|
|
|
const QVariantHash dirs = Preferences::instance()->getScanDirs();
|
2015-12-12 22:26:17 +02:00
|
|
|
|
2019-05-17 11:24:01 +08:00
|
|
|
for (auto i = dirs.cbegin(); i != dirs.cend(); ++i) {
|
2015-12-12 22:26:17 +02:00
|
|
|
if (i.value().type() == QVariant::Int)
|
|
|
|
addPath(i.key(), static_cast<PathType>(i.value().toInt()), QString());
|
|
|
|
else
|
|
|
|
addPath(i.key(), CUSTOM_LOCATION, i.value().toString());
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ScanFoldersModel::addTorrentsToSession(const QStringList &pathList)
|
|
|
|
{
|
2018-11-18 20:40:37 +02:00
|
|
|
for (const QString &file : pathList) {
|
2017-08-13 13:56:03 +03:00
|
|
|
qDebug("File %s added", qUtf8Printable(file));
|
2015-12-12 22:26:17 +02:00
|
|
|
|
|
|
|
BitTorrent::AddTorrentParams params;
|
2020-03-19 21:13:44 +02:00
|
|
|
if (downloadInWatchFolder(file)) {
|
2015-12-12 22:26:17 +02:00
|
|
|
params.savePath = QFileInfo(file).dir().path();
|
2020-03-19 21:13:44 +02:00
|
|
|
params.useAutoTMM = TriStateBool::False;
|
|
|
|
}
|
|
|
|
else if (!downloadInDefaultFolder(file)) {
|
2015-12-12 22:26:17 +02:00
|
|
|
params.savePath = downloadPathTorrentFolder(file);
|
2020-03-19 21:13:44 +02:00
|
|
|
params.useAutoTMM = TriStateBool::False;
|
|
|
|
}
|
2015-12-12 22:26:17 +02:00
|
|
|
|
2019-09-06 12:30:50 +08:00
|
|
|
if (file.endsWith(".magnet", Qt::CaseInsensitive)) {
|
2015-04-19 18:17:47 +03:00
|
|
|
QFile f(file);
|
2015-12-31 22:31:19 +02:00
|
|
|
if (f.open(QIODevice::ReadOnly | QIODevice::Text)) {
|
|
|
|
QTextStream str(&f);
|
|
|
|
while (!str.atEnd())
|
|
|
|
BitTorrent::Session::instance()->addTorrent(str.readLine(), params);
|
|
|
|
|
|
|
|
f.close();
|
|
|
|
Utils::Fs::forceRemove(file);
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
else {
|
2017-08-13 13:56:03 +03:00
|
|
|
qDebug("Failed to open magnet file: %s", qUtf8Printable(f.errorString()));
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2019-02-21 23:31:43 +02:00
|
|
|
const BitTorrent::TorrentInfo torrentInfo = BitTorrent::TorrentInfo::loadFromFile(file);
|
2015-04-19 18:17:47 +03:00
|
|
|
if (torrentInfo.isValid()) {
|
|
|
|
BitTorrent::Session::instance()->addTorrent(torrentInfo, params);
|
2015-05-06 14:53:27 +03:00
|
|
|
Utils::Fs::forceRemove(file);
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
else {
|
2017-08-13 13:56:03 +03:00
|
|
|
qDebug("Ignoring incomplete torrent file: %s", qUtf8Printable(file));
|
2015-04-19 18:17:47 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-05-17 03:02:27 +08:00
|
|
|
|
|
|
|
QString ScanFoldersModel::pathTypeDisplayName(const PathType type)
|
|
|
|
{
|
2018-06-06 16:48:17 +03:00
|
|
|
switch (type) {
|
2016-05-17 03:02:27 +08:00
|
|
|
case DOWNLOAD_IN_WATCH_FOLDER:
|
|
|
|
return tr("Monitored folder");
|
|
|
|
case DEFAULT_LOCATION:
|
|
|
|
return tr("Default save location");
|
|
|
|
case CUSTOM_LOCATION:
|
|
|
|
return tr("Browse...");
|
|
|
|
default:
|
|
|
|
qDebug("Invalid PathType: %d", type);
|
|
|
|
};
|
2019-02-14 19:16:42 +02:00
|
|
|
return {};
|
2016-05-17 03:02:27 +08:00
|
|
|
}
|