Allow remote DIE and RESTART (from ircd-seven)

This commit is contained in:
William Pitcock 2016-01-12 00:04:54 -06:00
parent 3b1c2aa62c
commit cc7ae51cdc
6 changed files with 92 additions and 4 deletions

View file

@ -672,6 +672,7 @@ shared {
* tdline - allow setting temp dlines * tdline - allow setting temp dlines
* undline - allow removing dlines * undline - allow removing dlines
* grant - allow granting operator status * grant - allow granting operator status
* die - allow remote DIE/RESTART
* none - disallow everything * none - disallow everything
*/ */

View file

@ -97,6 +97,7 @@ struct remote_conf
#define SHARED_PDLINE 0x1000 #define SHARED_PDLINE 0x1000
#define SHARED_UNDLINE 0x2000 #define SHARED_UNDLINE 0x2000
#define SHARED_GRANT 0x4000 #define SHARED_GRANT 0x4000
#define SHARED_DIE 0x8000
#define SHARED_ALL (SHARED_TKLINE | SHARED_PKLINE | SHARED_UNKLINE |\ #define SHARED_ALL (SHARED_TKLINE | SHARED_PKLINE | SHARED_UNKLINE |\
SHARED_PXLINE | SHARED_TXLINE | SHARED_UNXLINE |\ SHARED_PXLINE | SHARED_TXLINE | SHARED_UNXLINE |\

View file

@ -390,6 +390,7 @@ static struct mode_table shared_table[] =
{ "locops", SHARED_LOCOPS }, { "locops", SHARED_LOCOPS },
{ "rehash", SHARED_REHASH }, { "rehash", SHARED_REHASH },
{ "grant", SHARED_GRANT }, { "grant", SHARED_GRANT },
{ "die", SHARED_DIE },
{ "all", SHARED_ALL }, { "all", SHARED_ALL },
{ "none", 0 }, { "none", 0 },
{NULL, 0} {NULL, 0}

View file

@ -36,12 +36,15 @@
#include "parse.h" #include "parse.h"
#include "modules.h" #include "modules.h"
#include "s_newconf.h" #include "s_newconf.h"
#include "hash.h"
static int mo_die(struct Client *, struct Client *, int, const char **); static int mo_die(struct Client *, struct Client *, int, const char **);
static int me_die(struct Client *, struct Client *, int, const char **);
static int do_die(struct Client *, const char *);
static struct Message die_msgtab = { static struct Message die_msgtab = {
"DIE", 0, 0, 0, MFLG_SLOW, "DIE", 0, 0, 0, MFLG_SLOW,
{mg_unreg, mg_not_oper, mg_ignore, mg_ignore, mg_ignore, {mo_die, 0}} {mg_unreg, mg_not_oper, mg_ignore, mg_ignore, {me_die, 1}, {mo_die, 0}}
}; };
mapi_clist_av1 die_clist[] = { &die_msgtab, NULL }; mapi_clist_av1 die_clist[] = { &die_msgtab, NULL };
@ -65,7 +68,44 @@ mo_die(struct Client *client_p __unused, struct Client *source_p, int parc, cons
sendto_one_notice(source_p, ":Need server name /die %s", me.name); sendto_one_notice(source_p, ":Need server name /die %s", me.name);
return 0; return 0;
} }
else if(irccmp(parv[1], me.name))
if(parc > 2)
{
/* Remote die. Pass it along. */
struct Client *server_p = find_server(NULL, parv[2]);
if (!server_p)
{
sendto_one_numeric(source_p, ERR_NOSUCHSERVER, form_str(ERR_NOSUCHSERVER), parv[2]);
return 0;
}
if (!IsMe(server_p))
{
sendto_one(server_p, ":%s ENCAP %s DIE %s", source_p->name, parv[2], parv[1]);
return 0;
}
}
return do_die(source_p, parv[1]);
}
static int
me_die(struct Client *client_p __unused, struct Client *source_p, int parc, const char *parv[])
{
if(!find_shared_conf(source_p->username, source_p->host, source_p->servptr->name, SHARED_DIE))
{
sendto_one_notice(source_p, ":*** You do not have an appropriate shared block to "
"remotely shut down this server.");
return 0;
}
return do_die(source_p, parv[1]);
}
static int
do_die(struct Client *source_p, const char *servername)
{
if(irccmp(servername, me.name))
{ {
sendto_one_notice(source_p, ":Mismatch on /die %s", me.name); sendto_one_notice(source_p, ":Mismatch on /die %s", me.name);
return 0; return 0;

View file

@ -38,12 +38,15 @@
#include "msg.h" #include "msg.h"
#include "parse.h" #include "parse.h"
#include "modules.h" #include "modules.h"
#include "hash.h"
static int mo_restart(struct Client *, struct Client *, int, const char **); static int mo_restart(struct Client *, struct Client *, int, const char **);
static int me_restart(struct Client *, struct Client *, int, const char **);
static int do_restart(struct Client *source_p, const char *servername);
struct Message restart_msgtab = { struct Message restart_msgtab = {
"RESTART", 0, 0, 0, MFLG_SLOW, "RESTART", 0, 0, 0, MFLG_SLOW,
{mg_unreg, mg_not_oper, mg_ignore, mg_ignore, mg_ignore, {mo_restart, 0}} {mg_unreg, mg_not_oper, mg_ignore, mg_ignore, {me_restart, 1}, {mo_restart, 0}}
}; };
mapi_clist_av1 restart_clist[] = { &restart_msgtab, NULL }; mapi_clist_av1 restart_clist[] = { &restart_msgtab, NULL };
@ -72,7 +75,48 @@ mo_restart(struct Client *client_p, struct Client *source_p, int parc, const cha
sendto_one_notice(source_p, ":Need server name /restart %s", me.name); sendto_one_notice(source_p, ":Need server name /restart %s", me.name);
return 0; return 0;
} }
else if(irccmp(parv[1], me.name))
if(parc > 2)
{
/* Remote restart. Pass it along. */
struct Client *server_p = find_server(NULL, parv[2]);
if (!server_p)
{
sendto_one_numeric(source_p, ERR_NOSUCHSERVER, form_str(ERR_NOSUCHSERVER), parv[2]);
return 0;
}
if (!IsMe(server_p))
{
sendto_one(server_p, ":%s ENCAP %s RESTART %s", source_p->name, parv[2], parv[1]);
return 0;
}
}
return do_restart(source_p, parv[1]);
}
static int
me_restart(struct Client *client_p __unused, struct Client *source_p, int parc, const char *parv[])
{
if(!find_shared_conf(source_p->username, source_p->host, source_p->servptr->name, SHARED_DIE))
{
sendto_one_notice(source_p, ":*** You do not have an appropriate shared block to "
"remotely restart this server.");
return 0;
}
return do_restart(source_p, parv[1]);
}
static int
do_restart(struct Client *source_p, const char *servername)
{
char buf[BUFSIZE];
rb_dlink_node *ptr;
struct Client *target_p;
if(irccmp(servername, me.name))
{ {
sendto_one_notice(source_p, ":Mismatch on /restart %s", me.name); sendto_one_notice(source_p, ":Mismatch on /restart %s", me.name);
return 0; return 0;

View file

@ -1054,6 +1054,7 @@ static struct shared_flags shared_flagtable[] =
{ SHARED_PDLINE, 'D' }, { SHARED_PDLINE, 'D' },
{ SHARED_UNDLINE, 'E' }, { SHARED_UNDLINE, 'E' },
{ SHARED_GRANT, 'G' }, { SHARED_GRANT, 'G' },
{ SHARED_DIE, 'I' },
{ 0, '\0'} { 0, '\0'}
}; };