X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.h;h=944c46b4c8fcb416f44cc6f90f9452356499d162;hp=adaabe7c10c3a4d9aa785ea7a0ae89bdf2405a4e;hb=4ed404c7a72dd21bb06b003274ae544ab5ca1ad7;hpb=23ebdc0a422294764ff3be3f8d7e56cc2b323185 diff --git a/src/core/sqlitestorage.h b/src/core/sqlitestorage.h index adaabe7c..944c46b4 100644 --- a/src/core/sqlitestorage.h +++ b/src/core/sqlitestorage.h @@ -33,13 +33,14 @@ class SqliteStorage : public AbstractSqlStorage { public: SqliteStorage(QObject *parent = 0); virtual ~SqliteStorage(); - + public slots: /* General */ - static bool isAvailable(); - static QString displayName(); - virtual QString engineName() ; + 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 */ @@ -51,11 +52,19 @@ public slots: virtual void delUser(UserId user); /* Network handling */ - virtual NetworkId createNetworkId(UserId user, const NetworkInfo &info); + virtual NetworkId createNetwork(UserId user, const NetworkInfo &info); + virtual bool updateNetwork(UserId user, const NetworkInfo &info); + virtual bool removeNetwork(UserId user, const NetworkId &networkId); + virtual QList networks(UserId user); /* Buffer handling */ - virtual BufferInfo getBufferInfo(UserId user, const NetworkId &networkId, const QString &buffer = ""); + virtual BufferInfo getBufferInfo(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer = ""); + virtual BufferInfo getBufferInfo(UserId user, const BufferId &bufferId); virtual QList requestBuffers(UserId user, QDateTime since = QDateTime()); + virtual bool removeBuffer(const UserId &user, const BufferId &bufferId); + virtual BufferId renameBuffer(const UserId &user, const NetworkId &networkId, const QString &newName, const QString &oldName); + virtual void setBufferLastSeen(UserId user, const BufferId &bufferId, const QDateTime &seenDate); + virtual QHash bufferLastSeenDates(UserId user); /* Message handling */ @@ -68,11 +77,15 @@ protected: inline virtual QString driverName() { return "QSQLITE"; } inline virtual QString databaseName() { return backlogFile(); } virtual int installedSchemaVersion(); + + virtual bool init(const QVariantMap &settings = QVariantMap()); // only needed for migration 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, const QString &buffer); + void createBuffer(UserId user, const NetworkId &networkId, BufferInfo::Type type, const QString &buffer); }; #endif