cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
dependabot[bot] 0a2c336a57
Bump num-traits from 0.2.14 to 0.2.15 in /src/rust (#7185)
Bumps [num-traits](https://github.com/rust-num/num-traits) from 0.2.14 to 0.2.15.
- [Release notes](https://github.com/rust-num/num-traits/releases)
- [Changelog](https://github.com/rust-num/num-traits/blob/master/RELEASES.md)
- [Commits](https://github.com/rust-num/num-traits/compare/num-traits-0.2.14...num-traits-0.2.15)

---
updated-dependencies:
- dependency-name: num-traits
  dependency-type: indirect
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2022-05-03 04:07:21 +00:00
.circleci switch to using venvs in our containers (#7023) 2022-04-02 00:51:36 +00:00
.github bump boringssl in ci (#7184) 2022-05-03 00:26:10 +00:00
docs add x509 pss certificate and public key (#7161) 2022-04-30 21:04:37 +00:00
src Bump num-traits from 0.2.14 to 0.2.15 in /src/rust (#7185) 2022-05-03 04:07:21 +00:00
tests Remove test that became duplicative at some point (#7182) 2022-05-03 00:16:30 +00:00
vectors add x509 pss certificate and public key (#7161) 2022-04-30 21:04:37 +00:00
.coveragerc switch to doing python coverage in actions (#7154) 2022-04-30 18:20:51 +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 Fixes #6602 -- restore the behavior of strict DER parsing for CSRs (#7159) 2022-04-30 19:59:24 +00:00
codecov.yml revert codecov.yml workaround and pin coverage to 4.3.4 (#3662) 2017-06-03 14:26:56 -04:00
CONTRIBUTING.rst
dev-requirements.txt Remove coverage from dev-requirements.txt (#6674) 2021-12-05 05:58:21 +08:00
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
LICENSE.PSF
MANIFEST.in Remove Zuul from our CI (#6778) 2022-01-02 17:44:34 -06:00
pyproject.toml Instead of ignoring _openssl with mypy, use a pyi (#7177) 2022-05-02 18:08:03 +00:00
README.rst update urls in readme to avoid redirect (#6683) 2021-12-08 12:39:03 +00:00
release.py release.py event we want is push not create (#6334) 2021-09-29 22:18:50 -04:00
setup.cfg Refs #7079 -- added basic scaffholding for benchmarks (#7087) 2022-04-18 20:52:20 -05:00
setup.py Bump MSRV to 1.48.0 (#7128) 2022-04-27 13:47:46 +00:00
tox.ini fancier tox configs for no coverage (#7166) 2022-04-30 23:49:37 +00: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

.. image:: https://codecov.io/github/pyca/cryptography/coverage.svg?branch=main
    :target: https://codecov.io/github/pyca/cryptography?branch=main


``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
    '...'
    >>> f.decrypt(token)
    '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/