X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.h;h=2518250784ac7ddae82ad2e16a0c05ef270f1e6c;hp=1df9ea10a180f48854a59ffdb651e94c0a744c0e;hb=6245a8d29e893eaff25a12b0be2f47b64f0f7bcd;hpb=f6781dc095957d65e8fc1683fda1c5a5b9cbedbb diff --git a/src/core/sqlitestorage.h b/src/core/sqlitestorage.h index 1df9ea10..25182507 100644 --- a/src/core/sqlitestorage.h +++ b/src/core/sqlitestorage.h @@ -41,17 +41,18 @@ public slots: bool isAvailable() const; QString displayName() const; - inline QVariantMap setupKeys() const { return QVariantMap(); } + virtual inline QStringList setupKeys() const { return QStringList(); } + virtual inline QVariantMap setupDefaults() const { return QVariantMap(); } QString description() const; // TODO: Add functions for configuring the backlog handling, i.e. defining auto-cleanup settings etc /* User handling */ - virtual UserId addUser(const QString &user, const QString &password); - virtual void updateUser(UserId user, const QString &password); + virtual bool updateUser(UserId user, const QString &password); virtual void renameUser(UserId user, const QString &newName); virtual UserId validateUser(const QString &user, const QString &password); + virtual UserId getUserId(const QString &username); virtual UserId internalUser(); virtual void delUser(UserId user); virtual void setUserSetting(UserId userId, const QString &settingName, const QVariant &data); @@ -110,11 +111,13 @@ protected: private: static QString backlogFile(); - bool isValidNetwork(UserId user, const NetworkId &networkId); - bool isValidBuffer(const UserId &user, const BufferId &bufferId); - NetworkId getNetworkId(UserId user, const QString &network); - void createBuffer(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer); + void bindNetworkInfo(QSqlQuery &query, const NetworkInfo &info); + void bindServerInfo(QSqlQuery &query, const Network::Server &server); + inline void lockForRead() { _dbLock.lockForRead(); } + inline void lockForWrite() { _dbLock.lockForWrite(); } + inline void unlock() { _dbLock.unlock(); } + QReadWriteLock _dbLock; static int _maxRetryCount; };