{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.ELBv2.DescribeListenerCertificates
(
describeListenerCertificates
, DescribeListenerCertificates
, dlcMarker
, dlcPageSize
, dlcListenerARN
, describeListenerCertificatesResponse
, DescribeListenerCertificatesResponse
, dlcrsCertificates
, dlcrsNextMarker
, dlcrsResponseStatus
) where
import Network.AWS.ELBv2.Types
import Network.AWS.ELBv2.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data DescribeListenerCertificates = DescribeListenerCertificates'
{ _dlcMarker :: !(Maybe Text)
, _dlcPageSize :: !(Maybe Nat)
, _dlcListenerARN :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeListenerCertificates
:: Text
-> DescribeListenerCertificates
describeListenerCertificates pListenerARN_ =
DescribeListenerCertificates'
{ _dlcMarker = Nothing
, _dlcPageSize = Nothing
, _dlcListenerARN = pListenerARN_
}
dlcMarker :: Lens' DescribeListenerCertificates (Maybe Text)
dlcMarker = lens _dlcMarker (\ s a -> s{_dlcMarker = a})
dlcPageSize :: Lens' DescribeListenerCertificates (Maybe Natural)
dlcPageSize = lens _dlcPageSize (\ s a -> s{_dlcPageSize = a}) . mapping _Nat
dlcListenerARN :: Lens' DescribeListenerCertificates Text
dlcListenerARN = lens _dlcListenerARN (\ s a -> s{_dlcListenerARN = a})
instance AWSRequest DescribeListenerCertificates
where
type Rs DescribeListenerCertificates =
DescribeListenerCertificatesResponse
request = postQuery eLBv2
response
= receiveXMLWrapper
"DescribeListenerCertificatesResult"
(\ s h x ->
DescribeListenerCertificatesResponse' <$>
(x .@? "Certificates" .!@ mempty >>=
may (parseXMLList "member"))
<*> (x .@? "NextMarker")
<*> (pure (fromEnum s)))
instance Hashable DescribeListenerCertificates where
instance NFData DescribeListenerCertificates where
instance ToHeaders DescribeListenerCertificates where
toHeaders = const mempty
instance ToPath DescribeListenerCertificates where
toPath = const "/"
instance ToQuery DescribeListenerCertificates where
toQuery DescribeListenerCertificates'{..}
= mconcat
["Action" =:
("DescribeListenerCertificates" :: ByteString),
"Version" =: ("2015-12-01" :: ByteString),
"Marker" =: _dlcMarker, "PageSize" =: _dlcPageSize,
"ListenerArn" =: _dlcListenerARN]
data DescribeListenerCertificatesResponse = DescribeListenerCertificatesResponse'
{ _dlcrsCertificates :: !(Maybe [Certificate])
, _dlcrsNextMarker :: !(Maybe Text)
, _dlcrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
describeListenerCertificatesResponse
:: Int
-> DescribeListenerCertificatesResponse
describeListenerCertificatesResponse pResponseStatus_ =
DescribeListenerCertificatesResponse'
{ _dlcrsCertificates = Nothing
, _dlcrsNextMarker = Nothing
, _dlcrsResponseStatus = pResponseStatus_
}
dlcrsCertificates :: Lens' DescribeListenerCertificatesResponse [Certificate]
dlcrsCertificates = lens _dlcrsCertificates (\ s a -> s{_dlcrsCertificates = a}) . _Default . _Coerce
dlcrsNextMarker :: Lens' DescribeListenerCertificatesResponse (Maybe Text)
dlcrsNextMarker = lens _dlcrsNextMarker (\ s a -> s{_dlcrsNextMarker = a})
dlcrsResponseStatus :: Lens' DescribeListenerCertificatesResponse Int
dlcrsResponseStatus = lens _dlcrsResponseStatus (\ s a -> s{_dlcrsResponseStatus = a})
instance NFData DescribeListenerCertificatesResponse
where