All Projects → Legrandin → Pycryptodome

Legrandin / Pycryptodome

Licence: other
A self-contained cryptographic library for Python

Programming Languages

c
50402 projects - #5 most used programming language
python
139335 projects - #7 most used programming language

Projects that are alternatives of or similar to Pycryptodome

Cryfs
Cryptographic filesystem for the cloud
Stars: ✭ 1,560 (-14.14%)
Mutual labels:  cryptography
Streamcryptor
Stream encryption & decryption with libsodium and protobuf
Stars: ✭ 112 (-93.84%)
Mutual labels:  cryptography
Multi Party Schnorr
Rust implementation of multi-party Schnorr signatures over elliptic curves.
Stars: ✭ 115 (-93.67%)
Mutual labels:  cryptography
Openssh Portable
Portable OpenSSH
Stars: ✭ 1,696 (-6.66%)
Mutual labels:  cryptography
Sputter
Ethereum Virtual Machine (EVM) implementation
Stars: ✭ 111 (-93.89%)
Mutual labels:  cryptography
Gitpass
Open Source Your Password (Mismanagement)!
Stars: ✭ 113 (-93.78%)
Mutual labels:  cryptography
Gcp Iot Core Examples
Google Cloud Platform IOT Core Examples
Stars: ✭ 103 (-94.33%)
Mutual labels:  cryptography
Cruzbit
A simple decentralized peer-to-peer ledger implementation
Stars: ✭ 118 (-93.51%)
Mutual labels:  cryptography
Tools For Cryptanalysis
A repository that aims to provide tools for cryptography and cryptanalysis
Stars: ✭ 112 (-93.84%)
Mutual labels:  cryptography
Open Crypto
🔑 Hashing (BCrypt, SHA2, HMAC), encryption (AES), public-key (RSA), and random data generation.
Stars: ✭ 115 (-93.67%)
Mutual labels:  cryptography
Yubikey Agent
yubikey-agent is a seamless ssh-agent for YubiKeys.
Stars: ✭ 1,744 (-4.02%)
Mutual labels:  cryptography
Pyce
Encrypted Python Execution
Stars: ✭ 111 (-93.89%)
Mutual labels:  cryptography
Foundational Knowledge For Programmers
List of resources about foundational knowledge for programmers (supposed to last a few decades)
Stars: ✭ 115 (-93.67%)
Mutual labels:  cryptography
Libsodium Go
A complete overhaul of the Golang wrapper for libsodium
Stars: ✭ 105 (-94.22%)
Mutual labels:  cryptography
Solar
🌞 Stellar wallet. Secure and user-friendly.
Stars: ✭ 117 (-93.56%)
Mutual labels:  cryptography
Cfrpki
Cloudflare's RPKI Toolbox
Stars: ✭ 104 (-94.28%)
Mutual labels:  cryptography
Node Sha3
SHA3 for JavaScript - The Keccak family of hash algorithms
Stars: ✭ 112 (-93.84%)
Mutual labels:  cryptography
Distaff
Zero-knowledge virtual machine written in Rust
Stars: ✭ 119 (-93.45%)
Mutual labels:  cryptography
Cryptogotchas
A collection of common (interesting) cryptographic mistakes.
Stars: ✭ 118 (-93.51%)
Mutual labels:  cryptography
Charm
A really tiny crypto library.
Stars: ✭ 116 (-93.62%)
Mutual labels:  cryptography
https://github.com/Legrandin/pycryptodome/workflows/Integration%20test/badge.svg?branch=master

PyCryptodome

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

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

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

  1. 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.

  2. 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)
  • Accelerated AES on Intel platforms via AES-NI
  • First class support for PyPy
  • Elliptic curves cryptography (NIST P-256, P-384 and P-521 curves only)
  • 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 XOF (derived from Keccak)
  • 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 and HKDF derivation functions
  • Deterministic (EC)DSA
  • 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 [email protected].

All the code can be downloaded from GitHub.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].