nettle-0.1.0: safe nettle binding

Portabilityportable
Stabilityexperimental
Maintainerstbuehler@web.de
Safe HaskellNone

Crypto.Nettle.Hash

Contents

Description

This module exports hash algorithms supported by nettle: http://www.lysator.liu.se/~nisse/nettle/

Synopsis

HashAlgorithm class

class HashAlgorithm a whereSource

HashAlgorithm is a class that hash algorithms will implement. generating a digest is a 3 step procedure:

The final digest has hashDigestSize bytes, and the algorithm uses hashBlockSize as internal block size.

Methods

hashBlockSize :: Tagged a IntSource

Block size in bytes the hash algorithm operates on

hashDigestSize :: Tagged a IntSource

Digest size in bytes the hash algorithm returns

hashName :: Tagged a StringSource

Name of the hash algorithm

hashInit :: aSource

Initialize a new context for this hash algorithm

hashUpdate :: a -> B.ByteString -> aSource

Update the context with bytestring, and return a new context with the updates.

hashUpdateLazy :: a -> ByteString -> aSource

Update the context with a lazy bytestring, and return a new context with the updates.

hashFinalize :: a -> B.ByteStringSource

Finalize a context and return a digest.

hashHMAC :: B.ByteString -> Tagged a KeyedHashSource

Use HashAlgorithm for HMAC; can use a optimized variant or the default hmacInit one

hash :: HashAlgorithm a => B.ByteString -> Tagged a B.ByteStringSource

Helper to hash a single (strict) B.ByteString in one step.

Example:

 untag (hash (fromString "abc") :: Tagged SHA256 B.ByteString)

hash' :: HashAlgorithm a => a -> B.ByteString -> B.ByteStringSource

Untagged variant of hash; takes a (possible undefined) typed HashAlgorithm context as parameter.

Example:

 hash' (undefined :: SHA256) $ fromString "abc"

hashLazy :: HashAlgorithm a => ByteString -> Tagged a ByteStringSource

Helper to hash a single (lazy) ByteString in one step.

Example:

 untag (hashLazy (fromString "abc") :: Tagged SHA256 L.ByteString)

hashLazy' :: HashAlgorithm a => a -> ByteString -> ByteStringSource

Untagged variant of hashLazy; takes a (possible undefined) typed HashAlgorithm context as parameter.

Example:

 hashLazy' (undefined :: SHA256) $ fromString "abc"

hash algorithms

Only members of the SHA2 and SHA3 family have no known weaknesses (according to http://www.lysator.liu.se/~nisse/nettle/nettle.html#Hash-functions)

GOSTHASH94

data GOSTHASH94 Source

The GOST94 or GOST R 34.11-94 hash algorithm is a Soviet-era algorithm used in Russian government standards (see RFC 4357). It outputs message digests of 32 bytes (256 bits).

MD family

data MD2 Source

MD2 is a hash function of Ronald Rivest's, described in RFC 1319. It outputs message digests of 16 bytes (128 bits).

Instances

data MD4 Source

MD4 is a hash function of Ronald Rivest's, described in RFC 1320. It outputs message digests of 16 bytes (128 bits).

Instances

data MD5 Source

MD5 is a hash function of Ronald Rivest's, described in RFC 1321. It outputs message digests of 16 bytes (128 bits).

Instances

RIPEMD160

data RIPEMD160 Source

RIPEMD160 is a hash function designed by Hans Dobbertin, Antoon Bosselaers, and Bart Preneel, as a strengthened version of RIPEMD. It produces message digests of 20 bytes (160 bits).

SHA1

data SHA1 Source

SHA1 is a hash function specified by NIST (The U.S. National Institute for Standards and Technology). It produces message digests of 20 bytes (160 bits).

Instances

SHA2 family

The SHA2 family supports digests lengths of 28, 32, 48 or 64 bytes (224, 256, 384, 512 bits), and the variants are named after the bit length.

The SHA2 family of hash functions were specified by NIST, intended as a replacement for SHA1.

data SHA224 Source

SHA224 is a member of the SHA2 family which outputs messages digests of 28 bytes (224 bits).

data SHA256 Source

SHA256 is a member of the SHA2 family which outputs messages digests of 32 bytes (256 bits).

data SHA384 Source

SHA384 is a member of the SHA2 family which outputs messages digests of 48 bytes (384 bits).

data SHA512 Source

SHA512 is a member of the SHA2 family which outputs messages digests of 64 bytes (512 bits).

SHA3 family

The SHA3 family supports (like SHA2) digests lengths of 28, 32, 48 or 64 bytes (224, 256, 384, 512 bits), and the variants are named after the bit length.

The SHA3 hash functions were specified by NIST in response to weaknesses in SHA1, and doubts about SHA2 hash functions which structurally are very similar to SHA1. The standard is a result of a competition, where the winner, also known as Keccak, was designed by Guido Bertoni, Joan Daemen, Michaël Peeters and Gilles Van Assche. It is structurally very different from all widely used earlier hash functions.

data SHA3_224 Source

SHA3_224 is a member of the SHA3 family which outputs messages digests of 28 bytes (224 bits).

data SHA3_256 Source

SHA3_256 is a member of the SHA3 family which outputs messages digests of 32 bytes (256 bits).

data SHA3_384 Source

SHA3_384 is a member of the SHA3 family which outputs messages digests of 48 bytes (384 bits).

data SHA3_512 Source

SHA3_512 is a member of the SHA3 family which outputs messages digests of 64 bytes (512 bits).