X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=core%2Fcore.h;h=c4a66465a997959fe07072a8107adb6c54ccce16;hp=96cba3a00924f95a35aa81d7663385dd7ef571ea;hb=b27b03c4239150189b7ae8963ca2e8c9b1a0ce4a;hpb=31d998779868a1b572972168b2e813893d70ab90 diff --git a/core/core.h b/core/core.h index 96cba3a0..c4a66465 100644 --- a/core/core.h +++ b/core/core.h @@ -21,38 +21,148 @@ #ifndef _CORE_H_ #define _CORE_H_ -#include #include #include +#include #include "server.h" +#include "storage.h" +#include "global.h" +#include "coreproxy.h" + +class CoreSession; class Core : public QObject { Q_OBJECT public: + static Core * instance(); + static void destroy(); + + static CoreSession * session(UserId); + static CoreSession * guiSession(); + static CoreSession * createSession(UserId); + + private slots: + void recvProxySignal(CoreSignal, QVariant, QVariant, QVariant); + bool startListening(uint port = 4242); + void stopListening(); + void incomingConnection(); + void clientHasData(); + void clientDisconnected(); + void updateGlobalData(UserId, QString); + private: Core(); + ~Core(); void init(); - VarMap loadNetworks(); - void storeNetworks(VarMap); - VarMap loadIdentities(); - void storeIdentities(VarMap); + static Core *instanceptr; + + void processClientInit(QTcpSocket *socket, const QVariant &v); + void processClientUpdate(QTcpSocket *socket, QString key, const QVariant &data); + + UserId guiUser; + QHash sessions; + Storage *storage; + + QTcpServer server; // TODO: implement SSL + QHash validClients; + QHash blockSizes; +}; + +class CoreSession : public QObject { + Q_OBJECT + + public: + CoreSession(UserId, Storage *); + ~CoreSession(); + + QList buffers() const; + inline UserId userId(); + QVariant sessionState(); + CoreProxy *proxy(); public slots: - void inputLine(QString); // temp - void connectToIrc(const QString &, quint16 port = 6667); + void connectToIrc(QStringList); + void processSignal(GUISignal, QVariant, QVariant, QVariant); + void sendBacklog(BufferId, QVariant, QVariant); + void msgFromGui(BufferId, QString message); + void sendServerStates(); signals: - void outputLine(const QString &); // temp + 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); + + void connectToIrc(QString net); + void disconnectFromIrc(QString net); + void serverStateRequested(); + + void backlogData(BufferId, QList, bool done); + + void bufferIdUpdated(BufferId); + + 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: - //void run(); + CoreProxy *coreProxy; + Storage *storage; + QHash servers; + UserId user; - Server server; // temp +}; + +/* +class Core : public QObject { + Q_OBJECT + + public: + + Core(); + ~Core(); + QList getBuffers(); + + public slots: + void connectToIrc(QStringList); + void sendBacklog(BufferId, QVariant, QVariant); + void msgFromGUI(BufferId, QString message); + + signals: + void msgFromGUI(QString net, QString buf, QString message); + void displayMsg(Message message); + void displayStatusMsg(QString, QString); + + void connectToIrc(QString net); + void disconnectFromIrc(QString net); + void serverStateRequested(); + + void backlogData(BufferId, QList, bool done); + + void bufferIdUpdated(BufferId); + + private slots: + void globalDataUpdated(QString); + void recvStatusMsgFromServer(QString msg); + void recvMessageFromServer(Message::Type, QString target, QString text, QString sender = "", quint8 flags = Message::None); + void serverDisconnected(QString net); + + private: + Storage *storage; + QHash servers; + UserId user; }; -extern Core *core; +*/ +//extern Core *core; + #endif