]> jfr.im git - solanum.git/blobdiff - modules/m_userhost.c
chmode: Get elevated access for op-only queries
[solanum.git] / modules / m_userhost.c
index e39866fed674b309a7b0e030cb68337186df1dea..6b0a9ac1f0a17272056cd2c5954402f309df5df5 100644 (file)
 #include "parse.h"
 #include "modules.h"
 #include "s_conf.h"
+#include "s_newconf.h"
 
-static char buf[BUFSIZE];
-
-static int m_userhost(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
 static const char userhost_desc[] =
        "Provides the USERHOST command to show a user's host";
 
+static char buf[BUFSIZE];
+
+static void m_userhost(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+
 struct Message userhost_msgtab = {
        "USERHOST", 0, 0, 0, 0,
        {mg_unreg, {m_userhost, 2}, mg_ignore, mg_ignore, mg_ignore, {m_userhost, 2}}
 };
 
 mapi_clist_av1 userhost_clist[] = { &userhost_msgtab, NULL };
+
 DECLARE_MODULE_AV2(userhost, NULL, NULL, userhost_clist, NULL, NULL, NULL, NULL, userhost_desc);
 
 /*
@@ -53,7 +56,7 @@ DECLARE_MODULE_AV2(userhost, NULL, NULL, userhost_clist, NULL, NULL, NULL, NULL,
  * the need for complicated requests like WHOIS. It returns user/host
  * information only (no spurious AWAY labels or channels).
  */
-static int
+static void
 m_userhost(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
 {
        struct Client *target_p;
@@ -83,7 +86,7 @@ m_userhost(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *sour
                        {
                                rl = sprintf(response, "%s%s=%c%s@%s ",
                                                target_p->name,
-                                               IsOper(target_p) ? "*" : "",
+                                               SeesOper(target_p, source_p) ? "*" : "",
                                                (target_p->user->away) ? '-' : '+',
                                                target_p->username,
                                                target_p->sockhost);
@@ -92,7 +95,7 @@ m_userhost(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *sour
                        {
                                rl = sprintf(response, "%s%s=%c%s@%s ",
                                                target_p->name,
-                                               IsOper(target_p) ? "*" : "",
+                                               SeesOper(target_p, source_p) ? "*" : "",
                                                (target_p->user->away) ? '-' : '+',
                                                target_p->username, target_p->host);
                        }
@@ -109,6 +112,4 @@ m_userhost(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *sour
        }
 
        sendto_one(source_p, "%s", buf);
-
-       return 0;
 }