module Stratosphere.MediaPackage.OriginEndpoint.MssEncryptionProperty (
module Exports, MssEncryptionProperty(..), mkMssEncryptionProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.MediaPackage.OriginEndpoint.SpekeKeyProviderProperty as Exports
import Stratosphere.ResourceProperties
data MssEncryptionProperty
=
MssEncryptionProperty {MssEncryptionProperty -> ()
haddock_workaround_ :: (),
MssEncryptionProperty -> SpekeKeyProviderProperty
spekeKeyProvider :: SpekeKeyProviderProperty}
deriving stock (MssEncryptionProperty -> MssEncryptionProperty -> Bool
(MssEncryptionProperty -> MssEncryptionProperty -> Bool)
-> (MssEncryptionProperty -> MssEncryptionProperty -> Bool)
-> Eq MssEncryptionProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: MssEncryptionProperty -> MssEncryptionProperty -> Bool
== :: MssEncryptionProperty -> MssEncryptionProperty -> Bool
$c/= :: MssEncryptionProperty -> MssEncryptionProperty -> Bool
/= :: MssEncryptionProperty -> MssEncryptionProperty -> Bool
Prelude.Eq, Int -> MssEncryptionProperty -> ShowS
[MssEncryptionProperty] -> ShowS
MssEncryptionProperty -> String
(Int -> MssEncryptionProperty -> ShowS)
-> (MssEncryptionProperty -> String)
-> ([MssEncryptionProperty] -> ShowS)
-> Show MssEncryptionProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> MssEncryptionProperty -> ShowS
showsPrec :: Int -> MssEncryptionProperty -> ShowS
$cshow :: MssEncryptionProperty -> String
show :: MssEncryptionProperty -> String
$cshowList :: [MssEncryptionProperty] -> ShowS
showList :: [MssEncryptionProperty] -> ShowS
Prelude.Show)
mkMssEncryptionProperty ::
SpekeKeyProviderProperty -> MssEncryptionProperty
mkMssEncryptionProperty :: SpekeKeyProviderProperty -> MssEncryptionProperty
mkMssEncryptionProperty SpekeKeyProviderProperty
spekeKeyProvider
= MssEncryptionProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), spekeKeyProvider :: SpekeKeyProviderProperty
spekeKeyProvider = SpekeKeyProviderProperty
spekeKeyProvider}
instance ToResourceProperties MssEncryptionProperty where
toResourceProperties :: MssEncryptionProperty -> ResourceProperties
toResourceProperties MssEncryptionProperty {()
SpekeKeyProviderProperty
haddock_workaround_ :: MssEncryptionProperty -> ()
spekeKeyProvider :: MssEncryptionProperty -> SpekeKeyProviderProperty
haddock_workaround_ :: ()
spekeKeyProvider :: SpekeKeyProviderProperty
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::MediaPackage::OriginEndpoint.MssEncryption",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Key
"SpekeKeyProvider" Key -> SpekeKeyProviderProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= SpekeKeyProviderProperty
spekeKeyProvider]}
instance JSON.ToJSON MssEncryptionProperty where
toJSON :: MssEncryptionProperty -> Value
toJSON MssEncryptionProperty {()
SpekeKeyProviderProperty
haddock_workaround_ :: MssEncryptionProperty -> ()
spekeKeyProvider :: MssEncryptionProperty -> SpekeKeyProviderProperty
haddock_workaround_ :: ()
spekeKeyProvider :: SpekeKeyProviderProperty
..}
= [(Key, Value)] -> Value
JSON.object [Key
"SpekeKeyProvider" Key -> SpekeKeyProviderProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= SpekeKeyProviderProperty
spekeKeyProvider]
instance Property "SpekeKeyProvider" MssEncryptionProperty where
type PropertyType "SpekeKeyProvider" MssEncryptionProperty = SpekeKeyProviderProperty
set :: PropertyType "SpekeKeyProvider" MssEncryptionProperty
-> MssEncryptionProperty -> MssEncryptionProperty
set PropertyType "SpekeKeyProvider" MssEncryptionProperty
newValue MssEncryptionProperty {()
SpekeKeyProviderProperty
haddock_workaround_ :: MssEncryptionProperty -> ()
spekeKeyProvider :: MssEncryptionProperty -> SpekeKeyProviderProperty
haddock_workaround_ :: ()
spekeKeyProvider :: SpekeKeyProviderProperty
..}
= MssEncryptionProperty {spekeKeyProvider :: SpekeKeyProviderProperty
spekeKeyProvider = PropertyType "SpekeKeyProvider" MssEncryptionProperty
SpekeKeyProviderProperty
newValue, ()
haddock_workaround_ :: ()
haddock_workaround_ :: ()
..}