X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_namedmodes.cpp;h=46710946b67a7adde9193e01aa4a14733a8d93d3;hb=fc4fc43ec232407b38d7ca182cb92c5cac4287aa;hp=1ba39b54a36cd83c77d310cce5a79f758dc99971;hpb=8170cabf0f43622c86220ddbe527bc84637cc3c7;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_namedmodes.cpp b/src/modules/m_namedmodes.cpp index 1ba39b54a..46710946b 100644 --- a/src/modules/m_namedmodes.cpp +++ b/src/modules/m_namedmodes.cpp @@ -1,16 +1,24 @@ -/* +------------------------------------+ - * | Inspire Internet Relay Chat Daemon | - * +------------------------------------+ +/* + * InspIRCd -- Internet Relay Chat Daemon * - * InspIRCd: (C) 2002-2010 InspIRCd Development Team - * See: http://wiki.inspircd.org/Credits + * Copyright (C) 2009-2010 Daniel De Graaf * - * This program is free but copyrighted software; see - * the file COPYING for details. + * This file is part of InspIRCd. InspIRCd is free software: you can + * redistribute it and/or modify it under the terms of the GNU General Public + * License as published by the Free Software Foundation, version 2. * - * --------------------------------------------------- + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more + * details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . */ + +/* $ModDesc: Provides the ability to manipulate modes via long names. */ + #include "inspircd.h" static void DisplayList(User* user, Channel* channel) @@ -23,10 +31,14 @@ static void DisplayList(User* user, Channel* channel) continue; if (!channel->IsModeSet(letter)) continue; - std::string item = mh->name; + items << " +" << mh->name; if (mh->GetNumParams(true)) - item += "=" + channel->GetModeParameter(letter); - items << item << " "; + { + if ((letter == 'k') && (!channel->HasUser(user)) && (!user->HasPrivPermission("channels/auspex"))) + items << " "; + else + items << " " << channel->GetModeParameter(letter); + } } char pfx[MAXBUF]; snprintf(pfx, MAXBUF, ":%s 961 %s %s", ServerInstance->Config->ServerName.c_str(), user->nick.c_str(), channel->name.c_str()); @@ -58,6 +70,8 @@ class CommandProp : public Command while (i < parameters.size()) { std::string prop = parameters[i++]; + if (prop.empty()) + continue; bool plus = prop[0] != '-'; if (prop[0] == '+' || prop[0] == '-') prop.erase(prop.begin()); @@ -70,9 +84,8 @@ class CommandProp : public Command modes[1].append((plus ? "+" : "-") + std::string(1, letter)); if (mh->GetNumParams(plus)) { - if (i == parameters.size()) - return CMD_FAILURE; - modes.push_back(parameters[i++]); + if (i != parameters.size()) + modes.push_back(parameters[i++]); } } } @@ -82,19 +95,31 @@ class CommandProp : public Command } }; +class DummyZ : public ModeHandler +{ + public: + DummyZ(Module* parent) : ModeHandler(parent, "namebase", 'Z', PARAM_ALWAYS, MODETYPE_CHANNEL) + { + list = true; + } +}; + class ModuleNamedModes : public Module { CommandProp cmd; + DummyZ dummyZ; public: - ModuleNamedModes() : cmd(this) + ModuleNamedModes() : cmd(this), dummyZ(this) { } void init() { ServerInstance->Modules->AddService(cmd); - Implementation eventlist[] = { I_OnPreMode, I_On005Numeric }; - ServerInstance->Modules->Attach(eventlist, this, 2); + ServerInstance->Modules->AddService(dummyZ); + + Implementation eventlist[] = { I_OnPreMode }; + ServerInstance->Modules->Attach(eventlist, this, sizeof(eventlist)/sizeof(Implementation)); } Version GetVersion() @@ -107,18 +132,6 @@ class ModuleNamedModes : public Module ServerInstance->Modules->SetPriority(this, I_OnPreMode, PRIORITY_FIRST); } - void On005Numeric(std::string& line) - { - std::string::size_type pos = line.find(" CHANMODES="); - if (pos != std::string::npos) - { - pos += 11; - while (line[pos] > 'A' && line[pos] < 'Z') - pos++; - line.insert(pos, 1, 'Z'); - } - } - ModResult OnPreMode(User* source, User* dest, Channel* channel, const std::vector& parameters) { if (!channel)