X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fcoresession.h;h=66e273546bc20f838947ff1ffb744d2c18321696;hp=24d3d8d049251c902aca66520fad2b39371ce479;hb=c7ad7451b1e899ba0de2ded9ac08359dff5cca61;hpb=0ac9ce4d7cf768d13993d6aa1d6b791c4149a843 diff --git a/src/core/coresession.h b/src/core/coresession.h index 24d3d8d0..66e27354 100644 --- a/src/core/coresession.h +++ b/src/core/coresession.h @@ -25,33 +25,43 @@ #include #include -#include "coreproxy.h" +#include "message.h" class Server; +class SignalProxy; class Storage; class CoreSession : public QObject { Q_OBJECT public: - CoreSession(UserId, Storage *); + CoreSession(UserId, Storage *, QObject *parent = 0); ~CoreSession(); QList buffers() const; UserId userId() const; QVariant sessionState(); - CoreProxy *proxy(); public slots: - void connectToIrc(QStringList); - void processSignal(ClientSignal, QVariant, QVariant, QVariant); + //! Store a piece session-wide data and distribute it to connected clients. + void storeSessionData(const QString &key, const QVariant &data); + + void addClient(QIODevice *connection); + + public: + //! Retrieve a piece of session-wide data. + QVariant retrieveSessionData(const QString &key, const QVariant &def = QVariant()); + + SignalProxy *signalProxy() const; + + public slots: + void connectToNetwork(QString); + //void processSignal(ClientSignal, QVariant, QVariant, QVariant); void sendBacklog(BufferId, QVariant, QVariant); void msgFromGui(BufferId, QString message); void sendServerStates(); signals: - void proxySignal(CoreSignal, QVariant arg1 = QVariant(), QVariant arg2 = QVariant(), QVariant arg3 = QVariant()); - void msgFromGui(QString net, QString buf, QString message); void displayMsg(Message message); void displayStatusMsg(QString, QString); @@ -60,24 +70,27 @@ class CoreSession : public QObject { void disconnectFromIrc(QString net); void serverStateRequested(); - void backlogData(BufferId, QList, bool done); + void backlogData(BufferId, QVariantList, bool done); void bufferIdUpdated(BufferId); + void sessionDataChanged(const QString &key); + void sessionDataChanged(const QString &key, const QVariant &data); private slots: - //void recvProxySignal(CoreSignal, QVariant arg1 = QVariant(), QVariant arg2 = QVariant(), QVariant arg3 = QVariant()); - void globalDataUpdated(UserId, QString); void recvStatusMsgFromServer(QString msg); void recvMessageFromServer(Message::Type, QString target, QString text, QString sender = "", quint8 flags = Message::None); void serverConnected(QString net); void serverDisconnected(QString net); private: - CoreProxy *coreProxy; + UserId user; + + SignalProxy *_signalProxy; Storage *storage; QHash servers; - UserId user; + QVariantMap sessionData; + QMutex mutex; }; #endif