+#include "client.h"
+#include "quassel.h"
+
+ClientSettings::ClientSettings(QString g)
+ : Settings(g, Quassel::buildInfo().clientApplicationName)
+{}
+
+/***********************************************************************************************/
+
+CoreAccountSettings::CoreAccountSettings(QString subgroup)
+ : ClientSettings("CoreAccounts")
+ , _subgroup(std::move(subgroup))
+{}
+
+QString CoreAccountSettings::keyForNotify(const QString& key) const
+{
+ return QString{"%1/%2/%3"}.arg(Client::currentCoreAccount().accountId().toInt()).arg(_subgroup).arg(key);
+}
+
+QList<AccountId> CoreAccountSettings::knownAccounts() const
+{
+ QList<AccountId> ids;
+ foreach (const QString& key, localChildGroups()) {
+ AccountId acc = key.toInt();
+ if (acc.isValid())
+ ids << acc;
+ }
+ return ids;
+}
+
+AccountId CoreAccountSettings::lastAccount() const
+{
+ return localValue("LastAccount", 0).toInt();
+}
+
+void CoreAccountSettings::setLastAccount(AccountId account)
+{
+ setLocalValue("LastAccount", account.toInt());
+}
+
+AccountId CoreAccountSettings::autoConnectAccount() const
+{
+ return localValue("AutoConnectAccount", 0).toInt();
+}
+
+void CoreAccountSettings::setAutoConnectAccount(AccountId account)
+{
+ setLocalValue("AutoConnectAccount", account.toInt());
+}
+
+bool CoreAccountSettings::autoConnectOnStartup() const
+{
+ return localValue("AutoConnectOnStartup", false).toBool();
+}
+
+void CoreAccountSettings::setAutoConnectOnStartup(bool b)
+{
+ setLocalValue("AutoConnectOnStartup", b);
+}
+
+bool CoreAccountSettings::autoConnectToFixedAccount() const
+{
+ return localValue("AutoConnectToFixedAccount", false).toBool();
+}
+
+void CoreAccountSettings::setAutoConnectToFixedAccount(bool b)
+{
+ setLocalValue("AutoConnectToFixedAccount", b);
+}
+
+void CoreAccountSettings::storeAccountData(AccountId id, const QVariantMap& data)
+{
+ QString base = QString::number(id.toInt());
+ foreach (const QString& key, data.keys()) {
+ setLocalValue(base + "/" + key, data.value(key));
+ }
+
+ // FIXME Migration from 0.5 -> 0.6
+ removeLocalKey(QString("%1/Connection").arg(base));
+}
+
+QVariantMap CoreAccountSettings::retrieveAccountData(AccountId id) const
+{
+ QVariantMap map;
+ QString base = QString::number(id.toInt());
+ foreach (const QString& key, localChildKeys(base)) {
+ map[key] = localValue(base + "/" + key);
+ }
+
+ // FIXME Migration from 0.5 -> 0.6
+ if (!map.contains("Uuid") && map.contains("Connection")) {
+ QVariantMap oldmap = map.value("Connection").toMap();
+ map["AccountName"] = oldmap.value("AccountName");
+ map["HostName"] = oldmap.value("Host");
+ map["Port"] = oldmap.value("Port");
+ map["User"] = oldmap.value("User");
+ map["Password"] = oldmap.value("Password");
+ map["StorePassword"] = oldmap.value("RememberPasswd");
+ map["UseSSL"] = oldmap.value("useSsl");
+ map["UseProxy"] = oldmap.value("useProxy");
+ map["ProxyHostName"] = oldmap.value("proxyHost");
+ map["ProxyPort"] = oldmap.value("proxyPort");
+ map["ProxyUser"] = oldmap.value("proxyUser");
+ map["ProxyPassword"] = oldmap.value("proxyPassword");
+ map["ProxyType"] = oldmap.value("proxyType");
+ map["Internal"] = oldmap.value("InternalAccount");
+
+ map["AccountId"] = id.toInt();
+ map["Uuid"] = QUuid::createUuid().toString();
+ }
+
+ return map;
+}
+
+void CoreAccountSettings::setAccountValue(const QString& key, const QVariant& value)
+{
+ if (!Client::currentCoreAccount().isValid())
+ return;
+ setLocalValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().accountId().toInt()).arg(_subgroup).arg(key), value);
+}
+
+QVariant CoreAccountSettings::accountValue(const QString& key, const QVariant& def) const
+{
+ if (!Client::currentCoreAccount().isValid())
+ return QVariant();
+ return localValue(QString("%1/%2/%3").arg(Client::currentCoreAccount().accountId().toInt()).arg(_subgroup).arg(key), def);
+}
+
+void CoreAccountSettings::setJumpKeyMap(const QHash<int, BufferId>& keyMap)
+{
+ QVariantMap variants;
+ QHash<int, BufferId>::const_iterator mapIter = keyMap.constBegin();
+ while (mapIter != keyMap.constEnd()) {
+ variants[QString::number(mapIter.key())] = QVariant::fromValue(mapIter.value());
+ ++mapIter;
+ }
+ setAccountValue("JumpKeyMap", variants);
+}
+
+QHash<int, BufferId> CoreAccountSettings::jumpKeyMap() const
+{
+ QHash<int, BufferId> keyMap;
+ QVariantMap variants = accountValue("JumpKeyMap", QVariant()).toMap();
+ QVariantMap::const_iterator mapIter = variants.constBegin();
+ while (mapIter != variants.constEnd()) {
+ keyMap[mapIter.key().toInt()] = mapIter.value().value<BufferId>();
+ ++mapIter;
+ }
+ return keyMap;
+}
+
+void CoreAccountSettings::setBufferViewOverlay(const QSet<int>& viewIds)
+{
+ QVariantList variants;
+ foreach (int viewId, viewIds) {
+ variants << QVariant::fromValue(viewId);
+ }
+ setAccountValue("BufferViewOverlay", variants);
+}