diff --git a/src/historykeeper.cpp b/src/historykeeper.cpp index a145b1fc4..13d3c9d81 100644 --- a/src/historykeeper.cpp +++ b/src/historykeeper.cpp @@ -130,6 +130,8 @@ HistoryKeeper::HistoryKeeper(GenericDdInterface *db_) : updateChatsID(); updateAliases(); + setSyncType(Settings::getInstance().getDbSyncType()); + QSqlQuery sqlAnswer = db->exec("select seq from sqlite_sequence where name=\"history\";"); sqlAnswer.first(); messageID = sqlAnswer.value(0).toInt(); @@ -315,3 +317,25 @@ void HistoryKeeper::markAsSent(int m_id) { db->exec(QString("UPDATE sent_status SET status = 1 WHERE id = %1;").arg(m_id)); } + +void HistoryKeeper::setSyncType(Db::syncType sType) +{ + QString syncCmd; + + switch (sType) { + case Db::syncType::stFull: + syncCmd = "FULL"; + break; + case Db::syncType::stNormal: + syncCmd = "NORMAL"; + break; + case Db::syncType::stOff: + syncCmd = "OFF"; + break; + default: + syncCmd = "FULL"; + break; + } + + db->exec(QString("PRAGMA synchronous=%1;").arg(syncCmd)); +} diff --git a/src/historykeeper.h b/src/historykeeper.h index bbe050c13..65e7b9e75 100644 --- a/src/historykeeper.h +++ b/src/historykeeper.h @@ -22,6 +22,7 @@ #include class GenericDdInterface; +namespace Db { enum class syncType; } class HistoryKeeper { @@ -51,6 +52,8 @@ public: QList getChatHistory(ChatType ct, const QString &chat, const QDateTime &time_from, const QDateTime &time_to); void markAsSent(int m_id); + void setSyncType(Db::syncType sType); + private: HistoryKeeper(GenericDdInterface *db_); HistoryKeeper(HistoryKeeper &hk) = delete; diff --git a/src/misc/db/plaindb.h b/src/misc/db/plaindb.h index a0b85b8cc..4584bb461 100644 --- a/src/misc/db/plaindb.h +++ b/src/misc/db/plaindb.h @@ -21,6 +21,10 @@ #include +namespace Db { + enum class syncType : int {stOff = 0, stNormal = 1, stFull = 2}; +} + class PlainDb : public GenericDdInterface { public: diff --git a/src/misc/settings.cpp b/src/misc/settings.cpp index d6ef0b506..c6f309c33 100644 --- a/src/misc/settings.cpp +++ b/src/misc/settings.cpp @@ -17,6 +17,7 @@ #include "settings.h" #include "smileypack.h" #include "src/corestructs.h" +#include "src/misc/db/plaindb.h" #include #include @@ -121,12 +122,17 @@ void Settings::load() proxyAddr = s.value("proxyAddr", "").toString(); proxyPort = s.value("proxyPort", 0).toInt(); currentProfile = s.value("currentProfile", "").toString(); - autoAwayTime = s.value("autoAwayTime", 10).toInt(); + autoAwayTime = s.value("autoAwayTime", 10).toInt(); checkUpdates = s.value("checkUpdates", false).toBool(); showInFront = s.value("showInFront", false).toBool(); fauxOfflineMessaging = s.value("fauxOfflineMessaging", true).toBool(); s.endGroup(); + s.beginGroup("Advanced"); + int sType = s.value("dbSyncType", static_cast(Db::syncType::stFull)).toInt(); + setDbSyncType(sType); + s.endGroup(); + s.beginGroup("Widgets"); QList objectNames = s.childKeys(); for (const QString& name : objectNames) { @@ -267,6 +273,10 @@ void Settings::save(QString path) s.setValue("fauxOfflineMessaging", fauxOfflineMessaging); s.endGroup(); + s.beginGroup("Advanced"); + s.setValue("dbSyncType", static_cast(dbSyncType)); + s.endGroup(); + s.beginGroup("Widgets"); const QList widgetNames = widgetSettings.keys(); for (const QString& name : widgetNames) { @@ -597,6 +607,19 @@ void Settings::setEncryptTox(bool newValue) encryptTox = newValue; } +Db::syncType Settings::getDbSyncType() const +{ + return dbSyncType; +} + +void Settings::setDbSyncType(int newValue) +{ + if (newValue >= 0 && newValue <= 2) + dbSyncType = static_cast(newValue); + else + dbSyncType = Db::syncType::stFull; +} + int Settings::getAutoAwayTime() const { return autoAwayTime; diff --git a/src/misc/settings.h b/src/misc/settings.h index 842892b95..49f60f58d 100644 --- a/src/misc/settings.h +++ b/src/misc/settings.h @@ -22,6 +22,7 @@ #include struct ToxID; +namespace Db { enum class syncType; } class Settings : public QObject { @@ -99,6 +100,9 @@ public: bool getEncryptTox() const; void setEncryptTox(bool newValue); + Db::syncType getDbSyncType() const; + void setDbSyncType(int newValue); + int getAutoAwayTime() const; void setAutoAwayTime(int newValue); @@ -278,6 +282,7 @@ private: // Privacy bool typingNotification; + Db::syncType dbSyncType; // Audio QString inDev;