cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
pyca-boringbot[bot] b01afff0ef
Bump x509-limbo and/or wycheproof in CI (#12193)
Co-authored-by: pyca-boringbot[bot] <pyca-boringbot[bot]+106132319@users.noreply.github.com>
2024-12-23 20:04:39 -05:00
.github Bump x509-limbo and/or wycheproof in CI (#12193) 2024-12-23 20:04:39 -05:00
docs Add RFC9174 OIDs (#12143) 2024-12-13 19:17:50 +00:00
src fix typing in ciphers.pyi (#12180) 2024-12-20 19:40:01 +01:00
tests Add ec.EllipticCurve group_order constants (#12113) 2024-12-10 08:10:36 +03:00
vectors add new invalid EC key (#12103) 2024-12-04 23:36:45 -05:00
.gitattributes
.gitignore
.readthedocs.yml add explicit config to rtd (#12184) 2024-12-21 08:54:24 -05:00
Cargo.lock chore(deps): bump syn from 2.0.90 to 2.0.91 (#12185) 2024-12-22 15:18:09 +00:00
Cargo.toml chore(deps): bump pyo3 from 0.23.2 to 0.23.3 (#12096) 2024-12-04 07:05:50 -05:00
CHANGELOG.rst reopen for 45 (#12053) 2024-11-27 18:16:39 +00:00
ci-constraints-requirements.txt fix urllib3 bump for python-requires change (#12189) 2024-12-22 18:53:10 +01:00
CONTRIBUTING.rst
LICENSE
LICENSE.APACHE
LICENSE.BSD
noxfile.py Move Cargo.toml workspace configuration to the root of the repo. (#11836) 2024-10-27 16:17:40 -05:00
pyproject.toml Rebuild ci-constraints-requirements.txt (#12178) 2024-12-20 14:38:38 +01:00
README.rst
release.py

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/