Used QSettings instead of KConfig in KdeConnectSettings

REVIEW: 122936
This commit is contained in:
Ashish Bansal 2015-03-15 19:20:24 -07:00 committed by Albert Vaca
parent 654ee39b37
commit 6b4d5be618

View file

@ -20,9 +20,6 @@
#include "kdeconnectconfig.h" #include "kdeconnectconfig.h"
#include <KConfig>
#include <KConfigGroup>
#include <KSharedConfig>
#include <KNotification> #include <KNotification>
#include <KLocalizedString> #include <KLocalizedString>
@ -36,6 +33,7 @@
#include <QStandardPaths> #include <QStandardPaths>
#include <QCoreApplication> #include <QCoreApplication>
#include <QHostInfo> #include <QHostInfo>
#include <QSettings>
#include "core_debug.h" #include "core_debug.h"
#include "dbushelper.h" #include "dbushelper.h"
@ -48,7 +46,7 @@ struct KdeConnectConfigPrivate {
QCA::PrivateKey privateKey; QCA::PrivateKey privateKey;
KSharedConfigPtr config; QSettings* config;
}; };
@ -75,15 +73,18 @@ KdeConnectConfig::KdeConnectConfig()
QDir().mkpath(baseConfigDir().path()); QDir().mkpath(baseConfigDir().path());
//.config/kdeconnect/config //.config/kdeconnect/config
d->config = KSharedConfig::openConfig(baseConfigDir().absoluteFilePath("config"), KSharedConfig::SimpleConfig); d->config = new QSettings(baseConfigDir().absoluteFilePath("config"), QSettings::IniFormat);
if (!d->config->group("myself").hasKey("id")) { //Register my own id if not there yet
d->config->beginGroup("myself");
if (!d->config->contains("id")) {
QString uuid = QUuid::createUuid().toString(); QString uuid = QUuid::createUuid().toString();
DbusHelper::filterNonExportableCharacters(uuid); DbusHelper::filterNonExportableCharacters(uuid);
d->config->group("myself").writeEntry("id", uuid); d->config->setValue("id", uuid);
d->config->sync(); d->config->sync();
qCDebug(KDECONNECT_CORE) << "My id:" << uuid; qCDebug(KDECONNECT_CORE) << "My id:" << uuid;
} }
d->config->endGroup();
const QFile::Permissions strict = QFile::ReadOwner | QFile::WriteOwner | QFile::ReadUser | QFile::WriteUser; const QFile::Permissions strict = QFile::ReadOwner | QFile::WriteOwner | QFile::ReadUser | QFile::WriteUser;
@ -112,15 +113,20 @@ KdeConnectConfig::KdeConnectConfig()
} }
} }
QString KdeConnectConfig::name() { QString KdeConnectConfig::name()
{
QString defaultName = qgetenv("USER") + "@" + QHostInfo::localHostName(); QString defaultName = qgetenv("USER") + "@" + QHostInfo::localHostName();
QString name = d->config->group("myself").readEntry("name", defaultName); d->config->beginGroup("myself");
QString name = d->config->value("name", defaultName).toString();
d->config->endGroup();
return name; return name;
} }
void KdeConnectConfig::setName(QString name) void KdeConnectConfig::setName(QString name)
{ {
d->config->group("myself").writeEntry("name", name); d->config->beginGroup("myself");
d->config->setValue("name", name);
d->config->endGroup();
d->config->sync(); d->config->sync();
} }
@ -129,8 +135,12 @@ QString KdeConnectConfig::deviceType()
return "desktop"; // TODO return "desktop"; // TODO
} }
QString KdeConnectConfig::deviceId() { QString KdeConnectConfig::deviceId()
return d->config->group("myself").readEntry("id", ""); {
d->config->beginGroup("myself");
QString id = d->config->value("id", "").toString();
d->config->endGroup();
return id;
} }
QString KdeConnectConfig::privateKeyPath() QString KdeConnectConfig::privateKeyPath()
@ -157,17 +167,21 @@ QDir KdeConnectConfig::baseConfigDir()
QStringList KdeConnectConfig::trustedDevices() QStringList KdeConnectConfig::trustedDevices()
{ {
const KConfigGroup& known = d->config->group("trusted_devices"); d->config->beginGroup("trustedDevices");
const QStringList& list = known.groupList(); const QStringList& list = d->config->childGroups();
d->config->endGroup();
return list; return list;
} }
void KdeConnectConfig::addTrustedDevice(QString id, QString name, QString type, QString publicKey) void KdeConnectConfig::addTrustedDevice(QString id, QString name, QString type, QString publicKey)
{ {
KConfigGroup device = d->config->group("trusted_devices").group(id); d->config->beginGroup("trustedDevices");
device.writeEntry("deviceName", name); d->config->beginGroup(id);
device.writeEntry("deviceType", type); d->config->setValue("name", name);
device.writeEntry("publicKey", publicKey); d->config->setValue("type", type);
d->config->setValue("publicKey", publicKey);
d->config->endGroup();
d->config->endGroup();
d->config->sync(); d->config->sync();
QDir().mkpath(deviceConfigDir(id).path()); QDir().mkpath(deviceConfigDir(id).path());
@ -175,20 +189,27 @@ void KdeConnectConfig::addTrustedDevice(QString id, QString name, QString type,
KdeConnectConfig::DeviceInfo KdeConnectConfig::getTrustedDevice(QString id) KdeConnectConfig::DeviceInfo KdeConnectConfig::getTrustedDevice(QString id)
{ {
KConfigGroup data = d->config->group("trusted_devices").group(id); d->config->beginGroup("trustedDevices");
d->config->beginGroup(id);
KdeConnectConfig::DeviceInfo info; KdeConnectConfig::DeviceInfo info;
info.deviceName = data.readEntry<QString>("deviceName", QLatin1String("unnamed")); info.deviceName = d->config->value("name", QLatin1String("unnamed")).toString();
info.deviceType = data.readEntry<QString>("deviceType", QLatin1String("unknown")); info.deviceType = d->config->value("type", QLatin1String("unknown")).toString();
info.publicKey = data.readEntry<QString>("publicKey", QString()); info.publicKey = d->config->value("publicKey", QString()).toString();
d->config->endGroup();
d->config->endGroup();
return info; return info;
} }
void KdeConnectConfig::removeTrustedDevice(QString deviceId) void KdeConnectConfig::removeTrustedDevice(QString deviceId)
{ {
d->config->group("trusted_devices").deleteGroup(deviceId); d->config->beginGroup("trustedDevices");
d->config->beginGroup(deviceId);
d->config->remove(QString());
d->config->endGroup();
d->config->endGroup();
d->config->sync();
//We do not remove the config files. //We do not remove the config files.
} }