cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
Paul Kehrer eb3e2e0d73 IssuingDistributionPoint support (parse only) (#4552)
* IssuingDistributionPoint support

h/t to Irina Renteria for the initial work here

* python 2 unfortunately still exists

* py2 repr

* typo caught by flake8

* add docs

* review feedback

* reorder args, other fixes

* use the alex name

* add changelog
2018-11-30 23:15:20 -05:00
.github Use a checklist for bumping openssl version (#4221) 2018-05-09 15:34:45 -05:00
.jenkins switch cryptography wheel builders back to pip wheel (#4334) 2018-07-14 10:43:13 -04:00
.travis fix certbot downstream, show commit hash for all downstreams (#4614) 2018-11-28 22:06:14 -05:00
docs IssuingDistributionPoint support (parse only) (#4552) 2018-11-30 23:15:20 -05:00
src IssuingDistributionPoint support (parse only) (#4552) 2018-11-30 23:15:20 -05:00
tests IssuingDistributionPoint support (parse only) (#4552) 2018-11-30 23:15:20 -05:00
vectors add ed448 test vectors (#4608) 2018-11-24 09:30:39 -06:00
.coveragerc properly merge pypy coverage with coveragerc paths 2016-01-07 10:41:04 -08:00
.gitignore Add bindings for SSL_OP_NO_DTLS* (#4079) 2018-01-16 09:07:23 -06:00
.travis.yml Debian sid is now Python 3.7 (#4602) 2018-11-22 14:48:57 -05:00
AUTHORS.rst Expose OpenSSL constant time bignum arithmetic (#4200) 2018-04-24 20:12:13 -04:00
CHANGELOG.rst IssuingDistributionPoint support (parse only) (#4552) 2018-11-30 23:15:20 -05: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 install only the minimum required to build our docs for rtd (#4133) 2018-03-05 19:50:10 -05:00
Jenkinsfile move linkcheck to travis (#4544) 2018-10-29 16:53:33 -04:00
LICENSE nit in LICENSE, itself doesn't make sense here (#4016) 2017-11-10 08:29:14 +08:00
LICENSE.APACHE Added new license files. Refs #1209 2014-10-31 07:51:41 -07: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 #3548 - add a pyproject.toml (#4363) 2018-07-23 13:10:13 -04:00
pyproject.toml Fixes #3548 - add a pyproject.toml (#4363) 2018-07-23 13:10:13 -04:00
README.rst Update URLs for new pypi! (#4194) 2018-04-16 07:41:11 +08:00
release.py Remove CDN purging, the new PyPI does the right thing (#4198) 2018-04-17 21:16:42 +08:00
rtd-requirements.txt install only the minimum required to build our docs for rtd (#4133) 2018-03-05 19:50:10 -05:00
setup.py blacklist latest hypothesis and pytest (#4510) 2018-10-23 07:34:01 -04:00
tox.ini Simplify build matrix (#4543) 2018-10-29 17:01:35 -04: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://travis-ci.org/pyca/cryptography.svg?branch=master
    :target: https://travis-ci.org/pyca/cryptography

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


``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 2.7, Python 3.4+, and PyPy 5.3+.

``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 ``#cryptography-dev`` on Freenode 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/