f0f3a855e3a5fd173eaed85bc1d6a1f3f1032fb0
[quassel.git] / network / 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 #error "obsolete code"
22
23 #ifndef _SERVER_H_
24 #define _SERVER_H_
25
26 #include <QtCore>
27 #include <QTimer>
28 #include <QtNetwork>
29
30 #include "global.h"
31 #include "buffer.h"
32 #include "message.h"
33
34 #define DEFAULT_PORT 6667
35
36
37 /*!
38  * This is a server object, managing a single connection to an IRC server, handling the associated channels and so on.
39  * We have this running in its own thread mainly to not block other server objects or the core if something goes wrong,
40  * e.g. if some scripts starts running wild...
41  */
42
43 class Server : public QThread {
44   Q_OBJECT
45
46   public:
47     Server(QString network);
48     ~Server();
49
50     // serverState state();
51     bool isConnected() { return socket.state() == QAbstractSocket::ConnectedState; }
52     QString getNetwork() { return network; }
53
54   public slots:
55     // void setServerOptions();
56     void connectToIrc(QString net);
57     void disconnectFromIrc(QString net);
58     void userInput(QString net, QString buffer, QString msg);
59
60     void putRawLine(QString input);
61     void putCmd(QString cmd, QStringList params, QString prefix = 0);
62
63     //void exitThread();
64
65   signals:
66     void recvRawServerMsg(QString);
67     void displayStatusMsg(QString);
68     void displayMsg(Message msg);
69     void disconnected();
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 handleUserVoice(QString, QString);
108
109     /* void handleServer(QString, QStringList); */
110     void handleServerJoin(QString, QStringList);
111     void handleServerKick(QString, QStringList);
112     void handleServerMode(QString, QStringList);
113     void handleServerNick(QString, QStringList);
114     void handleServerNotice(QString, QStringList);
115     void handleServerPart(QString, QStringList);
116     void handleServerPing(QString, QStringList);
117     void handleServerPrivmsg(QString, QStringList);
118     void handleServerQuit(QString, QStringList);
119
120     void handleServer001(QString, QStringList);   // RPL_WELCOME
121     void handleServer005(QString, QStringList);   // RPL_ISUPPORT
122     void handleServer331(QString, QStringList);   // RPL_NOTOPIC
123     void handleServer332(QString, QStringList);   // RPL_TOPIC
124     void handleServer333(QString, QStringList);   // Topic set by...
125     void handleServer353(QString, QStringList);   // RPL_NAMREPLY
126
127     void defaultServerHandler(QString cmd, QString prefix, QStringList params);
128     void defaultUserHandler(QString buf, QString cmd, QString msg);
129
130   private:
131     QString network;
132     QTcpSocket socket;
133     //QHash<QString, Buffer*> buffers;
134
135     QString currentNick;
136     QString currentServer;
137     VarMap networkSettings;
138     VarMap identity;
139     VarMap nicks;  // stores all known nicks for the server
140     VarMap serverSupports;  // stores results from RPL_ISUPPORT
141
142     void handleServerMsg(QString rawMsg);
143     void handleUserInput(QString buffer, QString usrMsg);
144
145     QString updateNickFromMask(QString mask);
146
147     class ParseError : public Exception {
148       public:
149         ParseError(QString cmd, QString prefix, QStringList params);
150     };
151
152     class UnknownCmdError : public Exception {
153       public:
154         UnknownCmdError(QString cmd, QString prefix, QStringList params);
155     };
156 };
157
158 #endif