-
-void CoreUserInputHandler::issueAway(const QString &msg, bool autoCheck) {
- QString awayMsg = msg;
- IrcUser *me = network()->me();
-
- // if there is no message supplied we have to check if we are already away or not
- if(autoCheck && msg.isEmpty()) {
- if(me && !me->isAway()) {
- Identity *identity = network()->identityPtr();
- if(identity) {
- awayMsg = identity->awayReason();
- }
- if(awayMsg.isEmpty()) {
- awayMsg = tr("away");
- }
- }
- }
- if(me)
- me->setAwayMessage(awayMsg);
-
- putCmd("AWAY", serverEncode(awayMsg));
-}
-
-void CoreUserInputHandler::handleBan(const BufferInfo &bufferInfo, const QString &msg) {
- banOrUnban(bufferInfo, msg, true);
-}
-
-void CoreUserInputHandler::handleUnban(const BufferInfo &bufferInfo, const QString &msg) {
- banOrUnban(bufferInfo, msg, false);
-}
-
-void CoreUserInputHandler::banOrUnban(const BufferInfo &bufferInfo, const QString &msg, bool ban) {
- QString banChannel;
- QString banUser;
-
- QStringList params = msg.split(" ");
-
- if(!params.isEmpty() && isChannelName(params[0])) {
- banChannel = params.takeFirst();
- } else if(bufferInfo.type() == BufferInfo::ChannelBuffer) {
- banChannel = bufferInfo.bufferName();
- } else {
- emit displayMsg(Message::Error, BufferInfo::StatusBuffer, "", QString("Error: channel unknown in command: /BAN %1").arg(msg));
- return;
- }
-
- if(!params.isEmpty() && !params.contains("!") && network()->ircUser(params[0])) {
- IrcUser *ircuser = network()->ircUser(params[0]);
- // generalizedHost changes <nick> to *!ident@*.sld.tld.
- QString generalizedHost = ircuser->host();
- if(generalizedHost.isEmpty()) {
- emit displayMsg(Message::Error, BufferInfo::StatusBuffer, "", QString("Error: host unknown in command: /BAN %1").arg(msg));
- return;
- }
-
- static QRegExp ipAddress("\\d+\\.\\d+\\.\\d+\\.\\d+");
- if(ipAddress.exactMatch(generalizedHost)) {
- int lastDotPos = generalizedHost.lastIndexOf('.') + 1;
- generalizedHost.replace(lastDotPos, generalizedHost.length() - lastDotPos, '*');
- } else if(generalizedHost.lastIndexOf(".") != -1 && generalizedHost.lastIndexOf(".", generalizedHost.lastIndexOf(".")-1) != -1) {
- int secondLastPeriodPosition = generalizedHost.lastIndexOf(".", generalizedHost.lastIndexOf(".")-1);
- generalizedHost.replace(0, secondLastPeriodPosition, "*");
- }
- banUser = QString("*!%1@%2").arg(ircuser->user(), generalizedHost);
- } else {
- banUser = params.join(" ");
- }
-
- QString banMode = ban ? "+b" : "-b";
- QString banMsg = QString("MODE %1 %2 %3").arg(banChannel, banMode, banUser);
- emit putRawLine(serverEncode(banMsg));
-}
-
-void CoreUserInputHandler::handleCtcp(const BufferInfo &bufferInfo, const QString &msg) {
- Q_UNUSED(bufferInfo)
-
- QString nick = msg.section(' ', 0, 0);
- QString ctcpTag = msg.section(' ', 1, 1).toUpper();
- if(ctcpTag.isEmpty())
- return;
-
- QString message = msg.section(' ', 2);
- QString verboseMessage = tr("sending CTCP-%1 request to %2").arg(ctcpTag).arg(nick);
-
- if(ctcpTag == "PING") {
- uint now = QDateTime::currentDateTime().toTime_t();
- message = QString::number(now);
- }
-
- network()->ctcpHandler()->query(nick, ctcpTag, message);
- emit displayMsg(Message::Action, BufferInfo::StatusBuffer, "", verboseMessage, network()->myNick());
-}
-
-void CoreUserInputHandler::handleDelkey(const BufferInfo &bufferInfo, const QString &msg) {
- #ifdef HAVE_QCA2
- if (!bufferInfo.isValid())
- return;
-
- QStringList parms = msg.split(' ', QString::SkipEmptyParts);
-
- if(parms.isEmpty() && !bufferInfo.bufferName().isEmpty())
- parms.prepend(bufferInfo.bufferName());
-
- if(parms.isEmpty()) {
- QString message = tr("[usage] /delkey <nick|channel> deletes the encryption key for nick or channel or just /delkey when in a channel or query.");
-
- if(bufferInfo.bufferName().isEmpty())
- emit displayMsg(Message::Info, BufferInfo::StatusBuffer, "", message);
- else
- emit displayMsg(Message::Info, bufferInfo.bufferName(), message);
- return;
- }
-
- if(network()->bufferKey(parms[0]).isEmpty()) {
- QString message = tr("No key has been set for %1.").arg(parms[0]);
-
- if(bufferInfo.bufferName().isEmpty())
- emit displayMsg(Message::Info, BufferInfo::StatusBuffer, "", message);
- else
- emit displayMsg(Message::Info, bufferInfo.bufferName(), message);
- return;
- }
-
- network()->setBufferKey(parms[0], "");
-
- if(network()->isChannelName(parms[0]) && network()->channels().contains(parms[0])) {
- network()->ircChannel(parms[0])->setEncrypted(false);
- }
- else if(network()->nicks().contains(parms[0])) {
- network()->ircUser(parms[0])->setEncrypted(false);
- }
-
- QString message = tr("The key for %1 has been deleted.").arg(parms[0]);
-
- if(bufferInfo.bufferName().isEmpty())
- emit displayMsg(Message::Info, BufferInfo::StatusBuffer, "", message);
- else
- emit displayMsg(Message::Info, bufferInfo.bufferName(), message);
-
- #else
- emit displayMsg(Message::Error, BufferInfo::StatusBuffer, "", tr("Error: Setting an encryption key requires Quassel to have been built "
- "with support for the Qt Cryptographic Architecture (QCA) library. "
- "Contact your distributor about a Quassel package with QCA "
- "support, or rebuild Quassel with QCA present."));
- #endif
-}
-
-void CoreUserInputHandler::handleDeop(const BufferInfo &bufferInfo, const QString &msg) {
- QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
- QString m = "-"; for(int i = 0; i < nicks.count(); i++) m += 'o';
- QStringList params;
- params << bufferInfo.bufferName() << m << nicks;
- emit putCmd("MODE", serverEncode(params));
-}
-
-void CoreUserInputHandler::handleDevoice(const BufferInfo &bufferInfo, const QString &msg) {
- QStringList nicks = msg.split(' ', QString::SkipEmptyParts);
- QString m = "-"; for(int i = 0; i < nicks.count(); i++) m += 'v';
- QStringList params;
- params << bufferInfo.bufferName() << m << nicks;
- emit putCmd("MODE", serverEncode(params));
-}
-
-void CoreUserInputHandler::handleInvite(const BufferInfo &bufferInfo, const QString &msg) {
- QStringList params;
- params << msg << bufferInfo.bufferName();
- emit putCmd("INVITE", serverEncode(params));
-}
-
-void CoreUserInputHandler::handleJoin(const BufferInfo &bufferInfo, const QString &msg) {
- Q_UNUSED(bufferInfo);
-
- // trim spaces before chans or keys
- QString sane_msg = msg;
- sane_msg.replace(QRegExp(", +"), ",");
- QStringList params = sane_msg.trimmed().split(" ");
-
- QStringList chans = params[0].split(",", QString::SkipEmptyParts);
- QStringList keys;
- if(params.count() > 1)
- keys = params[1].split(",");
-
- int i;
- for(i = 0; i < chans.count(); i++) {
- if(!network()->isChannelName(chans[i]))
- chans[i].prepend('#');
-
- if(i < keys.count()) {
- network()->addChannelKey(chans[i], keys[i]);
+
+
+void CoreUserInputHandler::banOrUnban(const BufferInfo &bufferInfo, const QString &msg, bool ban)
+{
+ QString banChannel;
+ QString banUser;
+
+ QStringList params = msg.split(" ");
+
+ if (!params.isEmpty() && isChannelName(params[0])) {
+ banChannel = params.takeFirst();
+ }
+ else if (bufferInfo.type() == BufferInfo::ChannelBuffer) {
+ banChannel = bufferInfo.bufferName();
+ }
+ else {
+ emit displayMsg(Message::Error, BufferInfo::StatusBuffer, "", QString("Error: channel unknown in command: /BAN %1").arg(msg));
+ return;
+ }
+
+ if (!params.isEmpty() && !params.contains("!") && network()->ircUser(params[0])) {
+ IrcUser *ircuser = network()->ircUser(params[0]);
+ // generalizedHost changes <nick> to *!ident@*.sld.tld.
+ QString generalizedHost = ircuser->host();
+ if (generalizedHost.isEmpty()) {
+ emit displayMsg(Message::Error, BufferInfo::StatusBuffer, "", QString("Error: host unknown in command: /BAN %1").arg(msg));
+ return;
+ }
+
+ static QRegExp ipAddress("\\d+\\.\\d+\\.\\d+\\.\\d+");
+ if (ipAddress.exactMatch(generalizedHost)) {
+ int lastDotPos = generalizedHost.lastIndexOf('.') + 1;
+ generalizedHost.replace(lastDotPos, generalizedHost.length() - lastDotPos, '*');
+ }
+ else if (generalizedHost.lastIndexOf(".") != -1 && generalizedHost.lastIndexOf(".", generalizedHost.lastIndexOf(".")-1) != -1) {
+ int secondLastPeriodPosition = generalizedHost.lastIndexOf(".", generalizedHost.lastIndexOf(".")-1);
+ generalizedHost.replace(0, secondLastPeriodPosition, "*");
+ }
+ banUser = QString("*!%1@%2").arg(ircuser->user(), generalizedHost);
+ }
+ else {
+ banUser = params.join(" ");
+ }
+
+ QString banMode = ban ? "+b" : "-b";
+ QString banMsg = QString("MODE %1 %2 %3").arg(banChannel, banMode, banUser);
+ emit putRawLine(serverEncode(banMsg));
+}
+
+
+void CoreUserInputHandler::handleCtcp(const BufferInfo &bufferInfo, const QString &msg)
+{
+ Q_UNUSED(bufferInfo)
+
+ QString nick = msg.section(' ', 0, 0);
+ QString ctcpTag = msg.section(' ', 1, 1).toUpper();
+ if (ctcpTag.isEmpty())
+ return;
+
+ QString message = msg.section(' ', 2);
+ QString verboseMessage = tr("sending CTCP-%1 request to %2").arg(ctcpTag).arg(nick);
+
+ if (ctcpTag == "PING") {
+ message = QString::number(QDateTime::currentMSecsSinceEpoch());
+ }
+
+ // FIXME make this a proper event
+ coreNetwork()->coreSession()->ctcpParser()->query(coreNetwork(), nick, ctcpTag, message);
+ emit displayMsg(Message::Action, BufferInfo::StatusBuffer, "", verboseMessage,
+ network()->myNick(), Message::Flag::Self);
+}
+
+
+void CoreUserInputHandler::handleDelkey(const BufferInfo &bufferInfo, const QString &msg)
+{
+ QString bufname = bufferInfo.bufferName().isNull() ? "" : bufferInfo.bufferName();
+#ifdef HAVE_QCA2
+ if (!bufferInfo.isValid())
+ return;
+
+ if (!Cipher::neededFeaturesAvailable()) {
+ emit displayMsg(Message::Error, typeByTarget(bufname), bufname, tr("Error: QCA provider plugin not found. It is usually provided by the qca-ossl plugin."));
+ return;
+ }
+
+ QStringList parms = msg.split(' ', QString::SkipEmptyParts);
+
+ if (parms.isEmpty() && !bufferInfo.bufferName().isEmpty() && bufferInfo.acceptsRegularMessages())
+ parms.prepend(bufferInfo.bufferName());
+
+ if (parms.isEmpty()) {
+ emit displayMsg(Message::Info, typeByTarget(bufname), bufname,
+ tr("[usage] /delkey <nick|channel> deletes the encryption key for nick or channel or just /delkey when in a channel or query."));
+ return;
+ }
+
+ QString target = parms.at(0);
+
+ if (network()->cipherKey(target).isEmpty()) {
+ emit displayMsg(Message::Info, typeByTarget(bufname), bufname, tr("No key has been set for %1.").arg(target));
+ return;
+ }
+
+ network()->setCipherKey(target, QByteArray());
+ emit displayMsg(Message::Info, typeByTarget(bufname), bufname, tr("The key for %1 has been deleted.").arg(target));
+
+#else
+ Q_UNUSED(msg)
+ emit displayMsg(Message::Error, typeByTarget(bufname), bufname, tr("Error: Setting an encryption key requires Quassel to have been built "
+ "with support for the Qt Cryptographic Architecture (QCA2) library. "
+ "Contact your distributor about a Quassel package with QCA2 "
+ "support, or rebuild Quassel with QCA2 present."));
+#endif
+}
+
+void CoreUserInputHandler::doMode(const BufferInfo &bufferInfo, const QChar& addOrRemove, const QChar& mode, const QString &nicks)
+{
+ QString m;
+ bool isNumber;
+ int maxModes = network()->support("MODES").toInt(&isNumber);
+ if (!isNumber || maxModes == 0) maxModes = 1;
+
+ QStringList nickList;
+ if (nicks == "*" && bufferInfo.type() == BufferInfo::ChannelBuffer) { // All users in channel
+ const QList<IrcUser*> users = network()->ircChannel(bufferInfo.bufferName())->ircUsers();
+ foreach(IrcUser *user, users) {
+ if ((addOrRemove == '+' && !network()->ircChannel(bufferInfo.bufferName())->userModes(user).contains(mode))
+ || (addOrRemove == '-' && network()->ircChannel(bufferInfo.bufferName())->userModes(user).contains(mode)))
+ nickList.append(user->nick());
+ }