{-# 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.SSMIncidents.Types.RelatedItemsUpdate 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
import Amazonka.SSMIncidents.Types.ItemIdentifier
import Amazonka.SSMIncidents.Types.RelatedItem
data RelatedItemsUpdate = RelatedItemsUpdate'
{
RelatedItemsUpdate -> Maybe RelatedItem
itemToAdd :: Prelude.Maybe RelatedItem,
RelatedItemsUpdate -> Maybe ItemIdentifier
itemToRemove :: Prelude.Maybe ItemIdentifier
}
deriving (RelatedItemsUpdate -> RelatedItemsUpdate -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: RelatedItemsUpdate -> RelatedItemsUpdate -> Bool
$c/= :: RelatedItemsUpdate -> RelatedItemsUpdate -> Bool
== :: RelatedItemsUpdate -> RelatedItemsUpdate -> Bool
$c== :: RelatedItemsUpdate -> RelatedItemsUpdate -> Bool
Prelude.Eq, ReadPrec [RelatedItemsUpdate]
ReadPrec RelatedItemsUpdate
Int -> ReadS RelatedItemsUpdate
ReadS [RelatedItemsUpdate]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [RelatedItemsUpdate]
$creadListPrec :: ReadPrec [RelatedItemsUpdate]
readPrec :: ReadPrec RelatedItemsUpdate
$creadPrec :: ReadPrec RelatedItemsUpdate
readList :: ReadS [RelatedItemsUpdate]
$creadList :: ReadS [RelatedItemsUpdate]
readsPrec :: Int -> ReadS RelatedItemsUpdate
$creadsPrec :: Int -> ReadS RelatedItemsUpdate
Prelude.Read, Int -> RelatedItemsUpdate -> ShowS
[RelatedItemsUpdate] -> ShowS
RelatedItemsUpdate -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [RelatedItemsUpdate] -> ShowS
$cshowList :: [RelatedItemsUpdate] -> ShowS
show :: RelatedItemsUpdate -> String
$cshow :: RelatedItemsUpdate -> String
showsPrec :: Int -> RelatedItemsUpdate -> ShowS
$cshowsPrec :: Int -> RelatedItemsUpdate -> ShowS
Prelude.Show, forall x. Rep RelatedItemsUpdate x -> RelatedItemsUpdate
forall x. RelatedItemsUpdate -> Rep RelatedItemsUpdate x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep RelatedItemsUpdate x -> RelatedItemsUpdate
$cfrom :: forall x. RelatedItemsUpdate -> Rep RelatedItemsUpdate x
Prelude.Generic)
newRelatedItemsUpdate ::
RelatedItemsUpdate
newRelatedItemsUpdate :: RelatedItemsUpdate
newRelatedItemsUpdate =
RelatedItemsUpdate'
{ $sel:itemToAdd:RelatedItemsUpdate' :: Maybe RelatedItem
itemToAdd = forall a. Maybe a
Prelude.Nothing,
$sel:itemToRemove:RelatedItemsUpdate' :: Maybe ItemIdentifier
itemToRemove = forall a. Maybe a
Prelude.Nothing
}
relatedItemsUpdate_itemToAdd :: Lens.Lens' RelatedItemsUpdate (Prelude.Maybe RelatedItem)
relatedItemsUpdate_itemToAdd :: Lens' RelatedItemsUpdate (Maybe RelatedItem)
relatedItemsUpdate_itemToAdd = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RelatedItemsUpdate' {Maybe RelatedItem
itemToAdd :: Maybe RelatedItem
$sel:itemToAdd:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe RelatedItem
itemToAdd} -> Maybe RelatedItem
itemToAdd) (\s :: RelatedItemsUpdate
s@RelatedItemsUpdate' {} Maybe RelatedItem
a -> RelatedItemsUpdate
s {$sel:itemToAdd:RelatedItemsUpdate' :: Maybe RelatedItem
itemToAdd = Maybe RelatedItem
a} :: RelatedItemsUpdate)
relatedItemsUpdate_itemToRemove :: Lens.Lens' RelatedItemsUpdate (Prelude.Maybe ItemIdentifier)
relatedItemsUpdate_itemToRemove :: Lens' RelatedItemsUpdate (Maybe ItemIdentifier)
relatedItemsUpdate_itemToRemove = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\RelatedItemsUpdate' {Maybe ItemIdentifier
itemToRemove :: Maybe ItemIdentifier
$sel:itemToRemove:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe ItemIdentifier
itemToRemove} -> Maybe ItemIdentifier
itemToRemove) (\s :: RelatedItemsUpdate
s@RelatedItemsUpdate' {} Maybe ItemIdentifier
a -> RelatedItemsUpdate
s {$sel:itemToRemove:RelatedItemsUpdate' :: Maybe ItemIdentifier
itemToRemove = Maybe ItemIdentifier
a} :: RelatedItemsUpdate)
instance Prelude.Hashable RelatedItemsUpdate where
hashWithSalt :: Int -> RelatedItemsUpdate -> Int
hashWithSalt Int
_salt RelatedItemsUpdate' {Maybe ItemIdentifier
Maybe RelatedItem
itemToRemove :: Maybe ItemIdentifier
itemToAdd :: Maybe RelatedItem
$sel:itemToRemove:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe ItemIdentifier
$sel:itemToAdd:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe RelatedItem
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe RelatedItem
itemToAdd
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ItemIdentifier
itemToRemove
instance Prelude.NFData RelatedItemsUpdate where
rnf :: RelatedItemsUpdate -> ()
rnf RelatedItemsUpdate' {Maybe ItemIdentifier
Maybe RelatedItem
itemToRemove :: Maybe ItemIdentifier
itemToAdd :: Maybe RelatedItem
$sel:itemToRemove:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe ItemIdentifier
$sel:itemToAdd:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe RelatedItem
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe RelatedItem
itemToAdd
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe ItemIdentifier
itemToRemove
instance Data.ToJSON RelatedItemsUpdate where
toJSON :: RelatedItemsUpdate -> Value
toJSON RelatedItemsUpdate' {Maybe ItemIdentifier
Maybe RelatedItem
itemToRemove :: Maybe ItemIdentifier
itemToAdd :: Maybe RelatedItem
$sel:itemToRemove:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe ItemIdentifier
$sel:itemToAdd:RelatedItemsUpdate' :: RelatedItemsUpdate -> Maybe RelatedItem
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"itemToAdd" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe RelatedItem
itemToAdd,
(Key
"itemToRemove" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe ItemIdentifier
itemToRemove
]
)