Add general::stats_l_oper_only

This commit is contained in:
Ed Kellett 2020-11-08 17:37:52 +00:00
parent a922755512
commit 63ab1dd609
4 changed files with 53 additions and 8 deletions

View file

@ -140,6 +140,12 @@ struct ConfItem
#define IsConfAllowSCTP(x) ((x)->flags & CONF_FLAGS_ALLOW_SCTP) #define IsConfAllowSCTP(x) ((x)->flags & CONF_FLAGS_ALLOW_SCTP)
#define IsConfKlineSpoof(x) ((x)->flags & CONF_FLAGS_KLINE_SPOOF) #define IsConfKlineSpoof(x) ((x)->flags & CONF_FLAGS_KLINE_SPOOF)
enum stats_l_oper_only {
STATS_L_OPER_ONLY_NO,
STATS_L_OPER_ONLY_SELF,
STATS_L_OPER_ONLY_YES,
};
/* flag definitions for opers now in client.h */ /* flag definitions for opers now in client.h */
struct config_file_entry struct config_file_entry
@ -191,6 +197,7 @@ struct config_file_entry
int stats_h_oper_only; int stats_h_oper_only;
int stats_o_oper_only; int stats_o_oper_only;
int stats_k_oper_only; int stats_k_oper_only;
enum stats_l_oper_only stats_l_oper_only;
int stats_i_oper_only; int stats_i_oper_only;
int stats_P_oper_only; int stats_P_oper_only;
int map_oper_only; int map_oper_only;

View file

