#include "modules.h"
#include "s_newconf.h"
+static const char kill_desc[] = "Provides the KILL command to remove a user from the network";
+
static int h_can_kill;
static char buf[BUFSIZE];
-static int ms_kill(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
-static int mo_kill(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void ms_kill(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
+static void mo_kill(struct MsgBuf *, struct Client *, struct Client *, int, const char **);
static void relay_kill(struct Client *, struct Client *, struct Client *,
const char *, const char *);
{ NULL, NULL},
};
-DECLARE_MODULE_AV1(kill, NULL, NULL, kill_clist, kill_hlist, NULL, "$Revision: 3408 $");
+DECLARE_MODULE_AV2(kill, NULL, NULL, kill_clist, kill_hlist, NULL, NULL, NULL, kill_desc);
/*
** mo_kill
** parv[1] = kill victim
** parv[2] = kill path
*/
-static int
+static void
mo_kill(struct MsgBuf *msgbuf_p, struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
struct Client *target_p;
user = parv[1];
- if(!IsOperLocalKill(source_p))
+ if(!IsOperKill(source_p))
{
- sendto_one(source_p, form_str(ERR_NOPRIVS), me.name, source_p->name, "local_kill");
- return 0;
+ sendto_one(source_p, form_str(ERR_NOPRIVS), me.name, source_p->name, "kill");
+ return;
}
if(!EmptyString(parv[2]))
else
sendto_one_numeric(source_p, ERR_NOSUCHNICK,
form_str(ERR_NOSUCHNICK), user);
- return 0;
+ return;
}
sendto_one_notice(source_p, ":KILL changed from %s to %s", user, target_p->name);
}
- if(!MyConnect(target_p) && (!IsOperGlobalKill(source_p)))
- {
- sendto_one_notice(source_p, ":Nick %s is not on your server "
- "and you do not have the global_kill flag",
- target_p->name);
- return 0;
- }
-
/* Last chance to stop the kill */
moduledata.client = source_p;
moduledata.target = target_p;
if (moduledata.approved == 0)
/* The callee should have sent a message. */
- return 0;
+ return;
if(MyConnect(target_p))
sendto_one(target_p, ":%s!%s@%s KILL %s :%s",
sprintf(buf, "Killed (%s (%s))", source_p->name, reason);
exit_client(client_p, target_p, source_p, buf);
-
- return 0;
}
/*
* parv[1] = kill victim
* parv[2] = kill path and reason
*/
-static int
+static void
ms_kill(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), IsDigit(*user) ? "*" : user);
- return 0;
+ return;
}
sendto_one_notice(source_p, ":KILL changed from %s to %s", user, target_p->name);
}
if(IsServer(target_p) || IsMe(target_p))
{
sendto_one_numeric(source_p, ERR_CANTKILLSERVER, form_str(ERR_CANTKILLSERVER));
- return 0;
+ return;
}
if(MyConnect(target_p))
sprintf(buf, "Killed (%s %s)", source_p->name, reason);
exit_client(client_p, target_p, source_p, buf);
-
- return 0;
}
static void