module Stratosphere.Greengrass.LoggerDefinitionVersion (
        module Exports, LoggerDefinitionVersion(..),
        mkLoggerDefinitionVersion
    ) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.Greengrass.LoggerDefinitionVersion.LoggerProperty as Exports
import Stratosphere.ResourceProperties
import Stratosphere.Value
data LoggerDefinitionVersion
  = -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-greengrass-loggerdefinitionversion.html>
    LoggerDefinitionVersion {LoggerDefinitionVersion -> ()
haddock_workaround_ :: (),
                             -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-greengrass-loggerdefinitionversion.html#cfn-greengrass-loggerdefinitionversion-loggerdefinitionid>
                             LoggerDefinitionVersion -> Value Text
loggerDefinitionId :: (Value Prelude.Text),
                             -- | See: <http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-greengrass-loggerdefinitionversion.html#cfn-greengrass-loggerdefinitionversion-loggers>
                             LoggerDefinitionVersion -> [LoggerProperty]
loggers :: [LoggerProperty]}
  deriving stock (LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool
(LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool)
-> (LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool)
-> Eq LoggerDefinitionVersion
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool
== :: LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool
$c/= :: LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool
/= :: LoggerDefinitionVersion -> LoggerDefinitionVersion -> Bool
Prelude.Eq, Int -> LoggerDefinitionVersion -> ShowS
[LoggerDefinitionVersion] -> ShowS
LoggerDefinitionVersion -> String
(Int -> LoggerDefinitionVersion -> ShowS)
-> (LoggerDefinitionVersion -> String)
-> ([LoggerDefinitionVersion] -> ShowS)
-> Show LoggerDefinitionVersion
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> LoggerDefinitionVersion -> ShowS
showsPrec :: Int -> LoggerDefinitionVersion -> ShowS
$cshow :: LoggerDefinitionVersion -> String
show :: LoggerDefinitionVersion -> String
$cshowList :: [LoggerDefinitionVersion] -> ShowS
showList :: [LoggerDefinitionVersion] -> ShowS
Prelude.Show)
mkLoggerDefinitionVersion ::
  Value Prelude.Text -> [LoggerProperty] -> LoggerDefinitionVersion
mkLoggerDefinitionVersion :: Value Text -> [LoggerProperty] -> LoggerDefinitionVersion
mkLoggerDefinitionVersion Value Text
loggerDefinitionId [LoggerProperty]
loggers
  = LoggerDefinitionVersion
      {haddock_workaround_ :: ()
haddock_workaround_ = (), loggerDefinitionId :: Value Text
loggerDefinitionId = Value Text
loggerDefinitionId,
       loggers :: [LoggerProperty]
loggers = [LoggerProperty]
loggers}
instance ToResourceProperties LoggerDefinitionVersion where
  toResourceProperties :: LoggerDefinitionVersion -> ResourceProperties
toResourceProperties LoggerDefinitionVersion {[LoggerProperty]
()
Value Text
haddock_workaround_ :: LoggerDefinitionVersion -> ()
loggerDefinitionId :: LoggerDefinitionVersion -> Value Text
loggers :: LoggerDefinitionVersion -> [LoggerProperty]
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
loggers :: [LoggerProperty]
..}
    = ResourceProperties
        {awsType :: Text
awsType = Text
"AWS::Greengrass::LoggerDefinitionVersion",
         supportsTags :: Bool
supportsTags = Bool
Prelude.False,
         properties :: Object
properties = [Key
"LoggerDefinitionId" 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
loggerDefinitionId,
                       Key
"Loggers" Key -> [LoggerProperty] -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= [LoggerProperty]
loggers]}
instance JSON.ToJSON LoggerDefinitionVersion where
  toJSON :: LoggerDefinitionVersion -> Value
toJSON LoggerDefinitionVersion {[LoggerProperty]
()
Value Text
haddock_workaround_ :: LoggerDefinitionVersion -> ()
loggerDefinitionId :: LoggerDefinitionVersion -> Value Text
loggers :: LoggerDefinitionVersion -> [LoggerProperty]
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
loggers :: [LoggerProperty]
..}
    = [(Key, Value)] -> Value
JSON.object
        [Key
"LoggerDefinitionId" 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
loggerDefinitionId,
         Key
"Loggers" Key -> [LoggerProperty] -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
JSON..= [LoggerProperty]
loggers]
instance Property "LoggerDefinitionId" LoggerDefinitionVersion where
  type PropertyType "LoggerDefinitionId" LoggerDefinitionVersion = Value Prelude.Text
  set :: PropertyType "LoggerDefinitionId" LoggerDefinitionVersion
-> LoggerDefinitionVersion -> LoggerDefinitionVersion
set PropertyType "LoggerDefinitionId" LoggerDefinitionVersion
newValue LoggerDefinitionVersion {[LoggerProperty]
()
Value Text
haddock_workaround_ :: LoggerDefinitionVersion -> ()
loggerDefinitionId :: LoggerDefinitionVersion -> Value Text
loggers :: LoggerDefinitionVersion -> [LoggerProperty]
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
loggers :: [LoggerProperty]
..}
    = LoggerDefinitionVersion {loggerDefinitionId :: Value Text
loggerDefinitionId = PropertyType "LoggerDefinitionId" LoggerDefinitionVersion
Value Text
newValue, [LoggerProperty]
()
haddock_workaround_ :: ()
loggers :: [LoggerProperty]
haddock_workaround_ :: ()
loggers :: [LoggerProperty]
..}
instance Property "Loggers" LoggerDefinitionVersion where
  type PropertyType "Loggers" LoggerDefinitionVersion = [LoggerProperty]
  set :: PropertyType "Loggers" LoggerDefinitionVersion
-> LoggerDefinitionVersion -> LoggerDefinitionVersion
set PropertyType "Loggers" LoggerDefinitionVersion
newValue LoggerDefinitionVersion {[LoggerProperty]
()
Value Text
haddock_workaround_ :: LoggerDefinitionVersion -> ()
loggerDefinitionId :: LoggerDefinitionVersion -> Value Text
loggers :: LoggerDefinitionVersion -> [LoggerProperty]
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
loggers :: [LoggerProperty]
..}
    = LoggerDefinitionVersion {loggers :: [LoggerProperty]
loggers = [LoggerProperty]
PropertyType "Loggers" LoggerDefinitionVersion
newValue, ()
Value Text
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
haddock_workaround_ :: ()
loggerDefinitionId :: Value Text
..}