summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteve Holme <steve_holme@hotmail.com>2015-01-03 17:25:11 +0000
committerSteve Holme <steve_holme@hotmail.com>2015-01-03 18:46:30 +0000
commit4967109ffc7380278099d48c3bf78a2468978d98 (patch)
tree1bb820d37e3e23dc996675bfd3b3887cd5ab32a1
parenta68aa81320aca4d376fe2a43ee8c76a6eb6b8f01 (diff)
downloadgnurl-4967109ffc7380278099d48c3bf78a2468978d98.tar.gz
gnurl-4967109ffc7380278099d48c3bf78a2468978d98.tar.bz2
gnurl-4967109ffc7380278099d48c3bf78a2468978d98.zip
ldap: Fixed attribute memory leaks on failed client write
Fixed memory leaks from commit 086ad79970 as was noted in the commit comments.
-rw-r--r--lib/ldap.c60
1 files changed, 53 insertions, 7 deletions
diff --git a/lib/ldap.c b/lib/ldap.c
index 80c2ddb09..c31adcf4f 100644
--- a/lib/ldap.c
+++ b/lib/ldap.c
@@ -413,6 +413,7 @@ static CURLcode Curl_ldap(struct connectdata *conn, bool *done)
ldap_memfree(dn);
}
+ /* Get the attributes and write them to the client */
for(attribute = ldap_first_attribute(server, entryIterator, &ber);
attribute;
attribute = ldap_next_attribute(server, entryIterator, ber)) {
@@ -421,17 +422,36 @@ static CURLcode Curl_ldap(struct connectdata *conn, bool *done)
if(vals != NULL) {
for(i = 0; (vals[i] != NULL); i++) {
result = Curl_client_write(conn, CLIENTWRITE_BODY, (char *)"\t", 1);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
result = Curl_client_write(conn, CLIENTWRITE_BODY,
(char *)attribute, 0);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
result = Curl_client_write(conn, CLIENTWRITE_BODY, (char *)": ", 2);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
+
dlsize += strlen(attribute)+3;
if((strlen(attribute) > 7) &&
@@ -452,37 +472,63 @@ static CURLcode Curl_ldap(struct connectdata *conn, bool *done)
result = error;
goto quit;
}
+
if(val_b64_sz > 0) {
result = Curl_client_write(conn, CLIENTWRITE_BODY, val_b64,
val_b64_sz);
free(val_b64);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
+
dlsize += val_b64_sz;
}
}
else {
result = Curl_client_write(conn, CLIENTWRITE_BODY, vals[i]->bv_val,
vals[i]->bv_len);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
+
dlsize += vals[i]->bv_len;
}
+
result = Curl_client_write(conn, CLIENTWRITE_BODY, (char *)"\n", 0);
- if(result)
+ if(result) {
+ ldap_value_free_len(vals);
+ ldap_memfree(attribute);
+ if(ber)
+ ber_free(ber, 0);
+
goto quit;
+ }
+
dlsize++;
}
/* Free memory used to store values */
ldap_value_free_len(vals);
}
+
+ /* Free the attribute as we are done with it */
+ ldap_memfree(attribute);
+
result = Curl_client_write(conn, CLIENTWRITE_BODY, (char *)"\n", 1);
if(result)
goto quit;
dlsize++;
Curl_pgrsSetDownloadCounter(data, dlsize);
- ldap_memfree(attribute);
}
if(ber)