cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
match man cd4ae74ef1
Add more demonstrative code to examples (#6234)
1. In signature generation code example, add a `key' assignment so it can be run solely.
2. In verify() code example, add a positive case before the negative one. Also use copy() to do self authentication.

Co-authored-by: Baofeng Wang <baofeng.wang67@gmail.com>
2021-08-29 08:45:19 -05:00
.github bump libre versions for test (#6230) 2021-08-25 20:02:51 -04:00
.zuul.d remove bionic and centos 8 arm64 jobs (#5974) 2021-04-15 00:10:52 -04:00
.zuul.playbooks/playbooks Build manylinux_2_24 wheels (#5952) 2021-04-03 18:15:32 -05:00
docs Add more demonstrative code to examples (#6234) 2021-08-29 08:45:19 -05:00
src Bump libc from 0.2.100 to 0.2.101 in /src/rust (#6231) 2021-08-26 08:33:25 -04:00
tests Added a missing test case for x509 scts (#6237) 2021-08-29 08:43:38 -05:00
vectors add invalid time CRL vector (#6152) 2021-07-01 06:51:55 -04:00
.coveragerc Added more paths to coverage path combiner (#5983) 2021-04-18 21:06:51 -05: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 Set dirhtml builder explicitly in the RTD config (#5964) 2021-04-12 11:33:40 -04:00
CHANGELOG.rst port 3.4.8 changelog to main (#6226) 2021-08-24 13:45:21 -04: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 link the CONTRIBUTING.rst to the development section of our docs 2014-03-02 09:23:46 -04:00
dev-requirements.txt goodbye azure (#5207) 2020-04-19 20:32:28 -04: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 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 fixes #5975 -- added typing stubs for rust module (#5976) 2021-04-15 10:02:09 -05:00
pyproject.toml Make whitespcae in pyproject.toml normal (#6130) 2021-06-19 17:00:16 -06:00
README.rst Update IRC in the README as well (#6055) 2021-05-19 15:26:15 -05:00
release.py Updates for our new main branch (#5818) 2021-02-11 21:15:39 -06:00
setup.cfg add project_urls especially changelog (#6228) 2021-08-26 09:24:41 -04:00
setup.py Add more debug assistance (#6210) 2021-08-17 09:07:32 -04:00
tox.ini Silence overly zealous flake8 warning (#6163) 2021-07-08 19:25:23 -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

.. 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.html
.. _`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.html