Unverified Commit d7ffd573 authored by Billy's avatar Billy Committed by GitHub

Fixes stream load memory leak in WifiSecureClient for SSL CACert, Certificate, and (#6387)

Private Key. Issue presented during any subsequent invocation of loadCACert, loadCertificate, and
loadPrivateKey, respectively, after the first invocation.
parent b88a70a0
...@@ -315,6 +315,7 @@ char *WiFiClientSecure::_streamLoad(Stream& stream, size_t size) { ...@@ -315,6 +315,7 @@ char *WiFiClientSecure::_streamLoad(Stream& stream, size_t size) {
} }
bool WiFiClientSecure::loadCACert(Stream& stream, size_t size) { bool WiFiClientSecure::loadCACert(Stream& stream, size_t size) {
if (_CA_cert != NULL) free(const_cast<char*>(_CA_cert));
char *dest = _streamLoad(stream, size); char *dest = _streamLoad(stream, size);
bool ret = false; bool ret = false;
if (dest) { if (dest) {
...@@ -325,6 +326,7 @@ bool WiFiClientSecure::loadCACert(Stream& stream, size_t size) { ...@@ -325,6 +326,7 @@ bool WiFiClientSecure::loadCACert(Stream& stream, size_t size) {
} }
bool WiFiClientSecure::loadCertificate(Stream& stream, size_t size) { bool WiFiClientSecure::loadCertificate(Stream& stream, size_t size) {
if (_cert != NULL) free(const_cast<char*>(_cert));
char *dest = _streamLoad(stream, size); char *dest = _streamLoad(stream, size);
bool ret = false; bool ret = false;
if (dest) { if (dest) {
...@@ -335,6 +337,7 @@ bool WiFiClientSecure::loadCertificate(Stream& stream, size_t size) { ...@@ -335,6 +337,7 @@ bool WiFiClientSecure::loadCertificate(Stream& stream, size_t size) {
} }
bool WiFiClientSecure::loadPrivateKey(Stream& stream, size_t size) { bool WiFiClientSecure::loadPrivateKey(Stream& stream, size_t size) {
if (_private_key != NULL) free(const_cast<char*>(_private_key));
char *dest = _streamLoad(stream, size); char *dest = _streamLoad(stream, size);
bool ret = false; bool ret = false;
if (dest) { if (dest) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment