cryptography is a package designed to expose cryptographic primitives and recipes to Python developers.
Find a file
Paul Kehrer 3e15ca5ee2 deprecate unicode input for RFC822Name (#3836)
* deprecate unicode input for RFC822Name

* pep8...?
2017-08-01 22:21:19 -04:00
.github Fixed #3520 -- added a github issue template for bugs (#3807) 2017-07-24 15:28:56 +03:00
.jenkins don't re-export the openssl symbols from our shared object (#3825) 2017-07-26 22:22:59 -04:00
.travis update pythons and pypy, a little prep for pypy3 in CI again (#3702) 2017-06-18 20:32:59 -04:00
docs deprecate unicode input for RFC822Name (#3836) 2017-08-01 22:21:19 -04:00
src deprecate unicode input for RFC822Name (#3836) 2017-08-01 22:21:19 -04:00
tests deprecate unicode input for RFC822Name (#3836) 2017-08-01 22:21:19 -04:00
vectors Open master for 2.1 (#3788) 2017-07-17 20:59:03 +02:00
.coveragerc properly merge pypy coverage with coveragerc paths 2016-01-07 10:41:04 -08:00
.gitignore Fix .gitignore. 2015-09-26 22:31:53 +08:00
.mention-bot @dstufft is also annoyed by the mentionbot 2016-01-02 10:25:39 -06:00
.travis.yml remove python 3.3 from CI (#3729) 2017-06-26 21:08:33 -04:00
AUTHORS.rst Dh serialization changelog (#3385) 2017-02-08 12:38:42 +08:00
CHANGELOG.rst deprecate unicode input for RFC822Name (#3836) 2017-08-01 22:21:19 -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 require a version of twine that uses pypi.org (#3743) 2017-07-01 10:50:49 -05:00
Jenkinsfile fixed #3780 -- test on the latest libressl (#3813) 2017-07-26 16:10:32 +03:00
LICENSE New osrandom_engine in C (#3229) 2016-12-09 10:02:26 -06: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 convert to cffi 1.0 precompile system 2015-06-07 23:27:54 -05:00
README.rst remove python 3.3 from CI (#3729) 2017-06-26 21:08:33 -04:00
release.py Refs #3646 -- Don't use shell globbing in our release script (#3809) 2017-07-24 15:28:25 +03:00
setup.py Blacklist pytest 3.2.0 because it breaks us (#3835) 2017-08-01 18:54:35 -05:00
tox.ini add pypy3.5 to our test matrix (#3709) 2017-06-19 06:59:13 -04:00

pyca/cryptography
=================

.. image:: https://img.shields.io/pypi/v/cryptography.svg
    :target: https://pypi.python.org/pypi/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.6-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.


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