1 /***************************************************************************
2 * Copyright (C) 2005-08 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
19 ***************************************************************************/
21 #ifndef _CORESESSION_H_
22 #define _CORESESSION_H_
30 class NetworkConnection; // FIXME get rid of
37 class CoreSession : public QObject {
41 CoreSession(UserId, bool restoreState, QObject *parent = 0);
44 QList<BufferInfo> buffers() const;
46 Network *network(NetworkId) const;
47 NetworkConnection *networkConnection(NetworkId) const;
48 Identity *identity(IdentityId) const;
50 QVariant sessionState();
52 //! Retrieve a piece of session-wide data.
53 QVariant retrieveSessionData(const QString &key, const QVariant &def = QVariant());
55 SignalProxy *signalProxy() const;
57 void attachNetworkConnection(NetworkConnection *conn);
59 //! Return necessary data for restoring the session after restarting the core
60 void saveSessionState() const;
61 void restoreSessionState();
64 //! Store a piece session-wide data and distribute it to connected clients.
65 void storeSessionData(const QString &key, const QVariant &data);
67 void networkStateRequested();
69 void addClient(QObject *socket);
71 void connectToNetwork(QString, const QVariant &previousState = QVariant());
72 void connectToNetwork(NetworkId, const QVariant &previousState = QVariant());
73 void disconnectFromNetwork(NetworkId id);
75 //void processSignal(ClientSignal, QVariant, QVariant, QVariant);
76 void sendBacklog(BufferInfo, QVariant, QVariant);
77 void msgFromClient(BufferInfo, QString message);
79 //! Create an identity and propagate the changes to the clients.
80 /** \param identity The identity to be created.
82 void createIdentity(const Identity &identity);
84 //! Update an identity and propagate the changes to the clients.
85 /** \param identity The identity to be updated.
87 void updateIdentity(const Identity &identity);
89 //! Remove identity and propagate that fact to the clients.
90 /** \param identity The identity to be removed.
92 void removeIdentity(IdentityId identity);
94 //! Create a network and propagate the changes to the clients.
95 /** \param info The network's settings.
97 void createNetwork(const NetworkInfo &info, bool useId = false);
99 //! Update a network and propagate the changes to the clients.
100 /** \param info The updated network settings.
102 void updateNetwork(const NetworkInfo &info);
104 //! Remove identity and propagate that fact to the clients.
105 /** \param identity The identity to be removed.
107 void removeNetwork(NetworkId network);
112 //void msgFromGui(uint netid, QString buf, QString message);
113 void displayMsg(Message message);
114 void displayStatusMsg(QString, QString);
116 //void connectToIrc(QString net);
117 //void disconnectFromIrc(QString net);
119 void backlogData(BufferInfo, QVariantList, bool done);
121 void bufferInfoUpdated(BufferInfo);
122 void sessionDataChanged(const QString &key);
123 void sessionDataChanged(const QString &key, const QVariant &data);
125 void scriptResult(QString result);
127 //! Identity has been created.
128 /** This signal is propagated to the clients to tell them that the given identity has been created.
129 * \param identity The new identity.
131 void identityCreated(const Identity &identity);
133 //! Identity has been removed.
134 /** This signal is propagated to the clients to inform them about the removal of the given identity.
135 * \param identity The identity that has been removed.
137 void identityRemoved(IdentityId identity);
139 void networkCreated(NetworkId);
140 void networkRemoved(NetworkId);
143 void recvStatusMsgFromServer(QString msg);
144 void recvMessageFromServer(Message::Type, QString target, QString text, QString sender = "", quint8 flags = Message::None);
145 void networkConnected(NetworkId networkid);
146 void networkDisconnected(NetworkId networkid);
148 //! Called when storage updated a BufferInfo.
149 /** This emits bufferInfoUpdated() via SignalProxy, iff it's one of our buffers.
150 * \param user The buffer's owner (not necessarily us)
151 * \param bufferInfo The updated BufferInfo
153 void updateBufferInfo(UserId user, const BufferInfo &bufferInfo);
155 void scriptRequest(QString script);
159 void initScriptEngine();
163 SignalProxy *_signalProxy;
164 QHash<NetworkId, NetworkConnection *> _connections;
165 QHash<NetworkId, Network *> _networks;
166 QHash<IdentityId, Identity *> _identities;
168 QVariantMap sessionData;
170 QScriptEngine *scriptEngine;