| Portability | Good | 
|---|---|
| Stability | experimental | 
| Maintainer | Vincent Hanquez <vincent@snarc.org> | 
Crypto.Cipher.RSA
Description
- data Error
- data PublicKey = PublicKey {}
- data PrivateKey = PrivateKey {}
- type HashF = ByteString -> ByteString
- type HashASN1 = ByteString
- generate :: CryptoRandomGen g => g -> Int -> Integer -> Either Error ((PublicKey, PrivateKey), g)
- decrypt :: PrivateKey -> ByteString -> Either Error ByteString
- encrypt :: CryptoRandomGen g => g -> PublicKey -> ByteString -> Either Error (ByteString, g)
- sign :: HashF -> HashASN1 -> PrivateKey -> ByteString -> Either Error ByteString
- verify :: HashF -> HashASN1 -> PublicKey -> ByteString -> ByteString -> Either Error Bool
Documentation
Constructors
| MessageSizeIncorrect | the message to decrypt is not of the correct size (need to be == private_size) | 
| MessageTooLong | the message to encrypt is too long (>= private_size - 11) | 
| MessageNotRecognized | the message decrypted doesn't have a PKCS15 structure (0 2 .. 0 msg) | 
| SignatureTooLong | the signature generated through the hash is too long to process with this key | 
| RandomGenFailure GenError | the random generator returns an error. give the opportunity to reseed for example. | 
| KeyInternalError | the whole key is probably not valid, since the message is bigger than the key size | 
Constructors
| PublicKey | |
data PrivateKey Source
Constructors
| PrivateKey | |
| Fields 
 | |
Instances
type HashF = ByteString -> ByteStringSource
type HashASN1 = ByteStringSource
generate :: CryptoRandomGen g => g -> Int -> Integer -> Either Error ((PublicKey, PrivateKey), g)Source
generate a pair of (private, public) key of size in bytes.
decrypt :: PrivateKey -> ByteString -> Either Error ByteStringSource
decrypt message using the private key.
encrypt :: CryptoRandomGen g => g -> PublicKey -> ByteString -> Either Error (ByteString, g)Source
encrypt a bytestring using the public key and a CryptoRandomGen random generator. - the message need to be smaller than the key size - 11
sign :: HashF -> HashASN1 -> PrivateKey -> ByteString -> Either Error ByteStringSource
sign message using private key, a hash and its ASN1 description
verify :: HashF -> HashASN1 -> PublicKey -> ByteString -> ByteString -> Either Error BoolSource
verify message with the signed message