2021-07-04 18:35:09 +02:00
|
|
|
/**
|
|
|
|
* SPDX-FileCopyrightText: 2021 Bart De Vries <bart@mogwai.be>
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only OR LicenseRef-KDE-Accepted-GPL
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "storagemanager.h"
|
2021-09-08 11:46:22 +02:00
|
|
|
#include "storagemanagerlogging.h"
|
2021-07-04 18:35:09 +02:00
|
|
|
|
|
|
|
#include <KLocalizedString>
|
|
|
|
#include <QCryptographicHash>
|
|
|
|
#include <QDateTime>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QDir>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QFileInfo>
|
|
|
|
#include <QStandardPaths>
|
|
|
|
|
|
|
|
#include "enclosure.h"
|
2021-09-23 19:23:39 +02:00
|
|
|
#include "models/errorlogmodel.h"
|
2021-07-04 18:35:09 +02:00
|
|
|
#include "settingsmanager.h"
|
|
|
|
#include "storagemovejob.h"
|
|
|
|
|
|
|
|
StorageManager::StorageManager()
|
|
|
|
{
|
2021-09-23 19:23:39 +02:00
|
|
|
connect(this, &StorageManager::error, &ErrorLogModel::instance(), &ErrorLogModel::monitorErrorMessages);
|
2021-07-04 18:35:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::storagePath() const
|
|
|
|
{
|
|
|
|
QString path = QStandardPaths::writableLocation(QStandardPaths::DataLocation);
|
|
|
|
|
|
|
|
if (!SettingsManager::self()->storagePath().isEmpty()) {
|
|
|
|
path = SettingsManager::self()->storagePath().toLocalFile();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create path if it doesn't exist yet
|
|
|
|
QFileInfo().absoluteDir().mkpath(path);
|
|
|
|
|
|
|
|
qCDebug(kastsStorageManager) << "Current storage path is" << path;
|
|
|
|
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
|
|
|
|
void StorageManager::setStoragePath(QUrl url)
|
|
|
|
{
|
|
|
|
qCDebug(kastsStorageManager) << "New storage path url:" << url;
|
|
|
|
QUrl oldUrl = SettingsManager::self()->storagePath();
|
|
|
|
QString oldPath = storagePath();
|
|
|
|
QString newPath = oldPath;
|
|
|
|
|
|
|
|
if (url.isEmpty()) {
|
|
|
|
qCDebug(kastsStorageManager) << "(Re)set storage path to default location";
|
|
|
|
SettingsManager::self()->setStoragePath(url);
|
|
|
|
newPath = storagePath(); // retrieve default storage path, since url is empty
|
|
|
|
} else if (url.isLocalFile()) {
|
|
|
|
SettingsManager::self()->setStoragePath(url);
|
|
|
|
newPath = url.toLocalFile();
|
|
|
|
} else {
|
|
|
|
qCDebug(kastsStorageManager) << "Cannot set storage path; path is not on local filesystem:" << url;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
qCDebug(kastsStorageManager) << "Current storage path in settings:" << SettingsManager::self()->storagePath();
|
|
|
|
qCDebug(kastsStorageManager) << "New storage path will be:" << newPath;
|
|
|
|
|
|
|
|
if (oldPath != newPath) {
|
|
|
|
QStringList list = {QStringLiteral("enclosures"), QStringLiteral("images")};
|
|
|
|
StorageMoveJob *moveJob = new StorageMoveJob(oldPath, newPath, list);
|
|
|
|
connect(moveJob, &KJob::processedAmountChanged, this, [this, moveJob]() {
|
|
|
|
m_storageMoveProgress = moveJob->processedAmount(KJob::Files);
|
|
|
|
Q_EMIT storageMoveProgressChanged(m_storageMoveProgress);
|
|
|
|
});
|
|
|
|
connect(moveJob, &KJob::totalAmountChanged, this, [this, moveJob]() {
|
|
|
|
m_storageMoveTotal = moveJob->totalAmount(KJob::Files);
|
|
|
|
Q_EMIT storageMoveTotalChanged(m_storageMoveTotal);
|
|
|
|
});
|
|
|
|
connect(moveJob, &KJob::result, this, [=]() {
|
|
|
|
if (moveJob->error() != 0) {
|
|
|
|
// Go back to previous old path
|
|
|
|
SettingsManager::self()->setStoragePath(oldUrl);
|
|
|
|
QString title =
|
|
|
|
i18n("Old location:") + QStringLiteral(" ") + oldPath + QStringLiteral("; ") + i18n("New location:") + QStringLiteral(" ") + newPath;
|
|
|
|
Q_EMIT error(Error::Type::StorageMoveError, QString(), QString(), moveJob->error(), moveJob->errorString(), title);
|
|
|
|
}
|
|
|
|
Q_EMIT storageMoveFinished();
|
|
|
|
Q_EMIT storagePathChanged(newPath);
|
|
|
|
|
|
|
|
// save settings now to avoid getting into an inconsistent app state
|
|
|
|
SettingsManager::self()->save();
|
|
|
|
disconnect(this, &StorageManager::cancelStorageMove, this, nullptr);
|
|
|
|
});
|
2021-11-04 15:38:09 +01:00
|
|
|
connect(this, &StorageManager::cancelStorageMove, this, [moveJob]() {
|
2021-07-04 18:35:09 +02:00
|
|
|
moveJob->doKill();
|
|
|
|
});
|
|
|
|
Q_EMIT storageMoveStarted();
|
|
|
|
moveJob->start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::imageDirPath() const
|
|
|
|
{
|
|
|
|
QString path = storagePath() + QStringLiteral("/images/");
|
|
|
|
// Create path if it doesn't exist yet
|
|
|
|
QFileInfo().absoluteDir().mkpath(path);
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::imagePath(const QString &url) const
|
|
|
|
{
|
|
|
|
return imageDirPath() + QString::fromStdString(QCryptographicHash::hash(url.toUtf8(), QCryptographicHash::Md5).toHex().toStdString());
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::enclosureDirPath() const
|
|
|
|
{
|
|
|
|
QString path = storagePath() + QStringLiteral("/enclosures/");
|
|
|
|
// Create path if it doesn't exist yet
|
|
|
|
QFileInfo().absoluteDir().mkpath(path);
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::enclosurePath(const QString &url) const
|
|
|
|
{
|
|
|
|
return enclosureDirPath() + QString::fromStdString(QCryptographicHash::hash(url.toUtf8(), QCryptographicHash::Md5).toHex().toStdString());
|
|
|
|
}
|
|
|
|
|
|
|
|
qint64 StorageManager::dirSize(const QString &path) const
|
|
|
|
{
|
|
|
|
qint64 size = 0;
|
|
|
|
QFileInfoList files = QDir(path).entryInfoList(QDir::Files);
|
|
|
|
|
|
|
|
for (QFileInfo info : files) {
|
|
|
|
size += info.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
return size;
|
|
|
|
}
|
|
|
|
|
|
|
|
void StorageManager::removeImage(const QString &url)
|
|
|
|
{
|
|
|
|
qCDebug(kastsStorageManager) << "Removing image" << imagePath(url);
|
|
|
|
QFile(imagePath(url)).remove();
|
|
|
|
Q_EMIT imageDirSizeChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
void StorageManager::clearImageCache()
|
|
|
|
{
|
|
|
|
qDebug() << imageDirPath();
|
|
|
|
QStringList images = QDir(imageDirPath()).entryList(QDir::Files);
|
|
|
|
qDebug() << images;
|
|
|
|
for (QString image : images) {
|
|
|
|
qDebug() << image;
|
|
|
|
QFile(QDir(imageDirPath()).absoluteFilePath(image)).remove();
|
|
|
|
}
|
|
|
|
Q_EMIT imageDirSizeChanged();
|
|
|
|
}
|
|
|
|
|
|
|
|
qint64 StorageManager::enclosureDirSize() const
|
|
|
|
{
|
|
|
|
return dirSize(enclosureDirPath());
|
|
|
|
}
|
|
|
|
|
|
|
|
qint64 StorageManager::imageDirSize() const
|
|
|
|
{
|
|
|
|
return dirSize(imageDirPath());
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::formattedEnclosureDirSize() const
|
|
|
|
{
|
|
|
|
return m_kformat.formatByteSize(enclosureDirSize());
|
|
|
|
}
|
|
|
|
|
|
|
|
QString StorageManager::formattedImageDirSize() const
|
|
|
|
{
|
|
|
|
return m_kformat.formatByteSize(imageDirSize());
|
|
|
|
}
|
2021-10-29 17:00:52 +02:00
|
|
|
|
|
|
|
QString StorageManager::passwordFilePath(const QString &username) const
|
|
|
|
{
|
|
|
|
return QStandardPaths::writableLocation(QStandardPaths::AppDataLocation) + QStringLiteral("/") + username;
|
|
|
|
}
|