module Stratosphere.S3.StorageLens.SSEKMSProperty (
SSEKMSProperty(..), mkSSEKMSProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data SSEKMSProperty
=
SSEKMSProperty {SSEKMSProperty -> ()
haddock_workaround_ :: (),
SSEKMSProperty -> Value Text
keyId :: (Value Prelude.Text)}
deriving stock (SSEKMSProperty -> SSEKMSProperty -> Bool
(SSEKMSProperty -> SSEKMSProperty -> Bool)
-> (SSEKMSProperty -> SSEKMSProperty -> Bool) -> Eq SSEKMSProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SSEKMSProperty -> SSEKMSProperty -> Bool
== :: SSEKMSProperty -> SSEKMSProperty -> Bool
$c/= :: SSEKMSProperty -> SSEKMSProperty -> Bool
/= :: SSEKMSProperty -> SSEKMSProperty -> Bool
Prelude.Eq, Int -> SSEKMSProperty -> ShowS
[SSEKMSProperty] -> ShowS
SSEKMSProperty -> String
(Int -> SSEKMSProperty -> ShowS)
-> (SSEKMSProperty -> String)
-> ([SSEKMSProperty] -> ShowS)
-> Show SSEKMSProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SSEKMSProperty -> ShowS
showsPrec :: Int -> SSEKMSProperty -> ShowS
$cshow :: SSEKMSProperty -> String
show :: SSEKMSProperty -> String
$cshowList :: [SSEKMSProperty] -> ShowS
showList :: [SSEKMSProperty] -> ShowS
Prelude.Show)
mkSSEKMSProperty :: Value Prelude.Text -> SSEKMSProperty
mkSSEKMSProperty :: Value Text -> SSEKMSProperty
mkSSEKMSProperty Value Text
keyId
= SSEKMSProperty {haddock_workaround_ :: ()
haddock_workaround_ = (), keyId :: Value Text
keyId = Value Text
keyId}
instance ToResourceProperties SSEKMSProperty where
toResourceProperties :: SSEKMSProperty -> ResourceProperties
toResourceProperties SSEKMSProperty {()
Value Text
haddock_workaround_ :: SSEKMSProperty -> ()
keyId :: SSEKMSProperty -> Value Text
haddock_workaround_ :: ()
keyId :: Value Text
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::S3::StorageLens.SSEKMS",
supportsTags :: Bool
supportsTags = Bool
Prelude.False, properties :: Object
properties = [Key
"KeyId" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
keyId]}
instance JSON.ToJSON SSEKMSProperty where
toJSON :: SSEKMSProperty -> Value
toJSON SSEKMSProperty {()
Value Text
haddock_workaround_ :: SSEKMSProperty -> ()
keyId :: SSEKMSProperty -> Value Text
haddock_workaround_ :: ()
keyId :: Value Text
..} = [(Key, Value)] -> Value
JSON.object [Key
"KeyId" Key -> Value Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Text
keyId]
instance Property "KeyId" SSEKMSProperty where
type PropertyType "KeyId" SSEKMSProperty = Value Prelude.Text
set :: PropertyType "KeyId" SSEKMSProperty
-> SSEKMSProperty -> SSEKMSProperty
set PropertyType "KeyId" SSEKMSProperty
newValue SSEKMSProperty {()
Value Text
haddock_workaround_ :: SSEKMSProperty -> ()
keyId :: SSEKMSProperty -> Value Text
haddock_workaround_ :: ()
keyId :: Value Text
..}
= SSEKMSProperty {keyId :: Value Text
keyId = PropertyType "KeyId" SSEKMSProperty
Value Text
newValue, ()
haddock_workaround_ :: ()
haddock_workaround_ :: ()
..}