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