X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fircserverhandler.cpp;h=e6e3b324d12d0c01305929126d0d7a9f9afd26bd;hp=d70144181850c86403c95dede64ff2f528262372;hb=6623fd2d46dadd0168e4e28d1db6944c26c2a773;hpb=e2ae384f869498c51d2b42cc366359547c25f890 diff --git a/src/core/ircserverhandler.cpp b/src/core/ircserverhandler.cpp index d7014418..e6e3b324 100644 --- a/src/core/ircserverhandler.cpp +++ b/src/core/ircserverhandler.cpp @@ -35,6 +35,7 @@ IrcServerHandler::IrcServerHandler(NetworkConnection *parent) : BasicHandler(parent), networkConnection(parent) { + _whowas = false; } IrcServerHandler::~IrcServerHandler() { @@ -308,10 +309,12 @@ void IrcServerHandler::handlePrivmsg(QString prefix, QList params) { if(network()->isMyNick(target)) { // it's possible to pack multiple privmsgs into one param using ctcp QStringList messages = networkConnection->ctcpHandler()->parse(CtcpHandler::CtcpQuery, prefix, target, userDecode(ircuser->nick(), params[1])); + quint8 flags; foreach(QString message, messages) { - if(!message.isEmpty()) { - emit displayMsg(Message::Plain, "", message, prefix, Message::PrivMsg); - } + flags = Message::PrivMsg; + if(message.contains(network()->myNick())) + flags |= Message::Highlight; + emit displayMsg(Message::Plain, "", message, prefix, flags); } } else { // so it's probably a channel.. @@ -321,8 +324,13 @@ void IrcServerHandler::handlePrivmsg(QString prefix, QList params) { } QStringList messages = networkConnection->ctcpHandler()->parse(CtcpHandler::CtcpQuery, prefix, target, bufferDecode(target, params[1])); - foreach(QString message, messages) - emit displayMsg(Message::Plain, target, message, prefix); + quint8 flags; + foreach(QString message, messages) { + flags = Message::None; + if(message.contains(network()->myNick())) + flags |= Message::Highlight; + emit displayMsg(Message::Plain, target, message, prefix, flags); + } } } @@ -381,6 +389,97 @@ void IrcServerHandler::handle005(QString prefix, QList params) { } +/* +WHOIS-Message: + Replies 311 - 313, 317 - 319 are all replies generated in response to a WHOIS message. + and 301 (RPL_AWAY) + " :" +WHO-Message: + Replies 352 and 315 paired are used to answer a WHO message. + +WHOWAS-Message: + Replies 314 and 369 are responses to a WHOWAS message. + + ??? BitlBee program, simulating IRC server with one channel, 374-378 +*/ + + +/* RPL_AWAY - " :" */ +void IrcServerHandler::handle301(QString prefix, QList params) { + Q_UNUSED(prefix) + IrcUser *ircuser = network()->ircUser(serverDecode(params[0])); + ircuser->setAwayMessage(serverDecode(params.last())); + ircuser->setAway(true); + emit displayMsg(Message::Server, "", tr("[Whois] %1").arg(serverDecode(params).join(" "))); +} + +/* RPL_WHOISUSER - " * :" */ +void IrcServerHandler::handle311(QString prefix, QList params) { + Q_UNUSED(prefix) + IrcUser *ircuser = network()->ircUser(serverDecode(params[0])); + ircuser->setUser(serverDecode(params[1])); + ircuser->setHost(serverDecode(params[2])); + ircuser->setRealName(serverDecode(params.last())); + emit displayMsg(Message::Server, "", tr("[Whois] %1 %2 %3 (%4)") + .arg(ircuser->nick(), ircuser->user(), ircuser->host(), ircuser->realName())); +} + +/* RPL_WHOISSERVER - " :" */ +void IrcServerHandler::handle312(QString prefix, QList params) { + Q_UNUSED(prefix) + IrcUser *ircuser = network()->ircUser(serverDecode(params[0])); + ircuser->setServer(serverDecode(params[1])); + if(_whowas) { + emit displayMsg(Message::Server, "", tr("[Whowas] %1").arg(serverDecode(params).join(" "))); + } else { + emit displayMsg(Message::Server, "", tr("[Whois] %1").arg(serverDecode(params).join(" "))); + } +} + +/* RPL_WHOISOPERATOR - " :is an IRC operator" */ +void IrcServerHandler::handle313(QString prefix, QList params) { + Q_UNUSED(prefix) + IrcUser *ircuser = network()->ircUser(serverDecode(params[0])); + ircuser->setIrcOperator(params.last()); + emit displayMsg(Message::Server, "", tr("[Whois] %1").arg(serverDecode(params).join(" "))); +} + +/* RPL_WHOWASUSER - " * :" */ +void IrcServerHandler::handle314(QString prefix, QList params) { + Q_UNUSED(prefix) + _whowas = true; + emit displayMsg(Message::Server, "", tr("[Whowas] %1").arg(serverDecode(params).join(" "))); +} + +/* RPL_ENDOFWHO: " :End of WHO list" */ +void IrcServerHandler::handle315(QString prefix, QList params) { + Q_UNUSED(prefix) + emit displayMsg(Message::Server, "", tr("[Who] %1").arg(serverDecode(params).join(" "))); +} + +/* RPL_WHOISIDLE - " :seconds idle" */ +void IrcServerHandler::handle317(QString prefix, QList params) { + Q_UNUSED(prefix) + IrcUser *ircuser = network()->ircUser(serverDecode(params[0])); + QDateTime now = QDateTime::currentDateTime(); + int idleSecs = serverDecode(params[1]).toInt(); + idleSecs *= -1; + ircuser->setIdleTime(now.addSecs(idleSecs)); + emit displayMsg(Message::Server, "", tr("[Whois] %1 %2").arg(ircuser->nick()).arg(ircuser->idleTime().secsTo(now))); +} + +/* RPL_ENDOFWHOIS - " :End of WHOIS list" */ +void IrcServerHandler::handle318(QString prefix, QList params) { + Q_UNUSED(prefix) + emit displayMsg(Message::Server, "", tr("[Whois] %1").arg(serverDecode(params).join(" "))); +} + +/* RPL_WHOISCHANNELS - " :*( ( "@" / "+" ) " " )" */ +void IrcServerHandler::handle319(QString prefix, QList params) { + Q_UNUSED(prefix) + emit displayMsg(Message::Server, "", tr("[Whois] %1").arg(serverDecode(params).join(" "))); +} + /* RPL_NOTOPIC */ void IrcServerHandler::handle331(QString prefix, QList params) { Q_UNUSED(prefix); @@ -406,6 +505,23 @@ void IrcServerHandler::handle333(QString prefix, QList params) { .arg(bufferDecode(channel, params[1]), QDateTime::fromTime_t(bufferDecode(channel, params[2]).toUInt()).toString())); } +/* RPL_WHOREPLY: " + ( "H" / "G" > ["*"] [ ( "@" / "+" ) ] : " */ +void IrcServerHandler::handle352(QString prefix, QList params) { + Q_UNUSED(prefix) + QString channel = serverDecode(params[0]); + IrcUser *ircuser = network()->ircUser(serverDecode(params[4])); + ircuser->setUser(serverDecode(params[1])); + ircuser->setHost(serverDecode(params[2])); + + bool away = serverDecode(params[5]).startsWith("G") ? true : false; + ircuser->setAway(away); + ircuser->setServer(serverDecode(params[3])); + ircuser->setRealName(serverDecode(params.last()).section(" ", 1)); + + emit displayMsg(Message::Server, "", tr("[Who] %1").arg(serverDecode(params).join(" "))); +} + /* RPL_NAMREPLY */ void IrcServerHandler::handle353(QString prefix, QList params) { Q_UNUSED(prefix) @@ -428,6 +544,13 @@ void IrcServerHandler::handle353(QString prefix, QList params) { } } +/* RPL_ENDOFWHOWAS - " :End of WHOWAS" */ +void IrcServerHandler::handle369(QString prefix, QList params) { + Q_UNUSED(prefix) + _whowas = false; + emit displayMsg(Message::Server, "", tr("[Whowas] %1").arg(serverDecode(params).join(" "))); +} + /* ERR_ERRONEUSNICKNAME */ void IrcServerHandler::handle432(QString prefix, QList params) { Q_UNUSED(prefix); @@ -444,7 +567,7 @@ void IrcServerHandler::handle432(QString prefix, QList params) { } else { QString errnick = params[0]; emit displayMsg(Message::Error, "", tr("Nick %1 contains illegal characters").arg(errnick)); - handle433(prefix, params); + tryNextNick(errnick); } } @@ -452,13 +575,18 @@ void IrcServerHandler::handle432(QString prefix, QList params) { void IrcServerHandler::handle433(QString prefix, QList params) { Q_UNUSED(prefix); - // if there is a problem while connecting to the server -> we handle it + QString errnick = serverDecode(params[0]); + emit displayMsg(Message::Error, "", tr("Nick already in use: %1").arg(errnick)); + // if there is a problem while connecting to the server -> we handle it // but only if our connection has not been finished yet... if(!networkConnection->network()->currentServer().isEmpty()) return; - - QString errnick = serverDecode(params[0]); + + tryNextNick(errnick); +} + +void IrcServerHandler::tryNextNick(const QString &errnick) { QStringList desiredNicks = networkConnection->coreSession()->identity(networkConnection->network()->identity())->nicks(); int nextNick = desiredNicks.indexOf(errnick) + 1; if(desiredNicks.size() > nextNick) { @@ -466,9 +594,9 @@ void IrcServerHandler::handle433(QString prefix, QList params) { } else { emit displayMsg(Message::Error, "", tr("No free and valid nicks in nicklist found. use: /nick to continue")); } - } + /***********************************************************************************/