#include "stdinc.h"
#include "client.h"
-#include "common.h"
#include "numeric.h"
#include "send.h"
#include "msg.h"
#include "s_conf.h"
#include "s_newconf.h"
-static int m_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
-static int me_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
-static int mo_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
static const char privs_desc[] = "Provides the PRIVS command to inspect an operator's privileges";
+static void m_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
+static void me_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
+static void mo_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[]);
+
struct Message privs_msgtab = {
"PRIVS", 0, 0, 0, 0,
{mg_unreg, {m_privs, 0}, mg_ignore, mg_ignore, {me_privs, 0}, {mo_privs, 0}}
NULL
};
-/* XXX this is a copy, not so nice */
+/* XXX this is a copy, not so nice
+ *
+ * Sort of... it's int in newconf.c since oper confs don't need 64-bit wide flags.
+ * --Elizafox
+ */
struct mode_table
{
const char *name;
- unsigned int mode;
+ uint64_t mode;
};
/* there is no such table like this anywhere else */
static struct mode_table auth_client_table[] = {
- {"resv_exempt", FLAGS2_EXEMPTRESV },
- {"kline_exempt", FLAGS2_EXEMPTKLINE },
- {"flood_exempt", FLAGS2_EXEMPTFLOOD },
- {"spambot_exempt", FLAGS2_EXEMPTSPAMBOT },
- {"shide_exempt", FLAGS2_EXEMPTSHIDE },
- {"jupe_exempt", FLAGS2_EXEMPTJUPE },
- {"extend_chans", FLAGS2_EXTENDCHANS },
+ {"resv_exempt", FLAGS_EXEMPTRESV },
+ {"kline_exempt", FLAGS_EXEMPTKLINE },
+ {"flood_exempt", FLAGS_EXEMPTFLOOD },
+ {"spambot_exempt", FLAGS_EXEMPTSPAMBOT },
+ {"shide_exempt", FLAGS_EXEMPTSHIDE },
+ {"jupe_exempt", FLAGS_EXEMPTJUPE },
+ {"extend_chans", FLAGS_EXTENDCHANS },
{NULL, 0}
};
p = &auth_client_table[0];
while (p->name != NULL)
{
- if (target_p->flags2 & p->mode)
+ if (target_p->flags & p->mode)
{
if (buf[0] != '\0')
rb_strlcat(buf, " ", sizeof buf);
target_p->name, buf);
}
-static int me_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+me_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Client *target_p;
if (!IsOper(source_p) || parc < 2 || EmptyString(parv[1]))
- return 0;
+ return;
/* we cannot show privs for remote clients */
if((target_p = find_person(parv[1])) && MyClient(target_p))
show_privs(source_p, target_p);
-
- return 0;
}
-static int mo_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+mo_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Client *target_p;
{
sendto_one_numeric(source_p, ERR_NOSUCHNICK,
form_str(ERR_NOSUCHNICK), parv[1]);
- return 0;
+ return;
}
}
get_id(source_p, target_p),
target_p->servptr->name,
use_id(target_p));
- return 0;
}
-static int m_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
+static void
+m_privs(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
if (parc >= 2 && !EmptyString(parv[1]) &&
irccmp(parv[1], source_p->name)) {
sendto_one_numeric(source_p, ERR_NOPRIVILEGES,
form_str(ERR_NOPRIVILEGES));
- return 0;
+ return;
}
show_privs(source_p, source_p);
- return 0;
}