License | BSD-style |
---|---|
Maintainer | Vincent Hanquez <vincent@snarc.org> |
Stability | experimental |
Portability | unknown |
Safe Haskell | None |
Language | Haskell2010 |
Key Derivation Function based on HMAC
See RFC5869
Synopsis
- data PRK a
- extract :: ( HashAlgorithm a, ByteArrayAccess salt, ByteArrayAccess ikm) => salt -> ikm -> PRK a
- extractSkip :: ByteArrayAccess ikm => ikm -> PRK a
- expand :: ( HashAlgorithm a, ByteArrayAccess info, ByteArray out) => PRK a -> info -> Int -> out
Documentation
:: ( HashAlgorithm a, ByteArrayAccess salt, ByteArrayAccess ikm) | |
=> salt |
Salt |
-> ikm |
Input Keying Material |
-> PRK a |
Pseudo random key |
Extract a Pseudo Random Key using the parameter and the underlaying hash mechanism
extractSkip :: ByteArrayAccess ikm => ikm -> PRK a Source #
Create a PRK directly from the input key material.
Only use when guaranteed to have a good quality and random data to use directly as key. This effectively skip a HMAC with key=salt and data=key.
:: ( HashAlgorithm a, ByteArrayAccess info, ByteArray out) | |
=> PRK a |
Pseudo Random Key |
-> info |
Optional context and application specific information |
-> Int |
Output length in bytes |
-> out |
Output data |
Expand key material of specific length out of the parameters