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 ***************************************************************************/
27 #include "corecoreinfo.h"
28 #include "corealiasmanager.h"
32 class CoreBacklogManager;
33 class CoreBufferViewManager;
34 class CoreIrcListHelper;
36 class NetworkConnection;
43 class CoreSession : public QObject {
47 CoreSession(UserId, bool restoreState, QObject *parent = 0);
50 QList<BufferInfo> buffers() const;
52 CoreNetwork *network(NetworkId) const;
53 NetworkConnection *networkConnection(NetworkId) const;
54 Identity *identity(IdentityId) const;
56 QVariant sessionState();
58 SignalProxy *signalProxy() const;
60 const AliasManager &aliasManager() const { return _aliasManager; }
61 AliasManager &aliasManager() { return _aliasManager; }
63 inline CoreIrcListHelper *ircListHelper() const { return _ircListHelper; }
65 void attachNetworkConnection(NetworkConnection *conn);
67 //! Return necessary data for restoring the session after restarting the core
68 void saveSessionState() const;
69 void restoreSessionState();
72 void networkStateRequested();
74 void addClient(QObject *socket);
76 void connectToNetwork(NetworkId);
77 void disconnectFromNetwork(NetworkId id);
79 void msgFromClient(BufferInfo, QString message);
81 //! Create an identity and propagate the changes to the clients.
82 /** \param identity The identity to be created.
84 void createIdentity(const Identity &identity);
86 //! Remove identity and propagate that fact to the clients.
87 /** \param identity The identity to be removed.
89 void removeIdentity(IdentityId identity);
91 //! Create a network and propagate the changes to the clients.
92 /** \param info The network's settings.
94 void createNetwork(const NetworkInfo &info);
96 //! Update a network and propagate the changes to the clients.
97 /** \param info The updated network settings.
99 void updateNetwork(const NetworkInfo &info);
101 //! Remove identity and propagate that fact to the clients.
102 /** \param identity The identity to be removed.
104 void removeNetwork(NetworkId network);
106 //! Remove a buffer and it's backlog permanently
107 /** \param bufferId The id of the buffer to be removed.
108 * emits bufferRemoved(bufferId) on success.
110 void removeBufferRequested(BufferId bufferId);
112 //! Rename a Buffer for a given network
113 /* \param networkId The id of the network the buffer belongs to
114 * \param newName The new name of the buffer
115 * \param oldName The old name of the buffer
116 * emits bufferRenamed(bufferId, newName) on success.
118 void renameBuffer(const NetworkId &networkId, const QString &newName, const QString &oldName);
120 void channelJoined(NetworkId id, const QString &channel, const QString &key = QString());
121 void channelParted(NetworkId, const QString &channel);
122 QHash<QString, QString> persistentChannels(NetworkId) const;
127 //void msgFromGui(uint netid, QString buf, QString message);
128 void displayMsg(Message message);
129 void displayStatusMsg(QString, QString);
131 //void connectToIrc(QString net);
132 //void disconnectFromIrc(QString net);
134 void bufferInfoUpdated(BufferInfo);
136 void scriptResult(QString result);
138 //! Identity has been created.
139 /** This signal is propagated to the clients to tell them that the given identity has been created.
140 * \param identity The new identity.
142 void identityCreated(const Identity &identity);
144 //! Identity has been removed.
145 /** This signal is propagated to the clients to inform them about the removal of the given identity.
146 * \param identity The identity that has been removed.
148 void identityRemoved(IdentityId identity);
150 void networkCreated(NetworkId);
151 void networkRemoved(NetworkId);
152 void bufferRemoved(BufferId);
153 void bufferRenamed(BufferId, QString);
156 void removeClient(QIODevice *dev);
158 void recvStatusMsgFromServer(QString msg);
159 void recvMessageFromServer(Message::Type, BufferInfo::Type, QString target, QString text, QString sender = "", Message::Flags flags = Message::None);
160 void networkConnected(NetworkId networkid);
161 void networkDisconnected(NetworkId networkid);
163 void destroyNetwork(NetworkId);
165 void identityUpdated(const QVariantMap &);
166 //void networkUpdated(const QVariantMap &);
168 //! Called when storage updated a BufferInfo.
169 /** This emits bufferInfoUpdated() via SignalProxy, iff it's one of our buffers.
170 * \param user The buffer's owner (not necessarily us)
171 * \param bufferInfo The updated BufferInfo
173 void updateBufferInfo(UserId user, const BufferInfo &bufferInfo);
175 void storeBufferLastSeenMsg(BufferId buffer, const MsgId &msgId);
177 void scriptRequest(QString script);
181 void initScriptEngine();
185 SignalProxy *_signalProxy;
186 CoreAliasManager _aliasManager;
187 QHash<NetworkId, NetworkConnection *> _connections;
188 QHash<NetworkId, CoreNetwork *> _networks;
189 // QHash<NetworkId, CoreNetwork *> _networksToRemove;
190 QHash<IdentityId, Identity *> _identities;
192 BufferSyncer *_bufferSyncer;
193 CoreBacklogManager *_backlogManager;
194 CoreBufferViewManager *_bufferViewManager;
195 CoreIrcListHelper *_ircListHelper;
196 CoreCoreInfo _coreInfo;
198 QScriptEngine *scriptEngine;