diff --git a/include/channel.h b/include/channel.h index 553a928..ed04505 100644 --- a/include/channel.h +++ b/include/channel.h @@ -191,6 +191,7 @@ typedef int (*ExtbanFunc)(const char *data, struct Client *client_p, #define MODE_NOREJOIN 0x200000 /* Block rejoin immediately after kick */ #define MODE_NOREPEAT 0x400000 /* Block repeat messages */ #define MODE_NOOPERKICK 0x800000 /* disallow kicking opers */ +#define MODE_HIDEBANS 0x1000000 /* disallow non-chanops from seeing ban/quiet lists */ #define CHFL_BAN 0x10000000 /* ban channel flag */ #define CHFL_EXCEPTION 0x20000000 /* exception to ban channel flag */ diff --git a/src/chmode.c b/src/chmode.c index f9b3e10..7424251 100644 --- a/src/chmode.c +++ b/src/chmode.c @@ -907,6 +907,12 @@ chm_ban(struct Client *source_p, struct Channel *chptr, } } + if(chptr->mode.mode & MODE_HIDEBANS) { + if(alevel != CHFL_CHANOP && alevel != CHFL_ADMIN && alevel != CHFL_HALFOP && alevel != CHFL_OWNER) { + goto skiplistdone; + } + } + RB_DLINK_FOREACH(ptr, list->head) { banptr = ptr->data; @@ -914,6 +920,7 @@ chm_ban(struct Client *source_p, struct Channel *chptr, me.name, source_p->name, chptr->chname, banptr->banstr, banptr->who, banptr->when); } +skiplistdone: sendto_one(source_p, form_str(rpl_endlist), me.name, source_p->name, chptr->chname); return; } @@ -2004,7 +2011,7 @@ struct ChannelMode chmode_table[256] = {chm_simple, MODE_REGONLY }, /* r */ {chm_simple, MODE_SECRET }, /* s */ {chm_simple, MODE_TOPICLIMIT }, /* t */ - {chm_nosuch, 0 }, /* u */ + {chm_simple, MODE_HIDEBANS }, /* u */ {chm_voice, 0 }, /* v */ {chm_nosuch, 0 }, /* w */ {chm_nosuch, 0 }, /* x */