module Stratosphere.SES.MailManagerRuleSet.RuleStringExpressionProperty (
        module Exports, RuleStringExpressionProperty(..),
        mkRuleStringExpressionProperty
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.SES.MailManagerRuleSet.RuleStringToEvaluateProperty as Exports
import Stratosphere.ResourceProperties
import Stratosphere.Value
data RuleStringExpressionProperty
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ses-mailmanagerruleset-rulestringexpression.html>
    RuleStringExpressionProperty {RuleStringExpressionProperty -> ()
haddock_workaround_ :: (),
                                  -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ses-mailmanagerruleset-rulestringexpression.html#cfn-ses-mailmanagerruleset-rulestringexpression-evaluate>
                                  RuleStringExpressionProperty -> RuleStringToEvaluateProperty
evaluate :: RuleStringToEvaluateProperty,
                                  -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ses-mailmanagerruleset-rulestringexpression.html#cfn-ses-mailmanagerruleset-rulestringexpression-operator>
                                  RuleStringExpressionProperty -> Value Text
operator :: (Value Prelude.Text),
                                  -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-ses-mailmanagerruleset-rulestringexpression.html#cfn-ses-mailmanagerruleset-rulestringexpression-values>
                                  RuleStringExpressionProperty -> ValueList Text
values :: (ValueList Prelude.Text)}
  deriving stock (RuleStringExpressionProperty
-> RuleStringExpressionProperty -> Bool
(RuleStringExpressionProperty
 -> RuleStringExpressionProperty -> Bool)
-> (RuleStringExpressionProperty
    -> RuleStringExpressionProperty -> Bool)
-> Eq RuleStringExpressionProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: RuleStringExpressionProperty
-> RuleStringExpressionProperty -> Bool
== :: RuleStringExpressionProperty
-> RuleStringExpressionProperty -> Bool
$c/= :: RuleStringExpressionProperty
-> RuleStringExpressionProperty -> Bool
/= :: RuleStringExpressionProperty
-> RuleStringExpressionProperty -> Bool
Prelude.Eq, Int -> RuleStringExpressionProperty -> ShowS
[RuleStringExpressionProperty] -> ShowS
RuleStringExpressionProperty -> String
(Int -> RuleStringExpressionProperty -> ShowS)
-> (RuleStringExpressionProperty -> String)
-> ([RuleStringExpressionProperty] -> ShowS)
-> Show RuleStringExpressionProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> RuleStringExpressionProperty -> ShowS
showsPrec :: Int -> RuleStringExpressionProperty -> ShowS
$cshow :: RuleStringExpressionProperty -> String
show :: RuleStringExpressionProperty -> String
$cshowList :: [RuleStringExpressionProperty] -> ShowS
showList :: [RuleStringExpressionProperty] -> ShowS
Prelude.Show)
mkRuleStringExpressionProperty ::
  RuleStringToEvaluateProperty
  -> Value Prelude.Text
     -> ValueList Prelude.Text -> RuleStringExpressionProperty
mkRuleStringExpressionProperty :: RuleStringToEvaluateProperty
-> Value Text -> ValueList Text -> RuleStringExpressionProperty
mkRuleStringExpressionProperty RuleStringToEvaluateProperty
evaluate Value Text
operator ValueList Text
values
  = RuleStringExpressionProperty
      {haddock_workaround_ :: ()
haddock_workaround_ = (), evaluate :: RuleStringToEvaluateProperty
evaluate = RuleStringToEvaluateProperty
evaluate,
       operator :: Value Text
operator = Value Text
operator, values :: ValueList Text
values = ValueList Text
values}
instance ToResourceProperties RuleStringExpressionProperty where
  toResourceProperties :: RuleStringExpressionProperty -> ResourceProperties
toResourceProperties RuleStringExpressionProperty {()
ValueList Text
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: RuleStringExpressionProperty -> ()
evaluate :: RuleStringExpressionProperty -> RuleStringToEvaluateProperty
operator :: RuleStringExpressionProperty -> Value Text
values :: RuleStringExpressionProperty -> ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
values :: ValueList Text
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::SES::MailManagerRuleSet.RuleStringExpression",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"Evaluate" Key -> RuleStringToEvaluateProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= RuleStringToEvaluateProperty
evaluate,
                       Key
"Operator" 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
operator, Key
"Values" Key -> ValueList Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= ValueList Text
values]}
instance JSON.ToJSON RuleStringExpressionProperty where
  toJSON :: RuleStringExpressionProperty -> Value
