Giter Site home page Giter Site logo

credentiality / pycryptodome Goto Github PK

View Code? Open in Web Editor NEW

This project forked from legrandin/pycryptodome

0.0 2.0 0.0 25.07 MB

A self-contained cryptographic library for Python

Home Page: https://www.pycryptodome.org

License: Other

Shell 0.22% PowerShell 0.16% Batchfile 0.15% Python 72.81% C 25.73% C++ 0.93%

pycryptodome's Introduction

https://travis-ci.org/Legrandin/pycryptodome.svg?branch=master https://ci.appveyor.com/api/projects/status/mbxyqdodw9ylfib9/branch/master?svg=true

PyCryptodome

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

It supports Python 2.4 or newer, all Python 3 versions and PyPy.

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

  1. a 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, you should have GMP installed in your system (except on Windows, as the wheel on PyPi already comes bundled with the equivalent MPIR library).

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 curve 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 (including SHAKE XOFs) and BLAKE2 hash algorithms
  • Salsa20 and ChaCha20 stream ciphers
  • scrypt and HKDF
  • 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.

All the code can be downloaded from GitHub.

News

  • 26 Aug 2017 (NEW). Bugfix release 3.4.7.
  • 17 May 2017. Bugfix release 3.4.6.
  • 6 Feb 2017. Bugfix release 3.4.5.
  • 1 Feb 2017. Bugfix release 3.4.4.
  • 17 Oct 2016. Bugfix release 3.4.3.
  • 8 Mar 2016. Bugfix release 3.4.2.
  • 21 Feb 2016. Release 3.4.1.
  • 7 Feb 2016. Release 3.4.
  • Nov 2015. Release 3.3.1.
  • 29 Oct 2015. Release 3.3.
  • 9 Sep 2015. Minor release 3.2.1.
  • 6 Sep 2015. Release 3.2.
  • 15 Mar 2015. Release 3.1.
  • 24 Jun 2014. Release 3.0.

pycryptodome's People

Contributors

4zm avatar akuchling avatar alsaan avatar dev-jjc avatar dfranganillo avatar dlitz avatar donlorenzo avatar frispete avatar fx5 avatar hannesvn avatar hsmtkk avatar iwonbigbro avatar jaraco avatar jaywink avatar legrandin avatar mitchellrj avatar msabramo avatar oxc avatar paxan avatar rfk avatar roughconsensusandrunningcode avatar saboya avatar sebastinas avatar stefanor avatar suckzoo avatar takluyver avatar thorsteneb avatar tintinweb avatar windwiny avatar wking avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.