module Stratosphere.Rbin.Rule.RetentionPeriodProperty (
RetentionPeriodProperty(..), mkRetentionPeriodProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data RetentionPeriodProperty
=
RetentionPeriodProperty {RetentionPeriodProperty -> ()
haddock_workaround_ :: (),
RetentionPeriodProperty -> Value Text
retentionPeriodUnit :: (Value Prelude.Text),
RetentionPeriodProperty -> Value Integer
retentionPeriodValue :: (Value Prelude.Integer)}
deriving stock (RetentionPeriodProperty -> RetentionPeriodProperty -> Bool
(RetentionPeriodProperty -> RetentionPeriodProperty -> Bool)
-> (RetentionPeriodProperty -> RetentionPeriodProperty -> Bool)
-> Eq RetentionPeriodProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: RetentionPeriodProperty -> RetentionPeriodProperty -> Bool
== :: RetentionPeriodProperty -> RetentionPeriodProperty -> Bool
$c/= :: RetentionPeriodProperty -> RetentionPeriodProperty -> Bool
/= :: RetentionPeriodProperty -> RetentionPeriodProperty -> Bool
Prelude.Eq, Int -> RetentionPeriodProperty -> ShowS
[RetentionPeriodProperty] -> ShowS
RetentionPeriodProperty -> String
(Int -> RetentionPeriodProperty -> ShowS)
-> (RetentionPeriodProperty -> String)
-> ([RetentionPeriodProperty] -> ShowS)
-> Show RetentionPeriodProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> RetentionPeriodProperty -> ShowS
showsPrec :: Int -> RetentionPeriodProperty -> ShowS
$cshow :: RetentionPeriodProperty -> String
show :: RetentionPeriodProperty -> String
$cshowList :: [RetentionPeriodProperty] -> ShowS
showList :: [RetentionPeriodProperty] -> ShowS
Prelude.Show)
mkRetentionPeriodProperty ::
Value Prelude.Text
-> Value Prelude.Integer -> RetentionPeriodProperty
mkRetentionPeriodProperty :: Value Text -> Value Integer -> RetentionPeriodProperty
mkRetentionPeriodProperty Value Text
retentionPeriodUnit Value Integer
retentionPeriodValue
= RetentionPeriodProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (),
retentionPeriodUnit :: Value Text
retentionPeriodUnit = Value Text
retentionPeriodUnit,
retentionPeriodValue :: Value Integer
retentionPeriodValue = Value Integer
retentionPeriodValue}
instance ToResourceProperties RetentionPeriodProperty where
toResourceProperties :: RetentionPeriodProperty -> ResourceProperties
toResourceProperties RetentionPeriodProperty {()
Value Integer
Value Text
haddock_workaround_ :: RetentionPeriodProperty -> ()
retentionPeriodUnit :: RetentionPeriodProperty -> Value Text
retentionPeriodValue :: RetentionPeriodProperty -> Value Integer
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
retentionPeriodValue :: Value Integer
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::Rbin::Rule.RetentionPeriod",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Key
"RetentionPeriodUnit" 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
retentionPeriodUnit,
Key
"RetentionPeriodValue" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
retentionPeriodValue]}
instance JSON.ToJSON RetentionPeriodProperty where
toJSON :: RetentionPeriodProperty -> Value
toJSON RetentionPeriodProperty {()
Value Integer
Value Text
haddock_workaround_ :: RetentionPeriodProperty -> ()
retentionPeriodUnit :: RetentionPeriodProperty -> Value Text
retentionPeriodValue :: RetentionPeriodProperty -> Value Integer
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
retentionPeriodValue :: Value Integer
..}
= [(Key, Value)] -> Value
JSON.object
[Key
"RetentionPeriodUnit" 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
retentionPeriodUnit,
Key
"RetentionPeriodValue" Key -> Value Integer -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= Value Integer
retentionPeriodValue]
instance Property "RetentionPeriodUnit" RetentionPeriodProperty where
type PropertyType "RetentionPeriodUnit" RetentionPeriodProperty = Value Prelude.Text
set :: PropertyType "RetentionPeriodUnit" RetentionPeriodProperty
-> RetentionPeriodProperty -> RetentionPeriodProperty
set PropertyType "RetentionPeriodUnit" RetentionPeriodProperty
newValue RetentionPeriodProperty {()
Value Integer
Value Text
haddock_workaround_ :: RetentionPeriodProperty -> ()
retentionPeriodUnit :: RetentionPeriodProperty -> Value Text
retentionPeriodValue :: RetentionPeriodProperty -> Value Integer
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
retentionPeriodValue :: Value Integer
..}
= RetentionPeriodProperty {retentionPeriodUnit :: Value Text
retentionPeriodUnit = PropertyType "RetentionPeriodUnit" RetentionPeriodProperty
Value Text
newValue, ()
Value Integer
haddock_workaround_ :: ()
retentionPeriodValue :: Value Integer
haddock_workaround_ :: ()
retentionPeriodValue :: Value Integer
..}
instance Property "RetentionPeriodValue" RetentionPeriodProperty where
type PropertyType "RetentionPeriodValue" RetentionPeriodProperty = Value Prelude.Integer
set :: PropertyType "RetentionPeriodValue" RetentionPeriodProperty
-> RetentionPeriodProperty -> RetentionPeriodProperty
set PropertyType "RetentionPeriodValue" RetentionPeriodProperty
newValue RetentionPeriodProperty {()
Value Integer
Value Text
haddock_workaround_ :: RetentionPeriodProperty -> ()
retentionPeriodUnit :: RetentionPeriodProperty -> Value Text
retentionPeriodValue :: RetentionPeriodProperty -> Value Integer
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
retentionPeriodValue :: Value Integer
..}
= RetentionPeriodProperty {retentionPeriodValue :: Value Integer
retentionPeriodValue = PropertyType "RetentionPeriodValue" RetentionPeriodProperty
Value Integer
newValue, ()
Value Text
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
haddock_workaround_ :: ()
retentionPeriodUnit :: Value Text
..}