-void Server::handleServerMode(QString prefix, QStringList params) {
- if(isChannelName(params[0])) {
- // TODO only channel-user modes supported by now
- QString prefixes = serverSupports["PrefixModes"].toString();
- QString modes = params[1];
- int p = 2;
- int m = 0;
- bool add = true;
- while(m < modes.length()) {
- if(modes[m] == '+') { add = true; m++; continue; }
- if(modes[m] == '-') { add = false; m++; continue; }
- if(prefixes.contains(modes[m])) { // it's a user channel mode
- Q_ASSERT(params.count() > m);
- QString nick = params[p++];
- if(nicks.contains(nick)) { // sometimes, a server might try to set a MODE on a nick that is no longer there
- VarMap n = nicks[nick]; VarMap clist = n["Channels"].toMap(); VarMap chan = clist[params[0]].toMap();
- QString mstr = chan["Mode"].toString();
- add ? mstr += modes[m] : mstr.remove(modes[m]);
- chan["Mode"] = mstr; clist[params[0]] = chan; n["Channels"] = clist; nicks[nick] = n;
- emit nickUpdated(network, nick, n);
- }
- m++;
- } else {
- // TODO add more modes
- m++;
- }
- }
- emit displayMsg(Message::Mode, params[0], params.join(" "), prefix);
- } else {
- //Q_ASSERT(nicks.contains(params[0]));
- //VarMap n = nicks[params[0]].toMap();
- //QString mode = n["Mode"].toString();
- emit displayMsg(Message::Mode, "", params.join(" "));
- }
-}
-
-void Server::handleServerNick(QString prefix, QStringList params) {
- QString oldnick = updateNickFromMask(prefix);
- QString newnick = params[0];
- VarMap v = nicks.take(oldnick);
- nicks[newnick] = v;
- VarMap chans = v["Channels"].toMap();
- foreach(QString c, chans.keys()) {
- if(oldnick != ownNick) { emit displayMsg(Message::Nick, c, newnick, prefix); }
- else { emit displayMsg(Message::Nick, c, newnick, newnick); }
- }
- emit nickRenamed(network, oldnick, newnick);
- if(oldnick == ownNick) {
- ownNick = newnick;
- emit ownNickSet(network, newnick);
- }
-}
-
-void Server::handleServerNotice(QString prefix, QStringList params) {
- //Message msg(Message::Notice, params[1], prefix);
- if(currentServer.isEmpty() || prefix == currentServer) emit displayMsg(Message::Server, "", params[1], prefix);
- else emit displayMsg(Message::Notice, "", params[1], prefix);
-}
-
-void Server::handleServerPart(QString prefix, QStringList params) {
- QString nick = updateNickFromMask(prefix);
- Q_ASSERT(nicks.contains(nick));
- VarMap n = nicks[nick];
- VarMap chans = n["Channels"].toMap();
- Q_ASSERT(chans.contains(params[0]));
- chans.remove(params[0]);
- QString msg;
- if(params.count() > 1) msg = params[1];
- emit displayMsg(Message::Part, params[0], msg, prefix);
- if(chans.count() > 0) {
- n["Channels"] = chans;
- nicks[nick] = n;
- emit nickUpdated(network, nick, n);
- } else {
- nicks.remove(nick);
- emit nickRemoved(network, nick);
- }
- if(nick == ownNick) {
- Q_ASSERT(topics.contains(params[0]));
- topics.remove(params[0]);
- }
-}
-
-void Server::handleServerPing(QString prefix, QStringList params) {
- putCmd("PONG", params);
-}
-
-void Server::handleServerPrivmsg(QString prefix, QStringList params) {
- updateNickFromMask(prefix);
- Q_ASSERT(params.count() >= 2);
- if(params.count()<2) emit displayMsg(Message::Plain, params[0], "", prefix);
- else {
- // it's possible to pack multiple privmsgs into one param using ctcp
- QStringList messages = parseCtcp(Server::CtcpQuery, prefix, params[0], params[1]);
- if(params[0].toLower() == ownNick.toLower()) { // Freenode sends nickname in lower case!
- foreach(QString message, messages) {
- if(!message.isEmpty()) {
- emit displayMsg(Message::Plain, "", message, prefix, Message::PrivMsg);
- }
- }
-
- } else {
- //qDebug() << prefix << params;
- Q_ASSERT(isChannelName(params[0])); // should be channel!
- foreach(QString message, messages) {
- if(!message.isEmpty()) {
- emit displayMsg(Message::Plain, params[0], message, prefix);
- }
- }
- }
- }
-}
-
-void Server::handleServerQuit(QString prefix, QStringList params) {
- QString nick = updateNickFromMask(prefix);
- Q_ASSERT(nicks.contains(nick));
- VarMap chans = nicks[nick]["Channels"].toMap();
- QString msg;
- if(params.count()) msg = params[0];
- foreach(QString c, chans.keys()) {
- emit displayMsg(Message::Quit, c, msg, prefix);
- }
- nicks.remove(nick);
- emit nickRemoved(network, nick);
-}
-
-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));
-}
-
-
-/***********************************************************************************/
-