X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcmd_userhost.cpp;h=363ba611cf833cea6017dc111f2280ac41702bc6;hb=fe04cdd9dc0d504e2a0d8fb74fcf80dc59a051d7;hp=64210b57ad3c62fb942e119cdc1097fe4f66062e;hpb=396c9ef9f7a96934d3227bb7d1d091315e3d4fa8;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/cmd_userhost.cpp b/src/cmd_userhost.cpp index 64210b57a..363ba611c 100644 --- a/src/cmd_userhost.cpp +++ b/src/cmd_userhost.cpp @@ -2,50 +2,62 @@ * | 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 "inspircd_config.h" #include "users.h" -#include "commands.h" -#include "helperfuncs.h" #include "inspircd.h" #include "commands/cmd_userhost.h" -extern InspIRCd* ServerInstance; -void cmd_userhost::Handle (const char** parameters, int pcnt, userrec *user) + +extern "C" command_t* init_command(InspIRCd* Instance) +{ + return new cmd_userhost(Instance); +} + +CmdResult cmd_userhost::Handle (const char** parameters, int pcnt, userrec *user) { - char Return[MAXBUF],junk[MAXBUF]; - snprintf(Return,MAXBUF,"302 %s :",user->nick); + std::string retbuf = std::string("302 ") + user->nick + " :"; + for (int i = 0; i < pcnt; i++) { userrec *u = ServerInstance->FindNick(parameters[i]); - if(u) + + if ((u) && (u->registered == REG_ALL)) { - if(*u->oper) - if(*user->oper) - snprintf(junk,MAXBUF,"%s*=+%s@%s ",u->nick,u->ident,u->host); - else - snprintf(junk,MAXBUF,"%s*=+%s@%s ",u->nick,u->ident,u->dhost); + retbuf = retbuf + " "; + + if (*u->oper) + { + retbuf = retbuf + "*=+"; + } else - if(*user->oper) - snprintf(junk,MAXBUF,"%s=+%s@%s ",u->nick,u->ident,u->host); - else - snprintf(junk,MAXBUF,"%s=+%s@%s ",u->nick,u->ident,u->dhost); + { + retbuf = retbuf + "=+"; + } + + retbuf = retbuf + u->ident + "@"; - strlcat(Return,junk,MAXBUF); + if (*user->oper) + { + retbuf = retbuf + u->host; + } + else + { + retbuf = retbuf + u->dhost; + } } } - user->WriteServ(Return); + + user->WriteServ(retbuf); + + return CMD_SUCCESS; }