{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TemplateHaskell #-}
module Crypto.JOSE.JWA.JWE
( Enc(..)
, AlgWithParams(..)
, AESGCMParameters(AESGCMParameters)
, ECDHParameters(ECDHParameters)
, PBES2Parameters(PBES2Parameters)
) where
import Data.Maybe (catMaybes)
import Crypto.JOSE.JWK
import Crypto.JOSE.TH
import Crypto.JOSE.Types
import Crypto.JOSE.Types.Internal (insertToObject)
import Data.Aeson
import qualified Data.Aeson.KeyMap as M
data AlgWithParams
= RSA1_5
| RSA_OAEP
| RSA_OAEP_256
| A128KW
| A192KW
| A256KW
| Dir
| ECDH_ES ECDHParameters
| ECDH_ES_A128KW ECDHParameters
| ECDH_ES_A192KW ECDHParameters
| ECDH_ES_A256KW ECDHParameters
| A128GCMKW AESGCMParameters
| A192GCMKW AESGCMParameters
| A256GCMKW AESGCMParameters
| PBES2_HS256_A128KW PBES2Parameters
| PBES2_HS384_A192KW PBES2Parameters
| PBES2_HS512_A256KW PBES2Parameters
deriving (AlgWithParams -> AlgWithParams -> Bool
(AlgWithParams -> AlgWithParams -> Bool)
-> (AlgWithParams -> AlgWithParams -> Bool) -> Eq AlgWithParams
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: AlgWithParams -> AlgWithParams -> Bool
== :: AlgWithParams -> AlgWithParams -> Bool
$c/= :: AlgWithParams -> AlgWithParams -> Bool
/= :: AlgWithParams -> AlgWithParams -> Bool
Eq, Int -> AlgWithParams -> ShowS
[AlgWithParams] -> ShowS
AlgWithParams -> String
(Int -> AlgWithParams -> ShowS)
-> (AlgWithParams -> String)
-> ([AlgWithParams] -> ShowS)
-> Show AlgWithParams
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> AlgWithParams -> ShowS
showsPrec :: Int -> AlgWithParams -> ShowS
$cshow :: AlgWithParams -> String
show :: AlgWithParams -> String
$cshowList :: [AlgWithParams] -> ShowS
showList :: [AlgWithParams] -> ShowS
Show)
instance FromJSON AlgWithParams where
parseJSON :: Value -> Parser AlgWithParams
parseJSON = String
-> (Object -> Parser AlgWithParams)
-> Value
-> Parser AlgWithParams
forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"Encryption alg and params" ((Object -> Parser AlgWithParams) -> Value -> Parser AlgWithParams)
-> (Object -> Parser AlgWithParams)
-> Value
-> Parser AlgWithParams
forall a b. (a -> b) -> a -> b
$ \Object
o ->
case Key -> Object -> Maybe Value
forall v. Key -> KeyMap v -> Maybe v
M.lookup Key
"alg" Object
o of
Maybe Value
Nothing -> String -> Parser AlgWithParams
forall a. String -> Parser a
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"\"alg\" parameter is required"
Just Value
"RSA1_5" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
RSA1_5
Just Value
"RSA-OAEP" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
RSA_OAEP
Just Value
"RSA-OAEP-256" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
RSA_OAEP_256
Just Value
"A128KW" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
A128KW
Just Value
"A192KW" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
A192KW
Just Value
"A256KW" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
A256KW
Just Value
"dir" -> AlgWithParams -> Parser AlgWithParams
forall a. a -> Parser a
forall (f :: * -> *) a. Applicative f => a -> f a
pure AlgWithParams
Dir
Just Value
"ECDH-ES" -> ECDHParameters -> AlgWithParams
ECDH_ES (ECDHParameters -> AlgWithParams)
-> Parser ECDHParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser ECDHParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"ECDH-ES+A128KW" -> ECDHParameters -> AlgWithParams
ECDH_ES_A128KW (ECDHParameters -> AlgWithParams)
-> Parser ECDHParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser ECDHParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"ECDH-ES+A192KW" -> ECDHParameters -> AlgWithParams
ECDH_ES_A192KW (ECDHParameters -> AlgWithParams)
-> Parser ECDHParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser ECDHParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"ECDH-ES+A256KW" -> ECDHParameters -> AlgWithParams
ECDH_ES_A256KW (ECDHParameters -> AlgWithParams)
-> Parser ECDHParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser ECDHParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"A128GCMKW" -> AESGCMParameters -> AlgWithParams
A128GCMKW (AESGCMParameters -> AlgWithParams)
-> Parser AESGCMParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser AESGCMParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"A192GCMKW" -> AESGCMParameters -> AlgWithParams
A192GCMKW (AESGCMParameters -> AlgWithParams)
-> Parser AESGCMParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser AESGCMParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"A256GCMKW" -> AESGCMParameters -> AlgWithParams
A256GCMKW (AESGCMParameters -> AlgWithParams)
-> Parser AESGCMParameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser AESGCMParameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"PBES2-HS256+A128KW" -> PBES2Parameters -> AlgWithParams
PBES2_HS256_A128KW (PBES2Parameters -> AlgWithParams)
-> Parser PBES2Parameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser PBES2Parameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"PBES2-HS384+A192KW" -> PBES2Parameters -> AlgWithParams
PBES2_HS384_A192KW (PBES2Parameters -> AlgWithParams)
-> Parser PBES2Parameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser PBES2Parameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Just Value
"PBES2-HS512+A256KW" -> PBES2Parameters -> AlgWithParams
PBES2_HS512_A256KW (PBES2Parameters -> AlgWithParams)
-> Parser PBES2Parameters -> Parser AlgWithParams
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Value -> Parser PBES2Parameters
forall a. FromJSON a => Value -> Parser a
parseJSON (Object -> Value
Object Object
o)
Maybe Value
_ -> String -> Parser AlgWithParams
forall a. String -> Parser a
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String -> Parser AlgWithParams) -> String -> Parser AlgWithParams
forall a b. (a -> b) -> a -> b
$ String
"unrecognised value; expected: "
String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
"[\"RSA1_5\",\"RSA-OAEP\",\"RSA-OAEP-256\",\"A128KW\",\"A192KW\",\"A256KW\",\"dir\",\"ECDH-ES\",\"ECDH-ES+A128KW\",\"ECDH-ES+A192KW\",\"ECDH-ES+A256KW\",\"A128GCMKW\",\"A192GCMKW\",\"A256GCMKW\",\"PBES2-HS256+A128KW\",\"PBES2-HS384+A128KW\",\"PBES2-HS512+A128KW\"]"
algObject :: Value -> Value
algObject :: Value -> Value
algObject Value
s = [Pair] -> Value
object [(Key
"alg", Value
s)]
algWithParamsObject :: ToJSON a => a -> Value -> Value
algWithParamsObject :: forall a. ToJSON a => a -> Value -> Value
algWithParamsObject a
a Value
s = Key -> Value -> Value -> Value
forall v. ToJSON v => Key -> v -> Value -> Value
insertToObject Key
"alg" Value
s (a -> Value
forall a. ToJSON a => a -> Value
toJSON a
a)
instance ToJSON AlgWithParams where
toJSON :: AlgWithParams -> Value
toJSON AlgWithParams
RSA1_5 = Value -> Value
algObject Value
"RSA1_5"
toJSON AlgWithParams
RSA_OAEP = Value -> Value
algObject Value
"RSA-OAEP"
toJSON AlgWithParams
RSA_OAEP_256 = Value -> Value
algObject Value
"RSA-OAEP-256"
toJSON AlgWithParams
A128KW = Value -> Value
algObject Value
"A128KW"
toJSON AlgWithParams
A192KW = Value -> Value
algObject Value
"A192KW"
toJSON AlgWithParams
A256KW = Value -> Value
algObject Value
"A256KW"
toJSON AlgWithParams
Dir = Value -> Value
algObject Value
"Dir"
toJSON (ECDH_ES ECDHParameters
params) = ECDHParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject ECDHParameters
params Value
"ECDH-ES"
toJSON (ECDH_ES_A128KW ECDHParameters
params) = ECDHParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject ECDHParameters
params Value
"ECDH-ES+A128KW"
toJSON (ECDH_ES_A192KW ECDHParameters
params) = ECDHParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject ECDHParameters
params Value
"ECDH-ES+A192KW"
toJSON (ECDH_ES_A256KW ECDHParameters
params) = ECDHParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject ECDHParameters
params Value
"ECDH-ES+A256KW"
toJSON (A128GCMKW AESGCMParameters
params) = AESGCMParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject AESGCMParameters
params Value
"A128GCMKW"
toJSON (A192GCMKW AESGCMParameters
params) = AESGCMParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject AESGCMParameters
params Value
"A192GCMKW"
toJSON (A256GCMKW AESGCMParameters
params) = AESGCMParameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject AESGCMParameters
params Value
"A256GCMKW"
toJSON (PBES2_HS256_A128KW PBES2Parameters
params) = PBES2Parameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject PBES2Parameters
params Value
"PBES2-HS256+A128KW"
toJSON (PBES2_HS384_A192KW PBES2Parameters
params) = PBES2Parameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject PBES2Parameters
params Value
"PBES2-HS384+A192KW"
toJSON (PBES2_HS512_A256KW PBES2Parameters
params) = PBES2Parameters -> Value -> Value
forall a. ToJSON a => a -> Value -> Value
algWithParamsObject PBES2Parameters
params Value
"PBES2-HS512+A256KW"
data ECDHParameters = ECDHParameters
{ ECDHParameters -> JWK
_epk :: JWK
, ECDHParameters -> Maybe Base64Octets
_apu :: Maybe Base64Octets
, ECDHParameters -> Maybe Base64Octets
_apv :: Maybe Base64Octets
} deriving (ECDHParameters -> ECDHParameters -> Bool
(ECDHParameters -> ECDHParameters -> Bool)
-> (ECDHParameters -> ECDHParameters -> Bool) -> Eq ECDHParameters
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ECDHParameters -> ECDHParameters -> Bool
== :: ECDHParameters -> ECDHParameters -> Bool
$c/= :: ECDHParameters -> ECDHParameters -> Bool
/= :: ECDHParameters -> ECDHParameters -> Bool
Eq, Int -> ECDHParameters -> ShowS
[ECDHParameters] -> ShowS
ECDHParameters -> String
(Int -> ECDHParameters -> ShowS)
-> (ECDHParameters -> String)
-> ([ECDHParameters] -> ShowS)
-> Show ECDHParameters
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ECDHParameters -> ShowS
showsPrec :: Int -> ECDHParameters -> ShowS
$cshow :: ECDHParameters -> String
show :: ECDHParameters -> String
$cshowList :: [ECDHParameters] -> ShowS
showList :: [ECDHParameters] -> ShowS
Show)
instance FromJSON ECDHParameters where
parseJSON :: Value -> Parser ECDHParameters
parseJSON = String
-> (Object -> Parser ECDHParameters)
-> Value
-> Parser ECDHParameters
forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"ECDH Parameters" ((Object -> Parser ECDHParameters)
-> Value -> Parser ECDHParameters)
-> (Object -> Parser ECDHParameters)
-> Value
-> Parser ECDHParameters
forall a b. (a -> b) -> a -> b
$ \Object
o -> JWK -> Maybe Base64Octets -> Maybe Base64Octets -> ECDHParameters
ECDHParameters
(JWK -> Maybe Base64Octets -> Maybe Base64Octets -> ECDHParameters)
-> Parser JWK
-> Parser
(Maybe Base64Octets -> Maybe Base64Octets -> ECDHParameters)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o Object -> Key -> Parser JWK
forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"epk"
Parser (Maybe Base64Octets -> Maybe Base64Octets -> ECDHParameters)
-> Parser (Maybe Base64Octets)
-> Parser (Maybe Base64Octets -> ECDHParameters)
forall a b. Parser (a -> b) -> Parser a -> Parser b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o Object -> Key -> Parser (Maybe Base64Octets)
forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"apu"
Parser (Maybe Base64Octets -> ECDHParameters)
-> Parser (Maybe Base64Octets) -> Parser ECDHParameters
forall a b. Parser (a -> b) -> Parser a -> Parser b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o Object -> Key -> Parser (Maybe Base64Octets)
forall a. FromJSON a => Object -> Key -> Parser (Maybe a)
.:? Key
"apv"
instance ToJSON ECDHParameters where
toJSON :: ECDHParameters -> Value
toJSON (ECDHParameters JWK
epk Maybe Base64Octets
apu Maybe Base64Octets
apv) = [Pair] -> Value
object ([Pair] -> Value) -> [Pair] -> Value
forall a b. (a -> b) -> a -> b
$ [Maybe Pair] -> [Pair]
forall a. [Maybe a] -> [a]
catMaybes
[ Pair -> Maybe Pair
forall a. a -> Maybe a
Just (Key
"epk" Key -> JWK -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.= JWK
epk)
, (Base64Octets -> Pair) -> Maybe Base64Octets -> Maybe Pair
forall a b. (a -> b) -> Maybe a -> Maybe b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (Key
"apu" Key -> Base64Octets -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.=) Maybe Base64Octets
apu
, (Base64Octets -> Pair) -> Maybe Base64Octets -> Maybe Pair
forall a b. (a -> b) -> Maybe a -> Maybe b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (Key
"apu" Key -> Base64Octets -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.=) Maybe Base64Octets
apv
]
data AESGCMParameters = AESGCMParameters
{ AESGCMParameters -> Base64Octets
_iv :: Base64Octets
, AESGCMParameters -> Base64Octets
_tag :: Base64Octets
} deriving (AESGCMParameters -> AESGCMParameters -> Bool
(AESGCMParameters -> AESGCMParameters -> Bool)
-> (AESGCMParameters -> AESGCMParameters -> Bool)
-> Eq AESGCMParameters
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: AESGCMParameters -> AESGCMParameters -> Bool
== :: AESGCMParameters -> AESGCMParameters -> Bool
$c/= :: AESGCMParameters -> AESGCMParameters -> Bool
/= :: AESGCMParameters -> AESGCMParameters -> Bool
Eq, Int -> AESGCMParameters -> ShowS
[AESGCMParameters] -> ShowS
AESGCMParameters -> String
(Int -> AESGCMParameters -> ShowS)
-> (AESGCMParameters -> String)
-> ([AESGCMParameters] -> ShowS)
-> Show AESGCMParameters
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> AESGCMParameters -> ShowS
showsPrec :: Int -> AESGCMParameters -> ShowS
$cshow :: AESGCMParameters -> String
show :: AESGCMParameters -> String
$cshowList :: [AESGCMParameters] -> ShowS
showList :: [AESGCMParameters] -> ShowS
Show)
instance FromJSON AESGCMParameters where
parseJSON :: Value -> Parser AESGCMParameters
parseJSON = String
-> (Object -> Parser AESGCMParameters)
-> Value
-> Parser AESGCMParameters
forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"AES-GCM Parameters" ((Object -> Parser AESGCMParameters)
-> Value -> Parser AESGCMParameters)
-> (Object -> Parser AESGCMParameters)
-> Value
-> Parser AESGCMParameters
forall a b. (a -> b) -> a -> b
$ \Object
o -> Base64Octets -> Base64Octets -> AESGCMParameters
AESGCMParameters
(Base64Octets -> Base64Octets -> AESGCMParameters)
-> Parser Base64Octets -> Parser (Base64Octets -> AESGCMParameters)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o Object -> Key -> Parser Base64Octets
forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"iv"
Parser (Base64Octets -> AESGCMParameters)
-> Parser Base64Octets -> Parser AESGCMParameters
forall a b. Parser (a -> b) -> Parser a -> Parser b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o Object -> Key -> Parser Base64Octets
forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"tag"
instance ToJSON AESGCMParameters where
toJSON :: AESGCMParameters -> Value
toJSON (AESGCMParameters Base64Octets
iv Base64Octets
tag) = [Pair] -> Value
object [Key
"iv" Key -> Base64Octets -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.= Base64Octets
iv, Key
"tag" Key -> Base64Octets -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.= Base64Octets
tag]
data PBES2Parameters = PBES2Parameters
{ PBES2Parameters -> Base64Octets
_p2s :: Base64Octets
, PBES2Parameters -> Int
_p2c :: Int
} deriving (PBES2Parameters -> PBES2Parameters -> Bool
(PBES2Parameters -> PBES2Parameters -> Bool)
-> (PBES2Parameters -> PBES2Parameters -> Bool)
-> Eq PBES2Parameters
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: PBES2Parameters -> PBES2Parameters -> Bool
== :: PBES2Parameters -> PBES2Parameters -> Bool
$c/= :: PBES2Parameters -> PBES2Parameters -> Bool
/= :: PBES2Parameters -> PBES2Parameters -> Bool
Eq, Int -> PBES2Parameters -> ShowS
[PBES2Parameters] -> ShowS
PBES2Parameters -> String
(Int -> PBES2Parameters -> ShowS)
-> (PBES2Parameters -> String)
-> ([PBES2Parameters] -> ShowS)
-> Show PBES2Parameters
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> PBES2Parameters -> ShowS
showsPrec :: Int -> PBES2Parameters -> ShowS
$cshow :: PBES2Parameters -> String
show :: PBES2Parameters -> String
$cshowList :: [PBES2Parameters] -> ShowS
showList :: [PBES2Parameters] -> ShowS
Show)
instance FromJSON PBES2Parameters where
parseJSON :: Value -> Parser PBES2Parameters
parseJSON = String
-> (Object -> Parser PBES2Parameters)
-> Value
-> Parser PBES2Parameters
forall a. String -> (Object -> Parser a) -> Value -> Parser a
withObject String
"AES-GCM Parameters" ((Object -> Parser PBES2Parameters)
-> Value -> Parser PBES2Parameters)
-> (Object -> Parser PBES2Parameters)
-> Value
-> Parser PBES2Parameters
forall a b. (a -> b) -> a -> b
$ \Object
o -> Base64Octets -> Int -> PBES2Parameters
PBES2Parameters
(Base64Octets -> Int -> PBES2Parameters)
-> Parser Base64Octets -> Parser (Int -> PBES2Parameters)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
o Object -> Key -> Parser Base64Octets
forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"p2s"
Parser (Int -> PBES2Parameters)
-> Parser Int -> Parser PBES2Parameters
forall a b. Parser (a -> b) -> Parser a -> Parser b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
o Object -> Key -> Parser Int
forall a. FromJSON a => Object -> Key -> Parser a
.: Key
"p2c"
instance ToJSON PBES2Parameters where
toJSON :: PBES2Parameters -> Value
toJSON (PBES2Parameters Base64Octets
p2s Int
p2c) = [Pair] -> Value
object [Key
"p2s" Key -> Base64Octets -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.= Base64Octets
p2s, Key
"p2c" Key -> Int -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
forall v. ToJSON v => Key -> v -> Pair
.= Int
p2c]
$(deriveJOSEType "Enc" [
"A128CBC-HS256"
, "A192CBC-HS384"
, "A256CBC-HS512"
, "A128GCM"
, "A192GCM"
, "A256GCM"
])