ba333d39b0514c77e3ac9739deb9e15e7e7a4839
[quassel.git] / core / server.h
1 /***************************************************************************
2  *   Copyright (C) 2005/06 by The Quassel Team                             *
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) any later version.                                   *
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 _SERVER_H_
22 #define _SERVER_H_
23
24 #include <QtCore>
25 #include <QTimer>
26 #include <QtNetwork>
27
28 #include "global.h"
29 #include "message.h"
30
31 #define DEFAULT_PORT 6667
32
33
34 /*!
35  * This is a server object, managing a single connection to an IRC server, handling the associated channels and so on.
36  * We have this running in its own thread mainly to not block other server objects or the core if something goes wrong,
37  * e.g. if some scripts starts running wild...
38  */
39
40 class Server : public QThread {
41   Q_OBJECT
42
43   public:
44     Server(QString network);
45     ~Server();
46
47     // serverState state();
48     bool isConnected() { return socket.state() == QAbstractSocket::ConnectedState; }
49     QString getNetwork() { return network; }
50
51   public slots:
52     // void setServerOptions();
53     void sendState();
54     void connectToIrc(QString net);
55     void disconnectFromIrc(QString net);
56     void userInput(QString net, QString buffer, QString msg);
57
58     void putRawLine(QString input);
59     void putCmd(QString cmd, QStringList params, QString prefix = 0);
60
61     //void exitThread();
62
63   signals:
64     void serverState(QString net, VarMap data);
65     void recvRawServerMsg(QString);
66     void displayStatusMsg(QString);
67     void displayMsg(Message msg);
68     void connected(QString network);
69     void disconnected(QString network);
70
71     void nickAdded(QString network, QString nick, VarMap props);
72     void nickRenamed(QString network, QString oldnick, QString newnick);
73     void nickRemoved(QString network, QString nick);
74     void nickUpdated(QString network, QString nick, VarMap props);
75     void modeSet(QString network, QString target, QString mode);
76     void topicSet(QString network, QString buffer, QString topic);
77     void setNicks(QString network, QString buffer, QStringList nicks);
78     void ownNickSet(QString network, QString newNick);
79
80
81   private slots:
82     void run();
83     void socketHasData();
84     void socketError(QAbstractSocket::SocketError);
85     void socketConnected();
86     void socketDisconnected();
87     void socketStateChanged(QAbstractSocket::SocketState);
88
89     /* Message Handlers */
90
91     /* void handleUser(QString, QString); */
92     void handleUserAway(QString, QString);
93     void handleUserDeop(QString, QString);
94     void handleUserDevoice(QString, QString);
95     void handleUserInvite(QString, QString);
96     void handleUserJoin(QString, QString);
97     void handleUserKick(QString, QString);
98     void handleUserList(QString, QString);
99     void handleUserMode(QString, QString);
100     void handleUserMsg(QString, QString);
101     void handleUserNick(QString, QString);
102     void handleUserOp(QString, QString);
103     void handleUserPart(QString, QString);
104     void handleUserQuit(QString, QString);
105     void handleUserQuote(QString, QString);
106     void handleUserSay(QString, QString);
107     void handleUserTopic(QString, QString);
108     void handleUserVoice(QString, QString);
109
110     /* void handleServer(QString, QStringList); */
111     void handleServerJoin(QString, QStringList);
112     void handleServerKick(QString, QStringList);
113     void handleServerMode(QString, QStringList);
114     void handleServerNick(QString, QStringList);
115     void handleServerNotice(QString, QStringList);
116     void handleServerPart(QString, QStringList);
117     void handleServerPing(QString, QStringList);
118     void handleServerPrivmsg(QString, QStringList);
119     void handleServerQuit(QString, QStringList);
120     void handleServerTopic(QString, QStringList);
121
122     void handleServer001(QString, QStringList);   // RPL_WELCOME
123     void handleServer005(QString, QStringList);   // RPL_ISUPPORT
124     void handleServer331(QString, QStringList);   // RPL_NOTOPIC
125     void handleServer332(QString, QStringList);   // RPL_TOPIC
126     void handleServer333(QString, QStringList);   // Topic set by...
127     void handleServer353(QString, QStringList);   // RPL_NAMREPLY
128
129     void defaultServerHandler(QString cmd, QString prefix, QStringList params);
130     void defaultUserHandler(QString buf, QString cmd, QString msg);
131
132   private:
133     QString network;
134     QTcpSocket socket;
135     //QHash<QString, Buffer*> buffers;
136
137     QString ownNick;
138     QString currentServer;
139     VarMap networkSettings;
140     VarMap identity;
141     QHash<QString, VarMap> nicks;  // stores all known nicks for the server
142     QHash<QString, QString> topics; // stores topics for each buffer
143     VarMap serverSupports;  // stores results from RPL_ISUPPORT
144
145     void handleServerMsg(QString rawMsg);
146     void handleUserInput(QString buffer, QString usrMsg);
147
148     QString updateNickFromMask(QString mask);
149
150     class ParseError : public Exception {
151       public:
152         ParseError(QString cmd, QString prefix, QStringList params);
153     };
154
155     class UnknownCmdError : public Exception {
156       public:
157         UnknownCmdError(QString cmd, QString prefix, QStringList params);
158     };
159 };
160
161 #endif