| Safe Haskell | Safe-Infered | 
|---|
OpenSSL.EVP.Cipher
Description
An interface to symmetric cipher algorithms.
- data Cipher
- getCipherByName :: String -> IO (Maybe Cipher)
- getCipherNames :: IO [String]
- data CryptoMode
- cipher :: Cipher -> String -> String -> CryptoMode -> String -> IO String
- cipherBS :: Cipher -> String -> String -> CryptoMode -> ByteString -> IO ByteString
- cipherLBS :: Cipher -> String -> String -> CryptoMode -> ByteString -> IO ByteString
- cipherStrictLBS :: Cipher -> ByteString -> ByteString -> CryptoMode -> ByteString -> IO ByteString
Documentation
getCipherByName :: String -> IO (Maybe Cipher)Source
getCipherByName namename. If no algorithms are found, the result is
 Nothing.
getCipherNames :: IO [String]Source
getCipherNames
data CryptoMode Source
CryptoMode represents instruction to cipher and such like.
Arguments
| :: Cipher | algorithm to use | 
| -> String | symmetric key | 
| -> String | IV | 
| -> CryptoMode | operation | 
| -> String | An input string to encrypt/decrypt. Note that the string must not contain any letters which aren't in the range of U+0000 - U+00FF. | 
| -> IO String | the result string | 
cipher
Arguments
| :: Cipher | algorithm to use | 
| -> String | symmetric key | 
| -> String | IV | 
| -> CryptoMode | operation | 
| -> ByteString | input string to encrypt/decrypt | 
| -> IO ByteString | the result string | 
cipherBS
Arguments
| :: Cipher | algorithm to use | 
| -> String | symmetric key | 
| -> String | IV | 
| -> CryptoMode | operation | 
| -> ByteString | input string to encrypt/decrypt | 
| -> IO ByteString | the result string | 
cipherLBS
Arguments
| :: Cipher | Cipher | 
| -> ByteString | Key | 
| -> ByteString | IV | 
| -> CryptoMode | Encrypt/Decrypt | 
| -> ByteString | Input | 
| -> IO ByteString | 
Encrypt a lazy bytestring in a strict manner. Does not leak the keys.