toJSON RuleStringExpressionProperty {()
ValueList Text
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: RuleStringExpressionProperty -> ()
evaluate :: RuleStringExpressionProperty -> RuleStringToEvaluateProperty
operator :: RuleStringExpressionProperty -> Value Text
values :: RuleStringExpressionProperty -> ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
values :: ValueList Text
..}
    = [(Key, Value)] -> Value
JSON.object
        [Key
"Evaluate" Key -> RuleStringToEvaluateProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= RuleStringToEvaluateProperty
evaluate, Key
"Operator" 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
operator,
         Key
"Values" Key -> ValueList Text -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= ValueList Text
values]
instance Property "Evaluate" RuleStringExpressionProperty where
  type PropertyType "Evaluate" RuleStringExpressionProperty = RuleStringToEvaluateProperty
  set :: PropertyType "Evaluate" RuleStringExpressionProperty
-> RuleStringExpressionProperty -> RuleStringExpressionProperty
set PropertyType "Evaluate" RuleStringExpressionProperty
newValue RuleStringExpressionProperty {()
ValueList Text
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: RuleStringExpressionProperty -> ()
evaluate :: RuleStringExpressionProperty -> RuleStringToEvaluateProperty
operator :: RuleStringExpressionProperty -> Value Text
values :: RuleStringExpressionProperty -> ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
values :: ValueList Text
..}
    = RuleStringExpressionProperty {evaluate :: RuleStringToEvaluateProperty
evaluate = PropertyType "Evaluate" RuleStringExpressionProperty
RuleStringToEvaluateProperty
newValue, ()
ValueList Text
Value Text
haddock_workaround_ :: ()
operator :: Value Text
values :: ValueList Text
haddock_workaround_ :: ()
operator :: Value Text
values :: ValueList Text
..}
instance Property "Operator" RuleStringExpressionProperty where
  type PropertyType "Operator" RuleStringExpressionProperty = Value Prelude.Text
  set :: PropertyType "Operator" RuleStringExpressionProperty
-> RuleStringExpressionProperty -> RuleStringExpressionProperty
set PropertyType "Operator" RuleStringExpressionProperty
newValue RuleStringExpressionProperty {()
ValueList Text
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: RuleStringExpressionProperty -> ()
evaluate :: RuleStringExpressionProperty -> RuleStringToEvaluateProperty
operator :: RuleStringExpressionProperty -> Value Text
values :: RuleStringExpressionProperty -> ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
values :: ValueList Text
..}
    = RuleStringExpressionProperty {operator :: Value Text
operator = PropertyType "Operator" RuleStringExpressionProperty
Value Text
newValue, ()
ValueList Text
RuleStringToEvaluateProperty
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
values :: ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
values :: ValueList Text
..}
instance Property "Values" RuleStringExpressionProperty where
  type PropertyType "Values" RuleStringExpressionProperty = ValueList Prelude.Text
  set :: PropertyType "Values" RuleStringExpressionProperty
-> RuleStringExpressionProperty -> RuleStringExpressionProperty
set PropertyType "Values" RuleStringExpressionProperty
newValue RuleStringExpressionProperty {()
ValueList Text
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: RuleStringExpressionProperty -> ()
evaluate :: RuleStringExpressionProperty -> RuleStringToEvaluateProperty
operator :: RuleStringExpressionProperty -> Value Text
values :: RuleStringExpressionProperty -> ValueList Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
values :: ValueList Text
..}
    = RuleStringExpressionProperty {values :: ValueList Text
values = PropertyType "Values" RuleStringExpressionProperty
ValueList Text
newValue, ()
Value Text
RuleStringToEvaluateProperty
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
haddock_workaround_ :: ()
evaluate :: RuleStringToEvaluateProperty
operator :: Value Text
..}