X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcmd_die.cpp;h=d9aecb4be4dc4490614268954a037c2d44191887;hb=ddb970dd670bcd905c8f34458f8fcf70e9fd89bd;hp=b0a826b6db7bb7151990e35c7422763af0575699;hpb=23a4885701cba4a87a5ae027257fb4207c917572;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/cmd_die.cpp b/src/cmd_die.cpp index b0a826b6d..d9aecb4be 100644 --- a/src/cmd_die.cpp +++ b/src/cmd_die.cpp @@ -2,41 +2,38 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. - * E-mail: - * - * + * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * See: http://www.inspircd.org/wiki/index.php/Credits * - * Written by Craig Edwards, Craig McLure, and others. * This program is free but copyrighted software; see * the file COPYING for details. * * --------------------------------------------------- */ -#include -#include -#include #include "configreader.h" #include "users.h" -#include "commands.h" -#include "helperfuncs.h" #include "commands/cmd_die.h" +#include "exitcodes.h" -extern InspIRCd* ServerInstance; -extern std::vector all_opers; +extern "C" command_t* init_command(InspIRCd* Instance) +{ + return new cmd_die(Instance); +} -void cmd_die::Handle (const char** parameters, int pcnt, userrec *user) +/** Handle /DIE + */ +CmdResult cmd_die::Handle (const char** parameters, int pcnt, userrec *user) { if (!strcmp(parameters[0],ServerInstance->Config->diepass)) { - log(SPARSE, "/DIE command from %s!%s@%s, terminating in %d seconds...", user->nick, user->ident, user->host, ServerInstance->Config->DieDelay); + ServerInstance->Log(SPARSE, "/DIE command from %s!%s@%s, terminating in %d seconds...", user->nick, user->ident, user->host, ServerInstance->Config->DieDelay); /* This would just be WriteOpers(), but as we just sleep() and then die then the write buffers never get flushed. * so we iterate the oper list, writing the message and immediately trying to flush their write buffer. */ - for (std::vector::iterator i = all_opers.begin(); i != all_opers.end(); i++) + for (std::vector::iterator i = ServerInstance->all_opers.begin(); i != ServerInstance->all_opers.end(); i++) { userrec* a = *i; @@ -47,12 +44,16 @@ void cmd_die::Handle (const char** parameters, int pcnt, userrec *user) } } - sleep(ServerInstance->Config->DieDelay); - InspIRCd::Exit(ERROR); + if (ServerInstance->Config->DieDelay) + sleep(ServerInstance->Config->DieDelay); + + InspIRCd::Exit(EXIT_STATUS_DIE); } else { - log(SPARSE, "Failed /DIE command from %s!%s@%s", user->nick, user->ident, user->host); + ServerInstance->Log(SPARSE, "Failed /DIE command from %s!%s@%s", user->nick, user->ident, user->host); ServerInstance->WriteOpers("*** Failed DIE Command from %s!%s@%s.",user->nick,user->ident,user->host); + return CMD_FAILURE; } + return CMD_SUCCESS; }