module Stratosphere.KafkaConnect.Connector.WorkerLogDeliveryProperty (
module Exports, WorkerLogDeliveryProperty(..),
mkWorkerLogDeliveryProperty
) where
import qualified Data.Aeson as JSON
import qualified Stratosphere.Prelude as Prelude
import Stratosphere.Property
import {-# SOURCE #-} Stratosphere.KafkaConnect.Connector.CloudWatchLogsLogDeliveryProperty as Exports
import {-# SOURCE #-} Stratosphere.KafkaConnect.Connector.FirehoseLogDeliveryProperty as Exports
import {-# SOURCE #-} Stratosphere.KafkaConnect.Connector.S3LogDeliveryProperty as Exports
import Stratosphere.ResourceProperties
data WorkerLogDeliveryProperty
=
WorkerLogDeliveryProperty {WorkerLogDeliveryProperty -> ()
haddock_workaround_ :: (),
WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
cloudWatchLogs :: (Prelude.Maybe CloudWatchLogsLogDeliveryProperty),
WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
firehose :: (Prelude.Maybe FirehoseLogDeliveryProperty),
WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
s3 :: (Prelude.Maybe S3LogDeliveryProperty)}
deriving stock (WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool
(WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool)
-> (WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool)
-> Eq WorkerLogDeliveryProperty
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool
== :: WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool
$c/= :: WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool
/= :: WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty -> Bool
Prelude.Eq, Int -> WorkerLogDeliveryProperty -> ShowS
[WorkerLogDeliveryProperty] -> ShowS
WorkerLogDeliveryProperty -> String
(Int -> WorkerLogDeliveryProperty -> ShowS)
-> (WorkerLogDeliveryProperty -> String)
-> ([WorkerLogDeliveryProperty] -> ShowS)
-> Show WorkerLogDeliveryProperty
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> WorkerLogDeliveryProperty -> ShowS
showsPrec :: Int -> WorkerLogDeliveryProperty -> ShowS
$cshow :: WorkerLogDeliveryProperty -> String
show :: WorkerLogDeliveryProperty -> String
$cshowList :: [WorkerLogDeliveryProperty] -> ShowS
showList :: [WorkerLogDeliveryProperty] -> ShowS
Prelude.Show)
mkWorkerLogDeliveryProperty :: WorkerLogDeliveryProperty
mkWorkerLogDeliveryProperty :: WorkerLogDeliveryProperty
mkWorkerLogDeliveryProperty
= WorkerLogDeliveryProperty
{haddock_workaround_ :: ()
haddock_workaround_ = (), cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
cloudWatchLogs = Maybe CloudWatchLogsLogDeliveryProperty
forall a. Maybe a
Prelude.Nothing,
firehose :: Maybe FirehoseLogDeliveryProperty
firehose = Maybe FirehoseLogDeliveryProperty
forall a. Maybe a
Prelude.Nothing, s3 :: Maybe S3LogDeliveryProperty
s3 = Maybe S3LogDeliveryProperty
forall a. Maybe a
Prelude.Nothing}
instance ToResourceProperties WorkerLogDeliveryProperty where
toResourceProperties :: WorkerLogDeliveryProperty -> ResourceProperties
toResourceProperties WorkerLogDeliveryProperty {Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: WorkerLogDeliveryProperty -> ()
cloudWatchLogs :: WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
firehose :: WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
s3 :: WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
= ResourceProperties
{awsType :: Text
awsType = Text
"AWS::KafkaConnect::Connector.WorkerLogDelivery",
supportsTags :: Bool
supportsTags = Bool
Prelude.False,
properties :: Object
properties = [Item Object] -> Object
forall l. IsList l => [Item l] -> l
Prelude.fromList
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[Key -> CloudWatchLogsLogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"CloudWatchLogs" (CloudWatchLogsLogDeliveryProperty -> (Key, Value))
-> Maybe CloudWatchLogsLogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe CloudWatchLogsLogDeliveryProperty
cloudWatchLogs,
Key -> FirehoseLogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"Firehose" (FirehoseLogDeliveryProperty -> (Key, Value))
-> Maybe FirehoseLogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe FirehoseLogDeliveryProperty
firehose,
Key -> S3LogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"S3" (S3LogDeliveryProperty -> (Key, Value))
-> Maybe S3LogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe S3LogDeliveryProperty
s3])}
instance JSON.ToJSON WorkerLogDeliveryProperty where
toJSON :: WorkerLogDeliveryProperty -> Value
toJSON WorkerLogDeliveryProperty {Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: WorkerLogDeliveryProperty -> ()
cloudWatchLogs :: WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
firehose :: WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
s3 :: WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
= [(Key, Value)] -> Value
JSON.object
([Item [(Key, Value)]] -> [(Key, Value)]
forall l. IsList l => [Item l] -> l
Prelude.fromList
([Maybe (Key, Value)] -> [(Key, Value)]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[Key -> CloudWatchLogsLogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"CloudWatchLogs" (CloudWatchLogsLogDeliveryProperty -> (Key, Value))
-> Maybe CloudWatchLogsLogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe CloudWatchLogsLogDeliveryProperty
cloudWatchLogs,
Key -> FirehoseLogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"Firehose" (FirehoseLogDeliveryProperty -> (Key, Value))
-> Maybe FirehoseLogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe FirehoseLogDeliveryProperty
firehose,
Key -> S3LogDeliveryProperty -> (Key, Value)
forall v. ToJSON v => Key -> v -> (Key, Value)
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
(JSON..=) Key
"S3" (S3LogDeliveryProperty -> (Key, Value))
-> Maybe S3LogDeliveryProperty -> Maybe (Key, Value)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe S3LogDeliveryProperty
s3]))
instance Property "CloudWatchLogs" WorkerLogDeliveryProperty where
type PropertyType "CloudWatchLogs" WorkerLogDeliveryProperty = CloudWatchLogsLogDeliveryProperty
set :: PropertyType "CloudWatchLogs" WorkerLogDeliveryProperty
-> WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty
set PropertyType "CloudWatchLogs" WorkerLogDeliveryProperty
newValue WorkerLogDeliveryProperty {Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: WorkerLogDeliveryProperty -> ()
cloudWatchLogs :: WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
firehose :: WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
s3 :: WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
= WorkerLogDeliveryProperty
{cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
cloudWatchLogs = CloudWatchLogsLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "CloudWatchLogs" WorkerLogDeliveryProperty
CloudWatchLogsLogDeliveryProperty
newValue, Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: ()
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
instance Property "Firehose" WorkerLogDeliveryProperty where
type PropertyType "Firehose" WorkerLogDeliveryProperty = FirehoseLogDeliveryProperty
set :: PropertyType "Firehose" WorkerLogDeliveryProperty
-> WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty
set PropertyType "Firehose" WorkerLogDeliveryProperty
newValue WorkerLogDeliveryProperty {Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: WorkerLogDeliveryProperty -> ()
cloudWatchLogs :: WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
firehose :: WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
s3 :: WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
= WorkerLogDeliveryProperty {firehose :: Maybe FirehoseLogDeliveryProperty
firehose = FirehoseLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "Firehose" WorkerLogDeliveryProperty
FirehoseLogDeliveryProperty
newValue, Maybe CloudWatchLogsLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
instance Property "S3" WorkerLogDeliveryProperty where
type PropertyType "S3" WorkerLogDeliveryProperty = S3LogDeliveryProperty
set :: PropertyType "S3" WorkerLogDeliveryProperty
-> WorkerLogDeliveryProperty -> WorkerLogDeliveryProperty
set PropertyType "S3" WorkerLogDeliveryProperty
newValue WorkerLogDeliveryProperty {Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
Maybe S3LogDeliveryProperty
()
haddock_workaround_ :: WorkerLogDeliveryProperty -> ()
cloudWatchLogs :: WorkerLogDeliveryProperty
-> Maybe CloudWatchLogsLogDeliveryProperty
firehose :: WorkerLogDeliveryProperty -> Maybe FirehoseLogDeliveryProperty
s3 :: WorkerLogDeliveryProperty -> Maybe S3LogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
s3 :: Maybe S3LogDeliveryProperty
..}
= WorkerLogDeliveryProperty {s3 :: Maybe S3LogDeliveryProperty
s3 = S3LogDeliveryProperty -> Maybe S3LogDeliveryProperty
forall a. a -> Maybe a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure PropertyType "S3" WorkerLogDeliveryProperty
S3LogDeliveryProperty
newValue, Maybe CloudWatchLogsLogDeliveryProperty
Maybe FirehoseLogDeliveryProperty
()
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
haddock_workaround_ :: ()
cloudWatchLogs :: Maybe CloudWatchLogsLogDeliveryProperty
firehose :: Maybe FirehoseLogDeliveryProperty
..}