summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNei <ailin.nemui@gmail.com>2017-02-03 11:49:16 +0000
committerNei <ailin.nemui@gmail.com>2017-02-03 11:49:16 +0000
commitaab24cf4a4456682e82de4eb96e44472b7e237b2 (patch)
treeaab9d6a8052f613538c82651b7a26be728f67992
parent1ee25d228655e4a35114c3f9d0045c5efd5597cc (diff)
parent19c51789967a2f63da033e60f6ef08848b9cd144 (diff)
downloadirssi-aab24cf4a4456682e82de4eb96e44472b7e237b2.zip
Merge branch 'dub-the-wub' into 'master'
Prevent a memory leak during the processing of the SASL response. See merge request !8
-rw-r--r--src/irc/core/sasl.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/irc/core/sasl.c b/src/irc/core/sasl.c
index 1021bea4..635b7dfb 100644
--- a/src/irc/core/sasl.c
+++ b/src/irc/core/sasl.c
@@ -174,10 +174,16 @@ static gboolean sasl_reassemble_incoming(IRC_SERVER_REC *server, const char *fra
*decoded = g_string_new_len("", 0);
} else {
gsize dec_len;
- gchar *tmp;
-
- tmp = (gchar *) g_base64_decode(enc_req->str, &dec_len);
- *decoded = g_string_new_len(tmp, dec_len);
+ gint state = 0;
+ guint save = 0;
+
+ /* Since we're not going to use the enc_req GString anymore we
+ * can perform the decoding in place. */
+ dec_len = g_base64_decode_step(enc_req->str, enc_req->len,
+ (guchar *)enc_req->str,
+ &state, &save);
+ /* A copy of the data is made when the GString is created. */
+ *decoded = g_string_new_len(enc_req->str, dec_len);
}
g_string_free(enc_req, TRUE);