nextcloud-desktop/src/libsync/configfile.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

786 lines
25 KiB
C++
Raw Normal View History

/*
* Copyright (C) by Klaas Freitag <freitag@owncloud.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.
*/
2012-05-21 18:48:49 +04:00
#include "config.h"
2014-11-10 01:25:57 +03:00
#include "configfile.h"
#include "theme.h"
#include "common/utility.h"
2017-09-01 19:11:43 +03:00
#include "common/asserts.h"
#include "creds/abstractcredentials.h"
#include "csync_exclude.h"
2014-04-06 21:34:56 +04:00
#ifndef TOKEN_AUTH_ONLY
#include <QWidget>
2014-04-06 21:34:56 +04:00
#include <QHeaderView>
#endif
2013-09-05 21:53:29 +04:00
#include <QCoreApplication>
2013-10-21 23:42:52 +04:00
#include <QDir>
#include <QFile>
#include <QFileInfo>
#include <QLoggingCategory>
2013-10-21 23:42:52 +04:00
#include <QSettings>
#include <QNetworkProxy>
#include <QStandardPaths>
#define DEFAULT_REMOTE_POLL_INTERVAL 30000 // default remote poll time in milliseconds
#define DEFAULT_FULL_LOCAL_DISCOVERY_INTERVAL (60 * 60 * 1000) // 1 hour
#define DEFAULT_MAX_LOG_LINES 20000
2012-08-06 15:57:26 +04:00
2014-11-10 00:34:07 +03:00
namespace OCC {
Q_LOGGING_CATEGORY(lcConfigFile, "sync.configfile", QtInfoMsg)
2015-04-15 15:58:27 +03:00
//static const char caCertsKeyC[] = "CaCertificates"; only used from account.cpp
static const char remotePollIntervalC[] = "remotePollInterval";
2013-08-08 16:30:45 +04:00
static const char forceSyncIntervalC[] = "forceSyncInterval";
static const char fullLocalDiscoveryIntervalC[] = "fullLocalDiscoveryInterval";
static const char notificationRefreshIntervalC[] = "notificationRefreshInterval";
static const char monoIconsC[] = "monoIcons";
static const char promptDeleteC[] = "promptDeleteAllFiles";
static const char crashReporterC[] = "crashReporter";
static const char optionalServerNotificationsC[] = "optionalServerNotifications";
static const char optionalServerActivitiesC[] = "optionalServerActivities";
static const char showInExplorerNavigationPaneC[] = "showInExplorerNavigationPane";
static const char skipUpdateCheckC[] = "skipUpdateCheck";
static const char updateCheckIntervalC[] = "updateCheckInterval";
static const char geometryC[] = "geometry";
static const char timeoutC[] = "timeout";
static const char chunkSizeC[] = "chunkSize";
static const char minChunkSizeC[] = "minChunkSize";
static const char maxChunkSizeC[] = "maxChunkSize";
static const char targetChunkUploadDurationC[] = "targetChunkUploadDuration";
static const char proxyHostC[] = "Proxy/host";
static const char proxyTypeC[] = "Proxy/type";
static const char proxyPortC[] = "Proxy/port";
static const char proxyUserC[] = "Proxy/user";
static const char proxyPassC[] = "Proxy/pass";
static const char proxyNeedsAuthC[] = "Proxy/needsAuth";
static const char useUploadLimitC[] = "BWLimit/useUploadLimit";
static const char useDownloadLimitC[] = "BWLimit/useDownloadLimit";
static const char uploadLimitC[] = "BWLimit/uploadLimit";
static const char downloadLimitC[] = "BWLimit/downloadLimit";
static const char newBigFolderSizeLimitC[] = "newBigFolderSizeLimit";
static const char useNewBigFolderSizeLimitC[] = "useNewBigFolderSizeLimit";
static const char confirmExternalStorageC[] = "confirmExternalStorage";
2015-07-07 17:28:48 +03:00
static const char maxLogLinesC[] = "Logging/maxLogLines";
const char certPath[] = "http_certificatePath";
const char certPasswd[] = "http_certificatePasswd";
QString ConfigFile::_confDir = QString();
2014-11-10 00:30:29 +03:00
bool ConfigFile::_askedUser = false;
2014-11-10 00:30:29 +03:00
ConfigFile::ConfigFile()
{
// QDesktopServices uses the application name to create a config path
qApp->setApplicationName(Theme::instance()->appNameGUI());
QSettings::setDefaultFormat(QSettings::IniFormat);
const QString config = configFile();
2013-11-14 18:48:46 +04:00
QSettings settings(config, QSettings::IniFormat);
settings.beginGroup(defaultConnection());
}
bool ConfigFile::setConfDir(const QString &value)
{
QString dirPath = value;
if (dirPath.isEmpty())
return false;
QFileInfo fi(dirPath);
if (!fi.exists()) {
QDir().mkpath(dirPath);
fi.setFile(dirPath);
}
if (fi.exists() && fi.isDir()) {
2013-08-15 15:09:20 +04:00
dirPath = fi.absoluteFilePath();
qCInfo(lcConfigFile) << "Using custom config dir " << dirPath;
2013-08-15 15:09:20 +04:00
_confDir = dirPath;
return true;
}
return false;
}
bool ConfigFile::optionalServerNotifications() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(optionalServerNotificationsC), false).toBool();
}
bool ConfigFile::optionalServerActivities() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(optionalServerActivitiesC), false).toBool();
}
bool ConfigFile::showInExplorerNavigationPane() const
{
const bool defaultValue =
#ifdef Q_OS_WIN
QSysInfo::windowsVersion() >= QSysInfo::WV_WINDOWS10
#else
false
#endif
;
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(showInExplorerNavigationPaneC), defaultValue).toBool();
}
void ConfigFile::setShowInExplorerNavigationPane(bool show)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(showInExplorerNavigationPaneC), show);
settings.sync();
}
2014-11-10 00:30:29 +03:00
int ConfigFile::timeout() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(timeoutC), 300).toInt(); // default to 5 min
}
quint64 ConfigFile::chunkSize() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(chunkSizeC), 10 * 1000 * 1000).toLongLong(); // default to 10 MB
}
2016-12-08 00:35:50 +03:00
quint64 ConfigFile::maxChunkSize() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(maxChunkSizeC), 100 * 1000 * 1000).toLongLong(); // default to 100 MB
2016-12-08 00:35:50 +03:00
}
quint64 ConfigFile::minChunkSize() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(minChunkSizeC), 1000 * 1000).toLongLong(); // default to 1 MB
}
quint64 ConfigFile::targetChunkUploadDuration() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(targetChunkUploadDurationC), 60 * 1000).toLongLong(); // default to 1 minute
2016-12-08 00:35:50 +03:00
}
void ConfigFile::setOptionalServerNotifications(bool show)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(optionalServerNotificationsC), show);
settings.sync();
}
void ConfigFile::setOptionalServerActivities(bool show)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(optionalServerActivitiesC), show);
settings.sync();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::saveGeometry(QWidget *w)
{
2014-04-06 21:34:56 +04:00
#ifndef TOKEN_AUTH_ONLY
ASSERT(!w->objectName().isNull());
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(w->objectName());
settings.setValue(QLatin1String(geometryC), w->saveGeometry());
settings.sync();
2014-04-06 21:34:56 +04:00
#endif
}
2014-11-10 00:30:29 +03:00
void ConfigFile::restoreGeometry(QWidget *w)
{
2014-04-06 21:34:56 +04:00
#ifndef TOKEN_AUTH_ONLY
w->restoreGeometry(getValue(geometryC, w->objectName()).toByteArray());
2014-04-06 21:34:56 +04:00
#endif
}
2014-11-10 00:30:29 +03:00
void ConfigFile::saveGeometryHeader(QHeaderView *header)
{
2014-04-06 21:34:56 +04:00
#ifndef TOKEN_AUTH_ONLY
if (!header)
return;
ASSERT(!header->objectName().isEmpty());
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(header->objectName());
settings.setValue(QLatin1String(geometryC), header->saveState());
settings.sync();
2014-04-06 21:34:56 +04:00
#endif
}
2014-11-10 00:30:29 +03:00
void ConfigFile::restoreGeometryHeader(QHeaderView *header)
{
2014-04-06 21:34:56 +04:00
#ifndef TOKEN_AUTH_ONLY
if (!header)
return;
ASSERT(!header->objectName().isNull());
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(header->objectName());
header->restoreState(settings.value(geometryC).toByteArray());
2014-04-06 21:34:56 +04:00
#endif
}
2014-11-10 00:30:29 +03:00
QVariant ConfigFile::getPolicySetting(const QString &setting, const QVariant &defaultValue) const
{
if (Utility::isWindows()) {
// check for policies first and return immediately if a value is found.
QSettings userPolicy(QString::fromLatin1("HKEY_CURRENT_USER\\Software\\Policies\\%1\\%2")
.arg(APPLICATION_VENDOR, Theme::instance()->appName()),
QSettings::NativeFormat);
if (userPolicy.contains(setting)) {
return userPolicy.value(setting);
}
QSettings machinePolicy(QString::fromLatin1("HKEY_LOCAL_MACHINE\\Software\\Policies\\%1\\%2")
.arg(APPLICATION_VENDOR, APPLICATION_NAME),
QSettings::NativeFormat);
if (machinePolicy.contains(setting)) {
return machinePolicy.value(setting);
}
}
return defaultValue;
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::configPath() const
2012-03-28 13:26:51 +04:00
{
if (_confDir.isEmpty()) {
// On Unix, use the AppConfigLocation for the settings, that's configurable with the XDG_CONFIG_HOME env variable.
// On Windows, use AppDataLocation, that's where the roaming data is and where we should store the config file
_confDir = QStandardPaths::writableLocation(Utility::isWindows() ? QStandardPaths::AppDataLocation : QStandardPaths::AppConfigLocation);
}
QString dir = _confDir;
2013-04-04 17:19:23 +04:00
2012-08-17 19:13:17 +04:00
if (!dir.endsWith(QLatin1Char('/')))
dir.append(QLatin1Char('/'));
2012-03-28 13:26:51 +04:00
return dir;
}
static const QLatin1String exclFile("sync-exclude.lst");
2014-11-10 00:30:29 +03:00
QString ConfigFile::excludeFile(Scope scope) const
{
// prefer sync-exclude.lst, but if it does not exist, check for
// exclude.lst for compatibility reasons in the user writeable
// directories.
QFileInfo fi;
switch (scope) {
case UserScope:
fi.setFile(configPath(), exclFile);
if (!fi.isReadable()) {
fi.setFile(configPath(), QLatin1String("exclude.lst"));
}
if (!fi.isReadable()) {
fi.setFile(configPath(), exclFile);
}
return fi.absoluteFilePath();
case SystemScope:
2014-11-10 00:30:29 +03:00
return ConfigFile::excludeFileFromSystem();
}
ASSERT(false);
return QString();
}
2012-08-17 19:00:03 +04:00
2014-11-10 00:30:29 +03:00
QString ConfigFile::excludeFileFromSystem()
{
QFileInfo fi;
#ifdef Q_OS_WIN
fi.setFile(QCoreApplication::applicationDirPath(), exclFile);
2012-05-16 16:55:19 +04:00
#endif
#ifdef Q_OS_UNIX
fi.setFile(QString(SYSCONFDIR "/" + Theme::instance()->appName()), exclFile);
if (!fi.exists()) {
// Prefer to return the preferred path! Only use the fallback location
// if the other path does not exist and the fallback is valid.
QFileInfo nextToBinary(QCoreApplication::applicationDirPath(), exclFile);
if (nextToBinary.exists()) {
fi = nextToBinary;
} else {
// For AppImage, the file might reside under a temporary mount path
QDir d(QCoreApplication::applicationDirPath()); // supposed to be /tmp/mount.xyz/usr/bin
d.cdUp(); // go out of bin
d.cdUp(); // go out of usr
if (!d.isRoot()) { // it is really a mountpoint
if (d.cd("etc") && d.cd(Theme::instance()->appName())) {
QFileInfo inMountDir(d, exclFile);
if (inMountDir.exists()) {
fi = inMountDir;
}
};
}
}
}
2012-05-16 16:55:19 +04:00
#endif
#ifdef Q_OS_MAC
// exec path is inside the bundle
fi.setFile(QCoreApplication::applicationDirPath(),
QLatin1String("../Resources/") + exclFile);
#endif
2017-05-17 11:55:42 +03:00
return fi.absoluteFilePath();
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::configFile() const
{
return configPath() + Theme::instance()->configFileName();
}
2014-11-10 00:30:29 +03:00
bool ConfigFile::exists()
{
QFile file(configFile());
return file.exists();
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::defaultConnection() const
{
return Theme::instance()->appName();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::storeData(const QString &group, const QString &key, const QVariant &value)
2012-12-04 20:27:59 +04:00
{
const QString con(group.isEmpty() ? defaultConnection() : group);
QSettings settings(configFile(), QSettings::IniFormat);
2012-12-04 20:27:59 +04:00
settings.beginGroup(con);
settings.setValue(key, value);
2012-12-04 20:27:59 +04:00
settings.sync();
}
2014-11-10 00:30:29 +03:00
QVariant ConfigFile::retrieveData(const QString &group, const QString &key) const
{
const QString con(group.isEmpty() ? defaultConnection() : group);
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
return settings.value(key);
}
2014-11-10 00:30:29 +03:00
void ConfigFile::removeData(const QString &group, const QString &key)
{
const QString con(group.isEmpty() ? defaultConnection() : group);
QSettings settings(configFile(), QSettings::IniFormat);
2012-12-28 16:41:26 +04:00
settings.beginGroup(con);
settings.remove(key);
}
2014-11-10 00:30:29 +03:00
bool ConfigFile::dataExists(const QString &group, const QString &key) const
{
const QString con(group.isEmpty() ? defaultConnection() : group);
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
return settings.contains(key);
}
2014-11-10 00:30:29 +03:00
int ConfigFile::remotePollInterval(const QString &connection) const
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
int remoteInterval = settings.value(QLatin1String(remotePollIntervalC), DEFAULT_REMOTE_POLL_INTERVAL).toInt();
if (remoteInterval < 5000) {
qCWarning(lcConfigFile) << "Remote Interval is less than 5 seconds, reverting to" << DEFAULT_REMOTE_POLL_INTERVAL;
remoteInterval = DEFAULT_REMOTE_POLL_INTERVAL;
}
return remoteInterval;
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setRemotePollInterval(int interval, const QString &connection)
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
if (interval < 5000) {
qCWarning(lcConfigFile) << "Remote Poll interval of " << interval << " is below five seconds.";
return;
}
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
settings.setValue(QLatin1String(remotePollIntervalC), interval);
settings.sync();
}
2014-11-10 00:30:29 +03:00
quint64 ConfigFile::forceSyncInterval(const QString &connection) const
2013-08-08 16:30:45 +04:00
{
uint pollInterval = remotePollInterval(connection);
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
quint64 defaultInterval = 2 * 60 * 60 * 1000ull; // 2h
quint64 interval = settings.value(QLatin1String(forceSyncIntervalC), defaultInterval).toULongLong();
2013-08-08 16:30:45 +04:00
if (interval < pollInterval) {
qCWarning(lcConfigFile) << "Force sync interval is less than the remote poll inteval, reverting to" << pollInterval;
2013-08-08 16:30:45 +04:00
interval = pollInterval;
}
return interval;
}
qint64 ConfigFile::fullLocalDiscoveryInterval() const
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(defaultConnection());
return settings.value(QLatin1String(fullLocalDiscoveryIntervalC), DEFAULT_FULL_LOCAL_DISCOVERY_INTERVAL).toLongLong();
}
quint64 ConfigFile::notificationRefreshInterval(const QString &connection) const
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
quint64 defaultInterval = 5 * 60 * 1000ull; // 5 minutes
quint64 interval = settings.value(QLatin1String(notificationRefreshIntervalC), defaultInterval).toULongLong();
if (interval < 60 * 1000ull) {
qCWarning(lcConfigFile) << "Notification refresh interval smaller than one minute, setting to one minute";
interval = 60 * 1000ull;
}
return interval;
}
int ConfigFile::updateCheckInterval(const QString &connection) const
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
int defaultInterval = 1000 * 60 * 60 * 10; // ten hours
int interval = settings.value(QLatin1String(updateCheckIntervalC), defaultInterval).toInt();
int minInterval = 1000 * 60 * 5;
if (interval < minInterval) {
qCWarning(lcConfigFile) << "Update check interval less than five minutes, setting " << minInterval;
interval = minInterval;
}
return interval;
}
2014-11-10 00:30:29 +03:00
bool ConfigFile::skipUpdateCheck(const QString &connection) const
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QVariant fallback = getValue(QLatin1String(skipUpdateCheckC), con, false);
fallback = getValue(QLatin1String(skipUpdateCheckC), QString(), fallback);
QVariant value = getPolicySetting(QLatin1String(skipUpdateCheckC), fallback);
return value.toBool();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setSkipUpdateCheck(bool skip, const QString &connection)
{
QString con(connection);
if (connection.isEmpty())
con = defaultConnection();
QSettings settings(configFile(), QSettings::IniFormat);
settings.beginGroup(con);
settings.setValue(QLatin1String(skipUpdateCheckC), QVariant(skip));
settings.sync();
}
2014-11-10 00:30:29 +03:00
int ConfigFile::maxLogLines() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(maxLogLinesC), DEFAULT_MAX_LOG_LINES).toInt();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setMaxLogLines(int lines)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(maxLogLinesC), lines);
settings.sync();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setProxyType(int proxyType,
const QString &host,
int port, bool needsAuth,
const QString &user,
const QString &pass)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(proxyTypeC), proxyType);
if (proxyType == QNetworkProxy::HttpProxy || proxyType == QNetworkProxy::Socks5Proxy) {
settings.setValue(QLatin1String(proxyHostC), host);
settings.setValue(QLatin1String(proxyPortC), port);
settings.setValue(QLatin1String(proxyNeedsAuthC), needsAuth);
settings.setValue(QLatin1String(proxyUserC), user);
settings.setValue(QLatin1String(proxyPassC), pass.toUtf8().toBase64());
}
settings.sync();
}
2014-11-10 00:30:29 +03:00
QVariant ConfigFile::getValue(const QString &param, const QString &group,
const QVariant &defaultValue) const
{
QVariant systemSetting;
if (Utility::isMac()) {
QSettings systemSettings(QLatin1String("/Library/Preferences/" APPLICATION_REV_DOMAIN ".plist"), QSettings::NativeFormat);
if (!group.isEmpty()) {
systemSettings.beginGroup(group);
}
systemSetting = systemSettings.value(param, defaultValue);
} else if (Utility::isUnix()) {
QSettings systemSettings(QString(SYSCONFDIR "/%1/%1.conf").arg(Theme::instance()->appName()), QSettings::NativeFormat);
if (!group.isEmpty()) {
systemSettings.beginGroup(group);
}
systemSetting = systemSettings.value(param, defaultValue);
} else { // Windows
QSettings systemSettings(QString::fromLatin1("HKEY_LOCAL_MACHINE\\Software\\%1\\%2")
.arg(APPLICATION_VENDOR, Theme::instance()->appName()),
QSettings::NativeFormat);
if (!group.isEmpty()) {
systemSettings.beginGroup(group);
}
systemSetting = systemSettings.value(param, defaultValue);
}
QSettings settings(configFile(), QSettings::IniFormat);
if (!group.isEmpty())
settings.beginGroup(group);
return settings.value(param, systemSetting);
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setValue(const QString &key, const QVariant &value)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(key, value);
}
2014-11-10 00:30:29 +03:00
int ConfigFile::proxyType() const
{
if (Theme::instance()->forceSystemNetworkProxy()) {
return QNetworkProxy::DefaultProxy;
}
return getValue(QLatin1String(proxyTypeC)).toInt();
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::proxyHostName() const
{
return getValue(QLatin1String(proxyHostC)).toString();
}
2014-11-10 00:30:29 +03:00
int ConfigFile::proxyPort() const
{
return getValue(QLatin1String(proxyPortC)).toInt();
}
2014-11-10 00:30:29 +03:00
bool ConfigFile::proxyNeedsAuth() const
{
return getValue(QLatin1String(proxyNeedsAuthC)).toBool();
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::proxyUser() const
{
return getValue(QLatin1String(proxyUserC)).toString();
}
2014-11-10 00:30:29 +03:00
QString ConfigFile::proxyPassword() const
{
QByteArray pass = getValue(proxyPassC).toByteArray();
return QString::fromUtf8(QByteArray::fromBase64(pass));
}
2014-11-10 00:30:29 +03:00
int ConfigFile::useUploadLimit() const
{
return getValue(useUploadLimitC, QString(), 0).toInt();
}
int ConfigFile::useDownloadLimit() const
{
return getValue(useDownloadLimitC, QString(), 0).toInt();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setUseUploadLimit(int val)
{
setValue(useUploadLimitC, val);
}
void ConfigFile::setUseDownloadLimit(int val)
{
setValue(useDownloadLimitC, val);
}
2014-11-10 00:30:29 +03:00
int ConfigFile::uploadLimit() const
{
return getValue(uploadLimitC, QString(), 10).toInt();
}
2014-11-10 00:30:29 +03:00
int ConfigFile::downloadLimit() const
{
return getValue(downloadLimitC, QString(), 80).toInt();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setUploadLimit(int kbytes)
{
setValue(uploadLimitC, kbytes);
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setDownloadLimit(int kbytes)
{
setValue(downloadLimitC, kbytes);
}
QPair<bool, quint64> ConfigFile::newBigFolderSizeLimit() const
2015-07-07 17:28:48 +03:00
{
auto defaultValue = Theme::instance()->newBigFolderSizeLimit();
qint64 value = getValue(newBigFolderSizeLimitC, QString(), defaultValue).toLongLong();
bool use = value >= 0 && getValue(useNewBigFolderSizeLimitC, QString(), true).toBool();
2015-07-07 17:28:48 +03:00
return qMakePair(use, quint64(qMax<qint64>(0, value)));
}
void ConfigFile::setNewBigFolderSizeLimit(bool isChecked, quint64 mbytes)
2015-07-07 17:28:48 +03:00
{
setValue(newBigFolderSizeLimitC, mbytes);
setValue(useNewBigFolderSizeLimitC, isChecked);
2015-07-07 17:28:48 +03:00
}
bool ConfigFile::confirmExternalStorage() const
{
return getValue(confirmExternalStorageC, QString(), true).toBool();
}
void ConfigFile::setConfirmExternalStorage(bool isChecked)
{
setValue(confirmExternalStorageC, isChecked);
}
bool ConfigFile::promptDeleteFiles() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(promptDeleteC), true).toBool();
}
void ConfigFile::setPromptDeleteFiles(bool promptDeleteFiles)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(promptDeleteC), promptDeleteFiles);
}
2014-11-10 00:30:29 +03:00
bool ConfigFile::monoIcons() const
{
QSettings settings(configFile(), QSettings::IniFormat);
bool monoDefault = false; // On Mac we want bw by default
#ifdef Q_OS_MAC
// OEM themes are not obliged to ship mono icons
monoDefault = (0 == (strcmp("ownCloud", APPLICATION_NAME)));
#endif
return settings.value(QLatin1String(monoIconsC), monoDefault).toBool();
}
2014-11-10 00:30:29 +03:00
void ConfigFile::setMonoIcons(bool useMonoIcons)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(monoIconsC), useMonoIcons);
}
2014-12-02 16:20:13 +03:00
bool ConfigFile::crashReporter() const
{
QSettings settings(configFile(), QSettings::IniFormat);
return settings.value(QLatin1String(crashReporterC), true).toBool();
}
2014-12-02 16:20:13 +03:00
void ConfigFile::setCrashReporter(bool enabled)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(crashReporterC), enabled);
}
QString ConfigFile::certificatePath() const
{
return retrieveData(QString(), QLatin1String(certPath)).toString();
}
void ConfigFile::setCertificatePath(const QString &cPath)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(certPath), cPath);
settings.sync();
}
QString ConfigFile::certificatePasswd() const
{
return retrieveData(QString(), QLatin1String(certPasswd)).toString();
}
void ConfigFile::setCertificatePasswd(const QString &cPasswd)
{
QSettings settings(configFile(), QSettings::IniFormat);
settings.setValue(QLatin1String(certPasswd), cPasswd);
settings.sync();
}
Q_GLOBAL_STATIC(QString, g_configFileName)
std::unique_ptr<QSettings> ConfigFile::settingsWithGroup(const QString &group, QObject *parent)
{
if (g_configFileName()->isEmpty()) {
// cache file name
ConfigFile cfg;
*g_configFileName() = cfg.configFile();
}
std::unique_ptr<QSettings> settings(new QSettings(*g_configFileName(), QSettings::IniFormat, parent));
settings->beginGroup(group);
return settings;
}
void ConfigFile::setupDefaultExcludeFilePaths(ExcludedFiles &excludedFiles)
{
ConfigFile cfg;
QString systemList = cfg.excludeFile(ConfigFile::SystemScope);
qCInfo(lcConfigFile) << "Adding system ignore list to csync:" << systemList;
excludedFiles.addExcludeFilePath(systemList);
QString userList = cfg.excludeFile(ConfigFile::UserScope);
if (QFile::exists(userList)) {
qCInfo(lcConfigFile) << "Adding user defined ignore list to csync:" << userList;
excludedFiles.addExcludeFilePath(userList);
}
}
}