diff options
author | Alex Gaynor <alex.gaynor@gmail.com> | 2014-01-01 16:08:34 -0800 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2014-01-01 16:08:34 -0800 |
commit | 92217366e331ab5bcdb7e64dccc14048647bc5c7 (patch) | |
tree | d2035e85ef17023137b35c37768e80dfd3d9c211 /cryptography/hazmat/bindings/openssl/x509name.py | |
parent | 5f4c492c8e9124ac51c27b4e323426003cca47e3 (diff) | |
parent | c368ac2edfa21a6686ccd613fe0b889feb05d421 (diff) | |
download | cryptography-92217366e331ab5bcdb7e64dccc14048647bc5c7.tar.gz cryptography-92217366e331ab5bcdb7e64dccc14048647bc5c7.tar.bz2 cryptography-92217366e331ab5bcdb7e64dccc14048647bc5c7.zip |
Merge pull request #380 from public/split-binding
WIP: Split OpenSSL binding from the backend interface
Diffstat (limited to 'cryptography/hazmat/bindings/openssl/x509name.py')
-rw-r--r-- | cryptography/hazmat/bindings/openssl/x509name.py | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/cryptography/hazmat/bindings/openssl/x509name.py b/cryptography/hazmat/bindings/openssl/x509name.py new file mode 100644 index 00000000..bf627d61 --- /dev/null +++ b/cryptography/hazmat/bindings/openssl/x509name.py @@ -0,0 +1,59 @@ +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or +# implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +INCLUDES = """ +#include <openssl/x509.h> + +/* + * See the comment above Cryptography_STACK_OF_X509 in x509.py + */ +typedef STACK_OF(X509_NAME) Cryptography_STACK_OF_X509_NAME; +""" + +TYPES = """ +typedef ... X509_NAME; +typedef ... X509_NAME_ENTRY; +typedef ... Cryptography_STACK_OF_X509_NAME; +""" + +FUNCTIONS = """ +int X509_NAME_entry_count(X509_NAME *); +X509_NAME_ENTRY *X509_NAME_get_entry(X509_NAME *, int); +ASN1_OBJECT *X509_NAME_ENTRY_get_object(X509_NAME_ENTRY *); +ASN1_STRING *X509_NAME_ENTRY_get_data(X509_NAME_ENTRY *); +unsigned long X509_NAME_hash(X509_NAME *); + +int i2d_X509_NAME(X509_NAME *, unsigned char **); +int X509_NAME_add_entry_by_NID(X509_NAME *, int, int, unsigned char *, + int, int, int); +X509_NAME_ENTRY *X509_NAME_delete_entry(X509_NAME *, int); +void X509_NAME_ENTRY_free(X509_NAME_ENTRY *); +int X509_NAME_get_index_by_NID(X509_NAME *, int, int); +int X509_NAME_cmp(const X509_NAME *, const X509_NAME *); +char *X509_NAME_oneline(X509_NAME *, char *, int); +X509_NAME *X509_NAME_dup(X509_NAME *); +void X509_NAME_free(X509_NAME *); +""" + +MACROS = """ +Cryptography_STACK_OF_X509_NAME *sk_X509_NAME_new_null(void); +int sk_X509_NAME_num(Cryptography_STACK_OF_X509_NAME *); +int sk_X509_NAME_push(Cryptography_STACK_OF_X509_NAME *, X509_NAME *); +X509_NAME *sk_X509_NAME_value(Cryptography_STACK_OF_X509_NAME *, int); +void sk_X509_NAME_free(Cryptography_STACK_OF_X509_NAME *); +""" + +CUSTOMIZATIONS = """ +""" + +CONDITIONAL_NAMES = {} |