#include "parse.h"
#include "modules.h"
#include "event.h"
+#include "reject.h"
static int mo_kline(struct Client *, struct Client *, int, const char **);
static int ms_kline(struct Client *, struct Client *, int, const char **);
const char *user, const char *host);
static void remove_permkline_match(struct Client *, struct ConfItem *);
static int flush_write(struct Client *, FILE *, const char *, const char *);
-static int remove_temp_kline(struct ConfItem *);
+static int remove_temp_kline(struct Client *, struct ConfItem *);
/* mo_kline()
*
return 0;
}
/* if we have cluster servers, send it to them.. */
- else if(dlink_list_length(&cluster_conf_list) > 0)
+ else if(rb_dlink_list_length(&cluster_conf_list) > 0)
cluster_generic(source_p, "KLINE",
(tkline_time > 0) ? SHARED_TKLINE : SHARED_PKLINE, CAP_KLN,
"%lu %s %s :%s",
if(tkline_time > 0)
{
- ircsnprintf(buffer, sizeof(buffer),
+ rb_snprintf(buffer, sizeof(buffer),
"Temporary K-line %d min. - %s (%s)",
(int) (tkline_time / 60), reason, current_date);
DupString(aconf->passwd, buffer);
}
else
{
- ircsnprintf(buffer, sizeof(buffer), "%s (%s)", reason, current_date);
+ rb_snprintf(buffer, sizeof(buffer), "%s (%s)", reason, current_date);
DupString(aconf->passwd, buffer);
apply_kline(source_p, aconf, reason, oper_reason, current_date);
}
if(tkline_time > 0)
{
- ircsnprintf(buffer, sizeof(buffer),
+ rb_snprintf(buffer, sizeof(buffer),
"Temporary K-line %d min. - %s (%s)",
(int) (tkline_time / 60), reason, current_date);
DupString(aconf->passwd, buffer);
}
else
{
- ircsnprintf(buffer, sizeof(buffer), "%s (%s)", reason, current_date);
+ rb_snprintf(buffer, sizeof(buffer), "%s (%s)", reason, current_date);
DupString(aconf->passwd, buffer);
apply_kline(source_p, aconf, reason, oper_reason, current_date);
}
if(match(parv[3], me.name) == 0)
return 0;
}
- else if(dlink_list_length(&cluster_conf_list) > 0)
+ else if(rb_dlink_list_length(&cluster_conf_list) > 0)
cluster_generic(source_p, "UNKLINE", SHARED_UNKLINE, CAP_UNKLN,
"%s %s", user, host);
return 0;
}
- if(remove_temp_kline(aconf))
- {
- sendto_one_notice(source_p, ":Un-klined [%s@%s] from temporary k-lines", user, host);
- sendto_realops_snomask(SNO_GENERAL, L_ALL,
- "%s has removed the temporary K-Line for: [%s@%s]",
- get_oper_name(source_p), user, host);
- ilog(L_KLINE, "UK %s %s %s",
- get_oper_name(source_p), user, host);
+ if(remove_temp_kline(source_p, aconf))
return 0;
- }
remove_permkline_match(source_p, aconf);
return;
}
- if(remove_temp_kline(aconf))
- {
- sendto_one_notice(source_p,
- ":Un-klined [%s@%s] from temporary k-lines",
- user, host);
-
- sendto_realops_snomask(SNO_GENERAL, L_ALL,
- "%s has removed the temporary K-Line for: [%s@%s]",
- get_oper_name(source_p), user, host);
-
- ilog(L_KLINE, "UK %s %s %s",
- get_oper_name(source_p), user, host);
+ if(remove_temp_kline(source_p, aconf))
return;
- }
remove_permkline_match(source_p, aconf);
}
static int
already_placed_kline(struct Client *source_p, const char *luser, const char *lhost, int tkline)
{
- const char *reason;
+ const char *reason, *p;
struct irc_sockaddr_storage iphost, *piphost;
struct ConfItem *aconf;
- int t;
- if(ConfigFileEntry.non_redundant_klines)
+ int t, bits;
+
+ aconf = find_exact_conf_by_address(lhost, CONF_KILL, luser);
+ if (aconf == NULL && ConfigFileEntry.non_redundant_klines)
{
- if((t = parse_netmask(lhost, (struct sockaddr *)&iphost, NULL)) != HM_HOST)
+ bits = 0;
+ if((t = parse_netmask(lhost, (struct sockaddr *)&iphost, &bits)) != HM_HOST)
{
#ifdef IPV6
if(t == HM_IPV6)
else
piphost = NULL;
- if((aconf = find_conf_by_address(lhost, NULL, NULL, (struct sockaddr *)piphost, CONF_KILL, t, luser)))
+ aconf = find_conf_by_address(lhost, NULL, NULL, (struct sockaddr *)piphost, CONF_KILL, t, luser);
+ if (aconf != NULL)
{
- /* setting a tkline, or existing one is perm */
- if(tkline || ((aconf->flags & CONF_FLAGS_TEMPORARY) == 0))
- {
- reason = aconf->passwd ? aconf->passwd : "<No Reason>";
+ /* The above was really a lookup of a single IP,
+ * so check if the new kline is wider than the
+ * existing one.
+ * -- jilles
+ */
+ p = strchr(aconf->host, '/');
+ if (bits > 0 && (p == NULL || bits < atoi(p + 1)))
+ aconf = NULL;
+ }
+ }
+ if (aconf != NULL)
+ {
+ /* setting a tkline, or existing one is perm */
+ if(tkline || ((aconf->flags & CONF_FLAGS_TEMPORARY) == 0))
+ {
+ reason = aconf->passwd ? aconf->passwd : "<No Reason>";
- sendto_one_notice(source_p,
- ":[%s@%s] already K-Lined by [%s@%s] - %s",
- luser, lhost, aconf->user,
- aconf->host, reason);
- return 1;
- }
+ sendto_one_notice(source_p,
+ ":[%s@%s] already K-Lined by [%s@%s] - %s",
+ luser, lhost, aconf->user,
+ aconf->host, reason);
+ return 1;
}
}
host = aconf->host;
user = aconf->user;
- ircsnprintf(temppath, sizeof(temppath),
+ rb_snprintf(temppath, sizeof(temppath),
"%s.tmp", ConfigFileEntry.klinefile);
filename = get_conf_name(KLINE_TYPE);
ilog(L_KLINE, "UK %s %s %s",
get_oper_name(source_p), user, host);
+ remove_reject_mask(aconf->user, aconf->host);
delete_one_address_conf(aconf->host, aconf);
return;
* side effects - tries to unkline anything that matches
*/
static int
-remove_temp_kline(struct ConfItem *aconf)
+remove_temp_kline(struct Client *source_p, struct ConfItem *aconf)
{
- dlink_node *ptr;
+ rb_dlink_node *ptr;
int i;
for (i = 0; i < LAST_TEMP_TYPE; i++)
{
- DLINK_FOREACH(ptr, temp_klines[i].head)
+ RB_DLINK_FOREACH(ptr, temp_klines[i].head)
{
if (aconf == ptr->data)
{
+ sendto_one_notice(source_p,
+ ":Un-klined [%s@%s] from temporary k-lines",
+ aconf->user, aconf->host);
+ sendto_realops_snomask(SNO_GENERAL, L_ALL,
+ "%s has removed the temporary K-Line for: [%s@%s]",
+ get_oper_name(source_p), aconf->user, aconf->host);
+
+ ilog(L_KLINE, "UK %s %s %s",
+ get_oper_name(source_p),
+ aconf->user, aconf->host);
dlinkDestroy(ptr, &temp_klines[i]);
+ remove_reject_mask(aconf->user, aconf->host);
delete_one_address_conf(aconf->host, aconf);
return YES;
}