Make --norestore work again
[quassel.git] / src / core / corenetwork.h
1 /***************************************************************************
2  *   Copyright (C) 2005-08 by the Quassel Project                          *
3  *   devel@quassel-irc.org                                                 *
4  *                                                                         *
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.                                           *
9  *                                                                         *
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.                          *
14  *                                                                         *
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  ***************************************************************************/
20
21 #ifndef CORENETWORK_H
22 #define CORENETWORK_H
23
24 #include "network.h"
25 #include "coreircchannel.h"
26
27 #include <QTimer>
28
29 #ifdef HAVE_SSL
30 # include <QSslSocket>
31 # include <QSslError>
32 #else
33 # include <QTcpSocket>
34 #endif
35
36 #include "coresession.h"
37
38 class CoreIdentity;
39 class IrcServerHandler;
40 class UserInputHandler;
41 class CtcpHandler;
42
43 class CoreNetwork : public Network {
44   Q_OBJECT
45
46 public:
47   CoreNetwork(const NetworkId &networkid, CoreSession *session);
48   ~CoreNetwork();
49   inline virtual const QMetaObject *syncMetaObject() const { return &Network::staticMetaObject; }
50
51   inline CoreIdentity *identityPtr() const { return coreSession()->identity(identity()); }
52   inline CoreSession *coreSession() const { return _coreSession; }
53
54   inline IrcServerHandler *ircServerHandler() const { return _ircServerHandler; }
55   inline UserInputHandler *userInputHandler() const { return _userInputHandler; }
56   inline CtcpHandler *ctcpHandler() const { return _ctcpHandler; }
57
58   //! Decode a string using the server (network) decoding.
59   inline QString serverDecode(const QByteArray &string) const { return decodeServerString(string); }
60
61   //! Decode a string using a channel-specific encoding if one is set (and use the standard encoding else).
62   QString channelDecode(const QString &channelName, const QByteArray &string) const;
63
64   //! Decode a string using an IrcUser-specific encoding, if one exists (using the standaed encoding else).
65   QString userDecode(const QString &userNick, const QByteArray &string) const;
66
67   //! Encode a string using the server (network) encoding.
68   inline QByteArray serverEncode(const QString &string) const { return encodeServerString(string); }
69
70   //! Encode a string using the channel-specific encoding, if set, and use the standard encoding else.
71   QByteArray channelEncode(const QString &channelName, const QString &string) const;
72
73   //! Encode a string using the user-specific encoding, if set, and use the standard encoding else.
74   QByteArray userEncode(const QString &userNick, const QString &string) const;
75
76   inline QString channelKey(const QString &channel) const { return _channelKeys.value(channel.toLower(), QString()); }
77   inline QStringList persistentChannels() const { return _channelKeys.keys(); }
78
79   inline bool isAutoWhoInProgress(const QString &channel) const { return _autoWhoInProgress.value(channel.toLower(), 0); }
80
81   inline UserId userId() const { return _coreSession->user(); }
82
83 public slots:
84   virtual void setMyNick(const QString &mynick);
85
86   virtual void requestConnect() const;
87   virtual void requestDisconnect() const;
88   virtual void requestSetNetworkInfo(const NetworkInfo &info);
89
90   virtual void setUseAutoReconnect(bool);
91   virtual void setAutoReconnectInterval(quint32);
92   virtual void setAutoReconnectRetries(quint16);
93
94   void connectToIrc(bool reconnecting = false);
95   void disconnectFromIrc(bool requested = true, const QString &reason = QString());
96
97   void userInput(BufferInfo bufferInfo, QString msg);
98   void putRawLine(QByteArray input);
99   void putCmd(const QString &cmd, const QList<QByteArray> &params, const QByteArray &prefix = QByteArray());
100
101   void setChannelJoined(const QString &channel);
102   void setChannelParted(const QString &channel);
103   void addChannelKey(const QString &channel, const QString &key);
104   void removeChannelKey(const QString &channel);
105
106   bool setAutoWhoDone(const QString &channel);
107
108   Server usedServer() const;
109
110 signals:
111   void recvRawServerMsg(QString);
112   void displayStatusMsg(QString);
113   void displayMsg(Message::Type, BufferInfo::Type, QString target, QString text, QString sender = "", Message::Flags flags = Message::None);
114   void disconnected(NetworkId networkId);
115   void connectionError(const QString &errorMsg);
116
117   void quitRequested(NetworkId networkId);
118   void sslErrors(const QVariant &errorData);
119
120 protected:
121   inline virtual IrcChannel *ircChannelFactory(const QString &channelname) { return new CoreIrcChannel(channelname, this); }
122
123 private slots:
124   void socketHasData();
125   void socketError(QAbstractSocket::SocketError);
126   void socketInitialized();
127   inline void socketCloseTimeout() { socket.disconnectFromHost(); }
128   void socketDisconnected();
129   void socketStateChanged(QAbstractSocket::SocketState);
130   void networkInitialized();
131
132   void sendPerform();
133   void doAutoReconnect();
134   void sendPing();
135   void sendAutoWho();
136   void startAutoWhoCycle();
137
138 #ifdef HAVE_SSL
139   void sslErrors(const QList<QSslError> &errors);
140 #endif
141
142   void fillBucketAndProcessQueue();
143
144   void writeToSocket(const QByteArray &data);
145
146 private:
147   CoreSession *_coreSession;
148
149 #ifdef HAVE_SSL
150   QSslSocket socket;
151 #else
152   QTcpSocket socket;
153 #endif
154
155   IrcServerHandler *_ircServerHandler;
156   UserInputHandler *_userInputHandler;
157   CtcpHandler *_ctcpHandler;
158
159   QHash<QString, QString> _channelKeys;  // stores persistent channels and their passwords, if any
160
161   QTimer _autoReconnectTimer;
162   int _autoReconnectCount;
163
164   QTimer _socketCloseTimer;
165
166   /* this flag triggers quitRequested() once the socket is closed
167    * it is needed to determine whether or not the connection needs to be
168    * in the automatic session restore. */
169   bool _quitRequested;
170
171   bool _previousConnectionAttemptFailed;
172   int _lastUsedServerIndex;
173
174   QTimer _pingTimer;
175
176   bool _autoWhoEnabled;
177   QStringList _autoWhoQueue;
178   QHash<QString, int> _autoWhoInProgress;
179   int _autoWhoInterval;
180   int _autoWhoNickLimit;
181   int _autoWhoDelay;
182   QTimer _autoWhoTimer, _autoWhoCycleTimer;
183
184   QTimer _tokenBucketTimer;
185   int _messagesPerSecond;   // token refill speed
186   int _burstSize;           // size of the token bucket
187   int _tokenBucket;         // the virtual bucket that holds the tokens
188   QList<QByteArray> _msgQueue;
189 };
190
191 #endif //CORENETWORK_H