{-# 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.ComputeOptimizer.Types.EnrollmentFilter where
import Amazonka.ComputeOptimizer.Types.EnrollmentFilterName
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
data EnrollmentFilter = EnrollmentFilter'
{
EnrollmentFilter -> Maybe [Text]
values :: Prelude.Maybe [Prelude.Text],
EnrollmentFilter -> Maybe EnrollmentFilterName
name :: Prelude.Maybe EnrollmentFilterName
}
deriving (EnrollmentFilter -> EnrollmentFilter -> Bool
(EnrollmentFilter -> EnrollmentFilter -> Bool)
-> (EnrollmentFilter -> EnrollmentFilter -> Bool)
-> Eq EnrollmentFilter
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnrollmentFilter -> EnrollmentFilter -> Bool
$c/= :: EnrollmentFilter -> EnrollmentFilter -> Bool
== :: EnrollmentFilter -> EnrollmentFilter -> Bool
$c== :: EnrollmentFilter -> EnrollmentFilter -> Bool
Prelude.Eq, ReadPrec [EnrollmentFilter]
ReadPrec EnrollmentFilter
Int -> ReadS EnrollmentFilter
ReadS [EnrollmentFilter]
(Int -> ReadS EnrollmentFilter)
-> ReadS [EnrollmentFilter]
-> ReadPrec EnrollmentFilter
-> ReadPrec [EnrollmentFilter]
-> Read EnrollmentFilter
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnrollmentFilter]
$creadListPrec :: ReadPrec [EnrollmentFilter]
readPrec :: ReadPrec EnrollmentFilter
$creadPrec :: ReadPrec EnrollmentFilter
readList :: ReadS [EnrollmentFilter]
$creadList :: ReadS [EnrollmentFilter]
readsPrec :: Int -> ReadS EnrollmentFilter
$creadsPrec :: Int -> ReadS EnrollmentFilter
Prelude.Read, Int -> EnrollmentFilter -> ShowS
[EnrollmentFilter] -> ShowS
EnrollmentFilter -> String
(Int -> EnrollmentFilter -> ShowS)
-> (EnrollmentFilter -> String)
-> ([EnrollmentFilter] -> ShowS)
-> Show EnrollmentFilter
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnrollmentFilter] -> ShowS
$cshowList :: [EnrollmentFilter] -> ShowS
show :: EnrollmentFilter -> String
$cshow :: EnrollmentFilter -> String
showsPrec :: Int -> EnrollmentFilter -> ShowS
$cshowsPrec :: Int -> EnrollmentFilter -> ShowS
Prelude.Show, (forall x. EnrollmentFilter -> Rep EnrollmentFilter x)
-> (forall x. Rep EnrollmentFilter x -> EnrollmentFilter)
-> Generic EnrollmentFilter
forall x. Rep EnrollmentFilter x -> EnrollmentFilter
forall x. EnrollmentFilter -> Rep EnrollmentFilter x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep EnrollmentFilter x -> EnrollmentFilter
$cfrom :: forall x. EnrollmentFilter -> Rep EnrollmentFilter x
Prelude.Generic)
newEnrollmentFilter ::
EnrollmentFilter
newEnrollmentFilter :: EnrollmentFilter
newEnrollmentFilter =
EnrollmentFilter' :: Maybe [Text] -> Maybe EnrollmentFilterName -> EnrollmentFilter
EnrollmentFilter'
{ $sel:values:EnrollmentFilter' :: Maybe [Text]
values = Maybe [Text]
forall a. Maybe a
Prelude.Nothing,
$sel:name:EnrollmentFilter' :: Maybe EnrollmentFilterName
name = Maybe EnrollmentFilterName
forall a. Maybe a
Prelude.Nothing
}
enrollmentFilter_values :: Lens.Lens' EnrollmentFilter (Prelude.Maybe [Prelude.Text])
enrollmentFilter_values :: (Maybe [Text] -> f (Maybe [Text]))
-> EnrollmentFilter -> f EnrollmentFilter
enrollmentFilter_values = (EnrollmentFilter -> Maybe [Text])
-> (EnrollmentFilter -> Maybe [Text] -> EnrollmentFilter)
-> Lens
EnrollmentFilter EnrollmentFilter (Maybe [Text]) (Maybe [Text])
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnrollmentFilter' {Maybe [Text]
values :: Maybe [Text]
$sel:values:EnrollmentFilter' :: EnrollmentFilter -> Maybe [Text]
values} -> Maybe [Text]
values) (\s :: EnrollmentFilter
s@EnrollmentFilter' {} Maybe [Text]
a -> EnrollmentFilter
s {$sel:values:EnrollmentFilter' :: Maybe [Text]
values = Maybe [Text]
a} :: EnrollmentFilter) ((Maybe [Text] -> f (Maybe [Text]))
-> EnrollmentFilter -> f EnrollmentFilter)
-> ((Maybe [Text] -> f (Maybe [Text]))
-> Maybe [Text] -> f (Maybe [Text]))
-> (Maybe [Text] -> f (Maybe [Text]))
-> EnrollmentFilter
-> f EnrollmentFilter
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. AnIso [Text] [Text] [Text] [Text]
-> Iso (Maybe [Text]) (Maybe [Text]) (Maybe [Text]) (Maybe [Text])
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 [Text] [Text] [Text] [Text]
forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
enrollmentFilter_name :: Lens.Lens' EnrollmentFilter (Prelude.Maybe EnrollmentFilterName)
enrollmentFilter_name :: (Maybe EnrollmentFilterName -> f (Maybe EnrollmentFilterName))
-> EnrollmentFilter -> f EnrollmentFilter
enrollmentFilter_name = (EnrollmentFilter -> Maybe EnrollmentFilterName)
-> (EnrollmentFilter
-> Maybe EnrollmentFilterName -> EnrollmentFilter)
-> Lens
EnrollmentFilter
EnrollmentFilter
(Maybe EnrollmentFilterName)
(Maybe EnrollmentFilterName)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnrollmentFilter' {Maybe EnrollmentFilterName
name :: Maybe EnrollmentFilterName
$sel:name:EnrollmentFilter' :: EnrollmentFilter -> Maybe EnrollmentFilterName
name} -> Maybe EnrollmentFilterName
name) (\s :: EnrollmentFilter
s@EnrollmentFilter' {} Maybe EnrollmentFilterName
a -> EnrollmentFilter
s {$sel:name:EnrollmentFilter' :: Maybe EnrollmentFilterName
name = Maybe EnrollmentFilterName
a} :: EnrollmentFilter)
instance Prelude.Hashable EnrollmentFilter
instance Prelude.NFData EnrollmentFilter
instance Core.ToJSON EnrollmentFilter where
toJSON :: EnrollmentFilter -> Value
toJSON EnrollmentFilter' {Maybe [Text]
Maybe EnrollmentFilterName
name :: Maybe EnrollmentFilterName
values :: Maybe [Text]
$sel:name:EnrollmentFilter' :: EnrollmentFilter -> Maybe EnrollmentFilterName
$sel:values:EnrollmentFilter' :: EnrollmentFilter -> Maybe [Text]
..} =
[Pair] -> Value
Core.object
( [Maybe Pair] -> [Pair]
forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Text
"values" Text -> [Text] -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..=) ([Text] -> Pair) -> Maybe [Text] -> Maybe Pair
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
values,
(Text
"name" Text -> EnrollmentFilterName -> Pair
forall kv v. (KeyValue kv, ToJSON v) => Text -> v -> kv
Core..=) (EnrollmentFilterName -> Pair)
-> Maybe EnrollmentFilterName -> Maybe Pair
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe EnrollmentFilterName
name
]
)