X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.h;h=5adae63fa9d4b95693b77a02301e9849ce961258;hb=7e18cab1aef55e7720c70319d98fd0c2bce7c160;hp=45f1c4681988396fe22087f010158de718183dec;hpb=4fef2ef49965b4e89a25e8cdc33100d9717d1aa8;p=quassel.git diff --git a/src/core/sqlitestorage.h b/src/core/sqlitestorage.h index 45f1c468..5adae63f 100644 --- a/src/core/sqlitestorage.h +++ b/src/core/sqlitestorage.h @@ -36,15 +36,15 @@ public: public slots: /* General */ - + bool isAvailable() const; QString displayName() const; 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 void renameUser(UserId user, const QString &newName); @@ -54,7 +54,12 @@ public slots: virtual void setUserSetting(UserId userId, const QString &settingName, const QVariant &data); virtual QVariant getUserSetting(UserId userId, const QString &settingName, const QVariant &defaultData = QVariant()); - + /* Identity handling */ + virtual IdentityId createIdentity(UserId user, CoreIdentity &identity); + virtual bool updateIdentity(UserId user, const CoreIdentity &identity); + virtual void removeIdentity(UserId user, IdentityId identityId); + virtual QList identities(UserId user); + /* Network handling */ virtual NetworkId createNetwork(UserId user, const NetworkInfo &info); virtual bool updateNetwork(UserId user, const NetworkInfo &info); @@ -67,7 +72,7 @@ public slots: virtual QHash persistentChannels(UserId user, const NetworkId &networkId); virtual void setChannelPersistent(UserId user, const NetworkId &networkId, const QString &channel, bool isJoined); virtual void setPersistentChannelKey(UserId user, const NetworkId &networkId, const QString &channel, const QString &key); - + /* Buffer handling */ virtual BufferInfo getBufferInfo(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer = ""); virtual BufferInfo getBufferInfo(UserId user, const BufferId &bufferId); @@ -77,25 +82,27 @@ public slots: virtual BufferId renameBuffer(const UserId &user, const NetworkId &networkId, const QString &newName, const QString &oldName); virtual void setBufferLastSeenMsg(UserId user, const BufferId &bufferId, const MsgId &msgId); virtual QHash bufferLastSeenMsgIds(UserId user); - + /* Message handling */ - + virtual MsgId logMessage(Message msg); - virtual QList requestMsgs(UserId user, BufferId bufferId, int lastmsgs = -1, int offset = -1); - virtual QList requestMsgs(UserId user, BufferId bufferId, QDateTime since, int offset = -1); - virtual QList requestMsgRange(UserId user, BufferId bufferId, int first, int last); + virtual QList requestMsgs(UserId user, BufferId bufferId, MsgId first = -1, MsgId last = -1, int limit = -1); + virtual QList requestAllMsgs(UserId user, MsgId first = -1, MsgId last = -1, int limit = -1); protected: inline virtual QString driverName() { return "QSQLITE"; } inline virtual QString databaseName() { return backlogFile(); } virtual int installedSchemaVersion(); - + bool safeExec(QSqlQuery &query, int retryCount = 0); + 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); + + static int _maxRetryCount; }; #endif