summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefan Sørensen <stefan.sorensen@spectralink.com>2016-08-08 13:31:15 +0200
committerNikos Mavrogiannopoulos <nmav@redhat.com>2016-08-08 16:10:31 +0200
commit67fc652b5d703d6955f43811e24c06de9a9cc7c9 (patch)
tree3f744f08f82a5e959fdaf18ba3feae4c222f7afc
parentf7d884720b128ef86f6b9dc9fc498be89faf1732 (diff)
downloadgnutls-stefan-fixes.tar.gz
Fix gnutls_pkcs12_simple_parse to always extract the complete chainstefan-fixes
gnutls_pkcs12_simple_parse was only collecting extra certificates that was possible elements of the certificate chain when the extra_certs argument was not NULL. Fix by allways collecting all the certificates, any unneeded certificates are released before returning if extra_certs is NULL anyway. Signed-off-by: Stefan Sørensen <stefan.sorensen@spectralink.com>
-rw-r--r--lib/x509/pkcs12.c35
1 files changed, 15 insertions, 20 deletions
diff --git a/lib/x509/pkcs12.c b/lib/x509/pkcs12.c
index 5b072dd8e6..e39dcde790 100644
--- a/lib/x509/pkcs12.c
+++ b/lib/x509/pkcs12.c
@@ -1683,27 +1683,22 @@ gnutls_pkcs12_simple_parse(gnutls_pkcs12_t p12,
}
if (memcmp(cert_id, key_id, cert_id_size) != 0) { /* they don't match - skip the certificate */
- if (extra_certs) {
- _extra_certs =
- gnutls_realloc_fast
- (_extra_certs,
- sizeof(_extra_certs
- [0]) *
- ++_extra_certs_len);
- if (!_extra_certs) {
- gnutls_assert();
- ret =
- GNUTLS_E_MEMORY_ERROR;
- goto done;
- }
- _extra_certs
- [_extra_certs_len -
- 1] = this_cert;
- this_cert = NULL;
- } else {
- gnutls_x509_crt_deinit
- (this_cert);
+ _extra_certs =
+ gnutls_realloc_fast
+ (_extra_certs,
+ sizeof(_extra_certs
+ [0]) *
+ ++_extra_certs_len);
+ if (!_extra_certs) {
+ gnutls_assert();
+ ret =
+ GNUTLS_E_MEMORY_ERROR;
+ goto done;
}
+ _extra_certs
+ [_extra_certs_len -
+ 1] = this_cert;
+ this_cert = NULL;
} else {
if (chain && _chain_len == 0) {
_chain =