File: Utils.hs

package info (click to toggle)
haskell-crypton 1.0.4-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 3,548 kB
  • sloc: haskell: 26,764; ansic: 22,294; makefile: 6
file content (21 lines) | stat: -rw-r--r-- 609 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
module Crypto.Cipher.Utils (
    validateKeySize,
) where

import Crypto.Cipher.Types
import Crypto.Error

import Data.ByteArray as BA

validateKeySize
    :: (ByteArrayAccess key, Cipher cipher) => cipher -> key -> CryptoFailable key
validateKeySize c k =
    if validKeyLength
        then CryptoPassed k
        else CryptoFailed CryptoError_KeySizeInvalid
  where
    keyLength = BA.length k
    validKeyLength = case cipherKeySize c of
        KeySizeRange low high -> keyLength >= low && keyLength <= high
        KeySizeEnum lengths -> keyLength `elem` lengths
        KeySizeFixed s -> keyLength == s