cryptohash-sha256: Fast, pure and practical SHA-256 implementation
This is a package candidate release! Here you can preview how this package release will appear once published to the main package index (which can be accomplished via the 'maintain' link below). Please note that once a package has been published to the main package index it cannot be undone! Please consult the package uploading documentation for more information.
A practical incremental and one-pass, pure API to the SHA-256 cryptographic hash algorithm according to FIPS 180-4 with performance close to the fastest implementations available in other languages.
The core SHA-256 algorithm is implemented in C and is thus expected to be as fast as the standard sha256sum(1) tool; for instance, on an Intel Core i7-3770 at 3.40GHz this implementation can compute a SHA-256 hash over 230 MiB of data in under one second. (If, instead, you require a pure Haskell implementation and performance is secondary, please refer to the SHA package.)
Additionally, this package provides support for
HMAC-SHA-256: SHA-256-based Hashed Message Authentication Codes (HMAC)
HKDF-SHA-256: HMAC-SHA-256-based Key Derivation Function (HKDF)
conforming to RFC6234, RFC4231, RFC5869, et al..
Relationship to the cryptohash
package and its API
This package has been originally a fork of cryptohash-0.11.7
because the cryptohash
package had been deprecated and so this package continues to satisfy the need for a
lightweight package providing the SHA-256 hash algorithm without any dependencies on packages
other than base
and bytestring
. The API exposed by cryptohash-sha256-0.11.*
's
Crypto.Hash.SHA256 module is guaranteed to remain a compatible superset of the API provided
by the cryptohash-0.11.7
's module of the same name.
Consequently, this package is designed to be used as a drop-in replacement for cryptohash-0.11.7
's
Crypto.Hash.SHA256 module, though with
a clearly smaller footprint by almost 3 orders of magnitude.
Properties
Versions | 0.11.7.1, 0.11.7.2, 0.11.100.0, 0.11.100.1, 0.11.101.0, 0.11.102.0, 0.11.102.0, 0.11.102.1 |
---|---|
Change log | changelog.md |
Dependencies | base (>=4.5 && <4.15), bytestring (>=0.9.2 && <0.10 || >=0.10.0 && <0.11 || >=0.11.0 && <0.12) [details] |
License | BSD-3-Clause |
Copyright | Vincent Hanquez, Herbert Valerio Riedel |
Author | |
Maintainer | Herbert Valerio Riedel <hvr@gnu.org> |
Category | Data, Cryptography |
Home page | https://github.com/hvr/cryptohash-sha256 |
Bug tracker | https://github.com/hvr/cryptohash-sha256/issues |
Source repo | head: git clone https://github.com/hvr/cryptohash-sha256.git |
Uploaded | by HerbertValerioRiedel at 2021-01-24T22:03:31Z |
Modules
[Index] [Quick Jump]
- Crypto
Flags
Manual Flags
Name | Description | Default |
---|---|---|
exe | Enable building | Disabled |
use-cbits | Use fast optimized C routines via FFI; if flag is disabled falls back to non-FFI Haskell optimized implementation. | Enabled |
Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info
Downloads
- cryptohash-sha256-0.11.102.0.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
Package maintainers
For package maintainers and hackage trustees