A self-contained cryptographic library for Python https://www.pycryptodome.org
Find a file
2025-03-16 00:33:33 +01:00
.github Include OS and package type in the wheels archive 2025-03-15 23:16:21 +01:00
Doc Clarify HPKE example 2025-03-16 00:33:33 +01:00
lib/Crypto Bump version 2025-03-15 22:28:00 +01:00
src GH#846: fix infinite loop with RC4 for data larger than 4GB 2025-03-10 15:24:19 +01:00
test_vectors Add HPKE test vectors from https://raw.githubusercontent.com/cfrg/draft-irtf-cfrg-hpke/refs/heads/master/test-vectors.json 2025-03-08 17:36:00 +01:00
.gitignore Update .gitignore with more junk 2021-01-03 23:49:50 +01:00
.readthedocs.yaml Add documentation for HPKE 2025-03-09 19:45:37 +01:00
AUTHORS.rst Reduce the minimum length of the EAX MAC tag to 2 bytes 2022-12-11 19:40:41 +01:00
bench_monty.py Rough benchmarker 2018-01-22 00:15:30 +01:00
Changelog.rst Fix Changelog 2025-03-16 00:21:34 +01:00
compiler_opt.py Use memset, to avoid emmintrin.h 2023-12-29 14:52:15 +01:00
INSTALL.rst Updating windows install instructions 2022-12-11 20:37:25 +01:00
LICENSE.rst Remove references to OCB patents (now abandoned) 2021-10-31 17:35:37 +01:00
MANIFEST.in Exclude .swp files 2024-10-04 08:54:36 +02:00
pct-speedtest.py Moved back to Crypto module 2022-12-14 08:36:15 +01:00
pyproject.toml Fix type check errors 2025-03-09 08:15:38 +01:00
README.rst Bump version 2025-03-15 22:28:00 +01:00
requirements-test.txt Use latest test vectors 2025-03-09 08:15:38 +01:00
setup.cfg Set py-limited-api dynamically 2024-08-12 09:40:11 +02:00
setup.py Bump version 2025-03-15 22:28:00 +01:00

.. image:: https://github.com/Legrandin/pycryptodome/workflows/Integration%20test/badge.svg
   :target: https://github.com/Legrandin/pycryptodome/actions

.. image:: https://badge.fury.io/py/pycryptodome.svg
   :target: https://pypi.org/project/pycryptodome

.. image:: https://badge.fury.io/py/pycryptodomex.svg
   :target: https://pypi.org/project/pycryptodomex

PyCryptodome
============

PyCryptodome is a self-contained Python package of low-level
cryptographic primitives.

It supports Python 2.7, Python 3.7 and newer, and PyPy.

The installation procedure depends on the package you want the library to be in.
PyCryptodome can be used as:

#. **an almost drop-in replacement for the old PyCrypto library**.
   You install it with::

       pip install pycryptodome

   In this case, all modules are installed under the ``Crypto`` package.

   One must avoid having both PyCrypto and PyCryptodome installed
   at the same time, as they will interfere with each other.

   This option is therefore recommended only when you are sure that
   the whole application is deployed in a ``virtualenv``.

#. **a library independent of the old PyCrypto**.
   You install it with::

       pip install pycryptodomex

   In this case, all modules are installed under the ``Cryptodome`` package.
   PyCrypto and PyCryptodome can coexist.

For faster public key operations in Unix, you should install `GMP`_ in your system.

PyCryptodome is a fork of PyCrypto. It brings the following enhancements
with respect to the last official version of PyCrypto (2.6.1):

* Authenticated encryption modes (GCM, CCM, EAX, SIV, OCB)
* Hybrid Public Key Encryption (HPKE)
* Accelerated AES on Intel platforms via AES-NI
* First class support for PyPy
* Elliptic curves cryptography (NIST P-curves; Ed25519, Ed448, Curve25519, Curve448)
* Better and more compact API (`nonce` and `iv` attributes for ciphers,
  automatic generation of random nonces and IVs, simplified CTR cipher mode,
  and more)
* SHA-3 hash algorithms (FIPS 202) and derived functions (NIST SP-800 185):

  - SHAKE128 and SHA256 XOFs
  - cSHAKE128 and cSHAKE256 XOFs
  - KMAC128 and KMAC256
  - TupleHash128 and TupleHash256

* KangarooTwelve, TurboSHAKE128, and TurboSHAKE256 XOFs
* Truncated hash algorithms SHA-512/224 and SHA-512/256 (FIPS 180-4)
* BLAKE2b and BLAKE2s hash algorithms
* Salsa20 and ChaCha20/XChaCha20 stream ciphers
* Poly1305 MAC
* ChaCha20-Poly1305 and XChaCha20-Poly1305 authenticated ciphers
* scrypt, bcrypt, HKDF, and NIST SP 800 108r1 Counter Mode key derivation functions
* Deterministic (EC)DSA and EdDSA
* Password-protected PKCS#8 key containers
* Shamir's Secret Sharing scheme
* Random numbers get sourced directly from the OS (and not from a CSPRNG in userspace)
* Simplified install process, including better support for Windows
* Cleaner RSA and DSA key generation (largely based on FIPS 186-4)
* Major clean ups and simplification of the code base

PyCryptodome is not a wrapper to a separate C library like *OpenSSL*.
To the largest possible extent, algorithms are implemented in pure Python.
Only the pieces that are extremely critical to performance (e.g. block ciphers)
are implemented as C extensions.

For more information, see the `homepage`_.

For security issues, please send an email to security@pycryptodome.org.

All the code can be downloaded from `GitHub`_.

.. _`homepage`: https://www.pycryptodome.org
.. _`GMP`: https://gmplib.org
.. _GitHub: https://github.com/Legrandin/pycryptodome