namespace CryptoFile
+open System
+open System.IO
+open System.Security.Cryptography
+
// Some cryptography primitives specific to CryptoFile.
module internal Crypto =
- open System
- open System.IO
- open System.Security.Cryptography
-
type Data = byte[]
let rsaKeySize = 2048
let HMACStream (key: byte[]) (outputStream: Stream) : Stream * HMACSHA256 =
assert (key.Length = 32)
let hmac = new HMACSHA256 (key)
- new CryptoStream (outputStream, hmac, CryptoStreamMode.Write) :> Stream, hmac
\ No newline at end of file
+ new CryptoStream (outputStream, hmac, CryptoStreamMode.Write) :> Stream, hmac
+
+ let ComputeHMAC (key: byte[]) (inputStream: Stream) : byte[] =
+ assert (key.Length = 32)
+ let hmac = new HMACSHA256 (key)
+ hmac.ComputeHash inputStream
\ No newline at end of file