diff options
author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-07-10 11:08:31 -0500 |
---|---|---|
committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-07-10 18:41:17 -0500 |
commit | 9ce25a9e624a43e47f677a764d4eedcdc7f6c86e (patch) | |
tree | e735eda05a0b5ffc187a78360684fe697879ed18 /src | |
parent | 907cc81149e6a89db683c206f8fe4fc5bea7f87d (diff) | |
download | cryptography-9ce25a9e624a43e47f677a764d4eedcdc7f6c86e.tar.gz cryptography-9ce25a9e624a43e47f677a764d4eedcdc7f6c86e.tar.bz2 cryptography-9ce25a9e624a43e47f677a764d4eedcdc7f6c86e.zip |
support DirectoryName encoding for general names
Diffstat (limited to 'src')
-rw-r--r-- | src/cryptography/hazmat/backends/openssl/backend.py | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/cryptography/hazmat/backends/openssl/backend.py b/src/cryptography/hazmat/backends/openssl/backend.py index d6493778..194f295c 100644 --- a/src/cryptography/hazmat/backends/openssl/backend.py +++ b/src/cryptography/hazmat/backends/openssl/backend.py @@ -171,6 +171,15 @@ def _encode_subject_alt_name(backend, san): ) assert obj != backend._ffi.NULL gn.d.registeredID = obj + elif isinstance(alt_name, x509.DirectoryName): + gn = backend._lib.GENERAL_NAME_new() + assert gn != backend._ffi.NULL + name = _encode_name(backend, alt_name.value) + # _encode_name registers the X509_NAME for gc so we'll duplicate + # a new one that is not gc'd for the struct + name = backend._lib.X509_NAME_dup(name) + gn.type = backend._lib.GEN_DIRNAME + gn.d.directoryName = name else: raise NotImplementedError( "Only DNSName and RegisteredID supported right now" |