]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/cmd_die.cpp
- first steps towards a working IPv6 port. I'll work more on this tomorrow. :-P
[user/henk/code/inspircd.git] / src / cmd_die.cpp
index 3966021b51e8d89e5a79edae39c21a668d1acc74..bc8f5809984f2551971bbfc3522d0f43f36799df 100644 (file)
@@ -34,20 +34,35 @@ using namespace std;
 #include "cmd_die.h"
 
 extern ServerConfig* Config;
+extern std::vector<userrec*> all_opers;
 
 void cmd_die::Handle (char **parameters, int pcnt, userrec *user)
 {
-       log(DEBUG,"die: %s",user->nick);
        if (!strcmp(parameters[0],Config->diepass))
        {
-               WriteOpers("*** DIE command from %s!%s@%s, terminating...",user->nick,user->ident,user->host);
+               log(SPARSE, "/DIE command from %s!%s@%s, terminating in %d seconds...", user->nick, user->ident, user->host, 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<userrec*>::iterator i = all_opers.begin(); i != all_opers.end(); i++)
+               {
+                       userrec* a = *i;
+                       
+                       if (IS_LOCAL(a) && (a->modebits & UM_SERVERNOTICE))
+                       {
+                               WriteServ(a->fd, "NOTICE %s :*** DIE command from %s!%s@%s, terminating...", a->nick, a->nick, a->ident, a->host);
+                               a->FlushWriteBuf();
+                       }
+               }
+               
                sleep(Config->DieDelay);
                Exit(ERROR);
        }
        else
        {
+               log(SPARSE, "Failed /DIE command from %s!%s@%s", user->nick, user->ident, user->host);
                WriteOpers("*** Failed DIE Command from %s!%s@%s.",user->nick,user->ident,user->host);
        }
 }
-
-