@ -1542,6 +1542,21 @@ conf_set_general_stats_i_oper_only(void *data)
conf_report_error("Invalid setting '%s' for general::stats_i_oper_only.", val); conf_report_error("Invalid setting '%s' for general::stats_i_oper_only.", val);
} }
static void
conf_set_general_stats_l_oper_only(void *data)
{
char *val = data;
if(rb_strcasecmp(val, "yes") == 0)
ConfigFileEntry.stats_l_oper_only = STATS_L_OPER_ONLY_YES;
else if(rb_strcasecmp(val, "self") == 0)
ConfigFileEntry.stats_l_oper_only = STATS_L_OPER_ONLY_SELF;
else if(rb_strcasecmp(val, "no") == 0)
ConfigFileEntry.stats_l_oper_only = STATS_L_OPER_ONLY_NO;
else
conf_report_error("Invalid setting '%s' for general::stats_l_oper_only.", val);
}
static void static void
conf_set_general_compression_level(void *data) conf_set_general_compression_level(void *data)
{ {
@ -2651,8 +2666,9 @@ static struct ConfEntry conf_general_table[] =
{ "compression_level", CF_INT, conf_set_general_compression_level, 0, NULL }, { "compression_level", CF_INT, conf_set_general_compression_level, 0, NULL },
{ "havent_read_conf", CF_YESNO, conf_set_general_havent_read_conf, 0, NULL }, { "havent_read_conf", CF_YESNO, conf_set_general_havent_read_conf, 0, NULL },
{ "hide_error_messages",CF_STRING, conf_set_general_hide_error_messages,0, NULL }, { "hide_error_messages",CF_STRING, conf_set_general_hide_error_messages,0, NULL },
{ "stats_k_oper_only", CF_STRING, conf_set_general_stats_k_oper_only, 0, NULL },
{ "stats_i_oper_only", CF_STRING, conf_set_general_stats_i_oper_only, 0, NULL }, { "stats_i_oper_only", CF_STRING, conf_set_general_stats_i_oper_only, 0, NULL },
{ "stats_k_oper_only", CF_STRING, conf_set_general_stats_k_oper_only, 0, NULL },
{ "stats_l_oper_only", CF_STRING, conf_set_general_stats_l_oper_only, 0, NULL },
{ "default_umodes", CF_QSTRING, conf_set_general_default_umodes, 0, NULL }, { "default_umodes", CF_QSTRING, conf_set_general_default_umodes, 0, NULL },
{ "default_operstring", CF_QSTRING, NULL, REALLEN, &ConfigFileEntry.default_operstring }, { "default_operstring", CF_QSTRING, NULL, REALLEN, &ConfigFileEntry.default_operstring },

View file

@ -738,6 +738,7 @@ set_default_conf(void)
ConfigFileEntry.stats_e_disabled = false; ConfigFileEntry.stats_e_disabled = false;
ConfigFileEntry.stats_o_oper_only = false; ConfigFileEntry.stats_o_oper_only = false;
ConfigFileEntry.stats_k_oper_only = 1; /* masked */ ConfigFileEntry.stats_k_oper_only = 1; /* masked */
ConfigFileEntry.stats_l_oper_only = 1; /* self */
ConfigFileEntry.stats_i_oper_only = 1; /* masked */ ConfigFileEntry.stats_i_oper_only = 1; /* masked */
ConfigFileEntry.stats_P_oper_only = false; ConfigFileEntry.stats_P_oper_only = false;
ConfigFileEntry.stats_c_oper_only = false; ConfigFileEntry.stats_c_oper_only = false;

View file

@ -1523,12 +1523,17 @@ stats_ltrace(struct Client *source_p, int parc, const char *parv[])
const char *name; const char *name;
char statchar = parv[1][0]; char statchar = parv[1][0];
if (ConfigFileEntry.stats_l_oper_only == STATS_L_OPER_ONLY_YES && !IsOperGeneral(source_p))
{
sendto_one_numeric(source_p, ERR_NOPRIVILEGES, form_str(ERR_NOPRIVILEGES));
return;
}
/* this is def targeted at us somehow.. */ /* this is def targeted at us somehow.. */
if(parc > 2 && !EmptyString(parv[2])) if (parc > 2 && !EmptyString(parv[2]))
{ {
/* directed at us generically? */ /* directed at us generically? */
if(match(parv[2], me.name) || if (match(parv[2], me.name) || (!MyClient(source_p) && !irccmp(parv[2], me.id)))
(!MyClient(source_p) && !irccmp(parv[2], me.id)))
{ {
name = me.name; name = me.name;
doall = true; doall = true;
@ -1540,24 +1545,31 @@ stats_ltrace(struct Client *source_p, int parc, const char *parv[])
} }
/* must be directed at a specific person thats not us */ /* must be directed at a specific person thats not us */
if(!doall && !wilds) if (!doall && !wilds)
{ {
struct Client *target_p; struct Client *target_p;
if(MyClient(source_p)) if (MyClient(source_p))
target_p = find_named_person(name); target_p = find_named_person(name);
else else
target_p = find_person(name); target_p = find_person(name);
if(target_p != NULL) if (target_p != source_p && ConfigFileEntry.stats_l_oper_only != STATS_L_OPER_ONLY_NO
&& !IsOperGeneral(source_p))
{
sendto_one_numeric(source_p, ERR_NOPRIVILEGES, form_str(ERR_NOPRIVILEGES));
}
else if (target_p != NULL)
{ {
stats_spy(source_p, statchar, target_p->name); stats_spy(source_p, statchar, target_p->name);
stats_l_client(source_p, target_p, statchar); stats_l_client(source_p, target_p, statchar);
} }
else else
{
sendto_one_numeric(source_p, ERR_NOSUCHSERVER, sendto_one_numeric(source_p, ERR_NOSUCHSERVER,
form_str(ERR_NOSUCHSERVER), form_str(ERR_NOSUCHSERVER),
name); name);
}
return; return;
} }
@ -1570,7 +1582,16 @@ stats_ltrace(struct Client *source_p, int parc, const char *parv[])
stats_spy(source_p, statchar, name); stats_spy(source_p, statchar, name);
if(doall) if (ConfigFileEntry.stats_l_oper_only != STATS_L_OPER_ONLY_NO && !IsOperGeneral(source_p))
{
if (doall && MyClient(source_p))
stats_l_client(source_p, source_p, statchar);
else
sendto_one_numeric(source_p, ERR_NOPRIVILEGES, form_str(ERR_NOPRIVILEGES));
return;
}
if (doall)
{ {
/* local opers get everyone */ /* local opers get everyone */
if(MyOper(source_p)) if(MyOper(source_p))