License | BSD3 |
---|---|
Maintainer | Marcello Seri <marcello.seri@gmail.com> |
Stability | experimental |
Portability | unknown |
Safe Haskell | None |
Language | Haskell2010 |
Crypto.Multihash.Weak
Description
Multihash library built on top of haskell cryptonite
crypto package
Multihash is a protocol for encoding the hash algorithm and digest length
at the start of the digest, see the official
multihash poroposal github repo.
The Weak
module contains a weaker implementation of the
MultihashDigest type that allows to deserialize multihashes and to work with
different algorithms at the same type. The API interface is almost identical
to the one exposed by Multihash
. The notable differences are:
- the hash algorithms is no longer a type
- the type returned by the multihash constructors is an
Either
(seeweakMultihash
andweakMultihashlazy
) - there is a function
toWeakMultihash
to deserialise multihashes
For additional informations refer to the README.md or the gihub repository.
- data WeakMultihashDigest
- data Base
- class Encodable a where
- encode :: IsString s => Base -> a -> Either String s
- encode' :: IsString s => Base -> a -> s
- check :: (IsString s, ConvertibleStrings s ByteString) => s -> a -> Either String Bool
- check' :: (IsString s, ConvertibleStrings s ByteString) => s -> a -> Bool
- weakMultihash :: ByteArrayAccess bs => ByteString -> bs -> Either String WeakMultihashDigest
- weakMultihash' :: ByteArrayAccess bs => ByteString -> bs -> WeakMultihashDigest
- weakMultihashlazy :: ByteString -> ByteString -> Either String WeakMultihashDigest
- weakMultihashlazy' :: ByteString -> ByteString -> WeakMultihashDigest
- truncatedWeakMultihash :: ByteArrayAccess bs => Int -> ByteString -> bs -> Either String WeakMultihashDigest
- truncatedWeakMultihash' :: ByteArrayAccess bs => Int -> ByteString -> bs -> WeakMultihashDigest
- toWeakMultihash :: ByteString -> Either String WeakMultihashDigest
- checkWeakMultihash :: (IsString s, ConvertibleStrings s ByteString, ByteArrayAccess bs) => s -> bs -> Either String Bool
- checkWeakMultihash' :: (IsString s, ConvertibleStrings s ByteString, ByteArrayAccess bs) => s -> bs -> Bool
- getBase :: ByteString -> Either String Base
Weak Multihash Types
data WeakMultihashDigest Source
Weak Multihash Digest container
Base
usable to encode the digest
class Encodable a where Source
Methods
encode :: IsString s => Base -> a -> Either String s Source
Safe encoder for Encodable
.
encode' :: IsString s => Base -> a -> s Source
Unsafe encoder for Encodable
.
Throws an error if there are encoding issues.
check :: (IsString s, ConvertibleStrings s ByteString) => s -> a -> Either String Bool Source
check' :: (IsString s, ConvertibleStrings s ByteString) => s -> a -> Bool Source
Unsafe version of check
. Throws on encoding/decoding errors instead of returning an Either type.
Instances
Encodable WeakMultihashDigest Source | |
(HashAlgorithm a, Codable a) => Encodable (MultihashDigest a) Source |
Weak Multihash Helpers
weakMultihash :: ByteArrayAccess bs => ByteString -> bs -> Either String WeakMultihashDigest Source
Helper to multihash a ByteArrayAccess
(e.g. a ByteString
) using a
supported hash algorithm. Uses hash
for hashing.
weakMultihash' :: ByteArrayAccess bs => ByteString -> bs -> WeakMultihashDigest Source
Unsafe equivalent of weakMultihash
. Throws on creation errors.
weakMultihashlazy :: ByteString -> ByteString -> Either String WeakMultihashDigest Source
Helper to multihash a lazy ByteString
using a supported hash algorithm.
Uses hashlazy
for hashing.
weakMultihashlazy' :: ByteString -> ByteString -> WeakMultihashDigest Source
Unsafe equivalent of weakMultihashlazy
. Throws on creation errors.
truncatedWeakMultihash :: ByteArrayAccess bs => Int -> ByteString -> bs -> Either String WeakMultihashDigest Source
Helper to multihash a ByteArrayAccess
using a supported hash algorithm.
Uses hash
for hashing and truncates the hash to the lenght
specified (must be positive and not longer than the digest length).
truncatedWeakMultihash' :: ByteArrayAccess bs => Int -> ByteString -> bs -> WeakMultihashDigest Source
Unsafe helper to multihash a ByteArrayAccess
using a supported hash algorithm.
Uses hash
for hashing and truncates the hash to the lenght
specified (must be positive and not longer than the digest length, otherwise
the function will throw an error).
toWeakMultihash :: ByteString -> Either String WeakMultihashDigest Source
Imports a multihash into a WeahMultihashDigest
if possible.
checkWeakMultihash :: (IsString s, ConvertibleStrings s ByteString, ByteArrayAccess bs) => s -> bs -> Either String Bool Source
Safely check the correctness of an encoded Encodable
against the
corresponding data.
checkWeakMultihash' :: (IsString s, ConvertibleStrings s ByteString, ByteArrayAccess bs) => s -> bs -> Bool Source
Unsafe version of checkWeakMultihash
.
Throws on encoding/decoding errors instead of returning an Either
type.