X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_cycle.cpp;h=686f4652adf858470ba443348ce242e74fc78173;hb=80e81e3b81b779901fd9d67f8ae030ee30c0bcec;hp=d190eda3cf71dcd36d199ca076613f0153044f78;hpb=cadc11999ee28545e9beb92de116c151832af5c4;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_cycle.cpp b/src/modules/m_cycle.cpp index d190eda3c..686f4652a 100644 --- a/src/modules/m_cycle.cpp +++ b/src/modules/m_cycle.cpp @@ -1,75 +1,79 @@ -/* +------------------------------------+ - * | Inspire Internet Relay Chat Daemon | - * +------------------------------------+ +/* + * InspIRCd -- Internet Relay Chat Daemon * - * InspIRCd: (C) 2002-2007 InspIRCd Development Team - * See: http://www.inspircd.org/wiki/index.php/Credits + * Copyright (C) 2017 B00mX0r + * Copyright (C) 2013, 2018, 2020 Sadie Powell + * Copyright (C) 2012-2014, 2016 Attila Molnar + * Copyright (C) 2012, 2019 Robby + * Copyright (C) 2010 Craig Edwards + * Copyright (C) 2009 Uli Schlachter + * Copyright (C) 2009 Daniel De Graaf + * Copyright (C) 2007-2008 Dennis Friis + * Copyright (C) 2007 Robin Burchell + * Copyright (C) 2007 John Brooks * - * 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 . */ -#include "inspircd.h" -/* $ModDesc: Provides support for unreal-style CYCLE command. */ +#include "inspircd.h" /** Handle /CYCLE */ -class CommandCycle : public Command +class CommandCycle : public SplitCommand { public: - CommandCycle (InspIRCd* Instance) : Command(Instance,"CYCLE", 0, 1, false, 3) + CommandCycle(Module* Creator) + : SplitCommand(Creator, "CYCLE", 1) { - this->source = "m_cycle.so"; - syntax = " :[reason]"; - TRANSLATE3(TR_TEXT, TR_TEXT, TR_END); + Penalty = 3; + syntax = " [:]"; } - CmdResult Handle (const char** parameters, int pcnt, User *user) + CmdResult HandleLocal(LocalUser* user, const Params& parameters) CXX11_OVERRIDE { Channel* channel = ServerInstance->FindChan(parameters[0]); - std::string reason = ConvToStr("Cycling"); - - if (pcnt > 1) + std::string reason = "Cycling"; + + if (parameters.size() > 1) { /* reason provided, use it */ reason = reason + ": " + parameters[1]; } - + if (!channel) { - user->WriteServ("403 %s %s :No such channel", user->nick, parameters[0]); + user->WriteNumeric(Numerics::NoSuchChannel(parameters[0])); return CMD_FAILURE; } - + if (channel->HasUser(user)) { - /* - * technically, this is only ever sent locally, but pays to be safe ;p - */ - if (IS_LOCAL(user)) + if (channel->GetPrefixValue(user) < VOICE_VALUE && channel->IsBanned(user)) { - if (channel->GetStatus(user) < STATUS_VOICE && channel->IsBanned(user)) - { - /* banned, boned. drop the message. */ - user->WriteServ("NOTICE "+std::string(user->nick)+" :*** You may not cycle, as you are banned on channel " + channel->name); - return CMD_FAILURE; - } - - /* XXX in the future, this may move to a static Channel method (the delete.) -- w00t */ - if (!channel->PartUser(user, reason.c_str())) - delete channel; - - Channel::JoinUser(ServerInstance, user, parameters[0], true, "", ServerInstance->Time(true)); + // User is banned, send an error and don't cycle them + user->WriteNotice("*** You may not cycle, as you are banned on channel " + channel->name); + return CMD_FAILURE; } - return CMD_LOCALONLY; + channel->PartUser(user, reason); + Channel::JoinUser(user, parameters[0], true); + + return CMD_SUCCESS; } else { - user->WriteServ("442 %s %s :You're not on that channel", user->nick, channel->name); + user->WriteNumeric(ERR_NOTONCHANNEL, channel->name, "You're not on that channel"); } return CMD_FAILURE; @@ -79,26 +83,18 @@ class CommandCycle : public Command class ModuleCycle : public Module { - CommandCycle* mycommand; - public: - ModuleCycle(InspIRCd* Me) - : Module(Me) - { - - mycommand = new CommandCycle(ServerInstance); - ServerInstance->AddCommand(mycommand); + CommandCycle cmd; - } - - virtual ~ModuleCycle() + public: + ModuleCycle() + : cmd(this) { } - - virtual Version GetVersion() + + Version GetVersion() CXX11_OVERRIDE { - return Version(1, 1, 0, 1, VF_COMMON | VF_VENDOR, API_VERSION); + return Version("Allows channel members to part and rejoin a channel without needing to worry about channel modes such as +i (inviteonly) which might prevent rejoining.", VF_VENDOR); } - }; MODULE_INIT(ModuleCycle)