module Stratosphere.IoT.TopicRule.SqsActionProperty (
SqsActionProperty(..), mkSqsActionProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data SqsActionProperty
=
SqsActionProperty {SqsActionProperty -> ()
haddock_workaround_ :: (),
SqsActionProperty -> Value Text
queueUrl :: (Value Prelude.Text),
SqsActionProperty -> Value Text
roleArn :: (Value Prelude.Text),
SqsActionProperty -> Maybe (Value Bool)
useBase64 :: (Prelude.Maybe (Value Prelude.Bool))}
deriving stock (SqsActionProperty -> SqsActionProperty -> Bool
(SqsActionProperty -> SqsActionProperty -> Bool)
-> (SqsActionProperty -> SqsActionProperty -> Bool)
-> Eq SqsActionProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SqsActionProperty -> SqsActionProperty -> Bool
== :: SqsActionProperty -> SqsActionProperty -> Bool
$c/= :: SqsActionProperty -> SqsActionProperty -> Bool
/= :: SqsActionProperty -> SqsActionProperty -> Bool
Prelude.Eq, Int -> SqsActionProperty -> ShowS
[SqsActionProperty] -> ShowS
SqsActionProperty -> String
(Int -> SqsActionProperty -> ShowS)
-> (SqsActionProperty -> String)
-> ([SqsActionProperty] -> ShowS)
-> Show SqsActionProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SqsActionProperty -> ShowS
showsPrec :: Int -> SqsActionProperty -> ShowS
$cshow :: SqsActionProperty -> String
show :: SqsActionProperty -> String
$cshowList :: [SqsActionProperty] -> ShowS
showList :: [SqsActionProperty] -> ShowS
Prelude.Show)
mkSqsActionProperty ::
Value Prelude.Text -> Value Prelude.Text -> SqsActionProperty
mkSqsActionProperty :: Value Text -> Value Text -> SqsActionProperty
mkSqsActionProperty Value Text
queueUrl Value Text
roleArn
= SqsActionProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), queueUrl :: Value Text
queueUrl = Value Text
queueUrl, roleArn :: Value Text
roleArn = Value Text
roleArn,
useBase64 :: Maybe (Value Bool)
useBase64 = Maybe (Value Bool)
forall a. Maybe a
Prelude.Nothing}
instance ToResourceProperties SqsActionProperty where
toResourceProperties :: SqsActionProperty -> ResourceProperties
toResourceProperties SqsActionProperty {Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: SqsActionProperty -> ()
queueUrl :: SqsActionProperty -> Value Text
roleArn :: SqsActionProperty -> Value Text
useBase64 :: SqsActionProperty -> Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::IoT::TopicRule.SqsAction",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Item Object] -> Object
forall l. IsList l => [Item l] -> l
Prelude.fromList
([(Key, Value)] -> [(Key, Value)] -> [(Key, Value)]
forall a. Semigroup a => a -> a -> a
(Prelude.<>)
[Key
"QueueUrl" 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
queueUrl, Key
"RoleArn" 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
roleArn]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes [Key -> Value Bool -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"UseBase64" (Value Bool -> (Key, Value))
-> Maybe (Value Bool) -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe (Value Bool)
useBase64]))}
instance JSON.ToJSON SqsActionProperty where
toJSON :: SqsActionProperty -> Value
toJSON SqsActionProperty {Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: SqsActionProperty -> ()
queueUrl :: SqsActionProperty -> Value Text
roleArn :: SqsActionProperty -> Value Text
useBase64 :: SqsActionProperty -> Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
= [(Key, Value)] -> Value
JSON.object
([Item [(Key, Value)]] -> [(Key, Value)]
forall l. IsList l => [Item l] -> l
Prelude.fromList
([(Key, Value)] -> [(Key, Value)] -> [(Key, Value)]
forall a. Semigroup a => a -> a -> a
(Prelude.<>)
[Key
"QueueUrl" 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
queueUrl, Key
"RoleArn" 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
roleArn]
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes [Key -> Value Bool -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"UseBase64" (Value Bool -> (Key, Value))
-> Maybe (Value Bool) -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe (Value Bool)
useBase64])))
instance Property "QueueUrl" SqsActionProperty where
type PropertyType "QueueUrl" SqsActionProperty = Value Prelude.Text
set :: PropertyType "QueueUrl" SqsActionProperty
-> SqsActionProperty -> SqsActionProperty
set PropertyType "QueueUrl" SqsActionProperty
newValue SqsActionProperty {Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: SqsActionProperty -> ()
queueUrl :: SqsActionProperty -> Value Text
roleArn :: SqsActionProperty -> Value Text
useBase64 :: SqsActionProperty -> Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
= SqsActionProperty {queueUrl :: Value Text
queueUrl = PropertyType "QueueUrl" SqsActionProperty
Value Text
newValue, Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: ()
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
haddock_workaround_ :: ()
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
instance Property "RoleArn" SqsActionProperty where
type PropertyType "RoleArn" SqsActionProperty = Value Prelude.Text
set :: PropertyType "RoleArn" SqsActionProperty
-> SqsActionProperty -> SqsActionProperty
set PropertyType "RoleArn" SqsActionProperty
newValue SqsActionProperty {Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: SqsActionProperty -> ()
queueUrl :: SqsActionProperty -> Value Text
roleArn :: SqsActionProperty -> Value Text
useBase64 :: SqsActionProperty -> Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
= SqsActionProperty {roleArn :: Value Text
roleArn = PropertyType "RoleArn" SqsActionProperty
Value Text
newValue, Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: ()
queueUrl :: Value Text
useBase64 :: Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
useBase64 :: Maybe (Value Bool)
..}
instance Property "UseBase64" SqsActionProperty where
type PropertyType "UseBase64" SqsActionProperty = Value Prelude.Bool
set :: PropertyType "UseBase64" SqsActionProperty
-> SqsActionProperty -> SqsActionProperty
set PropertyType "UseBase64" SqsActionProperty
newValue SqsActionProperty {Maybe (Value Bool)
()
Value Text
haddock_workaround_ :: SqsActionProperty -> ()
queueUrl :: SqsActionProperty -> Value Text
roleArn :: SqsActionProperty -> Value Text
useBase64 :: SqsActionProperty -> Maybe (Value Bool)
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
useBase64 :: Maybe (Value Bool)
..}
= SqsActionProperty {useBase64 :: Maybe (Value Bool)
useBase64 = Value Bool -> Maybe (Value Bool)
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "UseBase64" SqsActionProperty
Value Bool
newValue, ()
Value Text
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
haddock_workaround_ :: ()
queueUrl :: Value Text
roleArn :: Value Text
..}