Safe Haskell | None |
---|---|
Language | Haskell98 |
- newtype Cipher = Cipher (Ptr EVP_CIPHER)
- data EVP_CIPHER
- withCipherPtr :: Cipher -> (Ptr EVP_CIPHER -> IO a) -> IO a
- cipherIvLength :: Cipher -> Int
- newtype CipherCtx = CipherCtx (ForeignPtr EVP_CIPHER_CTX)
- data EVP_CIPHER_CTX
- newCipherCtx :: IO CipherCtx
- withCipherCtxPtr :: CipherCtx -> (Ptr EVP_CIPHER_CTX -> IO a) -> IO a
- withNewCipherCtxPtr :: (Ptr EVP_CIPHER_CTX -> IO a) -> IO a
- data CryptoMode
- cipherInitBS :: Cipher -> ByteString -> ByteString -> CryptoMode -> IO CipherCtx
- cipherUpdateBS :: CipherCtx -> ByteString -> IO ByteString
- cipherFinalBS :: CipherCtx -> IO ByteString
- cipherStrictly :: CipherCtx -> ByteString -> IO ByteString
- cipherLazily :: CipherCtx -> ByteString -> IO ByteString
- newtype Digest = Digest (Ptr EVP_MD)
- data EVP_MD
- withMDPtr :: Digest -> (Ptr EVP_MD -> IO a) -> IO a
- newtype DigestCtx = DigestCtx (ForeignPtr EVP_MD_CTX)
- data EVP_MD_CTX
- withDigestCtxPtr :: DigestCtx -> (Ptr EVP_MD_CTX -> IO a) -> IO a
- digestUpdateBS :: DigestCtx -> ByteString -> IO ()
- digestFinalBS :: DigestCtx -> IO ByteString
- digestFinal :: DigestCtx -> IO String
- digestStrictly :: Digest -> ByteString -> IO DigestCtx
- digestLazily :: Digest -> ByteString -> IO DigestCtx
- newtype VaguePKey = VaguePKey (ForeignPtr EVP_PKEY)
- data EVP_PKEY
- class PKey k where
- createPKey :: (Ptr EVP_PKEY -> IO a) -> IO VaguePKey
- wrapPKeyPtr :: Ptr EVP_PKEY -> IO VaguePKey
- withPKeyPtr :: VaguePKey -> (Ptr EVP_PKEY -> IO a) -> IO a
- withPKeyPtr' :: PKey k => k -> (Ptr EVP_PKEY -> IO a) -> IO a
- unsafePKeyToPtr :: VaguePKey -> Ptr EVP_PKEY
- touchPKey :: VaguePKey -> IO ()
Documentation
Cipher
is an opaque object that represents an algorithm of
symmetric cipher.
data EVP_CIPHER Source
withCipherPtr :: Cipher -> (Ptr EVP_CIPHER -> IO a) -> IO a Source
cipherIvLength :: Cipher -> Int Source
data EVP_CIPHER_CTX Source
withCipherCtxPtr :: CipherCtx -> (Ptr EVP_CIPHER_CTX -> IO a) -> IO a Source
withNewCipherCtxPtr :: (Ptr EVP_CIPHER_CTX -> IO a) -> IO a Source
:: Cipher | |
-> ByteString | key |
-> ByteString | IV |
-> CryptoMode | |
-> IO CipherCtx |
cipherUpdateBS :: CipherCtx -> ByteString -> IO ByteString Source
cipherFinalBS :: CipherCtx -> IO ByteString Source
cipherStrictly :: CipherCtx -> ByteString -> IO ByteString Source
cipherLazily :: CipherCtx -> ByteString -> IO ByteString Source
Digest
is an opaque object that represents an algorithm of
message digest.
data EVP_MD_CTX Source
withDigestCtxPtr :: DigestCtx -> (Ptr EVP_MD_CTX -> IO a) -> IO a Source
digestUpdateBS :: DigestCtx -> ByteString -> IO () Source
digestFinalBS :: DigestCtx -> IO ByteString Source
digestFinal :: DigestCtx -> IO String Source
digestStrictly :: Digest -> ByteString -> IO DigestCtx Source
digestLazily :: Digest -> ByteString -> IO DigestCtx Source
VaguePKey is a ForeignPtr
to EVP_PKEY
, that is either public
key or a ker pair. We can't tell which at compile time.