module Stratosphere.DataZone.DataSource.FilterExpressionProperty (
        FilterExpressionProperty(..), mkFilterExpressionProperty
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data FilterExpressionProperty
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-datazone-datasource-filterexpression.html>
    FilterExpressionProperty {FilterExpressionProperty -> ()
haddock_workaround_ :: (),
                              -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-datazone-datasource-filterexpression.html#cfn-datazone-datasource-filterexpression-expression>
                              FilterExpressionProperty -> Value Text
expression :: (Value Prelude.Text),
                              -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-datazone-datasource-filterexpression.html#cfn-datazone-datasource-filterexpression-type>
                              FilterExpressionProperty -> Value Text
type' :: (Value Prelude.Text)}
  deriving stock (FilterExpressionProperty -> FilterExpressionProperty -> Bool
(FilterExpressionProperty -> FilterExpressionProperty -> Bool)
-> (FilterExpressionProperty -> FilterExpressionProperty -> Bool)
-> Eq FilterExpressionProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: FilterExpressionProperty -> FilterExpressionProperty -> Bool
== :: FilterExpressionProperty -> FilterExpressionProperty -> Bool
$c/= :: FilterExpressionProperty -> FilterExpressionProperty -> Bool
/= :: FilterExpressionProperty -> FilterExpressionProperty -> Bool
Prelude.Eq, Int -> FilterExpressionProperty -> ShowS
[FilterExpressionProperty] -> ShowS
FilterExpressionProperty -> String
(Int -> FilterExpressionProperty -> ShowS)
-> (FilterExpressionProperty -> String)
-> ([FilterExpressionProperty] -> ShowS)
-> Show FilterExpressionProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> FilterExpressionProperty -> ShowS
showsPrec :: Int -> FilterExpressionProperty -> ShowS
$cshow :: FilterExpressionProperty -> String
show :: FilterExpressionProperty -> String
$cshowList :: [FilterExpressionProperty] -> ShowS
showList :: [FilterExpressionProperty] -> ShowS
Prelude.Show)
mkFilterExpressionProperty ::
  Value Prelude.Text
  -> Value Prelude.Text -> FilterExpressionProperty
mkFilterExpressionProperty :: Value Text -> Value Text -> FilterExpressionProperty
mkFilterExpressionProperty Value Text
expression Value Text
type'
  = FilterExpressionProperty
      {haddock_workaround_ :: ()
haddock_workaround_ = (), expression :: Value Text
expression = Value Text
expression, type' :: Value Text
type' = Value Text
type'}
instance ToResourceProperties FilterExpressionProperty where
  toResourceProperties :: FilterExpressionProperty -> ResourceProperties
toResourceProperties FilterExpressionProperty {()
Value Text
haddock_workaround_ :: FilterExpressionProperty -> ()
expression :: FilterExpressionProperty -> Value Text
type' :: FilterExpressionProperty -> Value Text
haddock_workaround_ :: ()
expression :: Value Text
type' :: Value Text
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::DataZone::DataSource.FilterExpression",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"Expression" 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
expression,
                       Key
"Type" 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
type']}
instance JSON.ToJSON FilterExpressionProperty where
  toJSON :: FilterExpressionProperty -> Value
toJSON FilterExpressionProperty {()
Value Text
haddock_workaround_ :: FilterExpressionProperty -> ()
expression :: FilterExpressionProperty -> Value Text
type' :: FilterExpressionProperty -> Value Text
haddock_workaround_ :: ()
expression :: Value Text
type' :: Value Text
..}
    = [(Key, Value)] -> Value
JSON.object
        [Key
"Expression" 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
expression, Key
"Type" 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
type']
instance Property "Expression" FilterExpressionProperty where
  type PropertyType "Expression" FilterExpressionProperty = Value Prelude.Text
  set :: PropertyType "Expression" FilterExpressionProperty
-> FilterExpressionProperty -> FilterExpressionProperty
set PropertyType "Expression" FilterExpressionProperty
newValue FilterExpressionProperty {()
Value Text
haddock_workaround_ :: FilterExpressionProperty -> ()
expression :: FilterExpressionProperty -> Value Text
type' :: FilterExpressionProperty -> Value Text
haddock_workaround_ :: ()
expression :: Value Text
type' :: Value Text
..}
    = FilterExpressionProperty {expression :: Value Text
expression = PropertyType "Expression" FilterExpressionProperty
Value Text
newValue, ()
Value Text
haddock_workaround_ :: ()
type' :: Value Text
haddock_workaround_ :: ()
type' :: Value Text
..}
instance Property "Type" FilterExpressionProperty where
  type PropertyType "Type" FilterExpressionProperty = Value Prelude.Text
  set :: PropertyType "Type" FilterExpressionProperty
-> FilterExpressionProperty -> FilterExpressionProperty
set PropertyType "Type" FilterExpressionProperty
newValue FilterExpressionProperty {()
Value Text
haddock_workaround_ :: FilterExpressionProperty -> ()
expression :: FilterExpressionProperty -> Value Text
type' :: FilterExpressionProperty -> Value Text
haddock_workaround_ :: ()
expression :: Value Text
type' :: Value Text
..}
    = FilterExpressionProperty {type' :: Value Text
type' = PropertyType "Type" FilterExpressionProperty
Value Text
newValue, ()
Value Text
haddock_workaround_ :: ()
expression :: Value Text
haddock_workaround_ :: ()
expression :: Value Text
..}