-void Server::handleServerTopic(QString prefix, QStringList params) {
- QString nick = updateNickFromMask(prefix);
- Q_ASSERT(nicks.contains(nick));
- topics[params[0]] = params[1];
- emit topicSet(network, params[0], params[1]);
- emit displayMsg(Message::Server, params[0], tr("%1 has changed topic for %2 to: \"%3\"").arg(nick).arg(params[0]).arg(params[1]));
-}
-
-/* RPL_WELCOME */
-void Server::handleServer001(QString prefix, QStringList params) {
- // there should be only one param: "Welcome to the Internet Relay Network <nick>!<user>@<host>"
- currentServer = prefix;
- ownNick = params[0].section(' ', -1, -1).section('!', 0, 0);
- VarMap n;
- n["Channels"] = VarMap();
- nicks[ownNick] = n;
- emit ownNickSet(network, ownNick);
- emit nickAdded(network, ownNick, VarMap());
- emit displayMsg(Message::Server, "", params[0], prefix);
- // send performlist
- QStringList performList = networkSettings["Perform"].toString().split( "\n" );
- int count = performList.count();
- for(int a = 0; a < count; a++) {
- if(!performList[a].isEmpty() ) {
- userInput(network, "", performList[a]);
- }
- }
-}
-
-/* RPL_ISUPPORT */
-// TODO Complete 005 handling, also use sensible defaults for non-sent stuff
-void Server::handleServer005(QString prefix, QStringList params) {
- //qDebug() << prefix << params;
- params.removeLast();
- foreach(QString p, params) {
- QString key = p.section("=", 0, 0);
- QString val = p.section("=", 1);
- serverSupports[key] = val;
- // handle some special cases
- if(key == "PREFIX") {
- VarMap foo; QString modes, prefixes;
- Q_ASSERT(val.contains(')') && val.startsWith('('));
- int m = 1, p;
- for(p = 2; p < val.length(); p++) if(val[p] == ')') break;
- p++;
- for(; val[m] != ')'; m++, p++) {
- Q_ASSERT(p < val.length());
- foo[QString(val[m])] = QString(val[p]);
- modes += val[m]; prefixes += val[p];
- }
- serverSupports["PrefixModes"] = modes; serverSupports["Prefixes"] = prefixes;
- serverSupports["ModePrefixMap"] = foo;
- }
- }
-}
-
-
-/* RPL_NOTOPIC */
-void Server::handleServer331(QString prefix, QStringList params) {
- topics[params[0]] = "";
- emit topicSet(network, params[0], "");
- emit displayMsg(Message::Server, params[0], tr("No topic is set for %1.").arg(params[0]));
-}
-
-/* RPL_TOPIC */
-void Server::handleServer332(QString prefix, QStringList params) {
- topics[params[0]] = params[1];
- emit topicSet(network, params[0], params[1]);
- emit displayMsg(Message::Server, params[0], tr("Topic for %1 is \"%2\"").arg(params[0]).arg(params[1]));
-}
-
-/* Topic set by... */
-void Server::handleServer333(QString prefix, QStringList params) {
- emit displayMsg(Message::Server, params[0],
- tr("Topic set by %1 on %2").arg(params[1]).arg(QDateTime::fromTime_t(params[2].toUInt()).toString()));
-}
-
-/* RPL_NAMREPLY */
-void Server::handleServer353(QString prefix, QStringList params) {
- params.removeFirst(); // = or *
- QString buf = params.takeFirst();
- QString prefixes = serverSupports["Prefixes"].toString();
- foreach(QString nick, params[0].split(' ')) {
- QString mode = "", pfx = "";
- if(prefixes.contains(nick[0])) {
- pfx = nick[0];
- for(int i = 0;; i++)
- if(prefixes[i] == nick[0]) { mode = serverSupports["PrefixModes"].toString()[i]; break; }
- nick.remove(0,1);
- }
- VarMap c; c["Mode"] = mode; c["Prefix"] = pfx;
- if(nicks.contains(nick)) {
- VarMap n = nicks[nick];
- VarMap chans = n["Channels"].toMap();
- chans[buf] = c;
- n["Channels"] = chans;
- nicks[nick] = n;
- emit nickUpdated(network, nick, n);
- } else {
- VarMap n; VarMap c; VarMap chans;
- c["Mode"] = mode;
- chans[buf] = c;
- n["Channels"] = chans;
- nicks[nick] = n;
- emit nickAdded(network, nick, n);
- }
- }
-}
-
-/* ERR_ERRONEUSNICKNAME */
-void Server::handleServer432(QString prefix, QStringList params) {
- if(params.size() < 2) {
- // handle unreal-ircd bug, where unreal ircd doesnt supply a TARGET in ERR_ERRONEUSNICKNAME during registration phase:
- // nick @@@
- // :irc.scortum.moep.net 432 @@@ :Erroneous Nickname: Illegal characters
- // correct server reply:
- // :irc.scortum.moep.net 432 * @@@ :Erroneous Nickname: Illegal characters
- emit displayMsg(Message::Error, "", tr("There is a nickname in your identity's nicklist which contains illegal characters"));
- emit displayMsg(Message::Error, "", tr("Due to a bug in Unreal IRCd (and maybe other irc-servers too) we're unable to determine the erroneous nick"));
- emit displayMsg(Message::Error, "", tr("Please use: /nick <othernick> to continue or clean up your nicklist"));
- } else {
- QString errnick = params[0];
- emit displayMsg(Message::Error, "", tr("Nick %1 contains illegal characters").arg(errnick));
- // if there is a problem while connecting to the server -> we handle it
- // TODO rely on another source...
- if(currentServer.isEmpty()) {
- QStringList desiredNicks = identity["NickList"].toStringList();
- int nextNick = desiredNicks.indexOf(errnick) + 1;
- if (desiredNicks.size() > nextNick) {
- putCmd("NICK", QStringList(desiredNicks[nextNick]));
- } else {
- emit displayMsg(Message::Error, "", tr("No free and valid nicks in nicklist found. use: /nick <othernick> to continue"));
- }
- }
- }
-}
-
-/* ERR_NICKNAMEINUSE */
-void Server::handleServer433(QString prefix, QStringList params) {
- QString errnick = params[0];
- emit displayMsg(Message::Error, "", tr("Nick %1 is already taken").arg(errnick));
- // if there is a problem while connecting to the server -> we handle it
- // TODO rely on another source...
- if(currentServer.isEmpty()) {
- QStringList desiredNicks = identity["NickList"].toStringList();
- int nextNick = desiredNicks.indexOf(errnick) + 1;
- if (desiredNicks.size() > nextNick) {
- putCmd("NICK", QStringList(desiredNicks[nextNick]));
- } else {
- emit displayMsg(Message::Error, "", tr("No free and valid nicks in nicklist found. use: /nick <othernick> to continue"));
- }
- }
-}
-
-/***********************************************************************************/
-// CTCP HANDLER
-
-void Server::handleCtcpAction(CtcpType ctcptype, QString prefix, QString target, QString param) {
- emit displayMsg(Message::Action, target, param, prefix);
-}
-
-void Server::handleCtcpPing(CtcpType ctcptype, QString prefix, QString target, QString param) {
- if(ctcptype == CtcpQuery) {
- ctcpReply(nickFromMask(prefix), "PING", param);
- emit displayMsg(Message::Server, "", tr("Received CTCP PING request by %1").arg(prefix));
- } else {
- // display ping answer
- }
-}
-
-void Server::handleCtcpVersion(CtcpType ctcptype, QString prefix, QString target, QString param) {
- if(ctcptype == CtcpQuery) {
- // FIXME use real Info about quassel :)
- //ctcpReply(nickFromMask(prefix), "VERSION", QString("Quassel:pre Release:*nix"));
- ctcpReply(nickFromMask(prefix), "VERSION", QString("Quassel IRC (Pre-Release) - http://www.quassel-irc.org"));
- emit displayMsg(Message::Server, "", tr("Received CTCP VERSION request by %1").arg(prefix));
- } else {
- // TODO display Version answer
- }
-}
-
-void Server::defaultCtcpHandler(CtcpType ctcptype, QString prefix, QString cmd, QString target, QString param) {
- emit displayMsg(Message::Error, "", tr("Received unknown CTCP %1 by %2").arg(cmd).arg(prefix));
-}
-
-
-/***********************************************************************************/
-