X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcmd_userhost.cpp;h=8a0e187fb0a4503b7fdd13e32bc5add9ee924e8d;hb=2b3394855d5adddb16285b905503d9ffe5a1d963;hp=4c94dcb909240dccffe95173ff303b99e61877d2;hpb=d54fd9b1e6b31f69332a9241b5f17330c0ad61e0;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/cmd_userhost.cpp b/src/cmd_userhost.cpp index 4c94dcb90..8a0e187fb 100644 --- a/src/cmd_userhost.cpp +++ b/src/cmd_userhost.cpp @@ -2,45 +2,61 @@ * | 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 "users.h" #include "inspircd.h" #include "commands/cmd_userhost.h" -void cmd_userhost::Handle (const char** parameters, int pcnt, userrec *user) +extern "C" DllExport command_t* init_command(InspIRCd* Instance) { - char Return[MAXBUF],junk[MAXBUF]; - snprintf(Return,MAXBUF,"302 %s :",user->nick); + return new cmd_userhost(Instance); +} + +CmdResult cmd_userhost::Handle (const char** parameters, int pcnt, userrec *user) +{ + std::string retbuf = std::string("302 ") + user->nick + " :"; + for (int i = 0; i < pcnt; i++) { userrec *u = ServerInstance->FindNick(parameters[i]); + 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 + u->nick; + + if (IS_OPER(u)) + { + 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 + "=+"; + } - strlcat(Return,junk,MAXBUF); + retbuf = retbuf + u->ident + "@"; + + if (IS_OPER(user)) + { + retbuf = retbuf + u->host; + } + else + { + retbuf = retbuf + u->dhost; + } + + retbuf = retbuf + " "; } } - user->WriteServ(Return); + + user->WriteServ(retbuf); + + return CMD_SUCCESS; }