cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
pyca-boringbot[bot] e04d52de6a
Bump BoringSSL and/or OpenSSL in CI (#10074)
Co-authored-by: pyca-boringbot[bot] <pyca-boringbot[bot]+106132319@users.noreply.github.com>
2023-12-28 00:14:45 +00:00
.github Bump BoringSSL and/or OpenSSL in CI (#10074) 2023-12-28 00:14:45 +00:00
docs document that we raise CryptographyDeprecationWarning on deprecation more clearly (#10053) 2023-12-23 14:48:55 -05:00
src Bump syn from 2.0.42 to 2.0.43 in /src/rust (#10060) 2023-12-25 08:01:07 -05:00
tests Added a benchmark for x.509 verification (#10042) 2023-12-23 12:55:21 -03:00
vectors regenerate x509/custom/ca/ca.pem to expire in 2100 (#9964) 2023-12-05 09:21:37 -05:00
.gitattributes test py27 with windows container on azure (#4880) 2019-05-08 18:29:42 -04:00
.gitignore Move the remainder of the Rust coverage logic into the noxfile (#8936) 2023-05-17 19:58:47 +08:00
.readthedocs.yml Use a newer rust in RTD (#9797) 2023-10-29 12:30:23 -05:00
CHANGELOG.rst CHANGELOG: record #8873 (#10035) 2023-12-22 22:48:13 +00:00
ci-constraints-requirements.txt Bump mypy from 1.7.1 to 1.8.0 (#10028) 2023-12-21 20:36:46 +00:00
CONTRIBUTING.rst
LICENSE drop support for openssl < 1.1.1d (#8449) 2023-03-24 08:36:58 -04:00
LICENSE.APACHE
LICENSE.BSD
MANIFEST.in Switch from tox to nox (#8651) 2023-04-02 16:28:22 +09:00
noxfile.py Simplify verifying README.rst in CI (#9991) 2023-12-12 14:24:27 -06:00
pyproject.toml Added certifi to test dependencies (#10043) 2023-12-23 12:42:56 -03:00
README.rst update pypy supported versions in the docs (#9318) 2023-07-31 17:41:15 -04:00
release.py Simplify the release process: No need to pass the version to release.py (#9990) 2023-12-12 06:09:51 -08: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.7+ and PyPy3 7.3.11+.

``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/