[svn] Prevent too wide klines with CIDR masks.

This commit is contained in:
jilles 2007-05-19 16:36:51 -07:00
parent 598ebb42c7
commit 88a2a1484b
3 changed files with 29 additions and 8 deletions

View File

@ -1,3 +1,12 @@
jilles 2007/05/19 22:21:10 UTC (20070519-3464)
Log:
Exempt klines with a fixed user@ (no */?) from min_nonwildcard checks.
Changes: Modified:
+4 -0 trunk/modules/m_kline.c (File Modified)
jilles 2007/05/18 20:31:33 UTC (20070518-3460) jilles 2007/05/18 20:31:33 UTC (20070518-3460)
Log: Log:
- fold conf_connect_allowed() into accept_connection() - fold conf_connect_allowed() into accept_connection()

View File

@ -1 +1 @@
#define SERNO "20070518-3460" #define SERNO "20070519-3464"

View File

@ -21,7 +21,7 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA * USA
* *
* $Id: m_kline.c 3464 2007-05-19 22:21:10Z jilles $ * $Id: m_kline.c 3466 2007-05-19 23:36:51Z jilles $
*/ */
#include "stdinc.h" #include "stdinc.h"
@ -65,7 +65,7 @@ struct Message unkline_msgtab = {
}; };
mapi_clist_av1 kline_clist[] = { &kline_msgtab, &unkline_msgtab, NULL }; mapi_clist_av1 kline_clist[] = { &kline_msgtab, &unkline_msgtab, NULL };
DECLARE_MODULE_AV1(kline, NULL, NULL, kline_clist, NULL, NULL, "$Revision: 3464 $"); DECLARE_MODULE_AV1(kline, NULL, NULL, kline_clist, NULL, NULL, "$Revision: 3466 $");
/* Local function prototypes */ /* Local function prototypes */
static int find_user_host(struct Client *source_p, const char *userhost, char *user, char *host); static int find_user_host(struct Client *source_p, const char *userhost, char *user, char *host);
@ -614,6 +614,7 @@ valid_wild_card(struct Client *source_p, const char *luser, const char *lhost)
const char *p; const char *p;
char tmpch; char tmpch;
int nonwild = 0; int nonwild = 0;
int bitlen;
/* user has no wildcards, always accept -- jilles */ /* user has no wildcards, always accept -- jilles */
if (!strchr(luser, '?') && !strchr(luser, '*')) if (!strchr(luser, '?') && !strchr(luser, '*'))
@ -632,6 +633,16 @@ valid_wild_card(struct Client *source_p, const char *luser, const char *lhost)
} }
/* try host, as user didnt contain enough */ /* try host, as user didnt contain enough */
/* special case for cidr masks -- jilles */
if ((p = strrchr(lhost, '/')) != NULL && IsDigit(p[1]))
{
bitlen = atoi(p + 1);
/* much like non-cidr for ipv6, rather arbitrary for ipv4 */
if (bitlen > 0 && bitlen >= (strchr(lhost, ':') ? 4 * (ConfigFileEntry.min_nonwildcard - nonwild) : 6 - 2 * nonwild))
return 1;
}
else
{
p = lhost; p = lhost;
while ((tmpch = *p++)) while ((tmpch = *p++))
{ {
@ -639,6 +650,7 @@ valid_wild_card(struct Client *source_p, const char *luser, const char *lhost)
if(++nonwild >= ConfigFileEntry.min_nonwildcard) if(++nonwild >= ConfigFileEntry.min_nonwildcard)
return 1; return 1;
} }
}
sendto_one_notice(source_p, sendto_one_notice(source_p,
":Please include at least %d non-wildcard " ":Please include at least %d non-wildcard "