diff options
author | Alex Gaynor <alex.gaynor@gmail.com> | 2015-12-23 21:25:00 -0500 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2015-12-23 21:25:00 -0500 |
commit | 8c52c203accd5fdb35fcdae33bbf3fa172c7879f (patch) | |
tree | f2e5d35a290c45f8b6f29b1e1cb76455edcbfb5e /src | |
parent | 6d99de1ba968215b6c8566738c3f5ff3b7ac3312 (diff) | |
parent | 7e75b620f1c63fcc6168fe611eafa97fd709121b (diff) | |
download | cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.tar.gz cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.tar.bz2 cryptography-8c52c203accd5fdb35fcdae33bbf3fa172c7879f.zip |
Merge pull request #2558 from reaperhulk/managing-memory-is-fun
fix a potential memory issue when retaining revoked certs from a CRL
Diffstat (limited to 'src')
-rw-r--r-- | src/cryptography/hazmat/backends/openssl/x509.py | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/src/cryptography/hazmat/backends/openssl/x509.py b/src/cryptography/hazmat/backends/openssl/x509.py index 7e89ac67..12f5d46f 100644 --- a/src/cryptography/hazmat/backends/openssl/x509.py +++ b/src/cryptography/hazmat/backends/openssl/x509.py @@ -747,8 +747,16 @@ def _decode_cert_issuer(backend, ext): @utils.register_interface(x509.RevokedCertificate) class _RevokedCertificate(object): - def __init__(self, backend, x509_revoked): + def __init__(self, backend, crl, x509_revoked): self._backend = backend + # The X509_REVOKED_value is a X509_REVOKED * that has + # no reference counting. This means when X509_CRL_free is + # called then the CRL and all X509_REVOKED * are freed. Since + # you can retain a reference to a single revoked certificate + # and let the CRL fall out of scope we need to retain a + # private reference to the CRL inside the RevokedCertificate + # object to prevent the gc from being called inappropriately. + self._crl = crl self._x509_revoked = x509_revoked @property @@ -861,7 +869,10 @@ class _CertificateRevocationList(object): for i in range(num): r = self._backend._lib.sk_X509_REVOKED_value(revoked, i) self._backend.openssl_assert(r != self._backend._ffi.NULL) - revoked_list.append(_RevokedCertificate(self._backend, r)) + revoked_certificate = _RevokedCertificate( + self._backend, self, r + ) + revoked_list.append(revoked_certificate) return revoked_list |