-void IrcServerHandler::handle301(QString prefix, QList<QByteArray> params) {
- 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(" ")));
+void IrcServerHandler::handle301(const QString &prefix, const QList<QByteArray> ¶ms) {
+ Q_UNUSED(prefix);
+ QString nickName = serverDecode(params[0]);
+ QString awayMessage = userDecode(nickName, params.last());
+
+ IrcUser *ircuser = network()->ircUser(nickName);
+ if(ircuser) {
+ ircuser->setAwayMessage(awayMessage);
+ ircuser->setAway(true);
+ }
+
+ // FIXME: proper redirection needed
+ if(_whois) {
+ emit displayMsg(Message::Server, BufferInfo::StatusBuffer, "", tr("[Whois] %1 is away: \"%2\"").arg(nickName).arg(awayMessage));
+ } else {
+ if(ircuser) {
+ int now = QDateTime::currentDateTime().toTime_t();
+ int silenceTime = 60;
+ if(ircuser->lastAwayMessage() + silenceTime < now) {
+ emit displayMsg(Message::Server, BufferInfo::QueryBuffer, params[0], tr("%1 is away: \"%2\"").arg(nickName).arg(awayMessage));
+ }
+ ircuser->setLastAwayMessage(now);
+ } else {
+ // probably should not happen
+ emit displayMsg(Message::Server, BufferInfo::QueryBuffer, params[0], tr("%1 is away: \"%2\"").arg(nickName).arg(awayMessage));
+ }
+ }