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_
31 class NetworkConnection;
38 class CoreSession : public QObject {
42 CoreSession(UserId, bool restoreState, QObject *parent = 0);
45 QList<BufferInfo> buffers() const;
47 Network *network(NetworkId) const;
48 NetworkConnection *networkConnection(NetworkId) const;
49 Identity *identity(IdentityId) const;
51 QVariant sessionState();
53 SignalProxy *signalProxy() const;
55 void attachNetworkConnection(NetworkConnection *conn);
57 //! Return necessary data for restoring the session after restarting the core
58 void saveSessionState() const;
59 void restoreSessionState();
62 void networkStateRequested();
64 void addClient(QObject *socket);
66 void connectToNetwork(NetworkId);
67 void disconnectFromNetwork(NetworkId id);
69 void sendBacklog(BufferInfo, QVariant, QVariant);
70 void msgFromClient(BufferInfo, QString message);
72 //! Create an identity and propagate the changes to the clients.
73 /** \param identity The identity to be created.
75 void createIdentity(const Identity &identity);
77 //! Update an identity and propagate the changes to the clients.
78 /** \param identity The identity to be updated.
80 void updateIdentity(const Identity &identity);
82 //! Remove identity and propagate that fact to the clients.
83 /** \param identity The identity to be removed.
85 void removeIdentity(IdentityId identity);
87 //! Create a network and propagate the changes to the clients.
88 /** \param info The network's settings.
90 void createNetwork(const NetworkInfo &info);
92 //! Update a network and propagate the changes to the clients.
93 /** \param info The updated network settings.
95 void updateNetwork(const NetworkInfo &info);
97 //! Remove identity and propagate that fact to the clients.
98 /** \param identity The identity to be removed.
100 void removeNetwork(NetworkId network);
102 //! Remove a buffer and it's backlog permanently
103 /** \param bufferId The id of the buffer to be removed.
104 * emits bufferRemoved(bufferId) on success.
106 void removeBufferRequested(BufferId bufferId);
108 //! Rename a Buffer for a given network
109 /* \param networkId The id of the network the buffer belongs to
110 * \param newName The new name of the buffer
111 * \param oldName The old name of the buffer
112 * emits bufferRenamed(bufferId, newName) on success.
114 void renameBuffer(const NetworkId &networkId, const QString &newName, const QString &oldName);
116 void channelJoined(NetworkId id, const QString &channel, const QString &key = QString());
117 void channelParted(NetworkId, const QString &channel);
118 QHash<QString, QString> persistentChannels(NetworkId) const;
123 //void msgFromGui(uint netid, QString buf, QString message);
124 void displayMsg(Message message);
125 void displayStatusMsg(QString, QString);
127 //void connectToIrc(QString net);
128 //void disconnectFromIrc(QString net);
130 void backlogData(BufferInfo, QVariantList, bool done);
132 void bufferInfoUpdated(BufferInfo);
134 void scriptResult(QString result);
136 //! Identity has been created.
137 /** This signal is propagated to the clients to tell them that the given identity has been created.
138 * \param identity The new identity.
140 void identityCreated(const Identity &identity);
142 //! Identity has been removed.
143 /** This signal is propagated to the clients to inform them about the removal of the given identity.
144 * \param identity The identity that has been removed.
146 void identityRemoved(IdentityId identity);
148 void networkCreated(NetworkId);
149 void networkRemoved(NetworkId);
150 void bufferRemoved(BufferId);
151 void bufferRenamed(BufferId, QString);
154 void recvStatusMsgFromServer(QString msg);
155 void recvMessageFromServer(Message::Type, BufferInfo::Type, QString target, QString text, QString sender = "", quint8 flags = Message::None);
156 void networkConnected(NetworkId networkid);
157 void networkDisconnected(NetworkId networkid);
159 void destroyNetwork(NetworkId);
161 //! Called when storage updated a BufferInfo.
162 /** This emits bufferInfoUpdated() via SignalProxy, iff it's one of our buffers.
163 * \param user The buffer's owner (not necessarily us)
164 * \param bufferInfo The updated BufferInfo
166 void updateBufferInfo(UserId user, const BufferInfo &bufferInfo);
168 void storeBufferLastSeen(BufferId buffer, const QDateTime &lastSeen);
170 void scriptRequest(QString script);
174 void initScriptEngine();
178 SignalProxy *_signalProxy;
179 QHash<NetworkId, NetworkConnection *> _connections;
180 QHash<NetworkId, Network *> _networks;
181 QHash<NetworkId, Network *> _networksToRemove;
182 QHash<IdentityId, Identity *> _identities;
184 BufferSyncer *_bufferSyncer;
186 QScriptEngine *scriptEngine;