{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.STS.GetAccessKeyInfo
(
GetAccessKeyInfo (..),
newGetAccessKeyInfo,
getAccessKeyInfo_accessKeyId,
GetAccessKeyInfoResponse (..),
newGetAccessKeyInfoResponse,
getAccessKeyInfoResponse_account,
getAccessKeyInfoResponse_httpStatus,
)
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 qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
import Amazonka.STS.Types
data GetAccessKeyInfo = GetAccessKeyInfo'
{
GetAccessKeyInfo -> AccessKey
accessKeyId :: Core.AccessKey
}
deriving (GetAccessKeyInfo -> GetAccessKeyInfo -> Bool
(GetAccessKeyInfo -> GetAccessKeyInfo -> Bool)
-> (GetAccessKeyInfo -> GetAccessKeyInfo -> Bool)
-> Eq GetAccessKeyInfo
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: GetAccessKeyInfo -> GetAccessKeyInfo -> Bool
== :: GetAccessKeyInfo -> GetAccessKeyInfo -> Bool
$c/= :: GetAccessKeyInfo -> GetAccessKeyInfo -> Bool
/= :: GetAccessKeyInfo -> GetAccessKeyInfo -> Bool
Prelude.Eq, ReadPrec [GetAccessKeyInfo]
ReadPrec GetAccessKeyInfo
Int -> ReadS GetAccessKeyInfo
ReadS [GetAccessKeyInfo]
(Int -> ReadS GetAccessKeyInfo)
-> ReadS [GetAccessKeyInfo]
-> ReadPrec GetAccessKeyInfo
-> ReadPrec [GetAccessKeyInfo]
-> Read GetAccessKeyInfo
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS GetAccessKeyInfo
readsPrec :: Int -> ReadS GetAccessKeyInfo
$creadList :: ReadS [GetAccessKeyInfo]
readList :: ReadS [GetAccessKeyInfo]
$creadPrec :: ReadPrec GetAccessKeyInfo
readPrec :: ReadPrec GetAccessKeyInfo
$creadListPrec :: ReadPrec [GetAccessKeyInfo]
readListPrec :: ReadPrec [GetAccessKeyInfo]
Prelude.Read, Int -> GetAccessKeyInfo -> ShowS
[GetAccessKeyInfo] -> ShowS
GetAccessKeyInfo -> String
(Int -> GetAccessKeyInfo -> ShowS)
-> (GetAccessKeyInfo -> String)
-> ([GetAccessKeyInfo] -> ShowS)
-> Show GetAccessKeyInfo
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> GetAccessKeyInfo -> ShowS
showsPrec :: Int -> GetAccessKeyInfo -> ShowS
$cshow :: GetAccessKeyInfo -> String
show :: GetAccessKeyInfo -> String
$cshowList :: [GetAccessKeyInfo] -> ShowS
showList :: [GetAccessKeyInfo] -> ShowS
Prelude.Show, (forall x. GetAccessKeyInfo -> Rep GetAccessKeyInfo x)
-> (forall x. Rep GetAccessKeyInfo x -> GetAccessKeyInfo)
-> Generic GetAccessKeyInfo
forall x. Rep GetAccessKeyInfo x -> GetAccessKeyInfo
forall x. GetAccessKeyInfo -> Rep GetAccessKeyInfo x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. GetAccessKeyInfo -> Rep GetAccessKeyInfo x
from :: forall x. GetAccessKeyInfo -> Rep GetAccessKeyInfo x
$cto :: forall x. Rep GetAccessKeyInfo x -> GetAccessKeyInfo
to :: forall x. Rep GetAccessKeyInfo x -> GetAccessKeyInfo
Prelude.Generic)
newGetAccessKeyInfo ::
Core.AccessKey ->
GetAccessKeyInfo
newGetAccessKeyInfo :: AccessKey -> GetAccessKeyInfo
newGetAccessKeyInfo AccessKey
pAccessKeyId_ =
GetAccessKeyInfo' {$sel:accessKeyId:GetAccessKeyInfo' :: AccessKey
accessKeyId = AccessKey
pAccessKeyId_}
getAccessKeyInfo_accessKeyId :: Lens.Lens' GetAccessKeyInfo Core.AccessKey
getAccessKeyInfo_accessKeyId :: Lens' GetAccessKeyInfo AccessKey
getAccessKeyInfo_accessKeyId = (GetAccessKeyInfo -> AccessKey)
-> (GetAccessKeyInfo -> AccessKey -> GetAccessKeyInfo)
-> Lens' GetAccessKeyInfo AccessKey
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAccessKeyInfo' {AccessKey
$sel:accessKeyId:GetAccessKeyInfo' :: GetAccessKeyInfo -> AccessKey
accessKeyId :: AccessKey
accessKeyId} -> AccessKey
accessKeyId) (\s :: GetAccessKeyInfo
s@GetAccessKeyInfo' {} AccessKey
a -> GetAccessKeyInfo
s {accessKeyId = a} :: GetAccessKeyInfo)
instance Core.AWSRequest GetAccessKeyInfo where
type
AWSResponse GetAccessKeyInfo =
GetAccessKeyInfoResponse
request :: (Service -> Service)
-> GetAccessKeyInfo -> Request GetAccessKeyInfo
request Service -> Service
overrides =
Service -> GetAccessKeyInfo -> Request GetAccessKeyInfo
forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetAccessKeyInfo
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse GetAccessKeyInfo)))
response =
Text
-> (Int
-> ResponseHeaders
-> [Node]
-> Either String (AWSResponse GetAccessKeyInfo))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetAccessKeyInfo
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse GetAccessKeyInfo)))
forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
-> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
Text
"GetAccessKeyInfoResult"
( \Int
s ResponseHeaders
h [Node]
x ->
Maybe Text -> Int -> GetAccessKeyInfoResponse
GetAccessKeyInfoResponse'
(Maybe Text -> Int -> GetAccessKeyInfoResponse)
-> Either String (Maybe Text)
-> Either String (Int -> GetAccessKeyInfoResponse)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> ([Node]
x [Node] -> Text -> Either String (Maybe Text)
forall a. FromXML a => [Node] -> Text -> Either String (Maybe a)
Data..@? Text
"Account")
Either String (Int -> GetAccessKeyInfoResponse)
-> Either String Int -> Either String GetAccessKeyInfoResponse
forall a b.
Either String (a -> b) -> Either String a -> Either String b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Int -> Either String Int
forall a. a -> Either String a
forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (Int -> Int
forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
)
instance Prelude.Hashable GetAccessKeyInfo where
hashWithSalt :: Int -> GetAccessKeyInfo -> Int
hashWithSalt Int
_salt GetAccessKeyInfo' {AccessKey
$sel:accessKeyId:GetAccessKeyInfo' :: GetAccessKeyInfo -> AccessKey
accessKeyId :: AccessKey
..} =
Int
_salt Int -> AccessKey -> Int
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` AccessKey
accessKeyId
instance Prelude.NFData GetAccessKeyInfo where
rnf :: GetAccessKeyInfo -> ()
rnf GetAccessKeyInfo' {AccessKey
$sel:accessKeyId:GetAccessKeyInfo' :: GetAccessKeyInfo -> AccessKey
accessKeyId :: AccessKey
..} = AccessKey -> ()
forall a. NFData a => a -> ()
Prelude.rnf AccessKey
accessKeyId
instance Data.ToHeaders GetAccessKeyInfo where
toHeaders :: GetAccessKeyInfo -> ResponseHeaders
toHeaders = ResponseHeaders -> GetAccessKeyInfo -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const ResponseHeaders
forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath GetAccessKeyInfo where
toPath :: GetAccessKeyInfo -> ByteString
toPath = ByteString -> GetAccessKeyInfo -> ByteString
forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery GetAccessKeyInfo where
toQuery :: GetAccessKeyInfo -> QueryString
toQuery GetAccessKeyInfo' {AccessKey
$sel:accessKeyId:GetAccessKeyInfo' :: GetAccessKeyInfo -> AccessKey
accessKeyId :: AccessKey
..} =
[QueryString] -> QueryString
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"Action"
ByteString -> ByteString -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"GetAccessKeyInfo" :: Prelude.ByteString),
ByteString
"Version"
ByteString -> ByteString -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2011-06-15" :: Prelude.ByteString),
ByteString
"AccessKeyId" ByteString -> AccessKey -> QueryString
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: AccessKey
accessKeyId
]
data GetAccessKeyInfoResponse = GetAccessKeyInfoResponse'
{
GetAccessKeyInfoResponse -> Maybe Text
account :: Prelude.Maybe Prelude.Text,
GetAccessKeyInfoResponse -> Int
httpStatus :: Prelude.Int
}
deriving (GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool
(GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool)
-> (GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool)
-> Eq GetAccessKeyInfoResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool
== :: GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool
$c/= :: GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool
/= :: GetAccessKeyInfoResponse -> GetAccessKeyInfoResponse -> Bool
Prelude.Eq, ReadPrec [GetAccessKeyInfoResponse]
ReadPrec GetAccessKeyInfoResponse
Int -> ReadS GetAccessKeyInfoResponse
ReadS [GetAccessKeyInfoResponse]
(Int -> ReadS GetAccessKeyInfoResponse)
-> ReadS [GetAccessKeyInfoResponse]
-> ReadPrec GetAccessKeyInfoResponse
-> ReadPrec [GetAccessKeyInfoResponse]
-> Read GetAccessKeyInfoResponse
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS GetAccessKeyInfoResponse
readsPrec :: Int -> ReadS GetAccessKeyInfoResponse
$creadList :: ReadS [GetAccessKeyInfoResponse]
readList :: ReadS [GetAccessKeyInfoResponse]
$creadPrec :: ReadPrec GetAccessKeyInfoResponse
readPrec :: ReadPrec GetAccessKeyInfoResponse
$creadListPrec :: ReadPrec [GetAccessKeyInfoResponse]
readListPrec :: ReadPrec [GetAccessKeyInfoResponse]
Prelude.Read, Int -> GetAccessKeyInfoResponse -> ShowS
[GetAccessKeyInfoResponse] -> ShowS
GetAccessKeyInfoResponse -> String
(Int -> GetAccessKeyInfoResponse -> ShowS)
-> (GetAccessKeyInfoResponse -> String)
-> ([GetAccessKeyInfoResponse] -> ShowS)
-> Show GetAccessKeyInfoResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> GetAccessKeyInfoResponse -> ShowS
showsPrec :: Int -> GetAccessKeyInfoResponse -> ShowS
$cshow :: GetAccessKeyInfoResponse -> String
show :: GetAccessKeyInfoResponse -> String
$cshowList :: [GetAccessKeyInfoResponse] -> ShowS
showList :: [GetAccessKeyInfoResponse] -> ShowS
Prelude.Show, (forall x.
GetAccessKeyInfoResponse -> Rep GetAccessKeyInfoResponse x)
-> (forall x.
Rep GetAccessKeyInfoResponse x -> GetAccessKeyInfoResponse)
-> Generic GetAccessKeyInfoResponse
forall x.
Rep GetAccessKeyInfoResponse x -> GetAccessKeyInfoResponse
forall x.
GetAccessKeyInfoResponse -> Rep GetAccessKeyInfoResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
GetAccessKeyInfoResponse -> Rep GetAccessKeyInfoResponse x
from :: forall x.
GetAccessKeyInfoResponse -> Rep GetAccessKeyInfoResponse x
$cto :: forall x.
Rep GetAccessKeyInfoResponse x -> GetAccessKeyInfoResponse
to :: forall x.
Rep GetAccessKeyInfoResponse x -> GetAccessKeyInfoResponse
Prelude.Generic)
newGetAccessKeyInfoResponse ::
Prelude.Int ->
GetAccessKeyInfoResponse
newGetAccessKeyInfoResponse :: Int -> GetAccessKeyInfoResponse
newGetAccessKeyInfoResponse Int
pHttpStatus_ =
GetAccessKeyInfoResponse'
{ $sel:account:GetAccessKeyInfoResponse' :: Maybe Text
account =
Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:GetAccessKeyInfoResponse' :: Int
httpStatus = Int
pHttpStatus_
}
getAccessKeyInfoResponse_account :: Lens.Lens' GetAccessKeyInfoResponse (Prelude.Maybe Prelude.Text)
getAccessKeyInfoResponse_account :: Lens' GetAccessKeyInfoResponse (Maybe Text)
getAccessKeyInfoResponse_account = (GetAccessKeyInfoResponse -> Maybe Text)
-> (GetAccessKeyInfoResponse
-> Maybe Text -> GetAccessKeyInfoResponse)
-> Lens' GetAccessKeyInfoResponse (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAccessKeyInfoResponse' {Maybe Text
$sel:account:GetAccessKeyInfoResponse' :: GetAccessKeyInfoResponse -> Maybe Text
account :: Maybe Text
account} -> Maybe Text
account) (\s :: GetAccessKeyInfoResponse
s@GetAccessKeyInfoResponse' {} Maybe Text
a -> GetAccessKeyInfoResponse
s {account = a} :: GetAccessKeyInfoResponse)
getAccessKeyInfoResponse_httpStatus :: Lens.Lens' GetAccessKeyInfoResponse Prelude.Int
getAccessKeyInfoResponse_httpStatus :: Lens' GetAccessKeyInfoResponse Int
getAccessKeyInfoResponse_httpStatus = (GetAccessKeyInfoResponse -> Int)
-> (GetAccessKeyInfoResponse -> Int -> GetAccessKeyInfoResponse)
-> Lens' GetAccessKeyInfoResponse Int
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetAccessKeyInfoResponse' {Int
$sel:httpStatus:GetAccessKeyInfoResponse' :: GetAccessKeyInfoResponse -> Int
httpStatus :: Int
httpStatus} -> Int
httpStatus) (\s :: GetAccessKeyInfoResponse
s@GetAccessKeyInfoResponse' {} Int
a -> GetAccessKeyInfoResponse
s {httpStatus = a} :: GetAccessKeyInfoResponse)
instance Prelude.NFData GetAccessKeyInfoResponse where
rnf :: GetAccessKeyInfoResponse -> ()
rnf GetAccessKeyInfoResponse' {Int
Maybe Text
$sel:account:GetAccessKeyInfoResponse' :: GetAccessKeyInfoResponse -> Maybe Text
$sel:httpStatus:GetAccessKeyInfoResponse' :: GetAccessKeyInfoResponse -> Int
account :: Maybe Text
httpStatus :: Int
..} =
Maybe Text -> ()
forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
account
() -> () -> ()
forall a b. a -> b -> b
`Prelude.seq` Int -> ()
forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus