This is a fork of the original project:
pyx509 - Python library for parsing X.509
Copyright (C) 2009-2012 CZ.NIC, z.s.p.o. (http://www.nic.cz)
Work in progress!
This is probably the most complete parser of X.509 certificates in python.
Code is in alpha stage! Don't use for anything sensitive. I wrote it (based on previous work of colleagues) since there is no comprehensive python parser for X.509 certificates. Often python programmers had to parse openssl output.
- I find it less painful to use than parsing output of 'openssl x509'
- somewhat stricter in extension parsing compared to openssl
- It's slow compared to openssl (about 2.3x compared to RHEL's openssl-1.0-fips)
- Currently not very strict in what string types in RDNs it accepts
- API is still rather ugly and has no documentation yet; code is nasty at some places (and there's some old dangling code like pkcs7/verifier.py)
pyasn1 >= 0.1.4
LGPL v2 or later:
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not, write to the Free
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- Subject alternative name doesn't show all subtypes, but 'DNS', 'dirName' and 'email' are supported.
- Name constraints don't distinguish among various GeneralName subtypes
- Some extensions are not shown very nicely when put in string format
- Not all extensions are supported
- String types accepted for various RDN subelements are rather too permissive
- RDN string conversion does not conform to RFC 4514
- Badly formed extensions are ignored if not marked critical
- easy to switch to more strict behavior
- other clients do this as well; RFC 5280 specifies behavior for unknown elements in extensions in appendix B.1, but does not cover all cases (e.g. element exists, but with string type different from spec)
- Packaging: aka setup.py, etc.
- Publish in Pypi
- Cleanup: This module has it's own pyasn1 models. Look if we can reuse the pyasn1_modules.rfc2459 X509 cert model.
- Cleanup: Currently, the signature verifier does not work.