/*
* InspIRCd -- Internet Relay Chat Daemon
*
- * Copyright (C) 2009 Daniel De Graaf <danieldg@inspircd.org>
- * Copyright (C) 2008 Craig Edwards <craigedwards@brainbox.cc>
+ * Copyright (C) 2017-2018 Sadie Powell <sadie@witchery.services>
+ * Copyright (C) 2016 Adam <Adam@anope.org>
+ * Copyright (C) 2012-2014, 2018 Attila Molnar <attilamolnar@hush.com>
+ * Copyright (C) 2012, 2019 Robby <robby@chatbelgie.be>
+ * Copyright (C) 2009-2010 Daniel De Graaf <danieldg@inspircd.org>
+ * Copyright (C) 2009 Uli Schlachter <psychon@inspircd.org>
* Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net>
+ * Copyright (C) 2007 Dennis Friis <peavey@inspircd.org>
+ * Copyright (C) 2007 Craig Edwards <brain@inspircd.org>
*
* 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
, protoev(parent, name)
{
flags_needed = 'o';
- syntax = "<nickname> <reason>";
+ syntax = "<nick>[,<nick>]+ :<reason>";
TRANSLATE2(TR_CUSTOM, TR_CUSTOM);
}
class KillMessage : public ClientProtocol::Message
{
public:
- KillMessage(ClientProtocol::EventProvider& protoev, User* user, LocalUser* target, const std::string& text)
+ KillMessage(ClientProtocol::EventProvider& protoev, User* user, LocalUser* target, const std::string& text, const std::string& hidenick)
: ClientProtocol::Message("KILL", NULL)
{
- if (ServerInstance->Config->HideKillsServer.empty())
+ if (hidenick.empty())
SetSourceUser(user);
else
- SetSource(ServerInstance->Config->HideKillsServer);
+ SetSource(hidenick);
PushParamRef(target->nick);
PushParamRef(text);
return CMD_FAILURE;
killreason = "Killed (";
- if (!ServerInstance->Config->HideKillsServer.empty())
+ if (!hidenick.empty())
{
// hidekills is on, use it
- killreason += ServerInstance->Config->HideKillsServer;
+ killreason += hidenick;
}
else
{
killreason.assign(parameters[1], 0, ServerInstance->Config->Limits.MaxQuit);
}
- if ((!ServerInstance->Config->HideULineKills) || (!user->server->IsULine()))
+ if ((!hideuline) || (!user->server->IsULine()))
{
if (IS_LOCAL(user) && IS_LOCAL(target))
ServerInstance->SNO->WriteGlobalSno('k', "Local kill by %s: %s (%s)", user->nick.c_str(), target->GetFullRealHost().c_str(), parameters[1].c_str());
if (IS_LOCAL(target))
{
LocalUser* localu = IS_LOCAL(target);
- KillMessage msg(protoev, user, localu, killreason);
+ KillMessage msg(protoev, user, localu, killreason, hidenick);
ClientProtocol::Event killevent(protoev, msg);
localu->Send(killevent);