Skip to main content

Python package for providing Mozilla's CA Bundle.

Project description

Certifi is a carefully curated collection of Root Certificates for validating the trustworthiness of SSL certificates while verifying the identity of TLS hosts. It has been extracted from the Requests project.

Installation

certifi is available on PyPI. Simply install it with pip:

$ pip install certifi

Usage

To reference the installed certificate authority (CA) bundle, you can use the built-in function:

>>> import certifi

>>> certifi.where()
'/usr/local/lib/python2.7/site-packages/certifi/cacert.pem'

Enjoy!

1024-bit Root Certificates

Browsers and certificate authorities have concluded that 1024-bit keys are unacceptably weak for certificates, particularly root certificates. For this reason, Mozilla has removed any weak (i.e. 1024-bit key) certificate from its bundle, replacing it with an equivalent strong (i.e. 2048-bit or greater key) certificate from the same CA. Because Mozilla removed these certificates from its bundle, certifi removed them as well.

Unfortunately, old versions of OpenSSL (less than 1.0.2) sometimes fail to validate certificate chains that use the strong roots. For this reason, if you fail to validate a certificate using the certifi.where() mechanism, you can intentionally re-add the 1024-bit roots back into your bundle by calling certifi.old_where() instead. This is not recommended in production: if at all possible you should upgrade to a newer OpenSSL. However, if you have no other option, this may work for you.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

certifi-2017.11.5.tar.gz (329.2 kB view details)

Uploaded Source

Built Distribution

certifi-2017.11.5-py2.py3-none-any.whl (330.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file certifi-2017.11.5.tar.gz.

File metadata

  • Download URL: certifi-2017.11.5.tar.gz
  • Upload date:
  • Size: 329.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for certifi-2017.11.5.tar.gz
Algorithm Hash digest
SHA256 5ec74291ca1136b40f0379e1128ff80e866597e4e2c1e755739a913bbc3613c0
MD5 c15ac46ed1fe4b607ff3405928f9a992
BLAKE2b-256 233f8be01c50ed24a4bd6b8da799839066ce0288f66f5e11f0367323467f0cbc

See more details on using hashes here.

File details

Details for the file certifi-2017.11.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for certifi-2017.11.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 244be0d93b71e93fc0a0a479862051414d0e00e16435707e5bf5000f92e04694
MD5 429fdf238d878f8090a80ccc3488049b
BLAKE2b-256 299b25ef61e948321296f029f53c9f67cc2b54e224db509eb67ce17e0df6044a

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page