summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2010-10-06 16:20:50 -0400
committerAdam <Adam@anope.org>2010-10-06 16:20:50 -0400
commit4c64c86ef4ddf9ff09c8f51f8a38e20f0513ae8d (patch)
tree747ade72b13bd960e4b404afe231c96e121677e9 /src
parentcb975f4a6c9199179ee8b0e6aec2c0951856709d (diff)
Fixed a potential crash from accessing invalid memory after unbanning people when checking whether a host is akick stuck. Fixes /cs unban not reapplying stuck ban masks.
Diffstat (limited to 'src')
-rw-r--r--src/actions.c9
-rw-r--r--src/botserv.c9
2 files changed, 14 insertions, 4 deletions
diff --git a/src/actions.c b/src/actions.c
index e464990aa..35ec93af3 100644
--- a/src/actions.c
+++ b/src/actions.c
@@ -184,11 +184,16 @@ void common_unban(ChannelInfo * ci, char *nick)
entry_match(ban, u->nick, u->username, u->chost, ip)) {
anope_cmd_mode(whosends(ci), ci->name, "-b %s", ban->mask);
if (ircdcap->tsmode)
- av[3] = ban->mask;
+ av[3] = sstrdup(ban->mask);
else
- av[2] = ban->mask;
+ av[2] = sstrdup(ban->mask);
do_cmode(whosends(ci), ac, av);
+
+ if (ircdcap->tsmode)
+ free(av[3]);
+ else
+ free(av[2]);
}
}
diff --git a/src/botserv.c b/src/botserv.c
index 0b2ad746c..605a0292e 100644
--- a/src/botserv.c
+++ b/src/botserv.c
@@ -789,11 +789,16 @@ void bot_join(ChannelInfo * ci)
anope_cmd_mode(whosends(ci), ci->name, "-b %s",
ban->mask);
if (ircdcap->tsmode)
- av[3] = ban->mask;
+ av[3] = sstrdup(ban->mask);
else
- av[2] = ban->mask;
+ av[2] = sstrdup(ban->mask);
do_cmode(whosends(ci), ac, av);
+
+ if (ircdcap->tsmode)
+ free(av[3]);
+ else
+ free(av[2]);
}
}