X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fsqlitestorage.h;h=944c46b4c8fcb416f44cc6f90f9452356499d162;hp=3b27205d30bce319fb2e4f5aa05a23edaf8d7840;hb=4ed404c7a72dd21bb06b003274ae544ab5ca1ad7;hpb=4b41d8800c38aa3bc4e88a76289b45bc888ba088 diff --git a/src/core/sqlitestorage.h b/src/core/sqlitestorage.h index 3b27205d..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 uint getNetworkId(UserId user, const QString &network); + 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 QString &network, 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,13 +77,15 @@ protected: inline virtual QString driverName() { return "QSQLITE"; } inline virtual QString databaseName() { return backlogFile(); } virtual int installedSchemaVersion(); - -signals: - void bufferInfoUpdated(BufferInfo); + + virtual bool init(const QVariantMap &settings = QVariantMap()); // only needed for migration private: static QString backlogFile(); - void createBuffer(UserId user, const QString &network, const QString &buffer); + 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); }; #endif