License | BSD-style |
---|---|
Maintainer | Vincent Hanquez <vincent@snarc.org> |
Stability | experimental |
Portability | unknown |
Safe Haskell | Trustworthy |
Language | Haskell98 |
Generalized cryptographic hash interface, that you can use with cryptographic hash algorithm that belong to the HashAlgorithm type class.
import Crypto.Hash sha1 :: ByteString -> Digest SHA1 sha1 = hash hexSha3_512 :: ByteString -> String hexSha3_512 bs = show (hash bs :: Digest SHA3_512)
- class HashAlgorithm a where
- type HashFunctionBS a = ByteString -> Digest a
- type HashFunctionLBS a = ByteString -> Digest a
- data Context a
- data Digest a
- digestToByteString :: Digest a -> ByteString
- digestToHexByteString :: Digest a -> ByteString
- hash :: HashAlgorithm a => ByteString -> Digest a
- hashlazy :: HashAlgorithm a => ByteString -> Digest a
- hashUpdate :: HashAlgorithm a => Context a -> ByteString -> Context a
- hashInitAlg :: HashAlgorithm alg => alg -> Context alg
- data MD2 :: * = MD2
- data MD4 :: * = MD4
- data MD5 :: * = MD5
- data SHA1 :: * = SHA1
- data SHA224 :: * = SHA224
- data SHA256 :: * = SHA256
- data SHA384 :: * = SHA384
- data SHA512 :: * = SHA512
- data RIPEMD160 :: * = RIPEMD160
- data Tiger :: * = Tiger
- data SHA3_224 :: * = SHA3_224
- data SHA3_256 :: * = SHA3_256
- data SHA3_384 :: * = SHA3_384
- data SHA3_512 :: * = SHA3_512
- data Skein256_224 :: * = Skein256_224
- data Skein256_256 :: * = Skein256_256
- data Skein512_224 :: * = Skein512_224
- data Skein512_256 :: * = Skein512_256
- data Skein512_384 :: * = Skein512_384
- data Skein512_512 :: * = Skein512_512
- data Whirlpool :: * = Whirlpool
- newtype HMAC a = HMAC {
- hmacGetDigest :: Digest a
- hmac :: HashAlgorithm a => ByteString -> ByteString -> HMAC a
- hmacAlg :: HashAlgorithm a => a -> ByteString -> ByteString -> HMAC a
Types
class HashAlgorithm a where #
Class representing hashing algorithms.
The hash algorithm is built over 3 primitives:
- init : create a new hashing context
- updates : update the hashing context with some strict bytestrings and return the new context
- finalize : finalize the context into a digest
hashBlockSize :: Context a -> Int #
Block size in bytes the hash algorithm operates on
Initialize a new context for this hash algorithm
hashUpdates :: Context a -> [ByteString] -> Context a #
Update the context with a list of strict bytestring, and return a new context with the updates.
hashFinalize :: Context a -> Digest a #
Finalize a context and return a digest.
digestFromByteString :: ByteString -> Maybe (Digest a) #
Try to convert a binary digest bytestring to a digest.
HashAlgorithm MD2 # | MD2 cryptographic hash |
HashAlgorithm MD4 # | MD4 cryptographic hash |
HashAlgorithm MD5 # | MD5 cryptographic hash |
HashAlgorithm RIPEMD160 # | RIPEMD160 cryptographic hash |
HashAlgorithm SHA1 # | SHA1 cryptographic hash |
HashAlgorithm SHA224 # | SHA224 cryptographic hash |
HashAlgorithm SHA256 # | SHA256 cryptographic hash |
HashAlgorithm SHA3_224 # | SHA3 (224 bits version) cryptographic hash |
HashAlgorithm SHA3_256 # | SHA3 (256 bits version) cryptographic hash |
HashAlgorithm SHA3_384 # | SHA3 (384 bits version) cryptographic hash |
HashAlgorithm SHA3_512 # | SHA3 (512 bits version) cryptographic hash |
HashAlgorithm SHA384 # | SHA384 cryptographic hash |
HashAlgorithm SHA512 # | SHA512 cryptographic hash |
HashAlgorithm Skein256_224 # | Skein256 (224 bits version) cryptographic hash |
HashAlgorithm Skein256_256 # | Skein256 (256 bits version) cryptographic hash |
HashAlgorithm Skein512_224 # | Skein512 (224 bits version) cryptographic hash |
HashAlgorithm Skein512_256 # | Skein512 (256 bits version) cryptographic hash |
HashAlgorithm Skein512_384 # | Skein512 (384 bits version) cryptographic hash |
HashAlgorithm Skein512_512 # | Skein512 (512 bits version) cryptographic hash |
HashAlgorithm Tiger # | Tiger cryptographic hash |
HashAlgorithm Whirlpool # | Whirlpool cryptographic hash |
type HashFunctionBS a = ByteString -> Digest a #
Alias to a single pass hash function that operate on a strict bytestring
type HashFunctionLBS a = ByteString -> Digest a #
Alias to a single pass hash function that operate on a lazy bytestring
Represent a digest for a given hash algorithm.
Functions
digestToByteString :: Digest a -> ByteString #
Deprecated: use toBytes from byteable:Data.Byteable
return the binary bytestring. deprecated use toBytes.
digestToHexByteString :: Digest a -> ByteString #
Return the hexadecimal (base16) bytestring of the digest
hash :: HashAlgorithm a => ByteString -> Digest a #
Hash a strict bytestring into a digest.
hashlazy :: HashAlgorithm a => ByteString -> Digest a #
Hash a lazy bytestring into a digest.
hashUpdate :: HashAlgorithm a => Context a -> ByteString -> Context a #
run hashUpdates on one single bytestring and return the updated context.
hashInitAlg :: HashAlgorithm alg => alg -> Context alg #
Initialize a new context for a specified hash algorithm
hash algorithms
MD2 cryptographic hash algorithm
Data MD2 | |
Show MD2 | |
HashAlgorithm MD2 | |
HashAlgorithm MD2 # | MD2 cryptographic hash |
MD4 cryptographic hash algorithm
Data MD4 | |
Show MD4 | |
HashAlgorithm MD4 | |
HashAlgorithm MD4 # | MD4 cryptographic hash |
MD5 cryptographic hash algorithm
Data MD5 | |
Show MD5 | |
HashAlgorithm MD5 | |
HashAlgorithm MD5 # | MD5 cryptographic hash |
SHA1 cryptographic hash algorithm
Data SHA1 | |
Show SHA1 | |
HashAlgorithm SHA1 | |
HashAlgorithm SHA1 # | SHA1 cryptographic hash |
SHA224 cryptographic hash algorithm
Data SHA224 | |
Show SHA224 | |
HashAlgorithm SHA224 | |
HashAlgorithm SHA224 # | SHA224 cryptographic hash |
SHA256 cryptographic hash algorithm
Data SHA256 | |
Show SHA256 | |
HashAlgorithm SHA256 | |
HashAlgorithm SHA256 # | SHA256 cryptographic hash |
SHA384 cryptographic hash algorithm
Data SHA384 | |
Show SHA384 | |
HashAlgorithm SHA384 | |
HashAlgorithm SHA384 # | SHA384 cryptographic hash |
SHA512 cryptographic hash algorithm
Data SHA512 | |
Show SHA512 | |
HashAlgorithm SHA512 | |
HashAlgorithm SHA512 # | SHA512 cryptographic hash |
RIPEMD160 cryptographic hash algorithm
Data RIPEMD160 | |
Show RIPEMD160 | |
HashAlgorithm RIPEMD160 | |
HashAlgorithm RIPEMD160 # | RIPEMD160 cryptographic hash |
Tiger cryptographic hash algorithm
Data Tiger | |
Show Tiger | |
HashAlgorithm Tiger | |
HashAlgorithm Tiger # | Tiger cryptographic hash |
SHA3 (224 bits) cryptographic hash algorithm
Data SHA3_224 | |
Show SHA3_224 | |
HashAlgorithm SHA3_224 | |
HashAlgorithm SHA3_224 # | SHA3 (224 bits version) cryptographic hash |
SHA3 (256 bits) cryptographic hash algorithm
Data SHA3_256 | |
Show SHA3_256 | |
HashAlgorithm SHA3_256 | |
HashAlgorithm SHA3_256 # | SHA3 (256 bits version) cryptographic hash |
SHA3 (384 bits) cryptographic hash algorithm
Data SHA3_384 | |
Show SHA3_384 | |
HashAlgorithm SHA3_384 | |
HashAlgorithm SHA3_384 # | SHA3 (384 bits version) cryptographic hash |
SHA3 (512 bits) cryptographic hash algorithm
Data SHA3_512 | |
Show SHA3_512 | |
HashAlgorithm SHA3_512 | |
HashAlgorithm SHA3_512 # | SHA3 (512 bits version) cryptographic hash |
data Skein256_224 :: * #
Skein256 (224 bits) cryptographic hash algorithm
Data Skein256_224 | |
Show Skein256_224 | |
HashAlgorithm Skein256_224 | |
HashAlgorithm Skein256_224 # | Skein256 (224 bits version) cryptographic hash |
data Skein256_256 :: * #
Skein256 (256 bits) cryptographic hash algorithm
Data Skein256_256 | |
Show Skein256_256 | |
HashAlgorithm Skein256_256 | |
HashAlgorithm Skein256_256 # | Skein256 (256 bits version) cryptographic hash |
data Skein512_224 :: * #
Skein512 (224 bits) cryptographic hash algorithm
Data Skein512_224 | |
Show Skein512_224 | |
HashAlgorithm Skein512_224 | |
HashAlgorithm Skein512_224 # | Skein512 (224 bits version) cryptographic hash |
data Skein512_256 :: * #
Skein512 (256 bits) cryptographic hash algorithm
Data Skein512_256 | |
Show Skein512_256 | |
HashAlgorithm Skein512_256 | |
HashAlgorithm Skein512_256 # | Skein512 (256 bits version) cryptographic hash |
data Skein512_384 :: * #
Skein512 (384 bits) cryptographic hash algorithm
Data Skein512_384 | |
Show Skein512_384 | |
HashAlgorithm Skein512_384 | |
HashAlgorithm Skein512_384 # | Skein512 (384 bits version) cryptographic hash |
data Skein512_512 :: * #
Skein512 (512 bits) cryptographic hash algorithm
Data Skein512_512 | |
Show Skein512_512 | |
HashAlgorithm Skein512_512 | |
HashAlgorithm Skein512_512 # | Skein512 (512 bits version) cryptographic hash |
Whirlpool cryptographic hash algorithm
Data Whirlpool | |
Show Whirlpool | |
HashAlgorithm Whirlpool | |
HashAlgorithm Whirlpool # | Whirlpool cryptographic hash |
MAC algorithms
Represent an HMAC that is a phantom type with the hash used to produce the mac.
The Eq instance is constant time.
HMAC | |
|
:: HashAlgorithm a | |
=> ByteString | Secret key |
-> ByteString | Message to MAC |
-> HMAC a |
compute a MAC using the supplied hashing function
:: HashAlgorithm a | |
=> a | the hash algorithm the actual value is unused. |
-> ByteString | Secret key |
-> ByteString | Message to MAC |
-> HMAC a |
compute a HMAC using a specified algorithm