Used QSettings instead of KConfig in KdeConnectSettings
REVIEW: 122936
This commit is contained in:
parent
654ee39b37
commit
6b4d5be618
1 changed files with 45 additions and 24 deletions
|
@ -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.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue