{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.Pinpoint.Types.WriteEventStream where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
data WriteEventStream = WriteEventStream'
{
WriteEventStream -> Text
roleArn :: Prelude.Text,
WriteEventStream -> Text
destinationStreamArn :: Prelude.Text
}
deriving (WriteEventStream -> WriteEventStream -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: WriteEventStream -> WriteEventStream -> Bool
$c/= :: WriteEventStream -> WriteEventStream -> Bool
== :: WriteEventStream -> WriteEventStream -> Bool
$c== :: WriteEventStream -> WriteEventStream -> Bool
Prelude.Eq, ReadPrec [WriteEventStream]
ReadPrec WriteEventStream
Int -> ReadS WriteEventStream
ReadS [WriteEventStream]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [WriteEventStream]
$creadListPrec :: ReadPrec [WriteEventStream]
readPrec :: ReadPrec WriteEventStream
$creadPrec :: ReadPrec WriteEventStream
readList :: ReadS [WriteEventStream]
$creadList :: ReadS [WriteEventStream]
readsPrec :: Int -> ReadS WriteEventStream
$creadsPrec :: Int -> ReadS WriteEventStream
Prelude.Read, Int -> WriteEventStream -> ShowS
[WriteEventStream] -> ShowS
WriteEventStream -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [WriteEventStream] -> ShowS
$cshowList :: [WriteEventStream] -> ShowS
show :: WriteEventStream -> String
$cshow :: WriteEventStream -> String
showsPrec :: Int -> WriteEventStream -> ShowS
$cshowsPrec :: Int -> WriteEventStream -> ShowS
Prelude.Show, forall x. Rep WriteEventStream x -> WriteEventStream
forall x. WriteEventStream -> Rep WriteEventStream x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep WriteEventStream x -> WriteEventStream
$cfrom :: forall x. WriteEventStream -> Rep WriteEventStream x
Prelude.Generic)
newWriteEventStream ::
Prelude.Text ->
Prelude.Text ->
WriteEventStream
newWriteEventStream :: Text -> Text -> WriteEventStream
newWriteEventStream Text
pRoleArn_ Text
pDestinationStreamArn_ =
WriteEventStream'
{ $sel:roleArn:WriteEventStream' :: Text
roleArn = Text
pRoleArn_,
$sel:destinationStreamArn:WriteEventStream' :: Text
destinationStreamArn = Text
pDestinationStreamArn_
}
writeEventStream_roleArn :: Lens.Lens' WriteEventStream Prelude.Text
writeEventStream_roleArn :: Lens' WriteEventStream Text
writeEventStream_roleArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\WriteEventStream' {Text
roleArn :: Text
$sel:roleArn:WriteEventStream' :: WriteEventStream -> Text
roleArn} -> Text
roleArn) (\s :: WriteEventStream
s@WriteEventStream' {} Text
a -> WriteEventStream
s {$sel:roleArn:WriteEventStream' :: Text
roleArn = Text
a} :: WriteEventStream)
writeEventStream_destinationStreamArn :: Lens.Lens' WriteEventStream Prelude.Text
writeEventStream_destinationStreamArn :: Lens' WriteEventStream Text
writeEventStream_destinationStreamArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\WriteEventStream' {Text
destinationStreamArn :: Text
$sel:destinationStreamArn:WriteEventStream' :: WriteEventStream -> Text
destinationStreamArn} -> Text
destinationStreamArn) (\s :: WriteEventStream
s@WriteEventStream' {} Text
a -> WriteEventStream
s {$sel:destinationStreamArn:WriteEventStream' :: Text
destinationStreamArn = Text
a} :: WriteEventStream)
instance Prelude.Hashable WriteEventStream where
hashWithSalt :: Int -> WriteEventStream -> Int
hashWithSalt Int
_salt WriteEventStream' {Text
destinationStreamArn :: Text
roleArn :: Text
$sel:destinationStreamArn:WriteEventStream' :: WriteEventStream -> Text
$sel:roleArn:WriteEventStream' :: WriteEventStream -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
roleArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
destinationStreamArn
instance Prelude.NFData WriteEventStream where
rnf :: WriteEventStream -> ()
rnf WriteEventStream' {Text
destinationStreamArn :: Text
roleArn :: Text
$sel:destinationStreamArn:WriteEventStream' :: WriteEventStream -> Text
$sel:roleArn:WriteEventStream' :: WriteEventStream -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
roleArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
destinationStreamArn
instance Data.ToJSON WriteEventStream where
toJSON :: WriteEventStream -> Value
toJSON WriteEventStream' {Text
destinationStreamArn :: Text
roleArn :: Text
$sel:destinationStreamArn:WriteEventStream' :: WriteEventStream -> Text
$sel:roleArn:WriteEventStream' :: WriteEventStream -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"RoleArn" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
roleArn),
forall a. a -> Maybe a
Prelude.Just
( Key
"DestinationStreamArn"
forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
destinationStreamArn
)
]
)