sledgehammer999
9 years ago
10 changed files with 566 additions and 6 deletions
@ -0,0 +1,174 @@
@@ -0,0 +1,174 @@
|
||||
/*
|
||||
* Bittorrent Client using Qt and libtorrent. |
||||
* Copyright (C) 2016 sledgehammer999 <hammered999@gmail.com> |
||||
* |
||||
* 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 <QDir> |
||||
#include <QFile> |
||||
#include <QTextStream> |
||||
#include "filelogger.h" |
||||
#include "base/preferences.h" |
||||
#include "base/logger.h" |
||||
#include "base/utils/fs.h" |
||||
|
||||
namespace |
||||
{ |
||||
enum FileLogAgeType |
||||
{ |
||||
DAYS, |
||||
MONTHS, |
||||
YEARS |
||||
}; |
||||
} |
||||
|
||||
FileLogger::FileLogger() |
||||
: m_logFile(nullptr) |
||||
{ |
||||
m_flusher.setInterval(0); |
||||
m_flusher.setSingleShot(true); |
||||
connect(&m_flusher, SIGNAL(timeout()), SLOT(flushLog())); |
||||
|
||||
configure(); |
||||
const Logger* const logger = Logger::instance(); |
||||
foreach (const Log::Msg& msg, logger->getMessages()) |
||||
addLogMessage(msg); |
||||
|
||||
connect(Preferences::instance(), SIGNAL(changed()), SLOT(configure())); |
||||
connect(logger, SIGNAL(newLogMessage(const Log::Msg &)), SLOT(addLogMessage(const Log::Msg &))); |
||||
} |
||||
|
||||
FileLogger::~FileLogger() |
||||
{ |
||||
if (!m_logFile) return; |
||||
closeLogFile(); |
||||
delete m_logFile; |
||||
} |
||||
|
||||
void FileLogger::configure() |
||||
{ |
||||
const Preferences* const pref = Preferences::instance(); |
||||
QString tmpPath = Utils::Fs::fromNativePath(pref->fileLogPath()); |
||||
QDir dir(tmpPath); |
||||
dir.mkpath(tmpPath); |
||||
tmpPath = dir.absoluteFilePath("qbittorrent.log"); |
||||
|
||||
if (tmpPath != m_path) { |
||||
m_path = tmpPath; |
||||
|
||||
if (m_logFile) { |
||||
closeLogFile(); |
||||
delete m_logFile; |
||||
} |
||||
m_logFile = new QFile(m_path); |
||||
openLogFile(); |
||||
} |
||||
|
||||
m_backup = pref->fileLogBackup(); |
||||
m_size = pref->fileLogMaxSize(); |
||||
|
||||
if (pref->fileLogDeleteOld()) { |
||||
QDateTime date = QDateTime::currentDateTime(); |
||||
|
||||
switch (static_cast<FileLogAgeType>(pref->fileLogAgeType())) { |
||||
case DAYS: |
||||
date = date.addDays(pref->fileLogAge()); |
||||
break; |
||||
case MONTHS: |
||||
date = date.addMonths(pref->fileLogAge()); |
||||
break; |
||||
default: |
||||
date = date.addYears(pref->fileLogAge()); |
||||
} |
||||
|
||||
foreach (const QFileInfo file, dir.entryInfoList(QStringList("qbittorrent.log.bak*"), QDir::Files | QDir::Writable, QDir::Time | QDir::Reversed)) { |
||||
if (file.lastModified() < date) |
||||
break; |
||||
Utils::Fs::forceRemove(file.absoluteFilePath()); |
||||
} |
||||
} |
||||
} |
||||
|
||||
void FileLogger::addLogMessage(const Log::Msg &msg) |
||||
{ |
||||
if (!m_logFile) return; |
||||
|
||||
QTextStream str(m_logFile); |
||||
|
||||
switch (msg.type) { |
||||
case Log::INFO: |
||||
str << "(I) "; |
||||
break; |
||||
case Log::WARNING: |
||||
str << "(W) "; |
||||
break; |
||||
case Log::CRITICAL: |
||||
str << "(C) "; |
||||
break; |
||||
default: |
||||
str << "(N) "; |
||||
} |
||||
|
||||
str << QDateTime::fromMSecsSinceEpoch(msg.timestamp).toString(Qt::ISODate) << " - " << msg.message << endl; |
||||
|
||||
if (m_backup && (m_logFile->size() >= (m_size * 1024 * 1024))) { |
||||
closeLogFile(); |
||||
int counter = 0; |
||||
QString backupLogFilename = m_path + ".bak"; |
||||
|
||||
while (QFile::exists(backupLogFilename)) { |
||||
++counter; |
||||
backupLogFilename = m_path + ".bak" + QString::number(counter); |
||||
} |
||||
|
||||
QFile::rename(m_path, backupLogFilename); |
||||
openLogFile(); |
||||
} |
||||
else { |
||||
m_flusher.start(); |
||||
} |
||||
} |
||||
|
||||
void FileLogger::flushLog() |
||||
{ |
||||
if (m_logFile) |
||||
m_logFile->flush(); |
||||
} |
||||
|
||||
void FileLogger::openLogFile() |
||||
{ |
||||
if (!m_logFile->open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text) |
||||
|| !m_logFile->setPermissions(QFile::ReadOwner | QFile::WriteOwner)) { |
||||
delete m_logFile; |
||||
m_logFile = nullptr; |
||||
Logger::instance()->addMessage(tr("An error occured while trying to open the log file. Logging to file is disabled."), Log::CRITICAL); |
||||
} |
||||
} |
||||
|
||||
void FileLogger::closeLogFile() |
||||
{ |
||||
m_flusher.stop(); |
||||
m_logFile->close(); |
||||
} |
@ -0,0 +1,68 @@
@@ -0,0 +1,68 @@
|
||||
/*
|
||||
* Bittorrent Client using Qt and libtorrent. |
||||
* Copyright (C) 2016 sledgehammer999 <hammered999@gmail.com> |
||||
* |
||||
* 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 FILELOGGER_H |
||||
#define FILELOGGER_H |
||||
|
||||
#include <QObject> |
||||
#include <QTimer> |
||||
|
||||
class QFile; |
||||
|
||||
namespace Log |
||||
{ |
||||
struct Msg; |
||||
} |
||||
|
||||
class FileLogger : public QObject |
||||
{ |
||||
Q_OBJECT |
||||
Q_DISABLE_COPY(FileLogger) |
||||
|
||||
public: |
||||
FileLogger(); |
||||
~FileLogger(); |
||||
|
||||
private slots: |
||||
void configure(); |
||||
void addLogMessage(const Log::Msg &msg); |
||||
void flushLog(); |
||||
|
||||
private: |
||||
void openLogFile(); |
||||
void closeLogFile(); |
||||
|
||||
bool m_backup; |
||||
int m_size; |
||||
QString m_path; |
||||
QFile *m_logFile; |
||||
QTimer m_flusher; |
||||
}; |
||||
|
||||
#endif // FILELOGGER_H
|
||||
|
Loading…
Reference in new issue