diff options
author | attilamolnar <attilamolnar@hush.com> | 2013-06-06 01:07:22 +0200 |
---|---|---|
committer | attilamolnar <attilamolnar@hush.com> | 2013-06-06 01:07:22 +0200 |
commit | d9d99cd02dadf34bfcc220734ba0c422f0acb3e6 (patch) | |
tree | 72a11fab75875b7e4f739ddd203da60e5dcbc851 /src/modules/m_userip.cpp | |
parent | 8a06d54076551387f83a29360478ee6605e241b6 (diff) | |
parent | e0ff94b310e9b73ac0131e9df14fb7ca2bf3a878 (diff) |
Merge insp20
Diffstat (limited to 'src/modules/m_userip.cpp')
-rw-r--r-- | src/modules/m_userip.cpp | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/src/modules/m_userip.cpp b/src/modules/m_userip.cpp index 7cc2fa04d..670e9a9d7 100644 --- a/src/modules/m_userip.cpp +++ b/src/modules/m_userip.cpp @@ -30,19 +30,37 @@ class CommandUserip : public Command public: CommandUserip(Module* Creator) : Command(Creator,"USERIP", 1) { - flags_needed = 'o'; syntax = "<nick>{,<nick>}"; + syntax = "<nick>{,<nick>}"; } CmdResult Handle (const std::vector<std::string> ¶meters, User *user) { std::string retbuf = "340 " + user->nick + " :"; int nicks = 0; + bool checked_privs = false; + bool has_privs; for (int i = 0; i < (int)parameters.size(); i++) { User *u = ServerInstance->FindNick(parameters[i]); if ((u) && (u->registered == REG_ALL)) { + // Anyone may query their own IP + if (u != user) + { + if (!checked_privs) + { + // Do not trigger the insufficient priviliges message more than once + checked_privs = true; + has_privs = user->HasPrivPermission("users/auspex"); + if (!has_privs) + user->WriteNumeric(ERR_NOPRIVILEGES, "%s :Permission Denied - You do not have the required operator privileges",user->nick.c_str()); + } + + if (!has_privs) + continue; + } + retbuf = retbuf + u->nick + (u->IsOper() ? "*" : "") + "="; if (u->IsAway()) retbuf += "-"; @@ -56,7 +74,6 @@ class CommandUserip : public Command if (nicks != 0) user->WriteServ(retbuf); - /* Dont send to the network */ return CMD_SUCCESS; } }; |