cryptohash-sha256: Fast, pure and practical SHA-256 implementation

[ bsd3, cryptography, data, library ] [ Propose Tags ] [ Report a vulnerability ]

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

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.

Modules

[Index] [Quick Jump]

Flags

Manual Flags

NameDescriptionDefault
exe

Enable building sha256sum executable

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

Note: This package has metadata revisions in the cabal description newer than included in the tarball. To unpack the package including the revisions, use 'cabal get'.

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

Versions [RSS] 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.1
Change log changelog.md
Dependencies base (>=4.5 && <4.21), bytestring (>=0.9.2.0 && <0.10 || >=0.10.0.0 && <0.11 || >=0.11.0.0 && <0.12 || >=0.12.0.2 && <0.13) [details]
Tested with ghc ==9.10.1, ghc ==9.8.2, ghc ==9.6.5, ghc ==9.4.8, ghc ==9.2.8, ghc ==9.0.2, ghc ==8.10.7, ghc ==8.8.4, ghc ==8.6.5, ghc ==8.4.4, ghc ==8.2.2, ghc ==8.0.2
License BSD-3-Clause
Copyright Vincent Hanquez, Herbert Valerio Riedel
Author
Maintainer Herbert Valerio Riedel <hvr@gnu.org>
Revised Revision 5 made by AndreasAbel at 2024-06-26T09:08:36Z
Category Data, Cryptography
Home page https://github.com/haskell-hvr/cryptohash-sha256
Bug tracker https://github.com/haskell-hvr/cryptohash-sha256/issues
Source repo head: git clone https://github.com/haskell-hvr/cryptohash-sha256.git
Uploaded by phadej at 2021-10-10T16:53:05Z
Distributions Arch:0.11.102.1, Debian:0.11.101.0, Fedora:0.11.102.1, LTSHaskell:0.11.102.1, NixOS:0.11.102.1, Stackage:0.11.102.1, openSUSE:0.11.102.1
Reverse Dependencies 44 direct, 119 indirect [details]
Executables sha256sum
Downloads 52601 total (182 in the last 30 days)
Rating 2.25 (votes: 2) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2021-10-10 [all 1 reports]