module Stratosphere.Lex.Bot.DataPrivacyProperty (
        DataPrivacyProperty(..), mkDataPrivacyProperty
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import Stratosphere.ResourceProperties
import Stratosphere.Value
data DataPrivacyProperty
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lex-bot-dataprivacy.html>
    DataPrivacyProperty {DataPrivacyProperty -> ()
haddock_workaround_ :: (),
                         -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-lex-bot-dataprivacy.html#cfn-lex-bot-dataprivacy-childdirected>
                         DataPrivacyProperty -> Value Bool
childDirected :: (Value Prelude.Bool)}
  deriving stock (DataPrivacyProperty -> DataPrivacyProperty -> Bool
(DataPrivacyProperty -> DataPrivacyProperty -> Bool)
-> (DataPrivacyProperty -> DataPrivacyProperty -> Bool)
-> Eq DataPrivacyProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: DataPrivacyProperty -> DataPrivacyProperty -> Bool
== :: DataPrivacyProperty -> DataPrivacyProperty -> Bool
$c/= :: DataPrivacyProperty -> DataPrivacyProperty -> Bool
/= :: DataPrivacyProperty -> DataPrivacyProperty -> Bool
Prelude.Eq, Int -> DataPrivacyProperty -> ShowS
[DataPrivacyProperty] -> ShowS
DataPrivacyProperty -> String
(Int -> DataPrivacyProperty -> ShowS)
-> (DataPrivacyProperty -> String)
-> ([DataPrivacyProperty] -> ShowS)
-> Show DataPrivacyProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> DataPrivacyProperty -> ShowS
showsPrec :: Int -> DataPrivacyProperty -> ShowS
$cshow :: DataPrivacyProperty -> String
show :: DataPrivacyProperty -> String
$cshowList :: [DataPrivacyProperty] -> ShowS
showList :: [DataPrivacyProperty] -> ShowS
Prelude.Show)
mkDataPrivacyProperty :: Value Prelude.Bool -> DataPrivacyProperty
mkDataPrivacyProperty :: Value Bool -> DataPrivacyProperty
mkDataPrivacyProperty Value Bool
childDirected
  = DataPrivacyProperty
      {haddock_workaround_ :: ()
haddock_workaround_ = (), childDirected :: Value Bool
childDirected = Value Bool
childDirected}
instance ToResourceProperties DataPrivacyProperty where
  toResourceProperties :: DataPrivacyProperty -> ResourceProperties
toResourceProperties DataPrivacyProperty {()
Value Bool
haddock_workaround_ :: DataPrivacyProperty -> ()
childDirected :: DataPrivacyProperty -> Value Bool
haddock_workaround_ :: ()
childDirected :: Value Bool
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::Lex::Bot.DataPrivacy",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"ChildDirected" 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..= Value Bool
childDirected]}
instance JSON.ToJSON DataPrivacyProperty where
  toJSON :: DataPrivacyProperty -> Value
toJSON DataPrivacyProperty {()
Value Bool
haddock_workaround_ :: DataPrivacyProperty -> ()
childDirected :: DataPrivacyProperty -> Value Bool
haddock_workaround_ :: ()
childDirected :: Value Bool
..}
    = [(Key, Value)] -> Value
JSON.object [Key
"ChildDirected" 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..= Value Bool
childDirected]
instance Property "ChildDirected" DataPrivacyProperty where
  type PropertyType "ChildDirected" DataPrivacyProperty = Value Prelude.Bool
  set :: PropertyType "ChildDirected" DataPrivacyProperty
-> DataPrivacyProperty -> DataPrivacyProperty
set PropertyType "ChildDirected" DataPrivacyProperty
newValue DataPrivacyProperty {()
Value Bool
haddock_workaround_ :: DataPrivacyProperty -> ()
childDirected :: DataPrivacyProperty -> Value Bool
haddock_workaround_ :: ()
childDirected :: Value Bool
..}
    = DataPrivacyProperty {childDirected :: Value Bool
childDirected = PropertyType "ChildDirected" DataPrivacyProperty
Value Bool
newValue, ()
haddock_workaround_ :: ()
haddock_workaround_ :: ()
..}