{-# 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.CodeDeploy.Types.OnPremisesTagSet where
import Amazonka.CodeDeploy.Types.TagFilter
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
data OnPremisesTagSet = OnPremisesTagSet'
{
OnPremisesTagSet -> Maybe [[TagFilter]]
onPremisesTagSetList :: Prelude.Maybe [[TagFilter]]
}
deriving (OnPremisesTagSet -> OnPremisesTagSet -> Bool
(OnPremisesTagSet -> OnPremisesTagSet -> Bool)
-> (OnPremisesTagSet -> OnPremisesTagSet -> Bool)
-> Eq OnPremisesTagSet
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: OnPremisesTagSet -> OnPremisesTagSet -> Bool
$c/= :: OnPremisesTagSet -> OnPremisesTagSet -> Bool
== :: OnPremisesTagSet -> OnPremisesTagSet -> Bool
$c== :: OnPremisesTagSet -> OnPremisesTagSet -> Bool
Prelude.Eq, ReadPrec [OnPremisesTagSet]
ReadPrec OnPremisesTagSet
Int -> ReadS OnPremisesTagSet
ReadS [OnPremisesTagSet]
(Int -> ReadS OnPremisesTagSet)
-> ReadS [OnPremisesTagSet]
-> ReadPrec OnPremisesTagSet
-> ReadPrec [OnPremisesTagSet]
-> Read OnPremisesTagSet
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [OnPremisesTagSet]
$creadListPrec :: ReadPrec [OnPremisesTagSet]
readPrec :: ReadPrec OnPremisesTagSet
$creadPrec :: ReadPrec OnPremisesTagSet
readList :: ReadS [OnPremisesTagSet]
$creadList :: ReadS [OnPremisesTagSet]
readsPrec :: Int -> ReadS OnPremisesTagSet
$creadsPrec :: Int -> ReadS OnPremisesTagSet
Prelude.Read, Int -> OnPremisesTagSet -> ShowS
[OnPremisesTagSet] -> ShowS
OnPremisesTagSet -> String
(Int -> OnPremisesTagSet -> ShowS)
-> (OnPremisesTagSet -> String)
-> ([OnPremisesTagSet] -> ShowS)
-> Show OnPremisesTagSet
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [OnPremisesTagSet] -> ShowS
$cshowList :: [OnPremisesTagSet] -> ShowS
show :: OnPremisesTagSet -> String
$cshow :: OnPremisesTagSet -> String
showsPrec :: Int -> OnPremisesTagSet -> ShowS
$cshowsPrec :: Int -> OnPremisesTagSet -> ShowS
Prelude.Show, (forall x. OnPremisesTagSet -> Rep OnPremisesTagSet x)
-> (forall x. Rep OnPremisesTagSet x -> OnPremisesTagSet)
-> Generic OnPremisesTagSet
forall x. Rep OnPremisesTagSet x -> OnPremisesTagSet
forall x. OnPremisesTagSet -> Rep OnPremisesTagSet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep OnPremisesTagSet x -> OnPremisesTagSet
$cfrom :: forall x. OnPremisesTagSet -> Rep OnPremisesTagSet x
Prelude.Generic)
newOnPremisesTagSet ::
OnPremisesTagSet
newOnPremisesTagSet :: OnPremisesTagSet
newOnPremisesTagSet =
OnPremisesTagSet' :: Maybe [[TagFilter]] -> OnPremisesTagSet
OnPremisesTagSet'
{ $sel:onPremisesTagSetList:OnPremisesTagSet' :: Maybe [[TagFilter]]
onPremisesTagSetList =
Maybe [[TagFilter]]
forall a. Maybe a
Prelude.Nothing
}
onPremisesTagSet_onPremisesTagSetList :: Lens.Lens' OnPremisesTagSet (Prelude.Maybe [[TagFilter]])
onPremisesTagSet_onPremisesTagSetList :: (Maybe [[TagFilter]] -> f (Maybe [[TagFilter]]))
-> OnPremisesTagSet -> f OnPremisesTagSet
onPremisesTagSet_onPremisesTagSetList = (OnPremisesTagSet -> Maybe [[TagFilter]])
-> (OnPremisesTagSet -> Maybe [[TagFilter]] -> OnPremisesTagSet)
-> Lens
OnPremisesTagSet
OnPremisesTagSet
(Maybe [[TagFilter]])
(Maybe [[TagFilter]])
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\OnPremisesTagSet' {Maybe [[TagFilter]]
onPremisesTagSetList :: Maybe [[TagFilter]]
$sel:onPremisesTagSetList:OnPremisesTagSet' :: OnPremisesTagSet -> Maybe [[TagFilter]]
onPremisesTagSetList} -> Maybe [[TagFilter]]
onPremisesTagSetList) (\s :: OnPremisesTagSet
s@OnPremisesTagSet' {} Maybe [[TagFilter]]
a -> OnPremisesTagSet
s {$sel:onPremisesTagSetList:OnPremisesTagSet' :: Maybe [[TagFilter]]
onPremisesTagSetList = Maybe [[TagFilter]]
a} :: OnPremisesTagSet) ((Maybe [[TagFilter]] -> f (Maybe [[TagFilter]]))
-> OnPremisesTagSet -> f OnPremisesTagSet)
-> ((Maybe [[TagFilter]] -> f (Maybe [[TagFilter]]))
-> Maybe [[TagFilter]] -> f (Maybe [[TagFilter]]))
-> (Maybe [[TagFilter]] -> f (Maybe [[TagFilter]]))
-> OnPremisesTagSet
-> f OnPremisesTagSet
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. AnIso [[TagFilter]] [[TagFilter]] [[TagFilter]] [[TagFilter]]
-> Iso
(Maybe [[TagFilter]])
(Maybe [[TagFilter]])
(Maybe [[TagFilter]])
(Maybe [[TagFilter]])
forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping AnIso [[TagFilter]] [[TagFilter]] [[TagFilter]] [[TagFilter]]
forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
instance Core.FromJSON OnPremisesTagSet where
parseJSON :: Value -> Parser OnPremisesTagSet
parseJSON =
String
-> (Object -> Parser OnPremisesTagSet)
-> Value
-> Parser OnPremisesTagSet
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Core.withObject
String
"OnPremisesTagSet"
( \Object
x ->
Maybe [[TagFilter]] -> OnPremisesTagSet
OnPremisesTagSet'
(Maybe [[TagFilter]] -> OnPremisesTagSet)
-> Parser (Maybe [[TagFilter]]) -> Parser OnPremisesTagSet
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ( Object
x Object -> Text -> Parser (Maybe (Maybe [[TagFilter]]))
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"onPremisesTagSetList"
Parser (Maybe (Maybe [[TagFilter]]))
-> Maybe [[TagFilter]] -> Parser (Maybe [[TagFilter]])
forall a. Parser (Maybe a) -> a -> Parser a
Core..!= Maybe [[TagFilter]]
forall a. Monoid a => a
Prelude.mempty
)
)
instance Prelude.Hashable OnPremisesTagSet
instance Prelude.NFData OnPremisesTagSet
instance Core.ToJSON OnPremisesTagSet where
toJSON :: OnPremisesTagSet -> Value
toJSON OnPremisesTagSet' {Maybe [[TagFilter]]
onPremisesTagSetList :: Maybe [[TagFilter]]
$sel:onPremisesTagSetList:OnPremisesTagSet' :: OnPremisesTagSet -> Maybe [[TagFilter]]
..} =
[Pair] -> Value
Core.object
( [Maybe Pair] -> [Pair]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Text
"onPremisesTagSetList" Text -> [[TagFilter]] -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..=)
([[TagFilter]] -> Pair) -> Maybe [[TagFilter]] -> Maybe Pair
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [[TagFilter]]
onPremisesTagSetList
]
)