cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
Paul Kehrer db7dd61de3
Add Certificate.verify_signed_by (#8011)
* Add Certificate.verify_signed_by

Verify that the signature on a certificate was created by the
private key belonging to another certificate's public key.

This code does not validate anything else! It is not a path builder,
general x509 validator, etc.

* switch to issued_by

validate issuer subject matches certificate issuer and refactor

* two fixes

* signed_by isn't the right target now

* coverage

* skip test on some *ssls

* extensive refactoring

* lol

* does any of this work

* final commit i swear
2023-01-12 04:32:52 +00:00
.circleci add arm64 pypy38 and pyp39 on manylinux_2_28 (#7986) 2023-01-05 07:34:44 -05:00
.github Bump BoringSSL and/or OpenSSL in CI (#8044) 2023-01-12 00:21:49 +00:00
docs Add Certificate.verify_signed_by (#8011) 2023-01-12 04:32:52 +00:00
src Add Certificate.verify_signed_by (#8011) 2023-01-12 04:32:52 +00:00
tests Add Certificate.verify_signed_by (#8011) 2023-01-12 04:32:52 +00:00
vectors fixes #8035 -- added a test for loading a cert with another PEM block containing headers (#8045) 2023-01-12 04:07:33 +00:00
.gitattributes test py27 with windows container on azure (#4880) 2019-05-08 18:29:42 -04:00
.gitignore Integrate Rust into the build process properly (#5410) 2020-12-22 13:33:47 -06:00
.readthedocs.yml Replace broken viewcode with linkcode in doc (#6207) 2021-10-03 06:10:10 +08:00
CHANGELOG.rst Add Certificate.verify_signed_by (#8011) 2023-01-12 04:32:52 +00:00
ci-constraints-requirements.txt Bump coverage from 7.0.4 to 7.0.5 (#8042) 2023-01-11 12:48:15 +00:00
CONTRIBUTING.rst
LICENSE Always rely on OpenSSL's builtin locking callbacks (#5561) 2020-11-11 13:35:47 -06:00
LICENSE.APACHE HTTPS a bunch of links in random places (#4666) 2018-12-31 10:10:09 -06:00
LICENSE.BSD Added new license files. Refs #1209 2014-10-31 07:51:41 -07:00
LICENSE.PSF C locking callback (#3226) 2016-11-13 12:55:22 -08:00
MANIFEST.in Pin python dev dependencies in CI with a pip constraints file (#7962) 2023-01-03 08:47:06 +07:00
pyproject.toml Replace more deprecated abstractproperty (#7944) 2022-12-28 17:33:22 +07:00
README.rst fix README for python3 (#7947) 2022-12-30 07:02:08 +07:00
release.py more release.py fixes and improvements (#7956) 2023-01-02 05:27:13 +00:00
setup.cfg Pin python dev dependencies in CI with a pip constraints file (#7962) 2023-01-03 08:47:06 +07:00
setup.py Error loudly if you somehow run setup.py without CFFI installed (#7640) 2022-09-23 08:22:54 -05:00
tox.ini Pin python dev dependencies in CI with a pip constraints file (#7962) 2023-01-03 08:47:06 +07:00

pyca/cryptography
=================

.. image:: https://img.shields.io/pypi/v/cryptography.svg
    :target: https://pypi.org/project/cryptography/
    :alt: Latest Version

.. image:: https://readthedocs.org/projects/cryptography/badge/?version=latest
    :target: https://cryptography.io
    :alt: Latest Docs

.. image:: https://github.com/pyca/cryptography/workflows/CI/badge.svg?branch=main
    :target: https://github.com/pyca/cryptography/actions?query=workflow%3ACI+branch%3Amain


``cryptography`` is a package which provides cryptographic recipes and
primitives to Python developers. Our goal is for it to be your "cryptographic
standard library". It supports Python 3.6+ and PyPy3 7.2+.

``cryptography`` includes both high level recipes and low level interfaces to
common cryptographic algorithms such as symmetric ciphers, message digests, and
key derivation functions. For example, to encrypt something with
``cryptography``'s high level symmetric encryption recipe:

.. code-block:: pycon

    >>> from cryptography.fernet import Fernet
    >>> # Put this somewhere safe!
    >>> key = Fernet.generate_key()
    >>> f = Fernet(key)
    >>> token = f.encrypt(b"A really secret message. Not for prying eyes.")
    >>> token
    b'...'
    >>> f.decrypt(token)
    b'A really secret message. Not for prying eyes.'

You can find more information in the `documentation`_.

You can install ``cryptography`` with:

.. code-block:: console

    $ pip install cryptography

For full details see `the installation documentation`_.

Discussion
~~~~~~~~~~

If you run into bugs, you can file them in our `issue tracker`_.

We maintain a `cryptography-dev`_ mailing list for development discussion.

You can also join ``#pyca`` on ``irc.libera.chat`` to ask questions or get
involved.

Security
~~~~~~~~

Need to report a security issue? Please consult our `security reporting`_
documentation.


.. _`documentation`: https://cryptography.io/
.. _`the installation documentation`: https://cryptography.io/en/latest/installation/
.. _`issue tracker`: https://github.com/pyca/cryptography/issues
.. _`cryptography-dev`: https://mail.python.org/mailman/listinfo/cryptography-dev
.. _`security reporting`: https://cryptography.io/en/latest/security/