X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcmd_whowas.cpp;h=bb8866239f444c3b1586713452e3a1de5dcd22c2;hb=84a19a9ab6129deb71cdc24b216b74dd8eb80978;hp=b710b5a083308144212eb8d84044163e4a6c0ad9;hpb=2bb1208eae529c1e87005626405e9dee86754077;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/cmd_whowas.cpp b/src/cmd_whowas.cpp index b710b5a08..bb8866239 100644 --- a/src/cmd_whowas.cpp +++ b/src/cmd_whowas.cpp @@ -14,53 +14,14 @@ * --------------------------------------------------- */ -using namespace std; - #include "inspircd_config.h" -#include "inspircd.h" -#include "inspircd_io.h" -#include -#include -#ifdef GCC3 -#include -#else -#include -#endif -#include -#include -#include -#include +#include "configreader.h" #include "users.h" -#include "ctables.h" -#include "globals.h" -#include "modules.h" -#include "dynamic.h" -#include "wildcard.h" -#include "message.h" #include "commands.h" -#include "mode.h" -#include "xline.h" -#include "inspstring.h" -#include "dnsqueue.h" #include "helperfuncs.h" -#include "hashcomp.h" -#include "socketengine.h" -#include "typedefs.h" -#include "command_parse.h" #include "cmd_whowas.h" extern ServerConfig* Config; -extern InspIRCd* ServerInstance; -extern int MODCOUNT; -extern std::vector modules; -extern std::vector factory; -extern time_t TIME; -extern user_hash clientlist; -extern chan_hash chanlist; -extern std::vector all_opers; -extern std::vector local_users; -extern userrec* fd_ref_table[MAX_DESCRIPTORS]; - extern whowas_users whowas; void cmd_whowas::Handle (char **parameters, int pcnt, userrec* user) @@ -73,22 +34,31 @@ void cmd_whowas::Handle (char **parameters, int pcnt, userrec* user) } else { - whowas_set* grp = (whowas_set*)i; + whowas_set* grp = i->second; if (grp->size()) { - for (whowas_set::iterator u = grp->begin(); u != grp->end(); u++) + for (whowas_set::iterator ux = grp->begin(); ux != grp->end(); ux++) { + WhoWasGroup* u = *ux; time_t rawtime = u->signon; tm *timeinfo; char b[MAXBUF]; timeinfo = localtime(&rawtime); + + /* XXX - 'b' could be only 25 chars long and then strlcpy() would terminate it for us too? */ strlcpy(b,asctime(timeinfo),MAXBUF); b[24] = 0; WriteServ(user->fd,"314 %s %s %s %s * :%s",user->nick,parameters[0],u->ident,u->dhost,u->gecos); - WriteServ(user->fd,"312 %s %s %s :%s",user->nick,parameters[0], *Config->HideWhoisServer ? Config->HideWhoisServer : u->server,b); - WriteServ(user->fd,"369 %s %s :End of WHOWAS",user->nick,parameters[0]); + + if(*user->oper) + WriteServ(user->fd,"379 %s %s :was connecting from *@%s", user->nick, parameters[0], u->host); + + if(*Config->HideWhoisServer && !(*user->oper)) + WriteServ(user->fd,"312 %s %s %s :%s",user->nick,parameters[0], Config->HideWhoisServer, b); + else + WriteServ(user->fd,"312 %s %s %s :%s",user->nick,parameters[0], u->server, b); } } else @@ -96,6 +66,6 @@ void cmd_whowas::Handle (char **parameters, int pcnt, userrec* user) WriteServ(user->fd,"406 %s %s :There was no such nickname",user->nick,parameters[0]); } } + WriteServ(user->fd,"369 %s %s :End of WHOWAS",user->nick,parameters[0]); } -