{-# 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.KMS.Types.AliasListEntry where
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
data AliasListEntry = AliasListEntry'
{
AliasListEntry -> Maybe Text
targetKeyId :: Prelude.Maybe Prelude.Text,
AliasListEntry -> Maybe Text
aliasName :: Prelude.Maybe Prelude.Text,
AliasListEntry -> Maybe POSIX
creationDate :: Prelude.Maybe Core.POSIX,
AliasListEntry -> Maybe POSIX
lastUpdatedDate :: Prelude.Maybe Core.POSIX,
AliasListEntry -> Maybe Text
aliasArn :: Prelude.Maybe Prelude.Text
}
deriving (AliasListEntry -> AliasListEntry -> Bool
(AliasListEntry -> AliasListEntry -> Bool)
-> (AliasListEntry -> AliasListEntry -> Bool) -> Eq AliasListEntry
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AliasListEntry -> AliasListEntry -> Bool
$c/= :: AliasListEntry -> AliasListEntry -> Bool
== :: AliasListEntry -> AliasListEntry -> Bool
$c== :: AliasListEntry -> AliasListEntry -> Bool
Prelude.Eq, ReadPrec [AliasListEntry]
ReadPrec AliasListEntry
Int -> ReadS AliasListEntry
ReadS [AliasListEntry]
(Int -> ReadS AliasListEntry)
-> ReadS [AliasListEntry]
-> ReadPrec AliasListEntry
-> ReadPrec [AliasListEntry]
-> Read AliasListEntry
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AliasListEntry]
$creadListPrec :: ReadPrec [AliasListEntry]
readPrec :: ReadPrec AliasListEntry
$creadPrec :: ReadPrec AliasListEntry
readList :: ReadS [AliasListEntry]
$creadList :: ReadS [AliasListEntry]
readsPrec :: Int -> ReadS AliasListEntry
$creadsPrec :: Int -> ReadS AliasListEntry
Prelude.Read, Int -> AliasListEntry -> ShowS
[AliasListEntry] -> ShowS
AliasListEntry -> String
(Int -> AliasListEntry -> ShowS)
-> (AliasListEntry -> String)
-> ([AliasListEntry] -> ShowS)
-> Show AliasListEntry
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AliasListEntry] -> ShowS
$cshowList :: [AliasListEntry] -> ShowS
show :: AliasListEntry -> String
$cshow :: AliasListEntry -> String
showsPrec :: Int -> AliasListEntry -> ShowS
$cshowsPrec :: Int -> AliasListEntry -> ShowS
Prelude.Show, (forall x. AliasListEntry -> Rep AliasListEntry x)
-> (forall x. Rep AliasListEntry x -> AliasListEntry)
-> Generic AliasListEntry
forall x. Rep AliasListEntry x -> AliasListEntry
forall x. AliasListEntry -> Rep AliasListEntry x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AliasListEntry x -> AliasListEntry
$cfrom :: forall x. AliasListEntry -> Rep AliasListEntry x
Prelude.Generic)
newAliasListEntry ::
AliasListEntry
newAliasListEntry :: AliasListEntry
newAliasListEntry =
AliasListEntry' :: Maybe Text
-> Maybe Text
-> Maybe POSIX
-> Maybe POSIX
-> Maybe Text
-> AliasListEntry
AliasListEntry'
{ $sel:targetKeyId:AliasListEntry' :: Maybe Text
targetKeyId = Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:aliasName:AliasListEntry' :: Maybe Text
aliasName = Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:creationDate:AliasListEntry' :: Maybe POSIX
creationDate = Maybe POSIX
forall a. Maybe a
Prelude.Nothing,
$sel:lastUpdatedDate:AliasListEntry' :: Maybe POSIX
lastUpdatedDate = Maybe POSIX
forall a. Maybe a
Prelude.Nothing,
$sel:aliasArn:AliasListEntry' :: Maybe Text
aliasArn = Maybe Text
forall a. Maybe a
Prelude.Nothing
}
aliasListEntry_targetKeyId :: Lens.Lens' AliasListEntry (Prelude.Maybe Prelude.Text)
aliasListEntry_targetKeyId :: (Maybe Text -> f (Maybe Text))
-> AliasListEntry -> f AliasListEntry
aliasListEntry_targetKeyId = (AliasListEntry -> Maybe Text)
-> (AliasListEntry -> Maybe Text -> AliasListEntry)
-> Lens AliasListEntry AliasListEntry (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AliasListEntry' {Maybe Text
targetKeyId :: Maybe Text
$sel:targetKeyId:AliasListEntry' :: AliasListEntry -> Maybe Text
targetKeyId} -> Maybe Text
targetKeyId) (\s :: AliasListEntry
s@AliasListEntry' {} Maybe Text
a -> AliasListEntry
s {$sel:targetKeyId:AliasListEntry' :: Maybe Text
targetKeyId = Maybe Text
a} :: AliasListEntry)
aliasListEntry_aliasName :: Lens.Lens' AliasListEntry (Prelude.Maybe Prelude.Text)
aliasListEntry_aliasName :: (Maybe Text -> f (Maybe Text))
-> AliasListEntry -> f AliasListEntry
aliasListEntry_aliasName = (AliasListEntry -> Maybe Text)
-> (AliasListEntry -> Maybe Text -> AliasListEntry)
-> Lens AliasListEntry AliasListEntry (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AliasListEntry' {Maybe Text
aliasName :: Maybe Text
$sel:aliasName:AliasListEntry' :: AliasListEntry -> Maybe Text
aliasName} -> Maybe Text
aliasName) (\s :: AliasListEntry
s@AliasListEntry' {} Maybe Text
a -> AliasListEntry
s {$sel:aliasName:AliasListEntry' :: Maybe Text
aliasName = Maybe Text
a} :: AliasListEntry)
aliasListEntry_creationDate :: Lens.Lens' AliasListEntry (Prelude.Maybe Prelude.UTCTime)
aliasListEntry_creationDate :: (Maybe UTCTime -> f (Maybe UTCTime))
-> AliasListEntry -> f AliasListEntry
aliasListEntry_creationDate = (AliasListEntry -> Maybe POSIX)
-> (AliasListEntry -> Maybe POSIX -> AliasListEntry)
-> Lens AliasListEntry AliasListEntry (Maybe POSIX) (Maybe POSIX)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AliasListEntry' {Maybe POSIX
creationDate :: Maybe POSIX
$sel:creationDate:AliasListEntry' :: AliasListEntry -> Maybe POSIX
creationDate} -> Maybe POSIX
creationDate) (\s :: AliasListEntry
s@AliasListEntry' {} Maybe POSIX
a -> AliasListEntry
s {$sel:creationDate:AliasListEntry' :: Maybe POSIX
creationDate = Maybe POSIX
a} :: AliasListEntry) ((Maybe POSIX -> f (Maybe POSIX))
-> AliasListEntry -> f AliasListEntry)
-> ((Maybe UTCTime -> f (Maybe UTCTime))
-> Maybe POSIX -> f (Maybe POSIX))
-> (Maybe UTCTime -> f (Maybe UTCTime))
-> AliasListEntry
-> f AliasListEntry
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. AnIso POSIX POSIX UTCTime UTCTime
-> Iso (Maybe POSIX) (Maybe POSIX) (Maybe UTCTime) (Maybe UTCTime)
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 POSIX POSIX UTCTime UTCTime
forall (a :: Format). Iso' (Time a) UTCTime
Core._Time
aliasListEntry_lastUpdatedDate :: Lens.Lens' AliasListEntry (Prelude.Maybe Prelude.UTCTime)
aliasListEntry_lastUpdatedDate :: (Maybe UTCTime -> f (Maybe UTCTime))
-> AliasListEntry -> f AliasListEntry
aliasListEntry_lastUpdatedDate = (AliasListEntry -> Maybe POSIX)
-> (AliasListEntry -> Maybe POSIX -> AliasListEntry)
-> Lens AliasListEntry AliasListEntry (Maybe POSIX) (Maybe POSIX)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AliasListEntry' {Maybe POSIX
lastUpdatedDate :: Maybe POSIX
$sel:lastUpdatedDate:AliasListEntry' :: AliasListEntry -> Maybe POSIX
lastUpdatedDate} -> Maybe POSIX
lastUpdatedDate) (\s :: AliasListEntry
s@AliasListEntry' {} Maybe POSIX
a -> AliasListEntry
s {$sel:lastUpdatedDate:AliasListEntry' :: Maybe POSIX
lastUpdatedDate = Maybe POSIX
a} :: AliasListEntry) ((Maybe POSIX -> f (Maybe POSIX))
-> AliasListEntry -> f AliasListEntry)
-> ((Maybe UTCTime -> f (Maybe UTCTime))
-> Maybe POSIX -> f (Maybe POSIX))
-> (Maybe UTCTime -> f (Maybe UTCTime))
-> AliasListEntry
-> f AliasListEntry
forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. AnIso POSIX POSIX UTCTime UTCTime
-> Iso (Maybe POSIX) (Maybe POSIX) (Maybe UTCTime) (Maybe UTCTime)
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 POSIX POSIX UTCTime UTCTime
forall (a :: Format). Iso' (Time a) UTCTime
Core._Time
aliasListEntry_aliasArn :: Lens.Lens' AliasListEntry (Prelude.Maybe Prelude.Text)
aliasListEntry_aliasArn :: (Maybe Text -> f (Maybe Text))
-> AliasListEntry -> f AliasListEntry
aliasListEntry_aliasArn = (AliasListEntry -> Maybe Text)
-> (AliasListEntry -> Maybe Text -> AliasListEntry)
-> Lens AliasListEntry AliasListEntry (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AliasListEntry' {Maybe Text
aliasArn :: Maybe Text
$sel:aliasArn:AliasListEntry' :: AliasListEntry -> Maybe Text
aliasArn} -> Maybe Text
aliasArn) (\s :: AliasListEntry
s@AliasListEntry' {} Maybe Text
a -> AliasListEntry
s {$sel:aliasArn:AliasListEntry' :: Maybe Text
aliasArn = Maybe Text
a} :: AliasListEntry)
instance Core.FromJSON AliasListEntry where
parseJSON :: Value -> Parser AliasListEntry
parseJSON =
String
-> (Object -> Parser AliasListEntry)
-> Value
-> Parser AliasListEntry
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Core.withObject
String
"AliasListEntry"
( \Object
x ->
Maybe Text
-> Maybe Text
-> Maybe POSIX
-> Maybe POSIX
-> Maybe Text
-> AliasListEntry
AliasListEntry'
(Maybe Text
-> Maybe Text
-> Maybe POSIX
-> Maybe POSIX
-> Maybe Text
-> AliasListEntry)
-> Parser (Maybe Text)
-> Parser
(Maybe Text
-> Maybe POSIX -> Maybe POSIX -> Maybe Text -> AliasListEntry)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"TargetKeyId")
Parser
(Maybe Text
-> Maybe POSIX -> Maybe POSIX -> Maybe Text -> AliasListEntry)
-> Parser (Maybe Text)
-> Parser
(Maybe POSIX -> Maybe POSIX -> Maybe Text -> AliasListEntry)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"AliasName")
Parser (Maybe POSIX -> Maybe POSIX -> Maybe Text -> AliasListEntry)
-> Parser (Maybe POSIX)
-> Parser (Maybe POSIX -> Maybe Text -> AliasListEntry)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x Object -> Text -> Parser (Maybe POSIX)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"CreationDate")
Parser (Maybe POSIX -> Maybe Text -> AliasListEntry)
-> Parser (Maybe POSIX) -> Parser (Maybe Text -> AliasListEntry)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x Object -> Text -> Parser (Maybe POSIX)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"LastUpdatedDate")
Parser (Maybe Text -> AliasListEntry)
-> Parser (Maybe Text) -> Parser AliasListEntry
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"AliasArn")
)
instance Prelude.Hashable AliasListEntry
instance Prelude.NFData AliasListEntry