{-# 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.CloudFront.GetKeyGroup
(
GetKeyGroup (..),
newGetKeyGroup,
getKeyGroup_id,
GetKeyGroupResponse (..),
newGetKeyGroupResponse,
getKeyGroupResponse_eTag,
getKeyGroupResponse_keyGroup,
getKeyGroupResponse_httpStatus,
)
where
import Amazonka.CloudFront.Types
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data GetKeyGroup = GetKeyGroup'
{
GetKeyGroup -> Text
id :: Prelude.Text
}
deriving (GetKeyGroup -> GetKeyGroup -> Bool
(GetKeyGroup -> GetKeyGroup -> Bool)
-> (GetKeyGroup -> GetKeyGroup -> Bool) -> Eq GetKeyGroup
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetKeyGroup -> GetKeyGroup -> Bool
$c/= :: GetKeyGroup -> GetKeyGroup -> Bool
== :: GetKeyGroup -> GetKeyGroup -> Bool
$c== :: GetKeyGroup -> GetKeyGroup -> Bool
Prelude.Eq, ReadPrec [GetKeyGroup]
ReadPrec GetKeyGroup
Int -> ReadS GetKeyGroup
ReadS [GetKeyGroup]
(Int -> ReadS GetKeyGroup)
-> ReadS [GetKeyGroup]
-> ReadPrec GetKeyGroup
-> ReadPrec [GetKeyGroup]
-> Read GetKeyGroup
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetKeyGroup]
$creadListPrec :: ReadPrec [GetKeyGroup]
readPrec :: ReadPrec GetKeyGroup
$creadPrec :: ReadPrec GetKeyGroup
readList :: ReadS [GetKeyGroup]
$creadList :: ReadS [GetKeyGroup]
readsPrec :: Int -> ReadS GetKeyGroup
$creadsPrec :: Int -> ReadS GetKeyGroup
Prelude.Read, Int -> GetKeyGroup -> ShowS
[GetKeyGroup] -> ShowS
GetKeyGroup -> String
(Int -> GetKeyGroup -> ShowS)
-> (GetKeyGroup -> String)
-> ([GetKeyGroup] -> ShowS)
-> Show GetKeyGroup
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetKeyGroup] -> ShowS
$cshowList :: [GetKeyGroup] -> ShowS
show :: GetKeyGroup -> String
$cshow :: GetKeyGroup -> String
showsPrec :: Int -> GetKeyGroup -> ShowS
$cshowsPrec :: Int -> GetKeyGroup -> ShowS
Prelude.Show, (forall x. GetKeyGroup -> Rep GetKeyGroup x)
-> (forall x. Rep GetKeyGroup x -> GetKeyGroup)
-> Generic GetKeyGroup
forall x. Rep GetKeyGroup x -> GetKeyGroup
forall x. GetKeyGroup -> Rep GetKeyGroup x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetKeyGroup x -> GetKeyGroup
$cfrom :: forall x. GetKeyGroup -> Rep GetKeyGroup x
Prelude.Generic)
newGetKeyGroup ::
Prelude.Text ->
GetKeyGroup
newGetKeyGroup :: Text -> GetKeyGroup
newGetKeyGroup Text
pId_ = GetKeyGroup' :: Text -> GetKeyGroup
GetKeyGroup' {$sel:id:GetKeyGroup' :: Text
id = Text
pId_}
getKeyGroup_id :: Lens.Lens' GetKeyGroup Prelude.Text
getKeyGroup_id :: (Text -> f Text) -> GetKeyGroup -> f GetKeyGroup
getKeyGroup_id = (GetKeyGroup -> Text)
-> (GetKeyGroup -> Text -> GetKeyGroup)
-> Lens GetKeyGroup GetKeyGroup Text Text
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetKeyGroup' {Text
id :: Text
$sel:id:GetKeyGroup' :: GetKeyGroup -> Text
id} -> Text
id) (\s :: GetKeyGroup
s@GetKeyGroup' {} Text
a -> GetKeyGroup
s {$sel:id:GetKeyGroup' :: Text
id = Text
a} :: GetKeyGroup)
instance Core.AWSRequest GetKeyGroup where
type AWSResponse GetKeyGroup = GetKeyGroupResponse
request :: GetKeyGroup -> Request GetKeyGroup
request = Service -> GetKeyGroup -> Request GetKeyGroup
forall a. ToRequest a => Service -> a -> Request a
Request.get Service
defaultService
response :: Logger
-> Service
-> Proxy GetKeyGroup
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse GetKeyGroup)))
response =
(Int
-> ResponseHeaders
-> [Node]
-> Either String (AWSResponse GetKeyGroup))
-> Logger
-> Service
-> Proxy GetKeyGroup
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse GetKeyGroup)))
forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> Logger
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXML
( \Int
s ResponseHeaders
h [Node]
x ->
Maybe Text -> Maybe KeyGroup -> Int -> GetKeyGroupResponse
GetKeyGroupResponse'
(Maybe Text -> Maybe KeyGroup -> Int -> GetKeyGroupResponse)
-> Either String (Maybe Text)
-> Either String (Maybe KeyGroup -> Int -> GetKeyGroupResponse)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (ResponseHeaders
h ResponseHeaders -> HeaderName -> Either String (Maybe Text)
forall a.
FromText a =>
ResponseHeaders -> HeaderName -> Either String (Maybe a)
Core..#? HeaderName
"ETag")
Either String (Maybe KeyGroup -> Int -> GetKeyGroupResponse)
-> Either String (Maybe KeyGroup)
-> Either String (Int -> GetKeyGroupResponse)
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> ([Node] -> Either String (Maybe KeyGroup)
forall a. FromXML a => [Node] -> Either String a
Core.parseXML [Node]
x)
Either String (Int -> GetKeyGroupResponse)
-> Either String Int -> Either String GetKeyGroupResponse
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Int -> Either String Int
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 GetKeyGroup
instance Prelude.NFData GetKeyGroup
instance Core.ToHeaders GetKeyGroup where
toHeaders :: GetKeyGroup -> ResponseHeaders
toHeaders = ResponseHeaders -> GetKeyGroup -> ResponseHeaders
forall a b. a -> b -> a
Prelude.const ResponseHeaders
forall a. Monoid a => a
Prelude.mempty
instance Core.ToPath GetKeyGroup where
toPath :: GetKeyGroup -> ByteString
toPath GetKeyGroup' {Text
id :: Text
$sel:id:GetKeyGroup' :: GetKeyGroup -> Text
..} =
[ByteString] -> ByteString
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ByteString
"/2020-05-31/key-group/", Text -> ByteString
forall a. ToByteString a => a -> ByteString
Core.toBS Text
id]
instance Core.ToQuery GetKeyGroup where
toQuery :: GetKeyGroup -> QueryString
toQuery = QueryString -> GetKeyGroup -> QueryString
forall a b. a -> b -> a
Prelude.const QueryString
forall a. Monoid a => a
Prelude.mempty
data GetKeyGroupResponse = GetKeyGroupResponse'
{
GetKeyGroupResponse -> Maybe Text
eTag :: Prelude.Maybe Prelude.Text,
GetKeyGroupResponse -> Maybe KeyGroup
keyGroup :: Prelude.Maybe KeyGroup,
GetKeyGroupResponse -> Int
httpStatus :: Prelude.Int
}
deriving (GetKeyGroupResponse -> GetKeyGroupResponse -> Bool
(GetKeyGroupResponse -> GetKeyGroupResponse -> Bool)
-> (GetKeyGroupResponse -> GetKeyGroupResponse -> Bool)
-> Eq GetKeyGroupResponse
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetKeyGroupResponse -> GetKeyGroupResponse -> Bool
$c/= :: GetKeyGroupResponse -> GetKeyGroupResponse -> Bool
== :: GetKeyGroupResponse -> GetKeyGroupResponse -> Bool
$c== :: GetKeyGroupResponse -> GetKeyGroupResponse -> Bool
Prelude.Eq, ReadPrec [GetKeyGroupResponse]
ReadPrec GetKeyGroupResponse
Int -> ReadS GetKeyGroupResponse
ReadS [GetKeyGroupResponse]
(Int -> ReadS GetKeyGroupResponse)
-> ReadS [GetKeyGroupResponse]
-> ReadPrec GetKeyGroupResponse
-> ReadPrec [GetKeyGroupResponse]
-> Read GetKeyGroupResponse
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetKeyGroupResponse]
$creadListPrec :: ReadPrec [GetKeyGroupResponse]
readPrec :: ReadPrec GetKeyGroupResponse
$creadPrec :: ReadPrec GetKeyGroupResponse
readList :: ReadS [GetKeyGroupResponse]
$creadList :: ReadS [GetKeyGroupResponse]
readsPrec :: Int -> ReadS GetKeyGroupResponse
$creadsPrec :: Int -> ReadS GetKeyGroupResponse
Prelude.Read, Int -> GetKeyGroupResponse -> ShowS
[GetKeyGroupResponse] -> ShowS
GetKeyGroupResponse -> String
(Int -> GetKeyGroupResponse -> ShowS)
-> (GetKeyGroupResponse -> String)
-> ([GetKeyGroupResponse] -> ShowS)
-> Show GetKeyGroupResponse
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetKeyGroupResponse] -> ShowS
$cshowList :: [GetKeyGroupResponse] -> ShowS
show :: GetKeyGroupResponse -> String
$cshow :: GetKeyGroupResponse -> String
showsPrec :: Int -> GetKeyGroupResponse -> ShowS
$cshowsPrec :: Int -> GetKeyGroupResponse -> ShowS
Prelude.Show, (forall x. GetKeyGroupResponse -> Rep GetKeyGroupResponse x)
-> (forall x. Rep GetKeyGroupResponse x -> GetKeyGroupResponse)
-> Generic GetKeyGroupResponse
forall x. Rep GetKeyGroupResponse x -> GetKeyGroupResponse
forall x. GetKeyGroupResponse -> Rep GetKeyGroupResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetKeyGroupResponse x -> GetKeyGroupResponse
$cfrom :: forall x. GetKeyGroupResponse -> Rep GetKeyGroupResponse x
Prelude.Generic)
newGetKeyGroupResponse ::
Prelude.Int ->
GetKeyGroupResponse
newGetKeyGroupResponse :: Int -> GetKeyGroupResponse
newGetKeyGroupResponse Int
pHttpStatus_ =
GetKeyGroupResponse' :: Maybe Text -> Maybe KeyGroup -> Int -> GetKeyGroupResponse
GetKeyGroupResponse'
{ $sel:eTag:GetKeyGroupResponse' :: Maybe Text
eTag = Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:keyGroup:GetKeyGroupResponse' :: Maybe KeyGroup
keyGroup = Maybe KeyGroup
forall a. Maybe a
Prelude.Nothing,
$sel:httpStatus:GetKeyGroupResponse' :: Int
httpStatus = Int
pHttpStatus_
}
getKeyGroupResponse_eTag :: Lens.Lens' GetKeyGroupResponse (Prelude.Maybe Prelude.Text)
getKeyGroupResponse_eTag :: (Maybe Text -> f (Maybe Text))
-> GetKeyGroupResponse -> f GetKeyGroupResponse
getKeyGroupResponse_eTag = (GetKeyGroupResponse -> Maybe Text)
-> (GetKeyGroupResponse -> Maybe Text -> GetKeyGroupResponse)
-> Lens
GetKeyGroupResponse GetKeyGroupResponse (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetKeyGroupResponse' {Maybe Text
eTag :: Maybe Text
$sel:eTag:GetKeyGroupResponse' :: GetKeyGroupResponse -> Maybe Text
eTag} -> Maybe Text
eTag) (\s :: GetKeyGroupResponse
s@GetKeyGroupResponse' {} Maybe Text
a -> GetKeyGroupResponse
s {$sel:eTag:GetKeyGroupResponse' :: Maybe Text
eTag = Maybe Text
a} :: GetKeyGroupResponse)
getKeyGroupResponse_keyGroup :: Lens.Lens' GetKeyGroupResponse (Prelude.Maybe KeyGroup)
getKeyGroupResponse_keyGroup :: (Maybe KeyGroup -> f (Maybe KeyGroup))
-> GetKeyGroupResponse -> f GetKeyGroupResponse
getKeyGroupResponse_keyGroup = (GetKeyGroupResponse -> Maybe KeyGroup)
-> (GetKeyGroupResponse -> Maybe KeyGroup -> GetKeyGroupResponse)
-> Lens
GetKeyGroupResponse
GetKeyGroupResponse
(Maybe KeyGroup)
(Maybe KeyGroup)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetKeyGroupResponse' {Maybe KeyGroup
keyGroup :: Maybe KeyGroup
$sel:keyGroup:GetKeyGroupResponse' :: GetKeyGroupResponse -> Maybe KeyGroup
keyGroup} -> Maybe KeyGroup
keyGroup) (\s :: GetKeyGroupResponse
s@GetKeyGroupResponse' {} Maybe KeyGroup
a -> GetKeyGroupResponse
s {$sel:keyGroup:GetKeyGroupResponse' :: Maybe KeyGroup
keyGroup = Maybe KeyGroup
a} :: GetKeyGroupResponse)
getKeyGroupResponse_httpStatus :: Lens.Lens' GetKeyGroupResponse Prelude.Int
getKeyGroupResponse_httpStatus :: (Int -> f Int) -> GetKeyGroupResponse -> f GetKeyGroupResponse
getKeyGroupResponse_httpStatus = (GetKeyGroupResponse -> Int)
-> (GetKeyGroupResponse -> Int -> GetKeyGroupResponse)
-> Lens GetKeyGroupResponse GetKeyGroupResponse Int Int
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetKeyGroupResponse' {Int
httpStatus :: Int
$sel:httpStatus:GetKeyGroupResponse' :: GetKeyGroupResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: GetKeyGroupResponse
s@GetKeyGroupResponse' {} Int
a -> GetKeyGroupResponse
s {$sel:httpStatus:GetKeyGroupResponse' :: Int
httpStatus = Int
a} :: GetKeyGroupResponse)
instance Prelude.NFData GetKeyGroupResponse