X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcore%2Fcore.h;h=119189574fceddc6303ba87b4cf70f8c958e0455;hb=0d3d7a861472313710b51c8d19e81af56e2208a1;hp=5a125a4f0f25585c341530b035385c2978863cd2;hpb=9204e98848ab202c0117aa1428fa0ea10b4dcd75;p=quassel.git diff --git a/src/core/core.h b/src/core/core.h index 5a125a4f..11918957 100644 --- a/src/core/core.h +++ b/src/core/core.h @@ -59,6 +59,24 @@ class Core : public QObject { /*** Storage access ***/ // These methods are threadsafe. + //! Store a user setting persistently + /** + * \param userId The users Id + * \param settingName The Name of the Setting + * \param data The Value + */ + static void setUserSetting(UserId userId, const QString &settingName, const QVariant &data); + + //! Retrieve a persistent user setting + /** + * \param userId The users Id + * \param settingName The Name of the Setting + * \param default Value to return in case it's unset. + * \return the Value of the Setting or the default value if it is unset. + */ + static QVariant getUserSetting(UserId userId, const QString &settingName, const QVariant &data = QVariant()); + + //! Create a Network in the Storage and store it's Id in the given NetworkInfo /** \note This method is thredsafe. * @@ -216,6 +234,16 @@ class Core : public QObject { */ static QList requestBuffers(UserId user); + + //! Request a list of BufferIds for a given NetworkId + /** \note This method is threadsafe. + * + * \param user The user whose buffers we request + * \param networkId The NetworkId of the network in question + * \return List of BufferIds belonging to the Network + */ + static QList requestBufferIdsForNetwork(UserId user, NetworkId networkId); + //! Remove permanently a buffer and it's content from the storage backend /** This call cannot be reverted! * \note This method is threadsafe. @@ -254,6 +282,8 @@ class Core : public QObject { */ static QHash bufferLastSeenMsgIds(UserId user); + const QDateTime &startTime() const { return _startTime; } + public slots: //! Make storage data persistent /** \note This method is threadsafe. @@ -265,7 +295,7 @@ class Core : public QObject { void bufferInfoUpdated(UserId user, const BufferInfo &info); private slots: - bool startListening(uint port = Global::defaultPort); + bool startListening(uint port = Global::parser.value("port").toUInt()); void stopListening(); void incomingConnection(); void clientHasData(); @@ -308,7 +338,7 @@ class Core : public QObject { QHash _storageBackends; - QDateTime startTime; + QDateTime _startTime; bool configured;