X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_cycle.cpp;h=686f4652adf858470ba443348ce242e74fc78173;hb=HEAD;hp=554bcd17dec4a4affd77b794adeb68a4b7b0c600;hpb=b57c7f4e466f72fdd2ac3deca42caa1ea7748338;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_cycle.cpp b/src/modules/m_cycle.cpp index 554bcd17d..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 cmd_cycle : public Command +class CommandCycle : public SplitCommand { public: - cmd_cycle (InspIRCd* Instance) : Command(Instance,"CYCLE", 0, 1) + 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,25 +83,18 @@ class cmd_cycle : public Command class ModuleCycle : public Module { - cmd_cycle* mycommand; + CommandCycle cmd; + public: - ModuleCycle(InspIRCd* Me) - : Module(Me) + ModuleCycle() + : cmd(this) { - - mycommand = new cmd_cycle(ServerInstance); - ServerInstance->AddCommand(mycommand); } - - virtual ~ModuleCycle() - { - } - - 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)